简介
Openfire是一个开源的实时协作(RTC)服务器,采用开源Apache许可证。它是一个即时通讯(IM)和群聊服务器,使用Java编写并使用XMPP协议。它非常易于设置和管理,但提供了坚实的安全性和性能
影响版本
3.10.0
<= Openfire <4.6.8
4.7.0
<=Openfire <4.7.5
选择搭建的版本为4.7.4
,windos下搭建省心省力,下载链接
环境搭建
data:image/s3,"s3://crabby-images/400a1/400a1fc6a2c2f90287e75a4fcdd1abdd08b4f73a" alt=""
一直下一步
data:image/s3,"s3://crabby-images/df553/df55341ee47687fc6235abee9abca629d9838608" alt=""
前提是环境已经安装过jdk
data:image/s3,"s3://crabby-images/906f1/906f15c46020ec52c32d2106236806c842c48e40" alt=""
data:image/s3,"s3://crabby-images/64de0/64de0547affa3a701dfefb0c978bd4c1d21d2814" alt=""
启动服务端,访问管理界面进行配置
data:image/s3,"s3://crabby-images/e4710/e4710e4e182e4fda33999dc72a2351f4ccc1e2d6" alt=""
data:image/s3,"s3://crabby-images/d9ae8/d9ae80cfb346a92ed642e471112a5ecc2ff02e6c" alt=""
掠过其它步骤,数据库无需配置,配置管理账户
data:image/s3,"s3://crabby-images/7579b/7579ba0704867d5078097dc1f67a3bb27d53709c" alt=""
data:image/s3,"s3://crabby-images/63199/631990c8c685b3711aed5b60b171853658f0f093" alt=""
漏洞复现
漏洞url
data:image/s3,"s3://crabby-images/aa936/aa93607f2608aac116c54b982b7ba7560560a0dc" alt=""
泄露日志文件,payload如下
/setup/setup-s/%u002e%u002e/%u002e%u002e/*.jsp
漏洞分析
查看配置文件xmppserver/src/main/webapp/WEB-INF/web.xm
<filter-mapping>
<filter-name>AuthCheck</filter-name>
<url-pattern>*.jsp</url-pattern>
</filter-mapping>
<filter>
<filter-name>AuthCheck</filter-name>
<filter-class>org.jivesoftware.admin.AuthCheckFilter</filter-class>
<init-param>
<param-name>excludes</param-name>
<param-value>
login.jsp,index.jsp?logout=true,setup/index.jsp,setup/setup-*,.gif,.png,error-serverdown.jsp,loginToken.jsp
</param-value>
</init-param>
</filter>
查看源文件该配置文件已经修改了,但是查看最新版本和4.7.4的文件对比发现该部分内容如上
data:image/s3,"s3://crabby-images/3bb3c/3bb3c6a6be7e5c7d4a9260a0a8292c9728f7d591" alt=""
xmppserver/src/main/java/org/jivesoftware/admin/AuthCheckFilter.java
public static boolean testURLPassesExclude(String url, String exclude) {
if (exclude.endsWith("*")) {
if (url.startsWith(exclude.substring(0, exclude.length()-1))) {
// Now make sure that there are no ".." characters in the rest of the URL.
if (!url.contains("..") && !url.toLowerCase().contains("%2e")) {
return true;
}
}
该代码部分导致了漏洞的产生,当url中含有setup的路径的时候满足第一个if语句,当满payload中含有../../
的时候满足第二个if条件,当../../
做uft-8编码的时候绕过了第三个if条件导致了bypass,所以在修复的代码中对于用户认证这部分增加utf8的解码以及在web.xml中
对exclude的值做了修改
同样4.7.5
中已经修改
data:image/s3,"s3://crabby-images/22f03/22f0312f127bd903dc113d9fb45d4008f8fec9f4" alt=""
创建用户
通过未授权进行命令执行,可以直接使用编译好的工具获取admin用户组的用户密码登录
data:image/s3,"s3://crabby-images/8b9de/8b9debc4b2b4254781ab41325dd734ce25e77e28" alt=""
图片来自于github,工具我没有测试,有兴趣的可以参考
这个用户身份bypass详细有的师傅能发现跟之前某大厂OA基本一样。
命令执行
根据创建的用户登录之后上传webshell,从上面的地址上传别人封装好的jar包,插件位置上传jar包
data:image/s3,"s3://crabby-images/6bd9a/6bd9a453ce7ae7f70cfd6e209e8d3cba90fa7a7e" alt=""
上传成功
data:image/s3,"s3://crabby-images/e1b84/e1b84cfd0a4345ae3184ed0d18df1961c8602beb" alt=""
执行命令
data:image/s3,"s3://crabby-images/ed93d/ed93d57fc1044c2cc1c106eb8f2eaca34279eb33" alt=""
data:image/s3,"s3://crabby-images/c9994/c9994a59779f7324313f8ec2768baaa9935d6d3d" alt=""