起因:這是很早的文章了,當初團隊師傅想看H片,奈何不想花錢購買,然後審計了H站自助提卡系統,並收穫了80G種子1
前言
並非有意願要審計該站,前面的走的黑盒沒有過於精彩部分就不在貼上了,對於此係統站你們懂的,多說無益,這套程式是開源的,像這種自助提卡系統相信大家已經不在陌生了,很多違法網站通過這種平臺方式提卡密的相當於購買邀請碼,原始碼是小夥伴提供的,採用的是php+mysql進行開發的24小時自動售卡平臺,廢話就不多說了。
相關環境
原始碼資訊:你猜啊
漏洞型別:Forwarded-For注入
搭建成功之後如下 :
看到如下頁面是不是有似曾相識的感受:
data:image/s3,"s3://crabby-images/1df38/1df388db242c8fe9169970394438b0b65208c670" alt="對自助提卡系統的一次程式碼審計"
上圖是安裝過後的首頁,就是一個提卡網,繼續吧繼續!
data:image/s3,"s3://crabby-images/3f91f/3f91ff0d42e99cd1e686904e69dfa6a10b21c383" alt="對自助提卡系統的一次程式碼審計"
這是首頁檔案,進去首先判斷了install目錄下的lock檔案是否不存在並且判斷是否有index.php檔案,如果滿足以上條件就跳轉到install目錄下的index.php,我們跟進install/index.php檔案:
data:image/s3,"s3://crabby-images/d93bb/d93bbdd6c17868bebfe3aa8d206bf3a35be2cd19" alt="對自助提卡系統的一次程式碼審計"
data:image/s3,"s3://crabby-images/ebb9c/ebb9c2478f6cc01f374f626a55d64eb94a0a1857" alt="對自助提卡系統的一次程式碼審計"
這裡我們只看判斷是否安裝過程式,判斷是否存在lock檔案並且step不等於5的情況下就執行判斷語句中的程式碼,當然這裡如果header函式後沒有exit就會存在重灌漏洞。
我們接著看index.php,光是index.php檔案就用413行程式碼,程式碼都不規範,所以我們先看看其它檔案,看看api.php檔案:
data:image/s3,"s3://crabby-images/bb62e/bb62ead507514b47a54b81d9397cdad677c2c1c9" alt="對自助提卡系統的一次程式碼審計"
這裡很明顯我們看到了SQL隱碼攻擊,首先判斷是否設定了$_POST[“dh”]再判斷$_POST[“dh”]不為空則將該引數拼接到SQL語句中,看到這裡就可以判斷出該程式存在聯合查詢注入,可是$config哪來的,這個檔案也沒包含其它的檔案啊!!!怎麼辦呢?那麼我們就來找找index檔案中是否包含了api.php,search一下
data:image/s3,"s3://crabby-images/1909f/1909fd7c82192376411cf8143b3d8efb44a65c46" alt="對自助提卡系統的一次程式碼審計"
可以看到在294行這裡包含了api.php檔案,我們構造下放入sqlmap中玩一玩
Python sqlmap.py -u “http://localhost:8081/index.php” --batch --dbms=”mysql” --data=”dh=a”
data:image/s3,"s3://crabby-images/828bb/828bbaa87b7ff6914fbabb80379bd3c1c9e3f756" alt="對自助提卡系統的一次程式碼審計"
這裡可以看到注入型別確實是聯合查詢,我們接著嘗試下這個提卡網是否存在SQL隱碼攻擊
Python sqlmap.py -u "http://xxxx.pw/index.php" --batch --dbms="mysql" --data="dh=a"
data:image/s3,"s3://crabby-images/518d8/518d847dab60746a5a7b698e3895ede26c1f5029" alt="對自助提卡系統的一次程式碼審計"
我們嘗試本地站點的時候毫無問題,可是為啥這個提卡網就存在問題了呢?很明顯這個網站可能是升級或者二開過的,我們接著看看其它點,進入./pay/pay.php檔案
data:image/s3,"s3://crabby-images/af181/af181a1f65a933e948b452d5267341965d3bfff1" alt="對自助提卡系統的一次程式碼審計"
data:image/s3,"s3://crabby-images/d2e62/d2e621e74332f3cd146cd944e8fe717e8828a14c" alt="對自助提卡系統的一次程式碼審計"
data:image/s3,"s3://crabby-images/655e6/655e69298c39b76963ecb260906cdb32eaa3092f" alt="對自助提卡系統的一次程式碼審計"
data:image/s3,"s3://crabby-images/0cc2f/0cc2ff3575868bb1276c5643781cfdde139fb307" alt="對自助提卡系統的一次程式碼審計"
data:image/s3,"s3://crabby-images/0097b/0097bc1f58841b6f4905aae2319b1d0ac1c5f5fd" alt="對自助提卡系統的一次程式碼審計"
程式碼過多就不一一貼圖出來了,主要構成漏洞的程式碼就在這其中,我們從38行開始看著走
這裡判斷$_GET[“type”]等於delete的時候則執行40-49行的程式碼,41將獲取到的ip拼接到sql語句中,我們看看ip函式:
data:image/s3,"s3://crabby-images/380c4/380c45d77dc0d646c961be1414ece17414c199ed" alt="對自助提卡系統的一次程式碼審計"
data:image/s3,"s3://crabby-images/4adb1/4adb19ef91800fc21cfe6d80f86ffd7e07783732" alt="對自助提卡系統的一次程式碼審計"
這裡可以看到程式獲取ip可以從客戶端的頭引數中獲取,分別為HTTP_X_FORWARDED_FOR,HTTP_CLIENT_IP,這個函式真的僅僅是獲取外部傳遞的引數的,一點也沒有過濾,我們看到了這裡就可以嘿嘿嘿了,基本上這個網站拿下了,我們接著看看,回到41行,再看下邊的,我們不宜在這裡進行SQL隱碼攻擊,因為接著會將查詢到的值又進行下一個SQL語句的拼接,這樣返回值就不準確,用工具的過程就很難判斷了,我們跳出這裡的判斷,看看51-54行分別判斷了$_GET['type'],$_GET['money'],$_GET['title'],$_GET['pwd']這幾個引數存不存在,所以我們這裡可以這樣構造get引數:type=a&money=1&title=adssad&pwd=123
我們接著看下邊的,第58-65行,首先是判斷了type是否等於zfb,若不等於則退出當前程式並列印Tip:Type error!,所以我們還得接著改改get引數:
type=zfb&money=1&title=adssad&pwd=123
接下來,可以看到67行中再次將獲取到的ip拼接到了SQL語句中,我們這樣來,在67行的下邊列印出當前執行的SQL語句
data:image/s3,"s3://crabby-images/a55ee/a55eec37f868a2c6a9d739c281175add94a8622f" alt="對自助提卡系統的一次程式碼審計"
好了,現在我們開啟burp進行抓包,然後偽造ip進行一系列的嘿嘿嘿了,因為./pay/index.php中包含了pay.php,所以我們對index.php進行注入就好
復現:
訪問http://localhost:8081/pay/index.php?type=zfb&money=1&title=adssad&pwd=123
data:image/s3,"s3://crabby-images/29275/29275fef8c947f189a13be538220647ee8c2634b" alt="對自助提卡系統的一次程式碼審計"
可以看到這是一個很正常的頁面了,並且列印出了SQL語句,我們抓包
data:image/s3,"s3://crabby-images/ff8a0/ff8a088f5281e9d26392787dad140c6d3d1ca9df" alt="對自助提卡系統的一次程式碼審計"
data:image/s3,"s3://crabby-images/5d844/5d844e27c127945d30c2f8be4b3636f50d973426" alt="對自助提卡系統的一次程式碼審計"
正常頁面:
data:image/s3,"s3://crabby-images/d37f6/d37f632046b70a1bd393ab6a5d086643698921a2" alt="對自助提卡系統的一次程式碼審計"
錯誤頁面:
data:image/s3,"s3://crabby-images/93bf2/93bf23fbfea1f0a75f85b13d5d646735dd4fe578" alt="對自助提卡系統的一次程式碼審計"
好的,現在看到了吧!我們放到SQLmap中跑一下看看,我們將這個資料包儲存到文字中,並且標註注入位置
data:image/s3,"s3://crabby-images/a5fae/a5faec191e24f8ea065e7725272ceb6af5b5efc8" alt="對自助提卡系統的一次程式碼審計"
Python sqlmap.py -r test.txt --batch --dbms="mysql"
data:image/s3,"s3://crabby-images/7634e/7634e09f201bced89f8bd68b6e3c7acfb621ef9f" alt="對自助提卡系統的一次程式碼審計"
我們對那個網站測試一番,訪問:http://xxxxx.pw/pay/index.php?type=zfb&money=1&title=adssad&pwd=123
data:image/s3,"s3://crabby-images/3ced3/3ced3b0300d0725c8930fe73929d460f5142d31e" alt="對自助提卡系統的一次程式碼審計"
可以看到缺少spid引數我們加上繼續訪問:
http://xxxxxx.pw/pay/index.php?type=zfb&money=1&title=adssad&pwd=123&spid=1
data:image/s3,"s3://crabby-images/97ce0/97ce001339d10949510a200609b830f7bc70cfb9" alt="對自助提卡系統的一次程式碼審計"
把該資料放到文字中,接著進行測試:
data:image/s3,"s3://crabby-images/ef313/ef313aabb2b3aac95c16c19d692481611a39ed60" alt="對自助提卡系統的一次程式碼審計"
Python sqlmap.py -r test.txt --batch --dbms="mysql"
data:image/s3,"s3://crabby-images/27518/275180b21dd0d3b958b861f84dd8e8486e18320f" alt="對自助提卡系統的一次程式碼審計"
成功挖掘到了該網站的漏洞,繼續。。。。
data:image/s3,"s3://crabby-images/966a5/966a5a416cb482734f89405cc936cad9c9477201" alt="對自助提卡系統的一次程式碼審計"
Python sqlmap.py -r test.txt --batch -D yulinxscom --tables
data:image/s3,"s3://crabby-images/4d7c1/4d7c18a198b7aedeadf177b2627f61b1dcd8d5b2" alt="對自助提卡系統的一次程式碼審計"
Python sqlmap.py -r test.txt --batch -D yulinxscom -T admin --dump
data:image/s3,"s3://crabby-images/3d74d/3d74d1a3e60a4f7e8694ad4bd8ce3ff6d1369221" alt="對自助提卡系統的一次程式碼審計"
成功拿到了管理賬號及密碼。。。。。接著來
預設後臺:http://xxxxx.pw/admin.php
data:image/s3,"s3://crabby-images/df786/df7866dd682537a9ce19faf96e58a75c1e423095" alt="對自助提卡系統的一次程式碼審計"
由於之前進去過一次,讓他虧損了點錢,現在後臺的名字也改了 。
寫在結尾
跟此網站的搭建人聊了會,從去年11月份搭建平臺以來已獲利普通人一年的薪資。為了養家餬口,冒此風險也是不容易,切勿為了蠅頭小利以身試法,就這樣做個記錄,到此為止吧。
文中提及技術細節,僅作交流,請勿用於非法活動!!