【网络安全】系统0day分析

前言

起因看见通告,描述是通过/lfw/core/rpc接口访问到PortalSpecServiceImpl类中的createSkinFile方法。


补丁名称:patch_portal65_lfw任意文件上传漏洞
补丁编码:NCM_NC6.5_000_109902_20240301_GP_281362040

【386G《黑客&网络安全入门&进阶学习资源包》免费分享​ 】icon-default.png?t=N7T8https://docs.qq.com/doc/DVVhkS25iQ0RhVXVE包含:
①网络安全学习路线
②20份渗透测试电子书
③安全攻防357页笔记
④50份安全攻防面试指南
⑤安全红队渗透工具包
⑥网络安全必备书籍
⑦100个漏洞实战案例
⑧安全大厂内部视频资源
⑨历年CTF夺旗赛题解析

搜了下网上没有相关描述
接口和关键类和函数描述中都给出来了,直接定位如下

调用handleRequest

继续跟进getControlPlugin

然后调用RpcControlPlugin.handle

RpcHelper.processJsonRequest如下,获取rpcdata参数,用json存储,并传递给call函数

在call()中,获取json中的rpcname和methond和params,通过paramList存储params参数,params参数最多不超过10个

然后一顿字符串处理,直接拉到call函数最后,instance、getMethod、method.invoke获取实例、获取类方法、反射调用,并且通过上面可以知道,所以参数都可控。

看起来是直接代码执行。

【386G《黑客&网络安全入门&进阶学习资源包》免费分享​ 】icon-default.png?t=N7T8https://docs.qq.com/doc/DVVhkS25iQ0RhVXVE包含:
①网络安全学习路线
②20份渗透测试电子书
③安全攻防357页笔记
④50份安全攻防面试指南
⑤安全红队渗透工具包
⑥网络安全必备书籍
⑦100个漏洞实战案例
⑧安全大厂内部视频资源
⑨历年CTF夺旗赛题解析

0x01

直接传递如下

rpcname为bsh.Interpreter
method为eval
params为ping o3n9.callback.red

直接发包,返回500,没这么简单。。。
先把命令改成whoami,再次发送,还是500,参数这么简单,中间代码是处理字符串和获取参数对应的class应该不会出什么问题
然后详细看了下获取实例的函数ServiceLocator.getService(className);

调用getInstance().doGetService(name);
doGetService函数如下,NCLocator.getInstance()看起来好熟悉,在哪个漏洞接口见过。

rpcname直接设置为ldap://xxx,method和params随便设置即可,因为反射调用找不到方法导致报错是后面的事了。
直接发,获取到请求,接着打jndi就行。

0x02

由于描述说的是文件上传,查了下ServiceLocator.getService,叫做服务定位器模式,这看起来像JNDI的样子

服务定位模式(Service Locator Pattern)是一种设计模式,用于解耦客户端和服务的依赖关系。在服务定位模式中,一个中心的服务定位器(Service Locator)负责管理和提供服务的实例,客户端通过服务定位器来获取所需的服务,即能够在不知道抽象类的具体类型的情况下定位到服务。

例子如下图所示

然后ServiceLocator这样调用service1、2

也就是说通过ServiceLocator.getService(className)去获取实例,className要先被加入到ServiceCache才能通过getService获取到。
上面用的bsh.Interpreter这个类是获取不到的,描述里的这个类PortalSpecServiceImpl应该能获取到的,并且有createSkinFile方法可以写文件
一共6个参数,分别拼接到filePath里

直接构造

rpcname为nc.uap.portal.service.impl.PortalSpecServiceImpl
method为createSkinFile
params为String1、2、3等

再次直接打,服务器还是返回500,正常来说,应该没啥问题的,有点难受。

0x03

下面两个思路

找ServiceCache里有哪些类,然后找有可以执行命令或者写文件public方法的类。
继续看下为什么PortalSpecServiceImpl调不了

下面继续看了,跟着上面的NCLocator.getInstance().lookup(name)

doGetService    
    -->ServerNCLocator#lookup
        -->BusinessAppServer#lookup
            -->AbstractContext#lookup

大概有三种方式加载

name以->开头通过findMeta()和findComponent()获取实例。
name不以->开头,直接通过服务定位模式this.getServiceCache().get(name)在Cache中取,如果有的话直接返回实例
name以java:comp/env/开头,进入jndiCtx.lookup。最后如果meta和retObject还是未获取到,则调用jndi(jndiName)

大概率PortalSpecServiceImpl这个应该不是在ServiceCache里,不然就成功获取到对象然后反射调用方法了,或者可以通过某种方式先添加PortalSpecServiceImpl到ServiceCache,再获取。
重点看下第一种方式,获取Meta如下。

进行实例化

查看实例化过程,通过this.getImplementationClass()获取对象

PortalSpecServiceImpl是实现的这个接口nc.uap.portal.service.itf.IPortalSpecService。
那类就应该为IPortalSpecService,重新构造发包
服务器返回200,exp没问题了,但是发现文件上传到目录不对,应该是filePath拼接的目录有问题。

0x04

回到上面的在call()中的处理参数字符串那段
会用fromJsObject进行处理

最后到JSONTokener的nextValue函数,会把传进去的字符串进行一个字符一个字符的判断。

如跳转目录的../../../被处理会变成了..

window环境下可以直接..\..\即可。为了通用的话还是需要处理一下
这里注意到在fromJsObject处理之后会调用如一次decode

这里传递两层url编码即可

当发送..%252f..%252f这个字符串后,服务器进行第一次解码,到fromJsObject处理时,此时的路径为..%2f..%2f,绕过/检测,接着经过JsURLDecoder.decode(),变成了../../,最后拼接到filePath。

到这里就可以web根目录上传文件了
最后,这里就是一个代码执行,也可以调用其他类方法,只是类有点限制,如读文件win.ini。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/572638.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

基于STM32的蓝牙小车(虚拟串口模拟)的Proteus仿真

文章目录 一、前言二、仿真图1.要求2.思路3.画图3.1 电源部分3.2 超声波测距部分3.3 电机驱动部分3.4 按键部分3.5 蓝牙部分3.6 显示屏部分3.7 整体 4.仿真5.软件 三、总结 一、前言 proteus本身并不支持蓝牙仿真,这里我采用虚拟串口的方式来模拟蓝牙控制。 这里给…

医院敏感文件交互 如何保障安全和效率?

医院会产生大量的敏感文件,这些敏感文件交互时,都需要使用特殊的手段,来保障数据的安全性。 医院的敏感数据主要包括以下几类: 1、患者基本信息:包括患者的姓名、身份证号码、户籍地或现住址、联系方式、文化程度、既…

jar包做成Windows Service 服务,不能访问网络映射磁盘

在Windows操作系统中,系统服务(Services)、计划任务(Scheduled Tasks)以及很多系统调用都是以SYSTEM系统账号进行操作的。用 net use 挂载,或者在文件管理器上直接挂载,挂载卷是以 Administrato…

504网关超时可能是哪些原因导致

当前随时互联网的发展普及,我们经常会使用到网站服务,许多网站为了提高打开速度,都会接入使用CDN。当我们在浏览网页或使用网络服务时,有时候可能有遇到网站打不开的情况,出现各式各样的错误代码,其中504网…

书生·浦语 大模型(学习笔记-5)XTuner 微调 LLM:1.8B、多模态、Agent

一:两种微调 增量与训练和指令微调的区别 二、数据的一生 原始数据转换为标准格式数据 添加对话模板,直接调用即可,会拼接 三、微调方案 三种加载对比 四、XTuner 五、8GB 显存玩转 LLM 五、InternLM2 1.8B模型(相关知识&#x…

【火柴题】509移动两根火柴变成最大的数字

题目 509移动两根火柴变成最大的数字 <font face"DS-Digital" size"6">5&thinsp;0&thinsp;9</font>答案 <font face"DS-Digital" size"6">9&thinsp;1&thinsp;1&thinsp;8&thinsp;</font…

【JavaScript】Mockjs

基础语法 <script src"https://cdn.bootcdn.net/ajax/libs/Mock.js/1.0.0/mock-min.js"></script> <script>let mockData Mock.mock({age|10-50: 1, // 此时生成对象的 age 属性会是 10-50 之间的数 1 此时只是用来确定类型arr|5-10: [{id|1: 1,…

物联网五层架构:每一层都扮演着不可或缺的角色——青创智通

物联网五层架构涵盖了感知层、网络层、数据层、应用层和业务层&#xff0c;每一层都扮演着不可或缺的角色&#xff0c;共同构成了物联网的完整生态系统。下面我们将详细探讨这五层架构的功能和特点。 首先&#xff0c;感知层是物联网的起点&#xff0c;负责获取和识别各种物理世…

3DTiles特性与内容解析

一篇19年整理的比较老的笔记了。更多精彩内容尽在数字孪生平台。 瓦片种类 3DTiles瓦片有多种类型&#xff1a; b3dm(Batched 3D Model&#xff0c;批量3D模型) b3dm瓦片存储了多个个体&#xff0c;b3dm中的glb代表的实际对象应该具有相同的种类但是可能数据内容不同。b3dm…

ROS摄像机标定

文章目录 一、环境准备二、摄像头标定2.1 为什么要标定2.2 标定前准备2.2.1 标定板2.2.2 摄像头调焦 2.3 开始标定2.4 测试标定结果 总结参考资料 一、环境准备 安装usb_cam相机驱动 sudo apt-get install ros-noetic-usb-cam 安装标定功能包 sudo apt-get install ros-noet…

力扣HOT100 - 108. 将有序数组转换为二叉搜索树

解题思路&#xff1a; 二叉搜索树一般使用中序遍历 class Solution {public TreeNode sortedArrayToBST(int[] nums) {return helper(nums,0,nums.length-1);}public TreeNode helper(int[] nums,int left,int right){if(left>right) return null;//确定根节点//总是选择中…

微软发布Phi-3,手机上就能跑,是时候聊聊小型语言模型了|TodayAI

微软公司最近宣布推出了其最新开发的最新AI语言模型&#xff0c;名为Phi-3。这款小型语言模型&#xff08;SLMs&#xff09;在市场上以其卓越的性能和成本效率获得关注&#xff0c;尤其在语言处理、推理、编程及数学基准测试方面表现出色&#xff0c;超越了同等规模甚至更大规模…

2024年教你学会如何把学浪视频下载到本地

今年是2024年&#xff0c;依然有很多小伙伴想下载学浪却不知道怎么下载&#xff0c;本文就教大家如何使用小浪助手工具下载学浪视频 小浪助手工具我已经打包好了&#xff0c;有需要的自己取一下 学浪下载工具链接&#xff1a;https://pan.baidu.com/s/1-axc7xDtwU_KtupCe52sV…

华为 2024 届实习校园招聘-硬件通⽤/单板开发——第九套

华为 2024 届实习校园招聘-硬件通⽤/单板开发——第九套 部分题目分享&#xff0c;完整版带答案(有答案和解析&#xff0c;答案非官方&#xff0c;未仔细校正&#xff0c;仅供参考&#xff09;&#xff08;共十套&#xff09;获取&#xff08;WX:didadidadidida313&#xff0c…

你如何看待AIGC技术?

你如何看待AIGC技术&#xff1f; AIGC技术&#xff08;Artificial Intelligence Generated Content&#xff09;是指由人工智能生成的内容。它在许多领域都有应用&#xff0c;包括自然语言处理、图像生成、音频合成等。虽然这些技术可以提高效率和创造力&#xff0c;但也需要注…

IP6505T最大输出24W,集成11种快充输出协议的SOC IC 为车载充电器、快充适配器、智能排插提供完整的解决方案

IP6505T产品概述&#xff1a; IP6505T是一款集成同步开关的降压转换器、 支持 11 种输出快充协议&#xff0c;为车载充电器、快充适配 器、智能排插提供完整的解决方案。内置功率 MOS&#xff0c;输入电压范围是 4.5V 到 32V&#xff0c;输出电压范围是 3V 到 12V&#xff0c;…

C语言编程题_3D接雨水

接雨水的题目描述如下。 (1) 2D接雨水&#xff1a; 字节员工是不是个个都会接雨水 &#xff1b; (2) 3D接雨水&#xff1a; 407. 接雨水 II &#xff1b; (3) 3D接雨水&#xff1a; 字节人都会的 3D接雨水 。 问题描述 难度&#xff1a;困难 给你一个 m x n 的矩阵&#xff…

企业有哪些常见网络需求场景?

企业的网络场景需求多种多样&#xff0c;主要取决于其业务规模、运营模式、技术应用等因素。 常见的企业网络场景需求 办公网络需求&#xff1a; 高速稳定的内部网络连接&#xff0c;以支持员工日常办公、数据传输和资源共享。 无线办公网络覆盖&#xff0c;以便员工在会议室…

OpenCV从入门到精通实战(七)——探索图像处理:自定义滤波与OpenCV卷积核

本文主要介绍如何使用Python和OpenCV库通过卷积操作来应用不同的图像滤波效果。主要分为几个步骤&#xff1a;图像的读取与处理、自定义卷积函数的实现、不同卷积核的应用&#xff0c;以及结果的展示。 卷积 在图像处理中&#xff0c;卷积是一种重要的操作&#xff0c;它通过…

C++|运算符重载(3)|日期类的计算

前面介绍了运算符重载相关规则和方法&#xff0c;今天用运算重载函数实现对日期类的操作。 目录 前面准备 实现功能&#xff1a; -运算符 Date类和int 相减 Date类和Date类相减 运算符 &#xff0c;-运算符 ,!运算符 >,>运算符 <,<运算符 &#xff0c;-…