Ubuntu Linux 查看、编辑、比较二进制文件

本文介绍了如何使用Vim编辑内核模块的二进制文件,包括使用hexdump、xd等命令进行十六进制打印,以及如何在Vim中以二进制模式编辑文件并保存。此外,还提到了一些十六进制编辑的GUI工具,如jeex、ghex和bless,以及如何使用vimdiff比较两个二进制文件。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

想根据gdb的反汇编来修改一个内核模块的汇编,没发现上面方便的工具,就直接用二进制编辑器来改了一下,还好是个简单的整型参数,该起来还比较简单。下面是用到的命令。

1.这两个命令都可以以十六进制打印输出二进制文件内容。可以指定偏移和打印格式等

hexdumpxxd

2。Vim可以用来查看和编辑二进制文件

vim-bddddd.ko加上-b参数,以二进制打开

然后输入命令:%!xxd-g1切换到十六进制模式显示

0000000:7f454c46010101000000000000000000.ELF............
0000010:01000300010000000000000000000000................
0000020:2ca70300000000003400000000002800,.......4.....(.
0000030:10000d005589e551518b450885c07411....U..QQ.E...t.
0000040:525250a10000000050e8fcffffff83c4RRP.....P.......
0000050:1089ec5dc38d76005589e55050b80100...]..v.U..PP...
0000060:00008b550839d073098d760001c039d0...U.9.s..v...9.
0000070:72fa8b5504515250a10000000050e8fcr..U.QRP.....P..
0000080:ffffff89ec5dc3905589e55050b80100.....]..U..PP...
0000090:00008b550839d073098d760001c039d0...U.9.s..v...9.
00000a0:72fa8b4d048b5510515250a100000000r..M..U.QRP.....
00000b0:50e8fcffffff89ec5dc389f65589e557P.......]...U..W
00000c0:565381ec8c0000008b5d1c8b451085dbVS.......]..E...
00000d0:757e85c07571508b450450a100000000u~..uqP.E.P.....
00000e0:688c00000050e8fcffffff83c41089c2h....P.........

然后就可以像修改文本文件一样修改16进制的字符,可以用/查找指定的偏移等等。修改右边的ascii字符应该无效。

修改完成后再执行;%!xxd-r切换会二进制模式,然后再:wq保存退出就可以了。在这vim里面这样编辑还是很方便的,注意一定要;%!xxd-r切换回来之后在保存才行。

3.linux上面也有十六进制编辑的GUI工具

jeex(http://www.hds619.net/jeex.php)

ghex

bless(BlessisaHexEditorforGtk#http://home.gna.org/bless/)

UltraEdit

试过bless要比ghex好用,用bless应该可以满足大部分要求了吧。在ubuntu的软件中心中都可以的到。

4.比较两个二进制文件,可以使用vimdiff。

vimdiff应该还是比较好用的,类似windows平台的windiff

vim-bdbase.kobase2.ko

打开后就可以在两个窗口里面显示两个文件

ctrl+W+L把输入焦点切换到右边的窗口,激活右边的窗口后输入的命令就是针对右窗口了
:%!xxd-g1切换成十六进制的一个字节的模式
ctrl+W+H把输入焦点切换到左边的窗口
:%!xxd-g1
]+c查找上一个不同点
[+c查找下一个不同点
0012930:89df6877010000e8fcff|0012930:89df6878010000e8fcf

<think>好的,我需要回答用户关于在Linux下如何编辑或修改二进制文件的问题。首先,我要根据用户提供的引用资料整理出几种可行的方法。用户提到了sed、hexedit、Vim的二进制模式、以及可能的其他工具如Bless或GHex。我需要确保每种方法都正确引用对应的资料,并且步骤清晰。 首先,sed作为流编辑器,虽然主要用于文本,但用户引用[1]提到它也可以处理二进制流,所以这里需要说明如何用sed修改二进制文件,比如替换特定字节。然后,hexedit工具在引用[4]中提到,是一个直观的十六进制编辑器,需要描述其安装和使用方法。接着,引用[3]提到Vim的二进制模式,需要详细说明如何用Vim打开文件,进入二进制模式,替换十六进制值,并保存。此外,其他工具如Bless和GHex可能也需要简要提及,作为替代选项。 需要注意用户要求所有数学表达式用$...$,但这个问题可能不涉及数学公式,所以可能不需要。但如果有的话,比如涉及偏移量计算,要确保格式正确。另外,回答结构要清晰,分步骤说明每种方法,并在引用处加上正确的标识符,如[^1]、[^3]等。最后生成相关问题,可能涉及工具比较、安全注意事项、恢复方法等。 需要检查每个步骤是否正确,引用是否对应正确。例如,sed的例子是否正确,Vim的步骤是否准确。另外,要确保语言简洁,用中文回答,不使用Markdown格式,但用户提供的示例中有代码块,可能需要保留。不过根据用户系统级指令,代码块需要用```python等格式,但实际回答中用户的问题是关于二进制编辑,可能使用其他语言的代码块,比如shell命令,需要注意格式正确。 最后生成的相关问题需要与主题相关,可能包括其他工具、风险、应用场景等。确保所有引用都正确对应到用户提供的参考资料。</think>在Linux系统中编辑或修改二进制文件需要借助特定工具和方法,以下是几种常用方式及操作步骤: ### 一、使用sed进行二进制流编辑 1. **替换二进制内容** 通过流编辑器`sed`直接替换文件中的二进制序列: ```bash sed -i 's/\x48\x65\x6C\x6C\x6F/\x48\x69\x21\x21/g' target.bin ``` 该命令将二进制文件中连续的`\x48\x65\x6C\x6C\x6F`(对应ASCII "Hello")替换为`\x48\x69\x21\x21`(对应ASCII "Hi!!")[^1]。 ### 二、使用hexedit工具 1. **安装与启动** 通过包管理器安装`hexedit`: ```bash sudo apt install hexedit # Debian/Ubuntu sudo yum install hexedit # CentOS/RHEL ``` 运行后直接编辑十六进制值: ```bash hexedit file.bin ``` 支持方向键导航、直接修改十六进制或ASCII区域[^4]。 ### 三、Vim二进制编辑模式 1. **启用二进制模式** 使用Vim打开文件时添加`-b`参数: ```bash vim -b file.bin ``` 2. **进入编辑状态** ```vim :%!xxd # 转换为十六进制视图 :%!xxd -r # 转换回二进制保存 ``` 输入`R`进入改写模式,仅修改左侧十六进制部分有效[^3]。 ### 四、其他图形化工具 - **Bless**:支持高亮语法和偏移量跳转 ```bash sudo apt install bless ``` - **GHex**:GNOME环境下的十六进制编辑器 ```bash sudo apt install ghex ``` ### 注意事项 - **备份文件**:修改前务必执行`cp file.bin file.bin.bak` - **权限问题**:需使用`sudo`编辑系统保护文件 - **兼容性**:部分工具对大文件(>1GB)支持有限
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值