私はARMベースのモデムLinuxホストで作業しており、binファイルを8、16、または32ビットの配列として読み取る必要があります。基本的に問題のファイルを暗号化する必要があり、ビットをXORするために任意のビットシーケンスを使用することを考えています(非常に複雑なシステムは必要ありません)。 LinuxホストにはCまたはPERLモジュールがないため使用できないため、これを行うにはシェルスクリプトを使用する必要があります。誰もがこれを行う方法についてアドバイスできますか?
答え1
使用tr
(ここではrot128):
LC_ALL=C tr '\0-\377' '\200-\377\0-\177' < infile > outfile
XOR 123の場合は、その行を計算する必要がありますtr
。
LC_ALL=C tr '\0-\377' '\173\172\171\170\177\176\175\174\163\162\161\160\167\166\165\164\153\152\151\150\157\156\155\154\143\142\141\140\147\146\145\144\133\132\131\130\137\136\135\134\123\122\121\120\127\126\125\124\113\112\111\110\117\116\115\114\103\102\101\100\107\106\105\104\73\72\71\70\77\76\75\74\63\62\61\60\67\66\65\64\53\52\51\50\57\56\55\54\43\42\41\40\47\46\45\44\33\32\31\30\37\36\35\34\23\22\21\20\27\26\25\24\13\12\11\10\17\16\15\14\3\2\1\0\7\6\5\4\373\372\371\370\377\376\375\374\363\362\361\360\367\366\365\364\353\352\351\350\357\356\355\354\343\342\341\340\347\346\345\344\333\332\331\330\337\336\335\334\323\322\321\320\327\326\325\324\313\312\311\310\317\316\315\314\303\302\301\300\307\306\305\304\273\272\271\270\277\276\275\274\263\262\261\260\267\266\265\264\253\252\251\250\257\256\255\254\243\242\241\240\247\246\245\244\233\232\231\230\237\236\235\234\223\222\221\220\227\226\225\224\213\212\211\210\217\216\215\214\203\202\201\200\207\206\205\204'
より一般的に質問に答えるには、標準コマンドを使用してシェルで使用できるようにファイルを数値配列に変換します。
set -- $(od -An -vtu1 < infile)
その後、必要な変換を適用し、awk
sを使用してファイルに戻すことができますprintf("%c")
。
しかし、これは非常に非効率的です。
良い:
for i in $(od -An -vtu1 < infile); do
echo "$(($i ^ 123))"
done | awk '{printf "%c", $0}' > outfile
、を使用して16ビットの数値を取得できますが、デフォルトのバイトod -An -vtu2
順序であるため、文字に変換するときに考慮する必要があります。
答え2
ほとんどのシェル変数ではNULLターミネータを使用できません(またはこれは可能ですが、通常は保存される方法なので終了します)。したがって、これはバイナリ読み取りに関する非常に重要な警告です。
あなたが持っている場合xxd
:
xxd -b | awk '{ for(i=2 ; i<=NF-1 ; i++) { print $i } }'
たとえば、
echo -n mayonnaise | xxd -b | awk '{ for(i=2 ; i<=NF-1 ; i++) { print $i } }'
01101101
01100001
01111001
01101111
01101110
01101110
01100001
01101001
01110011
01100101
答え3
私はこの非常に粗雑な関数を使って2つの128バイトファイルをXORします。
one_time_pad() {
asrc="$1"
bsrc="$2"
dst="$3"
atmp="`mktemp`"
btmp="`mktemp`"
hexdump -v -e '1/1 "%02x" " "' "$asrc" > "$atmp"
hexdump -v -e '1/1 "%02x" " "' "$bsrc" > "$btmp"
rm "$dst"
touch "$dst"
for i in `seq 1 128`
do
a=`awk '{print $'$i';}' < "$atmp"`
b=`awk '{print $'$i';}' < "$btmp"`
echo -n -e '\x'`printf "%x" $((0x$a^0x$b))` >> "$dst"
done
}
one_time_pad in1 in2 out
パフォーマンスの観点から、これはひどいです(各バイトに対してawkを2回呼び出します!)。私が知る限り、パフォーマンスはまったく問題にはなりません。私はあなたがより良い方法を見つけることができると確信しています。