buuoj xor writeup

题目(五):
【题型】Reverse
【题目】xor
【来源】(buuoj)https://buuoj.cn/challenges#xor
【思路】先用IDA pro进行逆向分析,然后编写脚本。
【具体步骤】
Step1:直接用IDApro这个逆向分析文件打开这个程序,我打开的是在文件夹之外的这个,我发现这个的内存更大。
在这里插入图片描述

Step2:先进入main函数进行查看,F5查看伪代码(如果键被占用,则用Ctrl+F5)
在这里插入图片描述

在这里插入图片描述

Step3:查看伪代码,发现当b与global相等时成功,然后点进去global查看再点进去查看数据,查看所代表的字符串,但是在主函数中对这串字符串做了处理
在这里插入图片描述
在这里插入图片描述

Step4:在这个循环里面将global字符串从第二位开始与前一位异或,然后得到flag。
在这里插入图片描述

Step5:将数据导出为c无符号字符数组(十六进制),选取出需要导出的数据然后shift加e,再选择c unsigned char array (hex)选项,然后导出(如果是编写脚本的话,直接复制也是可以的,这里我直接复制了,就不导出了)
在这里插入图片描述
在这里插入图片描述

Step6:然后编写c语言脚本,得到flag。
源码:

#include <stdio.h>
int main()
{
	int  str[] = { 0x66, 0x0A, 0x6B, 0x0C, 0x77, 0x26, 0x4F, 0x2E, 0x40, 0x11,
  0x78, 0x0D, 0x5A, 0x3B, 0x55, 0x11, 0x70, 0x19, 0x46, 0x1F,
  0x76, 0x22, 0x4D, 0x23, 0x44, 0x0E, 0x67, 0x06, 0x68, 0x0F,
  0x47, 0x32, 0x4F, 0x00 };
	int i;
	for (i = 33;i>0;i--)
	{
		str[i] ^= str[i-1];
	}
	for (i = 0;i < 34;i++)
	{
		printf("%c", str[i]);
	}
	return 0;
}

在这里插入图片描述

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值