本文详细分析了缓冲区溢出的原理,描述了网络攻击者利用缓冲区溢出漏洞进行系统攻击的一般过程,最后简单讨论了几种缓冲区溢出的保护方法。
在过去的十年中,以缓冲区溢出为攻击类型的安全漏洞是最为常见的一种形式。更为严重的是,缓冲区溢出漏洞占了远程网络攻击的绝大多数,这种攻击可以使得一个匿名的Internet用户有机会获得一台主机的部分或全部的控制权!由于这类攻击使任何人都有可能取得主机的控制权,所以它代表了一类极其严重的安全威胁。
缓冲区溢出攻击之所以成为一种常见的攻击手段,其原因在于缓冲区溢出漏洞太普通了,并且易于实现。而且,缓冲区溢出所以成为远程攻击的主要手段,其原因在于缓冲区溢出漏洞给予了攻击者所想要的一切:殖入并且执行攻击代码。被殖入的攻击代码以一定的权限运行有缓冲区溢出漏洞的程序,从而得到被攻击主机的控制权。本文简单介绍了缓冲区溢出的基本原理和预防办法。
一、缓冲区溢出的概念和原理
缓冲区是内存中存放数据的地方。在程序试图将数据放到机器内存中的某一个位置的时候,因为没有足够的空间就会发生缓冲区溢出。而人为的溢出则是有一定企图的,攻击者写一个超过缓冲区长度的字符串,植入到缓冲区,然后再向一个有限空间的缓冲区中植入超长的字符串,这时可能会出现两个结果:一是过长的字符串覆盖了相邻的存储单元,引起程序运行失败,严重的可导致系统崩溃;另一个结果就是利用这种漏洞可以执行任意指令,甚至可以取得系统root特级权限。
缓冲区是程序运行的时候机器内存中的一个连续块,它保存了给定类型的数据,随着动态分配变量会出现问题。大多时为了不占用太多的内存,一个有动态分配变量的程序在程序运行时才决定给它们分配多少内存。如果程序在动态分配缓冲区放入超长的数据,它就会溢出了。一个缓冲区溢出程序使用这个溢出的数据将汇编语言代码放到机器的内存里,通常是产生root权限的地方。仅仅单个的缓冲区溢出并不是问题的根本所在。但如果溢出送到能够以root权限运行命令的区域,一旦运行这些命令,那可就等于把机器拱手相让了。
造成缓冲区溢出的原因是程序中没有仔细检查用户输入的参数。例如下面程序:
example1.c
void func1(char *input) {
char buffer[16];
strcpy(buffer, input);
}
上面的strcpy()将直接吧input中的内容copy到buffer中。这样只要input的长度大于16,就会造成buffer的溢出,使程序运行出错。存在像strcpy这样的问题的标准函数还有strcat(),sprintf(),vsprintf(),gets(),scanf(),以及在循环内的getc(),fgetc(),getchar()等。
当然,随便往缓冲区中填东西造成它溢出一般只会出现Segmentation fault 错误,而不能达到攻击的目的。最常见的手段是通过制造缓冲区溢出使程序运行一个用户shell,再通过shell执行其他命令。如果该程序属于root且有suid权限的话,攻击者就获得了一个有root权限的shell,便可以对系统进行任意操作了。
请注意,如果没有特别说明,下面的内容都假设用户使用的平台为基于Intel x86 CPU的Linux系统。对其他平台来说,本文的概念同样适用,但程序要做相应修改。
二、制造缓冲区溢出
一个程序在内存中通常分为程序段、数据段和堆栈三部分。程序段里放着程序的机器码和只读数据。数据段放的是程序中的静态数据。动态数据则通过堆栈来存放。在内存中,它们的位置是:
当程序中发生函数调用时,计算机做如下操作:首先把参数压入堆栈;然后保存指令寄存器(IP)中的内容作为返回地址(RET);第三个放入堆栈的是基址寄存器(FP);然后把当前的栈指针(SP)拷贝到FP,做为新的基地址;最后为本地变量留出一定空间,把SP减去适当的数值。以下面程序为例:
example2.c
void func1(char * input) {
char buffer[16];
strcpy(buffer, input);
}
void main() {
char longstring[256];
int i;
for( i = 0; i < 255; i++)
longstring [i] = 'B';
func1(longstring);
}
当调用函数func1()时,堆栈如下:
不用说,程序执行的结果是"Segmentation fault (core dumped)"或类似的出错信息。因为从buffer开始的256个字节都将被* input的内容'B'覆盖,包括sfp, ret,甚至*input。'B'的16进值为0x41,所以函数的返回地址变成了0x41414141,这超出了程序的地址空间,所以出现段错误。
提示:试试键盘 “← →” 可以实现快速翻页
每日精选
-
在一起,就可以!鸿蒙星光盛典,将于北京时间12月20日19:30线上播出,敬请期待!
-
北京时间12月22日14:30,nova 15系列及全场景新品发布会,我们不见不散。
-
华为方面已开启Pura X阔折叠手机的新年礼遇活动,至高可享800元优惠。
-
Beats与国际偶像Travis Scott携手推出全新宣传片《只管去梦》,颂扬远见、自信与坚持,以实现伟大创作。
-
洛图科技最新公布了全球TOP电视ODM工厂月度出货情况,其表示进入11月,中国电视市场迎来了有史以来周期最长的“双十一”大促,但最终录得-19.6%的销量降幅。与此同时,北美“黑五”促销季于11月20日提前启动,最后也以销量下跌5%左右而收官。
-
近日,三星正式发布专为AI数据中心量身打造的SOCAMM2 LPDDR5X内存模块,凭借超高带宽、卓越能效与灵活集成的核心优势,为下一 AI基础设施升级提供关键支撑。
-
2025年第三季度全球智能眼市场出货量429.6万台,同比增长74.1%。其中全球音频和音频拍摄眼镜市场出货量299.4万台,同比增长287.5%。
-
IDC最新市场分析报告发布了一个重磅预警,受内存价格的冲击,2026年全球PC价格将迎来15%-20%的普遍上涨。2026年,对于那些想要购置新电脑、组装玩家的成本将会越来越大,处境尤为艰难。
-
近期科技新闻与黑科技产品频频爆发:三星DRAM回扣调查搅动存储器市场,缺货潮持续至2027年;联想将携卷轴屏电竞本登陆CES 2026,解锁移动大屏新形态;苹果启动OLED iMac研发,终于将显示技术升级延伸至桌面设备。
-
在小米总裁卢伟冰的直播活动中,卢伟冰针对小米17 Ultra的定价问题进行了回答,其表示小米17 Ultra的涨价已成定局,但产品一定会物超所值。
点击查看更多
网友评论