綠盟二面面試題

5000篇網安資料庫https://mp.weixin.qq.com/s?__biz=MzkwNjY1Mzc0Nw==&mid=2247486065&idx=2&sn=b30ade8200e842743339d428f414475e&chksm=c0e4732df793fa3bf39a6eab17cc0ed0fca5f0e4c979ce64bd112762def9ee7cf0112a7e76af&scene=21#wechat_redirect

1. 原理深度:Java反序列化漏洞的底層機制是什么?為什么反序列化可能導致RCE?

參考答案

  • 機制:Java反序列化通過ObjectInputStream將二進制數據還原為對象。若攻擊者控制輸入,可構造惡意對象,在反序列化時觸發危險操作(如動態代理、反射調用)。

  • RCE成因
    1. Gadget鏈:利用類庫中多個可串聯的類(如InvokerTransformerTemplatesImpl),通過鏈式調用執行任意代碼。

    2. 動態加載:某些類(如URLClassLoader)允許加載遠程代碼,結合反序列化觸發類初始化邏輯。

    3. 反射調用:利用Method.invoke()Runtime.exec()等實現命令執行。

  • 關鍵點:反序列化過程中未對輸入數據進行校驗,導致惡意類的readObject()readExternal()方法被觸發。

2. 框架漏洞:Apache Commons Collections如何被用于構造反序列化利用鏈?請描述具體類和方法的作用。

參考答案

  • 核心類
    • InvokerTransformer:通過反射調用任意方法,如Runtime.getRuntime().exec("cmd")

    • ChainedTransformer:將多個Transformer串聯,形成鏈式調用。

    • ConstantTransformer:返回固定值,用于傳遞惡意對象。

    • TransformedMap/LazyMap:在Map操作時觸發Transformer鏈。

  • 利用鏈構造
    1. 構造ChainedTransformer鏈,串聯反射調用Runtime.exec()

    2. 通過TransformedMap.decorate()包裝Map,使Map的put()get()操作觸發Transformer鏈。

    3. 利用AnnotationInvocationHandlerreadObject()反序列化入口,觸發Map操作。

  • 示例Payload
    Transformer[]?transformers?=?new?Transformer[]{new?ConstantTransformer(Runtime.class),new?InvokerTransformer("getMethod",?new?Class[]{String.class,?Class[].class},?new?Object[]{"getRuntime",?null}),new?InvokerTransformer("invoke",?new?Class[]{Object.class,?Object[].class},?new?Object[]{null,?null}),new?InvokerTransformer("exec",?new?Class[]{String.class},?new?Object[]{"calc.exe"})
    };
    ChainedTransformer?chain?=?new?ChainedTransformer(transformers);
    

3. 防御機制:如何有效防御Java反序列化漏洞?對比黑名單與白名單方案的優缺點。

參考答案

  • 防御手段
    1. 輸入驗證:禁止反序列化不可信數據。

    2. 白名單:使用ValidatingObjectInputStream(VOIS)僅允許反序列化安全類。

    3. 替換序列化機制:使用JSON(如Jackson)或Protocol Buffers替代Java原生序列化。

    4. JEP 290:JDK9+的過濾器機制,通過模式匹配限制反序列化類。

    5. 安全加固:移除危險類庫(如Commons Collections 3.x升級至4+)。

  • 黑名單 vs 白名單
    • 黑名單:攔截已知危險類(如InvokerTransformer),但易被繞過(新增Gadget或組合類)。

    • 白名單:僅允許已知安全類,安全性更高,但維護成本較大(需覆蓋業務所有合法類)。

4. 框架案例:Fastjson反序列化漏洞的原理是什么?如何利用TemplatesImpl類實現RCE?

參考答案

  • 漏洞原理:Fastjson的autoType功能允許反序列化時指定任意類。攻擊者可構造惡意JSON,觸發目標類的setter/getter或構造函數中的危險操作。

  • TemplatesImpl利用
    1. 構造惡意類:生成一個繼承AbstractTranslet的類,在靜態代碼塊或構造函數中插入惡意代碼。

    2. Base64編碼:將類字節碼Base64編碼后嵌入JSON。

    3. 觸發加載:通過@type指定com.sun.org.apache.xalan.internal.xsltc.trax.TemplatesImpl,并設置_bytecodes_outputProperties字段,觸發類加載與初始化。

  • Payload示例
    {"@type":?"com.sun.org.apache.xalan.internal.xsltc.trax.TemplatesImpl","_bytecodes":?["惡意類Base64編碼"],"_outputProperties":?{}
    }
    

5. 高級繞過:如何繞過反序列化黑名單機制?請舉例說明一種非傳統的Gadget鏈構造方法。

參考答案

  • 繞過手段
    1. 利用冷門類庫:如使用groovy.util.Expandoorg.apache.xbean等非默認黑名單類構造鏈。

    2. 動態加載字節碼:通過BCEL ClassLoaderClassLoader.defineClass()加載遠程字節碼。

    3. 二次反序列化:利用Serializable對象內部嵌套另一個反序列化入口點。

  • 示例:BCEL繞過
    String?className?=?"$$BCEL$$...";?//?BCEL格式的惡意類字節碼
    ClassLoader?loader?=?new?ClassLoader()?{};
    Class?clazz?=?loader.loadClass(className);
    clazz.newInstance();
    
  • 反射+動態代理:通過Proxy.newProxyInstance()創建代理類,結合InvocationHandler執行命令。

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

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

相關文章

線程安全學習

1 什么是線程 線程是cpu調度的最小單位&#xff0c;在Linux 下 實現線程的方式為輕量級進程&#xff0c;復用進程的結構體&#xff0c;使用clone函數創建 2 線程安全 所謂線程安全&#xff0c;更確切的應該描述為內存安全 #include <stdio.h> #include <pthread.h…

Linux紅帽:RHCSA認證知識講解(十 三)在serverb上破解root密碼

Linux紅帽&#xff1a;RHCSA認證知識講解&#xff08;十 三&#xff09;在serverb上破解root密碼 前言操作步驟 前言 在紅帽 Linux 系統的管理工作中&#xff0c;系統管理員可能會遇到需要重置 root 密碼的情況。本文將詳細介紹如何通過救援模式進入系統并重新設置 root 密碼。…

**Microsoft Certified Professional(MCP)** 認證考試

1. MCP 認證考試概述 MCP&#xff08;Microsoft Certified Professional&#xff09;是微軟認證體系中的一項入門級認證&#xff0c;旨在驗證考生在微軟產品和技術&#xff08;如 Windows Server、Azure、SQL Server、Microsoft 365&#xff09;方面的技能。2020 年&#xff0…

系統性能優化總結與思考-第一部分

1.C代碼優化策略總結 編譯器方面&#xff1a;用好的編譯器并用好編譯器&#xff08;支持C11的編譯器&#xff0c;IntelC&#xff08;速度最快&#xff09;GNU的C編譯器GCC/G&#xff08;非常符合標準&#xff09;&#xff0c;Visual C&#xff08;性能折中&#xff09;&#x…

RCL諧振電壓增益曲線

諧振電路如何通過調頻實現穩壓&#xff1f; 為什么要做諧振&#xff1f; 在諧振狀態實現ZVS導通&#xff0c;小電流關斷 電壓增益GVo/Vin&#xff0c;相當于產出投入比 當ff0時&#xff0c;G1時&#xff0c;輸出電壓輸入電壓 當G<1時&#xff0c;輸出電壓<輸入電壓 …

Linux進程相關選擇題及解析

1. 關于Linux進程創建,以下說法正確的是? A. fork()函數調用后,子進程從父進程的fork()之后開始執行 B. fork()函數返回兩次,父進程返回子進程PID,子進程返回0[10][11] C. exec函數族會替換當前進程的代碼段,但保留數據段和堆棧 D. wait()函數只能等待直接子進程退出 答…

STM32 HAL DHT11驅動程序

DHT11驅動程序會占用TIM3定時器&#xff0c;進行高精度延時。程序共包含4個文件 DHT11.c DHT11.h delay.c delay.h DHT11.c #include "stm32f1xx_hal.h" #include "dht11.h" #include "delay.h" // 添加延時頭文件 #define DHT_PORT GPIOB…

網頁防篡改與盜鏈防護:實時監控與自動化修復實踐

摘要&#xff1a;針對網頁內容篡改與盜鏈問題&#xff0c;本文基于群聯AI云防護系統&#xff0c;詳解如何通過哈希校驗、實時監控與CDN聯動實現秒級修復&#xff0c;并提供Python與AWS S3集成代碼。 一、網頁安全的核心需求 防篡改&#xff1a;保障頁面內容完整性&#xff0c;…

【4】k8s集群管理系列--harbor鏡像倉庫本地化搭建

一、harbor基本概念 ?Harbor是一個由VMware開源的企業級Docker鏡像倉庫解決方案?&#xff0c;旨在解決企業在容器化應用部署中的痛點&#xff0c;提供鏡像存儲、管理、安全和分發的全生命周期管理?。Harbor擴展了Docker Registry&#xff0c;增加了企業級功能&#xff0c;如…

Docker 安裝 Elasticsearch 8.x

Docker 安裝 Elasticsearch 8.x 前言一、準備工作二、設置容器的目錄結構三、啟動一個臨時的容器來復制配置文件四、復制配置文件到本地目錄五、刪除臨時容器六、創建并運行容器&#xff0c;掛載本地目錄七、修改文件配置監聽端口八、端口配置&#xff1a;Host 網絡模式 vs Por…

C#: 用Libreoffice實現Word文件轉PDF

現實場景中要實現Word格式轉PDF格式還是比較常見的。 如果要用開源的組件&#xff0c;只有用Libreoffice了。 一、下載安裝Libreoffice 先進入如下鏈接&#xff0c;找到最新版本和匹配的操作系統來安裝。 官網試過&#xff0c;下載是能下載&#xff0c;但安裝了用不了&…

MoogDB數據庫日常維護技巧與常見問題解析

在當今的數據驅動世界中&#xff0c;數據庫作為信息存儲與管理的核心組件&#xff0c;扮演著舉足輕重的角色。MoogDB作為一款高性能、易擴展的數據庫解決方案&#xff0c;越來越受到開發者和企業的青睞。為了確保MoogDB的穩定性與高性能&#xff0c;定期的日常維護及對常見問題…

JAVA多線程的幾種實現方式

?1. 繼承 Thread 類? ?原理?&#xff1a;通過繼承 Thread 類并重寫 run() 方法定義線程任務&#xff0c;調用 start() 啟動線程?。?代碼示例?&#xff1a; public class MyThread extends Thread {Overridepublic void run() {System.out.println("線程 " g…

爬蟲(基本知識介紹,urllib庫的說明)

爬蟲 爬蟲基礎&#xff08;一些基本原理的梳理&#xff09; scheme://[username:password]hostname[:port][/path][;parameters][?query][#fragment] 注&#xff1a; parameters 和 query 混用&#xff0c;并且現在 query 用的多 ?query 查詢 &#xff0c;用來查詢某類資源…

探秘串口服務器廠家:背后的故事與應用

在科技飛速發展的今天&#xff0c;串口服務器作為連接串口設備與網絡的橋梁&#xff0c;在工業自動化、智能交通、智能家居等眾多領域發揮著關鍵作用。你是否好奇&#xff0c;那些生產串口服務器的廠家究竟有著怎樣的故事&#xff1f;它們的產品背后又蘊含著怎樣的原理呢&#…

工廠能耗系統智能化解決方案 —— 安科瑞企業能源管控平臺

安科瑞顧強 政策背景與“雙碳”戰略驅動 2025年《政府工作報告》明確提出“單位國內生產總值能耗降低3%左右”的目標&#xff0c;要求通過產業結構升級&#xff08;如高耗能行業技術革新或轉型&#xff09;、能源結構優化&#xff08;提高非化石能源占比&#xff09;及數字化…

BI面向模型開發和面向報表開發,有什么區別?

在數字化時代&#xff0c;商業智能&#xff08;BI&#xff09;已成為企業決策不可或缺的工具。BI項目實施時&#xff0c;通常有兩種開發模式&#xff1a;面向模型開發和面向報表開發。雖然兩者都旨在通過數據驅動決策&#xff0c;但在開發邏輯、目標價值和技術路徑上存在顯著差…

OpenHarmony人才認證證書

OpenHarmony人才認證體系目前支持初級工程師認證&#xff0c;要求了解OpenHarmony開源項目、生態進展及系統移植等基礎知識&#xff0c;熟練掌握OpenHarmony的ArkUI、分布式軟總線、分布式硬件、分布式數據管理等基礎能力使用&#xff0c;具備基礎的開發能力。 考試流程可參考O…

映射網絡路路徑和ftp路徑原理是什么,如何使用,有什么區別

文章目錄 一、原理1. 映射網絡路徑2. FTP路徑 二、使用方法1. 映射網絡路徑2. FTP路徑 三、主要區別1. 協議與功能2. 安全性與權限3. 適用場景 四、如何選擇&#xff1f;五、注意事項 映射網絡路徑&#xff08;如SMB/CIFS或NFS&#xff09;和FTP路徑&#xff08;FTP/FTPS/SFTP&…

Windows 圖形顯示驅動開發-WDDM 1.2功能—Windows 8 中的 DirectX 功能改進(一)

Windows 8包括 Microsoft DirectX 功能改進&#xff0c;使開發人員、最終用戶和系統制造商受益。 功能改進在以下幾個方面&#xff1a; 像素格式 (5551、565、4444) &#xff1a;在低功耗硬件配置下&#xff0c;DirectX 應用程序的性能更高。雙精度著色器功能&#xff1a;高級…