pwnable从入门到放弃第七题。

ssh random@pwnable.kr -p2222 (pw:guest)

目前为止做的最快的一道题...

#include <stdio.h>

int main(){
unsigned int random;
random = rand(); // random value!
//key = 0x6b8b4567
unsigned int key=;
scanf("%d", &key); if( (key ^ random) == 0xdeadbeef ){
printf("Good!\n");
system("/bin/cat flag");
return ;
} printf("Wrong, maybe you should try 2^32 cases.\n");
return ;
}

瞬间就看见了rand()函数,这个函数本身就是一个伪随机函数,没次运行这个程序,初始化后这个值都相同,用gdb跟踪了两次也都一样。

都是0x6b8b4567,。

异或函数也是可逆的,a^b = c ,a = c^b.

因此,需要输入的key就是0x6b8b4567^0xdeadbeef

就是0xb526fb88

但是需要注意的就是scanf("%d")只能接收十进制数,就用calc转换一下:

输入:

最新文章

  1. ORACLE查看SQL的执行次数/频率
  2. Apache、NGINX支持中文URL
  3. BackTrack5-r3系统软件更新
  4. 修改Shp文件名称
  5. App_GlobalResources.afvubzdv.resources.dll”--“拒绝访问。“
  6. 多线程之 Final变量 详解
  7. PLSQL_低效SQL的识别和查询汇总(案例)
  8. MVC开发Markdown编辑器(1)
  9. 用jQuery解决弹出层的问题
  10. hdu-4612-Warm up(边双连通分量--有重边)
  11. 一天搞定CSS: 清除浮动(float)--13
  12. Ant的使用
  13. ASP.NET Core的身份认证框架IdentityServer4--(4)添加第三方快捷登录
  14. bzoj4665 小w的喜糖(dp+容斥)
  15. jmeter用Windows电脑分布式部署
  16. 最适合入门的Laravel中级教程(一)
  17. R语言-散点图阵
  18. BZOJ3720 Gty的妹子树 询问分块、主席树
  19. 2 jmeter常用功能介绍-测试计划、线程组
  20. mysql 记录的增删改查

热门文章

  1. SpringCloud学习之Zuul路由转发、拦截和熔断处理(七)
  2. windows远程桌面不显示本地磁盘
  3. android EditText中inputType的属性列表
  4. 生成MyEclipse6.5&amp;7.5&amp;8.5 注册机源码
  5. StringGrid换行功能
  6. STL中的全排列实现
  7. 16 SQL Mode
  8. 编写第一个JavaScript程序
  9. 机器学习中 为何要使用 独热编码 one-hot
  10. Codeforces 591 B:Rebranding