這篇文章跟大家分析一下“LDAP NULL bind導致登錄繞過漏洞分析和修復方案是什么”。內(nèi)容詳細易懂,對“LDAP NULL bind導致登錄繞過漏洞分析和修復方案是什么”感興趣的朋友可以跟著小編的思路慢慢深入來閱讀一下,希望閱讀后能夠?qū)Υ蠹矣兴鶐椭?。下面跟著小編一起深入學習“LDAP NULL bind導致登錄繞過漏洞分析和修復方案是什么”的知識吧。
目前創(chuàng)新互聯(lián)已為超過千家的企業(yè)提供了網(wǎng)站建設、域名、網(wǎng)站空間、網(wǎng)站托管、服務器租用、企業(yè)網(wǎng)站設計、城區(qū)網(wǎng)站維護等服務,公司將堅持客戶導向、應用為本的策略,正道將秉承"和諧、參與、激情"的文化,與客戶和合作伙伴齊心協(xié)力一起成長,共同發(fā)展。
LDAP輕型目錄訪問協(xié)議是一個開放的,中立的,工業(yè)標準的應用協(xié)議,通過IP協(xié)議提供訪問控制和維護分布式信息的目錄信息。有優(yōu)異的讀性能,但寫性能差。
LDAP作為開放的Internet標準,支持跨平臺,在業(yè)界中得到廣泛認可和使用,只需要通過簡單的配置就可以實現(xiàn)與服務器的認證交互,可以很便捷的實現(xiàn)LDAP統(tǒng)一認證服務,如我們?nèi)粘J褂玫膕so。
LDAP bind綁定可以理解為一個登陸認證的過程,通常,在根據(jù)LDAP進行身份驗證時,判斷是否登陸成功會采取以下三種方法之一:
使用LDAP用戶的用戶名和密碼綁定到LDAP服務器;
最常見的簡單代碼實現(xiàn)方式,第三方應用也常用;
在LDAP中檢索用戶的條目,然后將用戶輸入的密碼和檢索到的LDAP記錄中的密碼屬性相比較;
LDAP服務器對于password屬性可讀的情況,較少見;
“兩次綁定”驗證方法
支持匿名綁定的LDAP服務器下,進行初次匿名,第二次提交身份信息進行綁定,也比較常見。
或者稱為Anonymous bind,不同于匿名訪問,匿名綁定很多情況下不被認為構成漏洞。匿名綁定指用戶無需身份驗證,即可直接提交空值,以“NULL BIND”的方式連接到該服務器完成綁定,但不能執(zhí)行訪問/查詢。如果存在匿名訪問漏洞,則還可以執(zhí)行查詢等操作。
如圖為Windows Server 2016的AD,可以對rootDSE匿名綁定,但不能匿名查詢支持的DN
圖1.匿名綁定成功
圖2.匿名訪問/查詢不成功
圖3.通過驗證可以查詢/訪問
在rfc【反和諧】4513的5.1.2和6.3.1小節(jié),有關于該問題的描述
“https://datatracker.ietf.org/doc/rfc【反和諧】4513/?include_text=1”
重要部分翻譯如下
5.1.2
LDAP客戶機可以使用簡單綁定方法,通過未經(jīng)驗證的身份驗證機制來建立匿名授權狀態(tài),方法是發(fā)送帶有名稱值(LDAP字符串形式為非零長度的RFC【反和諧】44514的可分辨名稱)的綁定請求,并指定包含零長度密碼值的簡單身份驗證選項
...
打算執(zhí)行身份驗證的用戶可能會無意中提供空密碼,從而導致執(zhí)行不佳的客戶端請求未經(jīng)身份驗證的訪問??蛻舳藨摻瓜蛎Q/密碼驗證用戶界面輸入空密碼。此外,默認情況下服務器應失敗未經(jīng)身份驗證的綁定請求。
...
6.3.1
...
使用簡單Bind操作的結果來做出授權決策的客戶端應主動檢測未經(jīng)身份驗證的Bind請求(通過驗證提供的密碼是否為空)并做出適當?shù)姆磻?/p>
...
微軟AD(Windows ActiveDirectories)在默認情況下,不支持針對活動目錄Active Directory的任何LDAP匿名操作,但支持對rootDSE的匿名搜索和綁定,且無法禁用。
Windows server 2003之前的版本需要手動調(diào)整,以禁用對活動目錄Active Directory的LDAP匿名操作,包括綁定、搜索和查詢。
微軟官方說明:“https://docs.microsoft.com/en-us/troubleshoot/windows-server/identity/anonymous-ldap-operations-active-directory-disabled”
Active Directory:存儲了有關對象的信息,能讓管理員和用戶能夠輕松地查找和使用這些信息。
rootDSE:是目錄信務器目錄信息樹的根,目的是提供關于directory Server的本身的數(shù)據(jù)。例如,如果一個客戶端知道目錄服務器正在監(jiān)聽的主機名和端口,則它應該通過詢問rootDSE來了解directory server本身的信息和數(shù)據(jù)。
通常包含下面的一些信息
廠商/供應商=Vendor
服務器支持的命名上下文=naming contexts
服務器支持的請求控制=request control
支持的SASL機制
支持的功能
Schema位置等等信息
OpenLDAP在simple配置下,現(xiàn)行版本默認情況下支持匿名綁定,可以手動調(diào)整禁用。部分早期版本還支持匿名訪問?!癶ttps://openldap.org/doc/admin24/security.html”
(1)某IT系統(tǒng),由管理員自己分配有權限的賬戶,維持一個列表,依據(jù)LDAP進行密碼校驗;
(2)登陸時,驗證用戶名是否在服務器賬戶列表內(nèi),提交到LDAP驗證,判斷登陸是否成功;
(3)離職用戶(即LDAP中不存在,但是在系統(tǒng)自身用戶列表內(nèi))可以使用任意密碼登陸
分析代碼發(fā)現(xiàn),系統(tǒng)邏輯如下:
校驗輸入用戶是否是已分配的合法用戶;
對于合法用戶,在LDAP服務器中查詢用戶DN信息;
提交DN與passwd密碼,通過與LDAP綁定是否成功,判定登錄狀態(tài)。
漏洞成因如下,在第2步時,因為離職員工信息在LDAP中已經(jīng)刪除,返回DN為空。而上層域控為windows server DC,允許對rootDSE的NULL綁定,因此提交了空DN與任意密碼。php代碼認為ldap_bind執(zhí)行結果為真,判定登陸成功。
等價于如圖所示的情況,Base不選擇的情況下默認為rootDSE。微軟AD的rootDSE允許匿名綁定。
有問題的代碼塊如下,ldap_bind的結果判定為真
修改后,增加了判斷l(xiāng)dap_user_dn是否為空的判定,若LDAP中不存在用戶信息,則直接返回錯誤不進行提交。
Nessus可以不穩(wěn)定的報出這個漏洞,描述如下,定義為中危的信息泄露
描述中明確,“此插件不能證明存在LDAP匿名訪問漏洞,且LDAP v3要求支持匿名綁定”
“https://www.tenable.com/plugins/nessus/10723”
輸入host,選擇匿名連接
支持的情況
不支持的情況
使用Softerra LDAP Browser 工具驗證過程如下
1.選擇服務器,并選擇Base DN為RootDSE;
2.選擇“Anonymous user”匿名用戶
3.選擇完成,發(fā)現(xiàn)可以匿名綁定,并加載根目錄信息
如果不支持NULL BIND,則無法加載根目錄信息
Python代碼,ldapconn.simple_bind_s傳空參數(shù),則會判定綁定成功
import ldap
ldapconn = ldap.initialize('ldap://X.X.X.X:389')
ldapconn.simple_bind_s('', '')
print("helllo")
官方python_LDAP庫文檔的說明如下,在who和cred參數(shù),可以接收空值
“https://pypi.org/project/python-ldap/”
根據(jù)官方文檔,需要在slapd.conf中指定“ disallow bind_anon ”來禁用匿名綁定機制。
“https://openldap.org/doc/admin24/security.html”
1.vi /etc/openldap/slapd.d/cn\=config.ldif
添加:
olcDisallows: bind_anon
olcRequires: authc
vi /etc/openldap/slapd.d/cn\=config/olcDatabase\=\{-1\}frontend.ldif
添加:
olcRequires: authc
2.重啟slapd服務
systemctl restart slapd
驗證,不允許匿名綁定
Windows-OpenLDAP直接修改此文件即可
Windows Server 2003之后的版本,默認不允許對Active Directory的匿名綁定
但因功能設計,針對rootDSE匿名綁定無法禁用
可以通過以下方式調(diào)整對Active Directory匿名訪問
“https://docs.microsoft.com/en-us/troubleshoot/windows-server/identity/anonymous-ldap-operations-active-directory-disabled”
服務器運行AdsiEdit.msc,連接到配置
2.選中LDAP條目,選擇【CN=Configuration,CN={GUID}】雙擊【CN=Services】, 雙擊【CN=Windows NT】,在【CN=Directory Service)】右鍵選擇屬性
2.將DsHeuristics 屬性值設置為0(0000002表示允許)
3.使用任意LDAP工具嘗試連接并Fetch DNS,可以看到對Active Directory的匿名訪問失敗
使用LDAP的服務器,后端驗證邏輯避免此問題比較簡單,對提交到LDAP的用戶輸入值,進行空值校驗即可。注意在前后端均做控制,并檢查提交參數(shù)的邏輯。
此外,使用LDAP認證登陸的應用系統(tǒng),也需要注意避免LDAP注入類的問題。
如圖示例,為vmware harbor開源平臺的LDAP驗證邏輯
關于LDAP NULL bind導致登錄繞過漏洞分析和修復方案是什么就分享到這里啦,希望上述內(nèi)容能夠讓大家有所提升。如果想要學習更多知識,請大家多多留意小編的更新。謝謝大家關注一下創(chuàng)新互聯(lián)網(wǎng)站!