ROIS冬令营——database

题目自取

链接:https://pan.baidu.com/s/1Il9rHDzfIloLQfx_bSw0ow?pwd=w1h1 
提取码:w1h1

开始

提前在文件夹里创建一个flag文本文件
bug出在case6

 

,这里的  sub_400ACD(s, 32LL);函数的意思是从标准输入中读入最多32个字节的数据,从标准输入读取一个字节,如果小于等于 0 则说明读取失败,返回 -1(0xFFFFFFFF).如果读取到换行符 ,将换行符替换为字符串0,则返回-1,就会停止。

这里的sprintf函数,sprintf(command, "echo %s", s); 是将一个格式化的字符串存储到 command 变量中。具体来说,它将格式化的字符串 "echo %s"s 变量中的字符串作为参数,将它们合并成一个新的字符串,最后将结果存储到 command 变量中。(也就是拼接起来,并输出)

但是这里没有栈溢出,漏洞在于最后
sprintf(command, "echo %s", s);
system(command);
这段代码,command的控制权教给了我们来控制,这是一个很大的bug。

如果使用了 '&&' 或者 ' ; '  意思就是分两次执行,如输入  echo hello world   &&   cat flag,它的意思就是执行system('echo hello world')   system('cat flag')

由此我们就可以拿到flag啦
 

拿到flag! 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值