搜尋
首頁運維安全如何實作C++程式釋放後使用所導致的漏洞分析

1、釋放後使用

當動態分配的記憶體釋放時,該記憶體的內容是不確定的,有可能保持完整併可以被訪問,因為何時重新分配或回收釋放的記憶體區塊是記憶體管理程式決定的,但是,也可能該記憶體的內容已經被改變,導致意外的程式行為。因此,當記憶體釋放之後,保證不再對它進行寫入或讀取。

2、 釋放後使用的危害

由記憶體管理不當導致的問題是 C/C 程式中常見的漏洞。釋放後使用會導致可被利用的潛在風險,包括程式異常終止、任意程式碼執行和拒絕服務攻擊等。 2018年1月至11月,CVE 中共有134個漏洞資訊與其相關。部分漏洞如下:

#CVE 漏洞概述
#CVE-2018-1000051  Artifex Mupdf 版本的fz_keep_key_storable 中存在一個釋放後使用漏洞,可導致拒絕服務或程式碼執行問題。透過誘騙受害者開啟一個特殊構造的 PDF 文件,該漏洞即可遭利用。
CVE-2018-17474 GoogleChrome 瀏覽器70.0.3538.67 先前版本Blink 引擎的HTMLImportsController 中存在一個釋放後使用漏洞,很有可能導致遠端攻擊者透過一個特殊構造的HTML 頁面利用堆疊損壞問題。
CVE-2018-15924 Adobe Acrobat 及Reader 2018.011.20063及先前版本、2017.011.30102 及先前版本、2015.006.30452後使用漏洞。遠端攻擊者可利用該漏洞執行任意程式碼。

3、範例程式碼

##範例源自於Samate Juliet TestSuite for C/C v1.3 (https://samate .nist.gov/SARD/testsuite.php),原始檔名:CWE416_Use_After_Free__malloc_free_char_01.c。

3.1缺陷代碼

如何實作C++程式釋放後使用所導致的漏洞分析

#使用360程式碼衛兵對上述範例程式碼進行偵測,可以檢出「釋放後使用」缺陷,顯示等級為高。如圖1所示:

如何實作C++程式釋放後使用所導致的漏洞分析

圖1:釋放後使用偵測範例

3.2 修正程式碼

如何實作C++程式釋放後使用所導致的漏洞分析

在上述修復程式碼中,Samate 給出的修復方式為:在第30行使用 malloc()進行記憶體分配,並在第36行使用 free() 進行釋放,釋放後不在對該內存進行其他操作。

使用360程式碼衛兵對修復後的程式碼進行偵測,可以看到已不存在「釋放後使用」缺陷。如圖2:

如何實作C++程式釋放後使用所導致的漏洞分析

圖2:修正後偵測結果

4 、如何避免釋放後使用

要避免釋放後使用,需要注意以下幾點:

(1) 釋放記憶體時請務必置空指針,雖然這種方法針對多重或複雜資料結構利用的有效性有限,但可以從一定程度上規避一部分問題。

(2) 在迴圈語句中進行記憶體分配或釋放時,需謹慎確認是否有問題。

(3) 使用原始碼靜態分析工具進行自動化的偵測,可以有效的發現原始碼中的釋放後使用問題。

以上是如何實作C++程式釋放後使用所導致的漏洞分析的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文轉載於:亿速云。如有侵權,請聯絡admin@php.cn刪除

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

SublimeText3 英文版

SublimeText3 英文版

推薦:為Win版本,支援程式碼提示!

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

mPDF

mPDF

mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境