内存缓冲区什么是“内存缓冲区溢出”

内存缓冲区  时间:2021-07-17  阅读:()

什么是“内存缓冲区溢出”

什么是缓冲区溢出 单的说就是程序对接受的输入数据没有进行有效的检测导致错误,后果可能造成程序崩溃或者执行攻击者的命令,详细的资料可以看的漏洞利用栏目 。

缓冲区溢出的概念   缓冲区溢出好比是将十磅的糖放进一个只能装五磅的容器里……   堆栈溢出(又称缓冲区溢出)攻击是最常用的黑客技术之一。

我们知道,UNIX本身以及其上的许多应用程序都是用C语言编写的,C语言不检查缓冲区的边界。

在某些情况下,如果用户输入的数据长度超过应用程序给定的缓冲区,就会覆盖其他数据区。

这称作“堆栈溢出或缓冲溢出”。

  一般情况下,覆盖其他数据区的数据是没有意义的,最多造成应用程序错误。

但是,如果输入的数据是经过“黑客”精心设计的,覆盖堆栈的数据恰恰是黑客的入侵程序代码,黑客就获取了程序的控制权。

如果该程序恰好是以root运行的,黑客就获得了root权限,然后他就可以编译黑客程序、留下入侵后门等,实施进一步地攻击。

按照这种原理进行的黑客入侵就叫做“堆栈溢出攻击”。

  为了便于理解,我们不妨打个比方。

缓冲区溢出好比是将十磅的糖放进一个只能装五磅的容器里。

一旦该容器放满了,余下的部分就溢出在柜台和地板上,弄得一团糟。

由于计算机程序的编写者写了一些编码,但是这些编码没有对目的区域或缓冲区——五磅的容器——做适当的检查,看它们是否够大,能否完全装入新的内容——十磅的糖,结果可能造成缓冲区溢出的产生。

如果打算被放进新地方的数据不适合,溢得到处都是,该数据也会制造很多麻烦。

但是,如果缓冲区仅仅溢出,这只是一个问题。

到此时为止,它还没有破坏性。

当糖溢出时,柜台被盖住。

可以把糖擦掉或用吸尘器吸走,还柜台本来面貌。

与之相对的是,当缓冲区溢出时,过剩的信息覆盖的是计算机内存中以前的内容。

除非这些被覆盖的内容被保存或能够恢复,否则就会永远丢失。

  在丢失的信息里有能够被程序调用的子程序的列表信息,直到缓冲区溢出发生。

另外,给那些子程序的信息——参数——也丢失了。

这意味着程序不能得到足够的信息从子程序返回,以完成它的任务。

就像一个人步行穿过沙漠。

如果他依赖于他的足迹走回头路,当沙暴来袭抹去了这些痕迹时,他将迷失在沙漠中。

这个问题比程序仅仅迷失方向严重多了。

入侵者用精心编写的入侵代码(一种恶意程序)使缓冲区溢出,然后告诉程序依据预设的方法处理缓冲区,并且执行。

此时的程序已经完全被入侵者操纵了。

  入侵者经常改编现有的应用程序运行不同的程序。

例如,一个入侵者能启动一个新的程序,发送秘密文件(支票本记录,口令文件,或财产清单)给入侵者的电子邮件。

这就好像不仅仅是沙暴吹了脚印,而且后来者也会踩出新的脚印,将我们的迷路者领向不同的地方,他自己一无所知的地方。

缓冲区溢出的处理   你屋子里的门和窗户越少,入侵者进入的方式就越少……   由于缓冲区溢出是一个编程问题,所以只能通过修复被破坏的程序的代码而解决问题。

如果你没有源代码,从上面“堆栈溢出攻击”的原理可以看出,要防止此类攻击,我们可以: 1、开放程序时仔细检查溢出情况,不允许数据溢出缓冲区。

由于编程和编程语言的原因,这非常困难,而且不适合大量已经在使用的程序; 2、使用检查堆栈溢出的编译器或者在程序中加入某些记号,以便程序运行时确认禁止黑客有意造成的溢出。

问题是无法针对已有程序,对新程序来讲,需要修改编译器; 3、经常检查你的操作系统和应用程序提供商的站点,一旦发现他们提供的补丁程序,就马上下载并且应用在系统上,这是最好的方法。

但是系统管理员总要比攻击者慢一步,如果这个有问题的软件是可选的,甚至是临时的,把它从你的系统中删除。

举另外一个例子,你屋子里的门和窗户越少,入侵者进入的方式就越少。

Virmach 3.23美元可用6个月的VPS主机

Virmach 商家算是比较久且一直在低价便宜VPS方案中玩的不亦乐乎的商家,有很多同时期的商家纷纷关闭转让,也有的转型到中高端用户。而前一段时间也有分享过一次Virmach商家推出所谓的一次性便宜VPS主机,比如很低的价格半年时间,时间到服务器也就关闭。这不今天又看到商家有提供这样的产品。这次的活动产品包括圣何塞和水牛城两个机房,为期六个月,一次性付费用完将会取消,就这么特别的产品,适合短期玩玩...

搬瓦工:香港PCCW机房即将关闭;可免费升级至香港CN2 GIA;2核2G/1Gbps大带宽高端线路,89美元/年

搬瓦工怎么样?这几天收到搬瓦工发来的邮件,告知香港pccw机房(HKHK_1)即将关闭,这也不算是什么出乎意料的事情,反而他不关闭我倒觉得奇怪。因为目前搬瓦工香港cn2 GIA 机房和香港pccw机房价格、配置都一样,可以互相迁移,但是不管是速度还是延迟还是丢包率,搬瓦工香港PCCW机房都比不上香港cn2 gia 机房,所以不知道香港 PCCW 机房存在还有什么意义?关闭也是理所当然的事情。点击进...

Virmach$7.2/年,新款月抛vps上线,$3.23/半年,/1核640M内存/10 GB存储/ 1Gbps/1T流量

Virmach自上次推出了短租30天的VPS后,也就是月抛型vps,到期不能续费,直接终止服务。此次又推出为期6个月的月抛VPS,可选圣何塞和水牛城机房,适合短期有需求的用户,有兴趣的可以关注一下。VirMach是一家创办于2014年的美国商家,支持支付宝、PayPal等方式,是一家主营廉价便宜VPS服务器的品牌,隶属于Virtual Machine Solutions LLC旗下!在廉价便宜美国...

内存缓冲区为你推荐
saltstacksaltstack使用中的问题?master端sudo salt-master -l debug提示信息像这样,是什么情况?怎样改?诺诺云代账诺诺云代账有什么优势?webcrackwebcrack4网页密码备忘录模式为什么我的华为手机界面总是有个框框在备忘录上面天融信防火墙如何使用天融信NGFW4000防火墙工具调度系统操作系统中为什么需要调度?spawning在c语言编译时出现Error spawning cl.exe,是怎么回事?基础设施即服务基础设施是什么意思啊?sungard上海sungard 中国区那家公司怎么样啊 谢谢桌面管理系统卸载桌面图标管理软件fences之后桌面无法显示了
香港服务器租用99idc 最新代理服务器ip 线路工具 网通代理服务器 个人免费空间 智能骨干网 ftp教程 免费吧 美国网站服务器 国外在线代理服务器 工信部icp备案查询 七牛云存储 广州服务器托管 沈阳idc windowsserver2012r2 apachetomcat 卡巴下载 免费php空间申请 大硬盘补丁 ddos防火墙 更多