CVE-2020-7982 OpenWrt 遠程命令執行漏洞學習(更新中)

OpenWrt是一款應用于嵌入式設備如路由器等的Linux操作系統。類似于kali等linux系統中的apt-get等,該系統中下載應用使用的是opgk工具,其通過非加密的HTTP連接來下載應用。但是其下載的應用使用了SHA256sum哈希值來進行檢驗,所以將下載到的數據包進行哈希值的比對即可知道是否下載的數據包被修改,所以理論上來說是沒有安全隱患的。

學習參考:

OPENWRT中的遠程命令執行漏洞(CVE-2020-7982)-安全客 - 安全資訊平臺

Uncovering OpenWRT Remote Code Execution (CVE-2020-7982) | Mayhem

我們對于這個漏洞將進行幾個步驟,具體的目錄如下:

目錄

分析學習漏洞以及利用條件

搭建OpenWrt環境并啟動

模擬漏洞利用和攻擊

漏洞的相關修復


分析學習漏洞以及利用條件

分析漏需要相應的源代碼,參考源代碼的地址為:

https://git.openwrt.org/?p=project/opkg-lede.git;a=blob;f=libopkg/pkg_parse.c;h=0baa4db396569be816386b50568c57e12d1cd98c;hb=80d161eb5b95ceb51db989196405eaa00950e03b#l312

也可以直接clone到本地學習代碼:

git clone https://git.openwrt.org/project/opkg-lede.git

首先對于源代碼中這個位置

針對哈希值采用了SHA256sum的情況,會調用函數pkg_set_sha256來進行處理。傳遞給該函數的字符串是字符串SHA256sum后面的字符串。該函數為:

https://git.openwrt.org/?p=project/opkg-lede.git;a=blob;f=libopkg/pkg.c;h=e5bfe6f61b67583c00e528fb381162ace308dc13;hb=80d161eb5b95ceb51db989196405eaa00950e03b#l244

其會繼續使用函數checksum_hex2bin來進行校驗處理。如果最終檢驗的結果是0或者文件的長度不為32,就會出現相應的錯誤,返回值為NULL,從而不會保存相應的哈希值。繼續進入函數checksum_hex2bin:

https://git.openwrt.org/?p=project/opkg-lede.git;a=blob;f=libopkg/file_util.c;h=61ff736cd2c82a224cb10f48d14532b8224bd792;hb=80d161eb5b95ceb51db989196405eaa00950e03b#l234

其中函數isxdigit是檢查其是否為十六進制數字字符,而isspace是檢查是否是空格。在這個函數中,最開始指針s和指針src是指向同一個位置的,而如果src所指向的內容出現空格,其會循環直到把空格去掉。也就是說,如果存在空格字符,也就是字符串SHA256sum后面的字符串的開頭是一個空格,src和s所指向的地址就不同了。但是在256行開始的循環中,判斷用到的字符是isxdigit(s[0]),依然用的是指針s所指向的內容。所以如果存在空格,此時循環會直接終止,指針len的長度為0,然后函數執行完畢。

也就是說,通過上面這樣的操作,我們就可以使checksum_hex2bin函數最終處理的len值長度為0,所以pkg_set_sha256函數也會返回NULL,最終其哈希值就沒有被成功設置。

接下來包列表解析就算完成了,下一步會開始HTTP下載包,然后會進入相應的驗證步驟。

首先要求下載的軟件包必須等于列表中指定好的大小,如下:

https://git.openwrt.org/?p=project/opkg-lede.git;a=blob;f=libopkg/opkg_install.c;h=27c9484cfb8189e42cbc073eaa14a67c71c3507a;hb=80d161eb5b95ceb51db989196405eaa00950e03b#l1379

檢查相應的文件大小。且還要求如果指定了軟件的哈希值,則其也需要匹配:

但是由于剛才checksum_hex2bin沒有對其進行hash編碼,所以這里1416行的if語句被直接跳過,不進行哈希驗證。這就是相應的漏洞存在的位置。

漏洞利用

為了利用這個漏洞,我們需要實現兩件事。首先讓被攻擊的電腦下載時重定向到我們有惡意軟件包的服務器,而不是直接與downloads.openwrt.org服務器進行通信,這個需要我們能夠做到更改本地的DNS或者基于ARP欺騙等策略。其次,兩重檢查中,哈希檢查已經被繞過了,就還剩一個數據包大小的檢查需要應對。那么參考文章中提供了一種很有效的方法:

1.創建一個受損的軟件包,但是其大小要小于原軟件包

2.計算兩者之間的大小差異

3.最受損包的末尾用0字節進行填充,使其相同大小

搭建OpenWrt環境并啟動

模擬漏洞利用和攻擊

漏洞的相關修復

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/web/13679.shtml
繁體地址,請注明出處:http://hk.pswp.cn/web/13679.shtml
英文地址,請注明出處:http://en.pswp.cn/web/13679.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

開發過程中使用MySQL和Oracle的差異

前言 小型項目中使用MySQL的占比還是相對較高的,但是也不排除隨著項目的擴大,產品的豐富,或者甲方的財大氣粗,有可能會有MySQL換成Oracle。那么這兩者對于開發者而言,有什么差異化的地方呢。 官方文檔 MySQL5.7 htt…

weblogic簡介

WebLogic是美國Oracle公司出品的一個Application Server,它是一個基于JAVA EE架構的中間件。WebLogic主要用于開發、集成、部署和管理大型分布式Web應用、網絡應用和數據庫應用的Java應用服務器。它將Java的動態功能和Java Enterprise標準的安全性引入大型網絡應用的…

什么是安全左移如何實現安全左移

文章目錄 一、傳統軟件開發面臨的安全挑戰二、什么是安全左移四、安全左移與安全開發生命周期(SDL)三、安全左移對開發的挑戰五、從DevOps到DevSecOps六、SDL與DevSecOps 一、傳統軟件開發面臨的安全挑戰 傳統軟件開發面臨的安全挑戰主要包括以下幾個方…

yarn常用命令

Yarn 是一個快速、可靠且安全的依賴管理工具,用于替代 npm。以下是一些常用的 Yarn 命令,用于不同的包管理和項目依賴安裝場景: 初始化一個新的項目 yarn init這個命令會引導你創建一個 package.json 文件。 安裝依賴 yarn add [package]…

抄表:現代生活中的數據采集關鍵

1.界定與發源 抄表,簡單的說,指從各種各樣計量機器設備(如智能水表、電度表、天然氣表等)載入做好記錄使用量的全過程。這一概念自工業化時代至今就出現了,最初由人工進行,伴隨著科技創新,如今已經演化出自動化和遠程…

Java中的時間戳【詳解】

一.何為Java時間戳 在Java中,時間戳通常指的是自1970年1月1日午夜(UTC)以來的毫秒數。 這個概念在Java中主要通過java.util.Date類和java.sql.Timestamp類來表示 而在Java 8及以后的版本中,引入了新的日期時間API,即…

給大家分享一套非常棒的python機器學習課程

給大家分享一套非常棒的python機器學習課程——《AI小天才:讓小學生輕松掌握機器學習》,2024年5月完結新課,提供配套的代碼筆記軟件包下載!學完本課程,可以輕松掌握機器學習的全面應用,復雜特征工程&#x…

【C++刷題】優選算法——遞歸第三輯

floodfill篇 圖像渲染 unordered_multimap<int, int> direction {{0, 1},{0, -1},{1, 0},{-1, 0} }; void dfs(vector<vector<int>>& image, int sr, int sc, int color, int val) {image[sr][sc] color;for(auto& e : direction){int x sr e.…

關于微服務的一點感悟和過往經驗的思考

一、為什么有微服務 解決單體應用的局限性 隨著業務發展&#xff0c;業務邏輯復雜、關聯方多&#xff0c;導致業務系統的代碼臃腫、難于做迭代或者維護&#xff0c;導致很多的問題&#xff0c;如&#xff1a;bug多、難于維護修復、每次需要評估改動服務接口影響的范圍&#xf…

碰撞器觸發事件(OnTriggerEnter/OnTriggerStay/OnTriggerExit)

碰撞器觸發事件&#xff08;OnTriggerEnter/OnTriggerStay/OnTriggerExit&#xff09;簡介 在Unity中&#xff0c;觸發器事件是當一個游戲對象進入、停留或離開另一個游戲對象的觸發器碰撞器時發生的事件。這些事件分別是: OnTriggerEnter: 當其他Collider首次進入觸發器時調用…

服務端Web資源緩存

1.前言 雖然客戶端緩存效果很好&#xff0c;但它有一個核心問題&#xff1a;要在本地提供資源&#xff0c;必須先將其存儲在緩存中。因此&#xff0c;每個客戶端都需要其緩存的資源。如果請求的資源需要大量計算&#xff0c;則無法擴展。服務器端緩存背后的理念是計算一次資源…

【CAN】libsocketcan庫詳解

1、簡介 libsocketcan是用戶空間通過SocketCAN操作CAN的接口。 源碼:https://github.com/linux-can/libsocketcan 2、API詳解 2.1 can_do_restart 1)說明:重啟CAN接口 2)原型: int can_do_restart(const char *name);3)參數: name:CAN接口名,比如:can0、can1,…

繼續分析開發人員容易被騙的原因和防范措施

繼續分析開發人員容易被騙的原因和防范措施&#xff0c;可以深入探討一些具體的技術細節和實際操作建議&#xff0c;以更全面地理解和應對這一問題。 技術細節&#xff1a; 未加密的敏感數據傳輸&#xff1a; 原因&#xff1a;開發人員可能忽視了數據傳輸過程中的安全性&#…

第10章 軟件架構的演化和維護

軟件架構周期&#xff1a;初始設計、實際使用、修改完善(這就是演化)、退化棄用。 演化和維護的目的&#xff1a;為了使軟件能夠適應環境的變化而進行的糾錯性修改和完善性修改等&#xff0c;而且這個過程是一個不斷迭代的過程。 架構演化的重要性、演化過程、演化分類、演化…

Vary HTTP 標頭

1.前言 服務器端 Web 資源緩存的想法是在客戶端和上游之間設置一個組件來緩存先前計算的結果&#xff0c;以避免后者過載。根據您的基礎架構和要求&#xff0c;此組件可以是反向代理或 API 網關。HTTP 提供Cache-Control標頭來自定義緩存的不同方面&#xff0c;例如&#xff0…

Java——通過方法交換實參值

想寫一個方法來交換main函數中的兩個變量值&#xff0c;代碼如下&#xff1a; public class Test {public static void swap(int x,int y) {int tmp x;x y;y tmp;}public static void main(String[] args) {int a 10;int b 20;System.out.println("交換前&#xff1…

Autodesk Maya 2025軟件安裝教程(附軟件下載地址)

軟件簡介&#xff1a; 軟件【下載地址】獲取方式見文末。注&#xff1a;推薦使用&#xff0c;更貼合此安裝方法&#xff01; Autodesk Maya 2025是一款領先的三維動畫設計軟件&#xff0c;界面直觀且功能豐富。它集成了全球領先的3D設計技術&#xff0c;提供了多種創意功能&a…

深度學習 --- stanford cs231 編程作業(如何在chrome中安裝colab)

stanford cs231 編程作業(如何開始你的colab編程&#xff09; 斯坦福231n的所有作業都要求在colab里面做&#xff0c;colab可以為你提供免費的云計算。實際上在他的官網中也有關于如何安裝colab的詳細說明視頻。 https://youtu.be/DsGd2e9JNH4https://youtu.be/DsGd2e9JNH4 我…

2831.找出最長等值子數組(哈希表+滑動窗口法)

給你一個下標從 0 開始的整數數組 nums 和一個整數 k 。 如果子數組中所有元素都相等&#xff0c;則認為子數組是一個 等值子數組 。注意&#xff0c;空數組是 等值子數組 。 從 nums 中刪除最多 k 個元素后&#xff0c;返回可能的最長等值子數組的長度。 子數組 是數組中一個連…

電路筆記 :元器件焊接相關 酒精燈松香浴加熱取芯片

記錄一下只使用松香和小火源加熱&#xff08;如酒精燈、小蠟燭&#xff09;從電路板中取芯片。 過程 多放松香 讓松香淹沒芯片盡量均勻加熱&#xff0c;等芯片旁邊的松香開始從芯片里冒細小的“泡泡”&#xff0c;就差不多了 注&#xff1a;這種方法也可以用于焊接&#xff0…