CRC32碰撞攻击上传符合校验的可执行ELF文件

博客讲述了在第六届XCTF比赛中遇到的一个挑战,涉及修改ELF文件的CRC校验值。通过介绍如何使用crc32工具,将ELF文件的CRC值从0x9ef13194更改为0x6751FC53,同时保持文件可执行性不变。具体步骤包括使用crc32.pyreverse命令生成补丁,并将其附加到ELF文件末尾,从而实现CRC校验值的修改。
摘要由CSDN通过智能技术生成

昨天第六届XCTF比赛比完了。队友说做到了个奇怪的题目。要求上传gdb的debug文件,但是debug文件的crc文件需要符合一定的crc校验值。
我们知道debug文件也是一种elf文件,elf文件需要满足他的可执行性就不能随便更改,但是恰好crc32本质也只是一种纠错码,对碰撞率的要求很低,我们可以在elf文件的结尾添加一些字符来使得他的crc满足一定的要求就行了。
使用如下工具可以轻易办到:
https://github.com/theonlypwner/crc32

首先查看原elf文件的crc32,比如是0x9ef13194我们需要他变到0x6751FC53,那么使用以下命令即可:

 ./crc32.py reverse 0x6751FC53 0x9ef13194

在这里插入图片描述
上面找出来很多补丁,随便选一个比如说是0gMchf

之后使用

echo -n 0gMchf>> elf 

注意上面要加-n,不然的话会多加一个空格,
这样就可以把elf的crc从0x9ef13194修改为0x6751FC53,同时不影响文件执行。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值