バイナリファイル内の2バイトを見つけて、それらの2バイトの値を増やし、ファイル内で置き換えようとしています。これらの2バイトは、位置0x82-0x83にあります。今のところ、これを使用してこれらの2バイトを正常に抽出しました。
#!/usr/bin/env bash
BYTES=$(tail -c +131 "$1" | head -c 2)
これらのバイトの値は1B 1F
です。私は立ち往生しています:
6943
10進数である必要があります。head -c 130 original.bin >> new_file.bin && magic_command_writing_bytes_to_file >> new_file.bin && tail -c +133 original.bin
を使用することもできますが、もっと良い方法があるはずです。PHPでそれを行うことができれば、もっと簡単になるはずですが、bashでこれを行う方法に興味があります。
このファイルでのテスト:
$ echo hello world > test.txt
$ echo -n $'\x1b\x1f' >> test.txt
$ echo whatever >> test.txt
$ hexdump -C test.txt
00000000 68 65 6c 6c 6f 20 77 6f 72 6c 64 0a 1b 1f 77 68 |hello world...wh|
00000010 61 74 65 76 65 72 0a |atever.|
$ grep -a -b --only-matching $'\x1b\x1f' test.txt
12:
したがって、この場合、1B 1F
は位置12
にあります。
整数に変換します(おそらくもっと簡単な方法があります)
$ echo 'ibase=16; '`xxd -u -ps -l 2 -s 12 test.txt` | bc
6943
そしてその逆:
$ printf '%04X' 6943 | xxd -r -ps | hexdump -C
00000000 1b 1f |..|
$ printf '%04X' 4242 | xxd -r -ps | hexdump -C
00000000 10 92 |..|
そしてそれをファイルに戻します:
$ printf '%04X' 4242 | xxd -r -ps | dd of=test.txt bs=1 count=2 seek=12 conv=notrunc
2+0 records in
2+0 records out
2 bytes (2 B) copied, 5.0241e-05 s, 39.8 kB/s
結果:
$ hexdump -C test.txt
00000000 68 65 6c 6c 6f 20 77 6f 72 6c 64 0a 10 92 77 68 |hello world...wh|
00000010 61 74 65 76 65 72 0a |atever.|
あ、ごめんなさい。 16進数の値がファイルにasciiとして記述されていると思ったので、この回答は廃止されました。
printf "%d" 0x1B1F
を使用して、16進数を10進法に変換できます。
バイトを変数BYTES=1B1F
に保存した場合は、printf "%d" 0x$BYTES
で結果が得られます。
だから、あなたが数を増やしたいなら、
$ echo $(($(printf "%d" 0x$BYTES) +1))
6944
その後、元に戻します
printf '%X' $(($(printf "%d" 0x$BYTES) +1))
1B20