乐趣区

关于编辑器:修改二进制文件中的某个字节

可能咱们很少会改写二进制文件,可是当咱们要改写的时候,咱们须要晓得怎么做!

一种办法是应用编辑器:

比方:010 Editor,UltraEdit。

另一种办法则是应用命令或者脚本,这样的益处是能够实现自动化,而不须要每次的手动编辑。

命令如下:

$(shell printf "\x80" | dd of=temp.elf bs=1 count=1 conv=notrunc bs=1 count=1 seek=27)

解释:

上述命令是指应用 dd 命令把 0x80 写入到 temp.elf 文件中的第 27 个字节处。

dd 命令:

dd:用指定大小的块拷贝一个文件,并在拷贝的同时进行指定的转换。

留神:指定数字的中央若以下列字符结尾,则乘以相应的数字:b=512;c=1;k=1024;w=2

参数正文:

if= 文件名:输出文件名,缺省为规范输出。即指定源文件。< if=input file > 

of= 文件名:输入文件名,缺省为规范输入。即指定目标文件。< of=output file > 

ibs=bytes:一次读入 bytes 个字节,即指定一个块大小为 bytes 个字节。obs=bytes:一次输入 bytes 个字节,即指定一个块大小为 bytes 个字节。bs=bytes:同时设置读入 / 输入的块大小为 bytes 个字节。cbs=bytes:一次转换 bytes 个字节,即指定转换缓冲区大小。skip=blocks:从输出文件结尾跳过 blocks 个块后再开始复制。seek=blocks:从输入文件结尾跳过 blocks 个块后再开始复制。留神:通常只用当输入文件是磁盘或磁带时才无效,即备份到磁盘或磁带时才无效。count=blocks:仅拷贝 blocks 个块,块大小等于 ibs 指定的字节数。conv=conversion:用指定的参数转换文件。ascii:转换 ebcdic 为 ascii 

ebcdic:转换 ascii 为 ebcdic 

ibm:转换 ascii 为 alternate ebcdic 

block:把每一行转换为长度为 cbs,有余局部用空格填充 

unblock:使每一行的长度都为 cbs,有余局部用空格填充 

lcase:把大写字符转换为小写字符 

ucase:把小写字符转换为大写字符 

swab:替换输出的每对字节 

noerror:出错时不进行 

notrunc:不截短输入文件 

sync:将每个输出块填充到 ibs 个字节,有余局部用空(NUL)字符补齐。

留神:

想晓得更多的 dd 命令解释,请自行百度。

退出移动版