すべてのキーストロークを記録し、storeをユーザーディレクトリ〜のファイルに記録する必要があります。アカウントを使用すると、sudoerではなく、プログラムをインストールできません( logKeys )のように。ターミナルを使用してどうすればできますか?
注:この質問は、他の言及の質問の複製ではありません。この質問では、すべてのキーストロークについて質問していますが、他の質問では、ターミナルセッションでのキーストロークについて質問しました。
xinput test
は、すべてのキーボードイベントをXサーバーに報告できます。 GNUシステムの場合:
xinput list |
grep -Po 'id=\K\d+(?=.*slave\s*keyboard)' |
xargs -P0 -n1 xinput test
キーコードからキー名を取得したい場合は、その出力を次のように後処理できます。
awk 'BEGIN{while (("xmodmap -pke" | getline) > 0) k[$2]=$4}
{print $0 "[" k[$NF] "]"}'
ログファイルに格納する> file.log
を追加します。または、| tee file.log
を使用して、ログに記録して表示します。
xinput
は、XサーバーのXinputExtensionを照会します。これは、標準(Xユーティリティをカバーする標準については知りません)またはそれを行うための一般的なコマンドと同じくらい近いものです。また、ルート権限も必要ありません。
XサーバーとxinputがXinputExtensionのバージョン2をサポートしている場合は、test
の代わりにtest-xi2
を使用して、詳細情報、特に修飾子の状態(shift、ctrl、alt ...)を提供できます。例:
$ xinput test-xi2 --root
EVENT type 2 (KeyPress)
device: 11 (11)
detail: 54
flags:
root: 846.80/451.83
event: 846.80/451.83
buttons:
modifiers: locked 0 latched 0 base 0x4 effective: 0x4
group: locked 0 latched 0 base 0 effective: 0
valuators:
windows: root 0x26c event 0x26c child 0x10006e6
xmodmap -pke
の助けを借りて、キーコード(detail
内)をキーシムに変換し、effective
修飾子ビットマスクをxmodmap -pm
の助けを借りて、より役立つものに変換できます。例えば:
xinput test-xi2 --root | Perl -lne '
BEGIN{$"=",";
open X, "-|", "xmodmap -pke";
while (<X>) {$k{$1}=$2 if /^keycode\s+(\d+) = (\w+)/}
open X, "-|", "xmodmap -pm"; <X>;<X>;
while (<X>) {if (/^(\w+)\s+(\w*)/){($k=$2)=~s/_[LR]$//;$m[$i++]=$k||$1}}
close X;
}
if (/^EVENT type.*\((.*)\)/) {$e = $1}
elsif (/detail: (\d+)/) {$d=$1}
elsif (/modifiers:.*effective: (.*)/) {
$m=$1;
if ($e =~ /^Key/){
my @mods;
for (0..$#m) {Push @mods, $m[$_] if (hex($m) & (1<<$_))}
print "$e $d [$k{$d}] $m [@mods]"
}
}'
出力:
KeyPress 24 [q] 0x19 [Shift,Alt,Num_Lock]
num-lockがオンのときにShift + Alt + qを押すと、.
プログラムにinstallを実行するためのスーパーユーザー権限は必要ありません。実行権限が付与されているファイルシステムのどこかに書き込みアクセス権がある場合(ホームディレクトリ、/tmp
、/var/tmp
...)、互換性のあるシステムからxinput
コマンドをコピーして実行できます。
script
コマンドの使用を検討しましたか?