中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

怎么檢測Linux上的庫注入

發布時間:2021-10-23 10:46:43 來源:億速云 閱讀:367 作者:小新 欄目:系統運維

這篇文章主要為大家展示了“怎么檢測Linux上的庫注入”,內容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領大家一起研究并學習一下“怎么檢測Linux上的庫注入”這篇文章吧。

共享庫漏洞

DLL 和 .so 文件都是允許代碼(有時候是數據)被不同的進程共享的共享庫文件。公用的代碼可以放進一個文件中使得每個需要它的進程可以重新使用而不是多次被重寫。這也促進了對公用代碼的管理。

Linux 進程經常使用這些共享庫。(顯示共享對象依賴的)ldd 命令可以對任何程序文件顯示其共享庫。這里有一些例子:

$ ldd /bin/date        linux-vdso.so.1 (0x00007ffc5f179000)        libc.so.6 => /lib/x86_64-linux-gnu/libc.so.6 (0x00007f02bea15000)        /lib64/ld-linux-x86-64.so.2 (0x00007f02bec3a000)$ ldd /bin/netstat        linux-vdso.so.1 (0x00007ffcb67cd000)        libselinux.so.1 => /lib/x86_64-linux-gnu/libselinux.so.1 (0x00007f45e5d7b000)        libc.so.6 => /lib/x86_64-linux-gnu/libc.so.6 (0x00007f45e5b90000)        libpcre.so.3 => /lib/x86_64-linux-gnu/libpcre.so.3 (0x00007f45e5b1c000)        libdl.so.2 => /lib/x86_64-linux-gnu/libdl.so.2 (0x00007f45e5b16000)        /lib64/ld-linux-x86-64.so.2 (0x00007f45e5dec000)        libpthread.so.0 => /lib/x86_64-linux-gnu/libpthread.so.0 (0x00007f45e5af5000)

linux-vdso.so.1 (在一些系統上也許會有不同的名字)是內核自動映射到每個進程地址空間的文件。它的工作是找到并定位進程所需的其他共享庫。

對庫加載機制加以利用的一種方法是通過使用 LD_PRELOAD 環境變量。正如 Jaime Blasco 在他的研究中所解釋的那樣,“LD_PRELOAD 是在進程啟動時加載共享庫的很簡單且非常受歡迎的方法。可以將此環境變量配置到共享庫的路徑,以便在加載其他共享對象之前加載該共享庫。”

為了展示有多簡單,我創建了一個極其簡單的共享庫并且賦值給我的(之前不存在) LD_PRELOAD 環境變量。之后我使用 ldd 命令查看它對于常用 Linux 命令的影響。

$ export LD_PRELOAD=/home/shs/shownum.so$ ldd /bin/date        linux-vdso.so.1 (0x00007ffe005ce000)        /home/shs/shownum.so (0x00007f1e6b65f000)     <== 它在這里        libc.so.6 => /lib/x86_64-linux-gnu/libc.so.6 (0x00007f1e6b458000)        /lib64/ld-linux-x86-64.so.2 (0x00007f1e6b682000)

注意,僅僅將新的庫賦給 LD_PRELOAD 就影響到了運行的任何程序。

通過設置 LD_PRELOAD 指定的共享庫首先被加載(緊隨 linux-vdso.so.1),這些庫可以極大程度上改變一個進程。例如,它們可以重定向系統調用到它們自己的資源,或對程序運行的行為方式進行意想不到的更改。

osquery 工具可以檢測庫注入

osquery 工具(可以在 osquery.io下載)提供了一個非常獨特的查看 Linux 系統的方式。它基本上將操作系統視作一個高性能的關系數據庫。然后,也許你會猜到,這就意味著它可以用來查詢并且生成 SQL 表,該表提供了諸如以下的詳細信息:

  • 運行中的進程

  • 加載的內核模塊

  • 打開的網絡鏈接

一個提供了進程信息的內核表叫做 process_envs。它提供了各種進程使用環境變量的詳細信息。Jaime Blasco 提供了一個相當復雜的查詢,可以使用 osquery 識別出使用 LD_PRELOAD 的進程。

注意,這個查詢是從 process_envs 表中獲取數據。攻擊 ID(T1055)參考 Mitre 對攻擊方法的解釋。

SELECT process_envs.pid as source_process_id, process_envs.key as environment_variable_key, process_envs.value as environment_variable_value, processes.name as source_process, processes.path as file_path, processes.cmdline as source_process_commandline, processes.cwd as current_working_directory, 'T1055' as event_attack_id, 'Process Injection' as event_attack_technique, 'Defense Evasion, Privilege Escalation' as event_attack_tactic FROM process_envs join processes USING (pid) WHERE key = 'LD_PRELOAD';

注意 LD_PRELOAD 環境變量有時是合法使用的。例如,各種安全監控工具可能會使用到它,因為開發人員需要進行故障排除、調試或性能分析。然而,它的使用仍然很少見,應當加以防范。

同樣值得注意的是 osquery 可以交互使用或是作為定期查詢的守護進程去運行。了解更多請查閱文章末尾給出的參考。

你也能夠通過查看用戶的環境設置來定位 LD_PRELOAD 的使用。如果在用戶賬戶中使用了 LD_PRELOAD,你可以使用這樣的命令來查看(假定以個人身份登錄后):

$ env | grep PRELOADLD_PRELOAD=/home/username/userlib.so

以上是“怎么檢測Linux上的庫注入”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

芦山县| 繁昌县| 砀山县| 阜平县| 抚顺市| 永和县| 都安| 旅游| 安康市| 贺兰县| 张家界市| 云和县| 肇州县| 乐都县| 汨罗市| 保德县| 阳西县| 霸州市| 利辛县| 边坝县| 密山市| 建宁县| 民丰县| 泸西县| 进贤县| 瓮安县| 大石桥市| 葵青区| 呼玛县| 彭州市| 黄大仙区| 吉安市| 老河口市| 乐都县| 诸暨市| 泗水县| 雷波县| 静海县| 博乐市| 中宁县| 萨迦县|