www.久久久久|狼友网站av天堂|精品国产无码a片|一级av色欲av|91在线播放视频|亚洲无码主播在线|国产精品草久在线|明星AV网站在线|污污内射久久一区|婷婷综合视频网站

當(dāng)前位置:首頁 > 智能硬件 > 安全設(shè)備/系統(tǒng)
[導(dǎo)讀] 編程語言數(shù)百種,哪種才是最安全的? 此前我們討論過主動解決內(nèi)存安全問題的必要性。顯然僅通過工具和指導(dǎo)無法阻止這類漏洞。十多年來,內(nèi)存安全問題與CVE(常見漏洞披露)的比例非常接近。我們認(rèn)

編程語言數(shù)百種,哪種才是最安全的?

此前我們討論過主動解決內(nèi)存安全問題的必要性。顯然僅通過工具和指導(dǎo)無法阻止這類漏洞。十多年來,內(nèi)存安全問題與CVE(常見漏洞披露)的比例非常接近。我們認(rèn)為,使用內(nèi)存安全語言可以通過工具和培訓(xùn)無法實現(xiàn)的方式來緩解這種情況。

內(nèi)存安全是編程語言的一種特性,在擁有內(nèi)存安全的編程語言中,所有的內(nèi)存訪問都有明確的定義。目前使用的大多數(shù)編程語言都通過某種形式的垃圾回收實現(xiàn)了內(nèi)存安全。然而,無法承受垃圾收集器那般繁重的運行時的系統(tǒng)級語言(即用于構(gòu)建其他軟件所依賴的底層系統(tǒng)的語言,比如OS內(nèi)核、網(wǎng)絡(luò)棧等)通常都不是內(nèi)存安全的。

微軟修復(fù)并指定了CVE的安全漏洞中,大約70%的根本原因都是內(nèi)存安全問題。盡管我們采取了緩解措施,包括嚴(yán)格的代碼審查、培訓(xùn)、靜態(tài)分析等等。雖然許多有經(jīng)驗的程序員可以編寫正確的系統(tǒng)級代碼,但很明顯無論采用何種緩解措施,使用傳統(tǒng)的系統(tǒng)級編程語言編寫內(nèi)存安全的代碼幾乎是不可能的。

該漏洞的修復(fù)很簡單:將“偏移檢查”移動到距離使用時更近的地方。問題在于,復(fù)雜的代碼庫中很容易出現(xiàn)這個錯誤,而且簡單地重構(gòu)代碼也可能會再次引發(fā)這個漏洞?,F(xiàn)代C++提供了span來強制執(zhí)行數(shù)組訪問的邊界檢查。然而,不幸的是這不是默認(rèn)值,所以是否使用span完全依賴于開發(fā)人員。因此在實踐中很難強制使用這種結(jié)構(gòu)。

如果編程語言能夠自動跟蹤和驗證大小,那么程序員就不必再擔(dān)心正確實現(xiàn)這些檢查,而我們也可以確定我們的代碼中不存在這些問題。時間內(nèi)存安全指的是確保指針在解引用時仍然指向有效的內(nèi)存。

這個錯誤的原因是,太多的復(fù)雜API互相交互,程序員無法強制整個代碼中的內(nèi)存所有權(quán)。在[0]處,程序獲取指向JavaScript對象擁有的對象指針。然后在[1]處,由于語言的復(fù)雜性,代碼需要執(zhí)行更多的JavaScript代碼才能獲取另一個變量。在[2]出,它會使用該緩沖區(qū)和寬度,使用該指針的內(nèi)容來創(chuàng)建新的JavaScript對象。

程序同時使用了垃圾回收和手動內(nèi)存管理。垃圾回收器會跟蹤JavaScript對象,但它并不知道是否有指針指向?qū)ο蟮膬?nèi)部。由于VarToInt重入了JavaScript,JS程序可以修改狀態(tài),并清除在[1]處創(chuàng)建過別名的那個指針的所有權(quán)。這個漏洞與迭代器失效bug類似,當(dāng)狀態(tài)被修改時,所有指向JavaScript內(nèi)部狀態(tài)的指針都可能變成無效指針。但是在瀏覽器這樣復(fù)雜的程序中,用靜態(tài)方式來確保不發(fā)生該bug幾乎不可能。該問題的根源在于給指向可修改狀態(tài)的指針添加別名。C和C++沒有相應(yīng)的工具來防止這種錯誤。但是,我們建議始終使用“智能指針”來跟蹤內(nèi)存所有權(quán)。

當(dāng)同一個進(jìn)程中的兩個或多個線程同時訪問同一個內(nèi)存地址,且至少有一個訪問是寫操作,而且線程沒有使用任何明確的操作來控制對該內(nèi)存的訪問時,就會發(fā)生數(shù)據(jù)競爭。在多線程訪問共享數(shù)據(jù)的情況下,保持空間和時間的內(nèi)存安全變得更加困難,而且更易于出錯。即使只在非常小的一段時間內(nèi)共享沒有同步的內(nèi)存,也有可能被其他線程修改數(shù)據(jù),而被修改的數(shù)據(jù)正是引用其他內(nèi)存地址的數(shù)據(jù)。這就是檢查時/使用時(TOCTOU)漏洞的原因之一,其會導(dǎo)致空間和時間內(nèi)存安全漏洞。

Jordan Rabet在Blackhat 2018上披露的VMSwitch漏洞演示了數(shù)據(jù)競爭可能造成的影響。這段代碼在虛擬機給宿主發(fā)送特定消息時被調(diào)用。這意味著,它可以以并行方式調(diào)用,來處理其他控制消息和數(shù)據(jù)包。這樣做是有問題的,因為控制消息的處理函數(shù)使用的信息在被修改時沒有進(jìn)行任何鎖操作[0]。

解決本文提出的幾個問題需要幾種不同的度量。C++中的“現(xiàn)代”結(jié)構(gòu)(如span)至少可以防止某些類型的內(nèi)存安全問題,而其他的現(xiàn)代C++特性(如智能指針)應(yīng)當(dāng)盡可能使用。但是,現(xiàn)代C++依然不是完全內(nèi)存安全、完全沒有數(shù)據(jù)競爭的語言。更糟糕的是,這些特性使用與否,完全依賴于程序員“做正確的事情”,在大型、模糊的代碼庫中幾乎不可能強制這一點。C++也沒有能夠用安全的抽象來包裹不安全代碼的工具,意味著盡管在局部可以強制正確的編程習(xí)慣,但用C或C++構(gòu)建安全的組件將極其困難。

除此之外,軟件還應(yīng)當(dāng)盡可能轉(zhuǎn)移到完全內(nèi)存安全的語言,如C#或F#等通過運行時檢查和垃圾回收來保證內(nèi)存安全的語言。畢竟,除非必要,否則不應(yīng)當(dāng)涉足復(fù)雜的內(nèi)存管理。如果出于速度、控制和可預(yù)測性等合理的理由而使用C++,那么可以考慮轉(zhuǎn)移到內(nèi)存安全的系統(tǒng)編程語言上。

本站聲明: 本文章由作者或相關(guān)機構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內(nèi)容真實性等。需要轉(zhuǎn)載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請及時聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫毥谦F公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

加利福尼亞州圣克拉拉縣2024年8月30日 /美通社/ -- 數(shù)字化轉(zhuǎn)型技術(shù)解決方案公司Trianz今天宣布,該公司與Amazon Web Services (AWS)簽訂了...

關(guān)鍵字: AWS AN BSP 數(shù)字化

倫敦2024年8月29日 /美通社/ -- 英國汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認(rèn)證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動 BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運行,同時企業(yè)卻面臨越來越多業(yè)務(wù)中斷的風(fēng)險,如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報道,騰訊和網(wǎng)易近期正在縮減他們對日本游戲市場的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會開幕式在貴陽舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機 衛(wèi)星通信

要點: 有效應(yīng)對環(huán)境變化,經(jīng)營業(yè)績穩(wěn)中有升 落實提質(zhì)增效舉措,毛利潤率延續(xù)升勢 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競爭力 堅持高質(zhì)量發(fā)展策略,塑強核心競爭優(yōu)勢...

關(guān)鍵字: 通信 BSP 電信運營商 數(shù)字經(jīng)濟

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺與中國電影電視技術(shù)學(xué)會聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會上宣布正式成立。 活動現(xiàn)場 NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會上,軟通動力信息技術(shù)(集團)股份有限公司(以下簡稱"軟通動力")與長三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉