博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
什么是缓冲区溢出 C++
阅读量:4147 次
发布时间:2019-05-25

本文共 467 字,大约阅读时间需要 1 分钟。

缓冲区定义

缓冲区是程序运行的时候机器内存中的一个连续块,它保存了给定类型的数据。

缓冲区溢出定义

是指当向缓冲区内填充数据位数超过了缓冲区自身的容量限制时,发生溢出的数据覆盖在合法数据(数据、下一条指令的指针、函数返回地址等)上的情况

溢出原因

由于大多数程序都会假设数据长度总是与所分配的存储数据相当,进而存在缓冲区溢出安全隐患,最好的情况是程序不允许输入超过缓冲区长度的字符并检查数据长度。

攻击方式

人为的缓冲区溢出一般是由于攻击者写一个超过缓冲区长度的字符串植入缓冲区,然后再向一个有限空间的缓冲区中植入超长的字符串。

造成结果

  1. 过长的字符串覆盖了相邻的存储单元,引起程序运行失败,严重的可导致系统崩溃
  2. 利用这个漏洞可以执行任意指令,甚至可以取得系统root特级权限,进而危害系统安全

现有例子

缓冲区溢出是目前导致“黑客”型病毒横行的主要原因。红色代码、Slammer、“冲击波”都是利用缓冲区溢出漏洞的典型。

防御措施

防止利用缓冲区溢出发起的攻击,关键在于程序开发者在开发程序时仔细检查溢出情况,不允许数据溢出缓冲区。

转载地址:http://bfvti.baihongyu.com/

你可能感兴趣的文章
go的值类型和引用类型------重要的概念
查看>>
求二叉树中结点的最大值(所有结点的值都是正整数)
查看>>
用go的flag包来解析命令行参数
查看>>
来玩下go的http get
查看>>
队列和栈的本质区别
查看>>
matlab中inline的用法
查看>>
如何用matlab求函数的最值?
查看>>
Git从入门到放弃
查看>>
java8采用stream对集合的常用操作
查看>>
EasySwift/YXJOnePixelLine 极其方便的画出真正的一个像素的线
查看>>
Ubuntu系统上安装Nginx服务器的简单方法
查看>>
Ubuntu Linux系统下apt-get命令详解
查看>>
ubuntu 16.04 下重置 MySQL 5.7 的密码(忘记密码)
查看>>
Ubuntu Navicat for MySQL安装以及破解方案
查看>>
HTTPS那些事 用java实现HTTPS工作原理
查看>>
oracle函数trunc的使用
查看>>
MySQL 存储过程或者函数中传参数实现where id in(1,2,3,...)IN条件拼接
查看>>
java反编译
查看>>
Class.forName( )你搞懂了吗?——转
查看>>
jarFile
查看>>