千家信息网

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

发表于:2025-01-19 作者:千家信息网编辑
千家信息网最后更新 2025年01月19日,今天就跟大家聊聊有关C/C++ 程序中的缓冲区下溢指的是什么,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。1、缓冲区下溢在前续专题中对缓冲区上
千家信息网最后更新 2025年01月19日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安全错误 数据库的锁怎样保障安全 东莞睿几何互联网科技有限公司 计算应用技术对比网络技术 网络安全伴我成长手抄报图片 网络安全手抄报一等奖手工版 怎么开我的世界斗罗大陆服务器 北京币上网络技术有限公司 没有基础如何做软件开发 ibm 官网 服务器 嵌入式软件开发工作说明书 电商网络安全的问题 西安升腾网络技术有限公司 银川新华互联网科技学校官网 北京推广网络技术咨询市场报价 仁聚网络技术有限公司 网络技术可以改行学软件吗 组态王删除数据库中数据 服务器参数选择 连接数据库生成报表打印 网络安全挑战响应协议 价格适中的软件开发 数据库串口 服务器管理口登录网页打不开 供应链网络安全管理制度 数据库服务器属于什么资产分类 万网数据库有哪些文件 刀塔传奇英雄数据库 dellemc服务器选择启动项 ip安全代理服务器 黄埔区无源网络技术开发咨询报价 郑州华泰软件开发有限公司简介
0