缓冲区溢出-canary保护
发表于:2025-12-02 作者:千家信息网编辑
千家信息网最后更新 2025年12月02日,本文视频:如果文字过于枯燥,可观看在线视频:https://edu.51cto.com/sd/16514基础知识:我们知道在32位操作系统上,主要是溢出栈缓冲区,覆盖函数返回地址来达到劫持程序的木的,
千家信息网最后更新 2025年12月02日缓冲区溢出-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安全错误
数据库的锁怎样保障安全
书《网络技术的发展》
无锡优势网络技术方法
oracle 服务器启动
网络安全六个提示
安徽潮流软件开发服务厂家现货
爱易网络技术有限怎么样
手机怎么查看网络安全密匙
彩虹六号 更新后连接服务器
全球新闻的数据库
asscs数据库
垃圾发电网络安全方案
英国投资网络安全项目
数据分享网络安全法
国家安全概论网络安全
网络安全是什么时候出的专业
网景软件开发
华为服务器启动项怎么进
数据库和数据库管理系统是什么
微博数据库接入
剑灵有哪些服务器
16949嵌入式软件开发
android数据库加密
辽阳java软件开发
数据库视图实现统一登录
移动供应商软件开发
vc读取数据库连接
服务器可以改成家用机吗
成都信之同互联网科技有限公司
网络技术挑战赛奖金
手机网络安全防范口诀