缓冲区溢出-canary保护
发表于:2024-12-01 作者:千家信息网编辑
千家信息网最后更新 2024年12月01日,本文视频:如果文字过于枯燥,可观看在线视频:https://edu.51cto.com/sd/16514基础知识:我们知道在32位操作系统上,主要是溢出栈缓冲区,覆盖函数返回地址来达到劫持程序的木的,
千家信息网最后更新 2024年12月01日缓冲区溢出-canary保护
本文视频:
如果文字过于枯燥,可观看在线视频:https://edu.51cto.com/sd/16514
基础知识:
我们知道在32位操作系统上,主要是溢出栈缓冲区,覆盖函数返回地址来达到劫持程序的木的,那么Linux为了防御该问题,使用了canary来保护函数的返回地址。
canary保护是Linux众多保护机制的一种,主要的作用是防御溢出***。他的工作原理是在函数执行时,取gs:0x14的值放到某一位置中,我们假设叫A,那么在程序执行结束后,把A位置的值和gs:0x14的值进行异或如果结果为0说明没有被修改,否则被修改了。
下面我们来通过代码来查看效果
首先我们不使用canary防护:gcc -m32 -o0 canary.c -o canary
使用canary防护:gcc -fstack-protector-all -m32 -o0 canary.c -o canary
在截图中标红的是我们加入-fstack-protector-all带来的效果,在开头取gs:0x14的数据保存到ebp-exc的位置
第二个标红的地方是讲ebp-0xc位置的数据拿出来和gs:0x14的值进行比对,如果想要更改函数返回地址的值,必须要先覆盖canary的值,而canary的值是随机的,所以如果没有办法获取到canary的值,是没有办法做到溢出***的。
位置
函数
保护
地址
办法
效果
数据
程序
视频
防御
防护
缓冲区
缓冲
枯燥
操作系统
代码
作用
原理
在线视频
地方
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
临沂软件开发价格
转录因子数据库
苹果手机怎么打开数据库文件
网络安全主体责任法律依据
kz服务器ip
内存服务器公司
百世网络技术有限公司
上汽软件开发工程师
火影服务器怎么查看等级
河南省网络安全大赛获奖名单
康佳电视服务器异常网络连接正常
csgo怎么修改国服服务器
yes网络安全联盟
福建企业软件开发哪家好
统治软件开发的定律
部队网络安全协议书
先开发软件还是先有服务器
南宁市东晴网络技术有限公司
大话西游3怎样选服务器
云和传统服务器耗电
银川灵武软件开发专业
php软件开发岗位职责
增强网络安全意识的方式方法
放管服优化服务器
服务器证书已过期
技术强华为云云数据库代理
聚焦网络安全微视频
诺顿网络安全运行
食物语多少个服务器
数据库事物日志太大