CTF|栈溢出guess num 练习及知识点总结

这篇博客详细介绍了CTF挑战中遇到的栈溢出题目guess_num,分析了题目关键点,包括gets()函数的安全隐患和rand()、srand()函数的工作原理。作者通过设置srand()种子来控制rand()生成的随机数,成功解答题目并获得flag。博客内容是作者学习过程的总结,旨在分享和交流。

CTF|栈溢出题目guess_num 练习及知识点总结

博客主要记录博主做的一栈溢出题目和所涉及到的知识点的总结

.

题目

在这里插入图片描述
将得到的文件拖入64位IDA中F5反编译得到伪代码
观察伪代码 得到如下信息:
定义char型 v9
让你输入内容,用gets()函数获取你输入的值,但是没有做限制
将v6 = v8就success!
在这里插入图片描述
实现success!之后可以进入sub-C3E函数,即可得到flag!
在这里插入图片描述
其中代码涉及到两个特殊的函数
在这里插入图片描述在这里插入图片描述

关于两个函数的知识点如下:

  1. rand()函数用来产生随机数,但是,rand()的内部实现是用线性同余法实现的,是伪随机数,
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值