C/C++ 程序中的缓冲区下溢指的是什么
1、缓冲区下溢
本文将描述另一种缓冲区溢出情况,即缓冲区下溢。在前续专题(见第7期)中已对缓冲区上溢进行了分析。原因同样适用于缓冲区下溢,所以在本文中不再重复介绍导致缓冲区上溢的因素。说得简单点,缓冲区下溢是指填充数据溢出时,下一级缓冲区被覆盖的情况。本文将描述缓冲区下溢的危害、在源代码中显露的迹象以及如何解决这个问题。
2、 缓冲区下溢的危害
在 C/C++ 程序中,缓冲区下溢是一种严重的漏洞类型,可能导致程序崩溃或执行恶意代码等后果。从2018年1月到10月,共涉及494条CVE漏洞信息。部分漏洞如下:
CVE | 漏洞概述 |
---|---|
CVE-2018-1000001 | Libc Realpath 缓冲区下溢漏洞,漏洞的产生是由于 GNU C 库没有正确处理 getcwd() 系统调用返回的相对路径,其他库也很可能受此影响。在受影响的系统中,通过 SUID binary 可以获得 root 权限。 |
CVE-2018-1000637 | zutils 是一款压缩文件处理实用程序包。该程序支持压缩/解压缩、压缩文件比较和压缩文件完整性校验等功能。zcat 是其中的一个解压缩实用程序。zutils 1.8-pre2 之前版本中的 zcat 存在缓冲区溢出漏洞。攻击者可借助特制的压缩文件利用该漏洞造成拒绝服务或执行任意代码。 |
CVE-2018-5388 | strongSwan 5.6.3 之前版本在实现上存在缓冲区下溢漏洞,攻击者利用此漏洞可耗尽资源,导致拒绝服务。 |
3、示例代码
示例源于 Samate Juliet Test Suite for C/C++ v1.3 (https://samate.nist.gov/SARD/testsuite.php),源文件名:CWE121_Stack_Based_Buffer_Overflow__CWE193_char_alloca_cpy_01.c。
3.1 缺陷代码
在上述示例代码中,在第36行对指针 data 进行赋值,通过赋值操作可以看出指针 data 指向 dataBadBuffer,当第41行使用 strcpy() 进行内存拷贝时,源缓冲区长度大于目的缓冲区长度从而产生溢出,溢出部分超出了 dataBadBuffer 的下边界,导致缓冲区下溢问题。
使用360代码卫士对上述示例代码进行检测,可以检出“缓冲区下溢”缺陷,显示等级为高。如图1所示:
图1:缓冲区下溢检测示例
3.2 修复代码
在上述修复代码中,Samate 给出的修复方式为:在第37行对指针 data 进行赋值,将 data指向 dataGoodBuffer,此时 data 的长度与 source 一致,当第42行使用 strcpy() 进行拷贝操作时,源缓冲区与目的缓冲区长度相同,从而避免了缓冲区下溢的问题。该问题也可以通过对边界进行检查等其他方法来进行避免。
使用360代码卫士对修复后的代码进行检测,可以看到已不存在“缓冲区下溢”缺陷。如图2:
图2:修复后检测结果
4 、如何避免缓冲区下溢
要避免缓冲区下溢,需要注意以下几点:
(1)尽量避免使用不安全的内存操作函数。(2)对返回值有明确指示意义的内存操作函数,应对函数返回值进行有效判断,从而判断操作是否成功。(3)在向缓冲区中填充数据时必须进行边界检查。
以上就是C/C++ 程序中的缓冲区下溢指的是什么的详细内容,更多请关注其它相关文章!
- 如何使用JavaScript根···
- “ChatGPT手机版”:智能···
- 作文软件推荐免费,助你轻松提升···
- 刷网站SEO排名,让你的站点脱···
- thinkphp提交表单收不到···
- 免费微网站_自助建站:一键生成···
- 翼牛闲鱼学堂值得学习吗?
- 如何通过SEO优化提升微信公众···
- 企业全网营销的推广方式
- 2024年提交了百度,多久才会···
- 网络营销是投资不是消费!
- 供应商系统省钱的方法有哪些
- 从零开始:主机控制面板建站中F···
- 浅谈Atom实现HTML实时预···
- 网站SEO,高效推广利器
- 多语言支持下的国外高防建站:满···
- 棘手的微信公众号编辑器
- 百度神器,一搜即达!
- 如何快速获取视频号直播数据?
- 如何判断文本是否由AI写作?
- 采集信息骗局:如何识破并保护自···
- 百度小程序富文本解析工具bdP···
- 驻马店SEO引擎优化:打造本地···
- gitee中如何获取文件
- 厦门SEO专家,咨询热线:13···
- 镰刀起,海外问卷调查是赚钱门道···
- 如何让淘宝关键词更优化?
- 月付购物网站的会员等级制度和积···
- 如何提高SEO权重,让你的网站···
- 快速提升SEO,百度收录新站秘···
- SEO优化,提升网站排名,助力···
- 全网营销的内容宣传应该如何做?
- 黄冈AI元儒,智慧教育领航者
- centos7下如何设置输入密···
- “中国行业网联盟计划”能否解行···
- 在微信上拍了拍别人是什么意思
- 网站流量突然激增,如何快速扩展···
- 如何轻松玩转小红书穿搭?
- 数据快照,安全备份
- Forget about ax···
- suse和centos的区别是···
- 吉林网站设计新趋势:打造地方特···
- 太原SEO首选,效果显著!
- 利用云虚拟主机搭建网站时,怎样···
- 闲鱼卖新品合法吗?
- 网站排名优化是怎么做的揭秘网站···
- 详细剖析Nginx的SSL/T···
- 如何为软件公司门户网站分类新闻···
- SEO快排+三高:打造网络营销···
- 校园APP:开启智慧学习新纪元