千家信息网

C/C++ 程序中的缓冲区下溢指的是什么

发表于:2025-02-16 作者:千家信息网编辑
千家信息网最后更新 2025年02月16日,今天就跟大家聊聊有关C/C++ 程序中的缓冲区下溢指的是什么,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。1、缓冲区下溢在前续专题中对缓冲区上
千家信息网最后更新 2025年02月16日C/C++ 程序中的缓冲区下溢指的是什么

今天就跟大家聊聊有关C/C++ 程序中的缓冲区下溢指的是什么,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。

1、缓冲区下溢

在前续专题中对缓冲区上溢进行了分析(见第7期),本文对缓冲区溢出的另一种情况--缓冲区下溢进行描述。缓冲区上溢专题中介绍的造成缓冲区溢出的原因同样适用于缓冲区下溢,因此在本文中就不再赘述。简单的说,缓冲区下溢是指当填充数据溢出时,溢出部分覆盖的是下级缓冲区。本文主要从缓冲区下溢的危害、在源代码中的表现以及如何修复等方面对该问题进行描述。

2、 缓冲区下溢的危害

缓冲区下溢是 C/C++ 程序中非常严重的漏洞类型,可能会导致程序崩溃、执行恶意代码等后果。2018年1月至10月,CVE中共有494条漏洞信息与其相关。部分漏洞如下:

CVE漏洞概述
CVE-2018-1000001Libc Realpath 缓冲区下溢漏洞,漏洞的产生是由于 GNU C 库没有正确处理 getcwd() 系统调用返回的相对路径,其他库也很可能受此影响。在受影响的系统中,通过 SUID binary 可以获得 root 权限。
CVE-2018-1000637zutils 是一款压缩文件处理实用程序包。该程序支持压缩/解压缩、压缩文件比较和压缩文件完整性校验等功能。zcat 是其中的一个解压缩实用程序。zutils 1.8-pre2 之前版本中的 zcat 存在缓冲区溢出漏洞。攻击者可借助特制的压缩文件利用该漏洞造成拒绝服务或执行任意代码。
CVE-2018-5388strongSwan 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++ 程序中的缓冲区下溢指的是什么有进一步的了解吗?如果还想了解更多知识或者相关内容,请关注行业资讯频道,感谢大家的支持。

缓冲区 缓冲 代码 漏洞 程序 示例 文件 长度 问题 检测 内存 内容 函数 指针 缺陷 边界 部分 实用 专题 卫士 数据库的安全要保护哪些东西 数据库安全各自的含义是什么 生产安全数据库录入 数据库的安全性及管理 数据库安全策略包含哪些 海淀数据库安全审计系统 建立农村房屋安全信息数据库 易用的数据库客户端支持安全管理 连接数据库失败ssl安全错误 数据库的锁怎样保障安全 鹰潭正规服务器价格 以网络安全的标题 金榜工程数据库公众号 网络技术与知识产权的特征 优化互联网管理服务器 电商erp软件开发哪家收费合理 软件开发定制公司未来发展 辽事通显示服务器错误怎么回事 大规模云计算网络安全 短链接服务器客户端处理方法 绝地大逃杀 服务器 皮皮麻将 软件开发商 网络安全问题措施 部落战争服务器连接不上 湖北网络安全技术培训线上学习 智能光网络技术简称 顶级网络安全专家被暗杀 维护网络安全注意 河南网络时间服务器哪家好 开软件开发公司容易吗 逍遥问到的数据库在哪里 组云服务器公司会泄露吗 云店网络技术有限公司 电脑输入网络安全密码 数据库索引以及如何创建索引 网络安全和信息化工作通报 租房订单数据库设计 重庆教育频道家庭与网络安全 数据库与普通数据文件的区别 北京名优网络技术开发哪个正规
0