ctf(pwn) canary保护机制讲解 与 解密方法介绍

Canary保护机制

canary的意思是金丝雀,来源于英国矿井工人用来探查井下气体是否有毒的金丝雀笼子。工人们每次下井都会带上一只金丝雀如果井下的气体有毒,金丝雀由于对毒性敏感就会停止鸣叫甚至死亡,从而使工人们得到预警。

在函数开始时就随机产生一个值,将这个值CANARY放到栈上紧挨ebp的上一个位置,当攻击者想通过缓冲区溢出覆盖ebp或者ebp下方的返回地址时,一定会覆盖掉CANARY的值;当程序结束时,程序会检查CANARY这个值和之前的是否一致,如果不一致,则不会往下运行,从而避免了缓冲区溢出攻击。

防止攻击手段:所有单纯的栈溢出

Canary绕过破解方式一般有两种方式

1.爆破canary

2.如果存在字符串格式化漏洞可以输出泄露canary的地址并利用栈溢出覆盖canary的地址返回到system地址从而达到绕过

例题查看: 攻防世界(pwn)–Mary_Morton 利用格式化字符串+栈溢出破解Canary的保护机制

猜你喜欢

转载自blog.csdn.net/weixin_45556441/article/details/114339182
今日推荐