oasys系统_JAVA代码审计

一、前言

oasys是一个OA办公自动化系统,使用Maven进行项目管理,基于springboot框架开发的项目。可以看到该项目的资源文件中是mappers且pom.xml里有Mybatis的相关依赖,所以数据库持久化框架是Mybatis。

全局搜索 “${” ,可看到疑似有漏洞的地方如下图所示:

二、单点漏洞

1. 通讯录处SQL注入漏洞

1.1 上图先随意选中一个进入,可以看到多个地方存在字符拼接操作,如下图所示:

1.2 点击左侧小绿键,跟踪到对应的Mapper文件里,如下图所示:

1.3 除了allDirector这个函数,没有发现其他什么信息,跟进去这个函数,如下图所示:

1.4 跟到了控制层,发现了接口,及前面用来拼接的参数,且没有对它们进行过滤处理,所以该处存在SQL注入漏洞。

1.5 找到后台对应功能处,如下图所示:

1.6 点击搜索时,同时抓包,如下图所示:

1.7 把抓到的包放到oasys.txt文件中,然后用sqlmap 跑这个命令python sqlmap.py -r “oasys.txt” -v 3 -level=5 ,如下图所示:

1.8 跑出“basekey”和“outtype”基于布尔的盲注。

2 通知列表处SQL注入漏洞

2.1 之前全局搜索“${”,还发现另外一个地方疑似有漏洞,该位置也是存在字符串拼接,如下图所示:

2.2 点击左侧小绿键,进入相应的Mapper文件中,如下图所示:

2.3 发现是关于“sortMyNotice”的函数方法,跟进去看看,如下图所示:

2.4 来到了控制层,可以看到对应的接口,以及“sortMyNotice”的函数方法需要的参数,没有对这些参数做过滤处理,所以该位置存在SQL注入漏洞。在后台找到对应功能处,如下图所示:

2.5 点击“搜索”图标的同时,开启抓包。如下图所示:

2.6 把包放到oasys1.txt文件中,然后用sqlmap 跑这个命令python sqlmap.py -r “oasys1.txt” -v 3 -level=5 ,如下图所示:

2.7 跑出“basekey”参数基于布尔的盲注和基于时间的盲注。

3 流程管理 -> 我的申请处,查看越权漏洞

3.1 登录普通用户“Bill”,流程管理 -> 我的申请,选择查看,如下图所示:

3.2 选择查看的同时开启抓包,发送,可看看“Bill”用户的申请,如下图所示:

3.3 把id号改为1,发送数据包,提单人员是“admin”的,如下图所示:

3.4 所以该点存在查看越权漏洞,找到该功能点对应的接口“/particular”,如下图所示:

3.5 获取“id”后,转换为有符号十进制long型,然后就直接用去查看申请了,没有进行用户身份验证。

4 日程管理处越权漏洞

4.1 登录管理员“admin”账号,日程管理 -> 删除,如下图所示:

4.2 删除标题为“放假通知”的日程,同时开启抓包,如下图所示:

4.3 数据包的“rcid”值为15,发送到“Repeater”模块,扔包,再查看该日程还没被删除,如下图所示:

4.4 登录普通用户“soli”,删除一天日程,如下图所示:

4.5 删除同时开启抓包,发送到“Repeater”模块,扔包,如下图所示:

4.6 把普通用户的“rcid”值改为15,发送,如下图所示:

4.7 登录管理员“admin”账号,发现标题为“放假通知”的日程已经被普通用户“soli”删除。

4.8 所以该点存在刪除越权漏洞,找到该功能点对应的接口“/dayremove”,如下图所示:

4.9 从请求包里传参“rcid”后,直接就拿去动态查找、删除,没有对用户身份进行验证。

5 任意文件读取

5.1 在src/main/java/cn/gson/oasys/controller/user/UserpanelController.java位置处,代码中首先通过getRequestURI方法当前访问的相对路径,然后将该路径中的iamge替换为空。接下来与rootpath拼接然后通过File打开文件后返回前端。

5.2 rootpath前面只是进行了简单的替换,后面就输出了。

oasys系统_JAVA代码审计的更多相关文章

  1. [代码审计]某租车系统JAVA代码审计[前台sql注入]

    0x00 前言 艰难徘徊这么久,终于迈出第一步,畏畏缩缩是阻碍大多数人前进的绊脚石,共勉. 系统是租车系统,这个系统是Adog师傅之前发在freebuf(http://www.freebuf.com/ ...

  2. 9.10 Binder系统_Java实现_hello服务

    怎么做?2.1 定义接口: 写IHelloService.aidl文件, 上传, 编译, 得到IHelloService.java 里面有Stub : onTransact, 它会分辨收到数据然后调用 ...

  3. 9.13 Binder系统_Java实现_内部机制_Server端

    logcat TestServer:* TestClient:* HelloService:* *:S &CLASSPATH=/mnt/android_fs/TestServer.jar ap ...

  4. 9.12 Binder系统_Java实现_内部机制_Client端

    Java实现中client端的RPC层(java实现)如何通过JNI来调用IPC层(C++实现)发送数据 TestServer通过addService向Service_manager注册的时候Test ...

  5. 9.9 Binder系统_Java实现_Android里java程序的编译启动

    如果知道了进程号:通过ls /proc/进程号/task 可以看到所有线程    cat /proc/进程号/task/线程号/comm  可以达到线程名字(主线程是main,主线程号就是进程号) d ...

  6. php代码审计基础笔记

    出处: 九零SEC连接:http://forum.90sec.org/forum.php?mod=viewthread&tid=8059 --------------------------- ...

  7. aspx代码审计-1

    今天和大家分享一下aspx网站的代码审计,漏洞类型就是SQL注入和cookie欺骗. 本文作者:i春秋签约作家——非主流 今天看的cms名字叫做:XX星员工请假系统 我们首先看一下网站的目录结构: 其 ...

  8. WebShell代码分析溯源(七)

    WebShell代码分析溯源(七) 一.一句话变形马样本 <?php $e = $_REQUEST['e'];$arr = array($_POST['POST'],);array_map(ba ...

  9. 2012高校GIS论坛

    江苏省会议中心 南京·钟山宾馆(2012年4月21-22日) 以"突破与提升"为主题的"2012高校GIS论坛"将于4月在南京举行,由南京大学和工程中心共同承办 ...

  10. [代码审计]云ec电商系统代码审计

    0x00 前言 看了一下博客内最新的文章,竟然是3月28号的,一个多月没写文章了,博客都长草了. 主要是临近毕业,事情繁多,也没有啥时间和心情静下来写.. 不过现在的话,毕业的东西告一段落了,几乎没啥 ...

随机推荐

  1. Oracle数据泵导入dmp文件,报ORA-39083、ORA-01917错误解决办法

    将10.16.23.111数据库服务器中的数据库名称为cwy_init1的数据导出,随后在10.16.23.112数据库服务器创建空库cwy_init2,将导出的cwy_init1数据文件(cwy_i ...

  2. 匿名方法、Lambda表达和自定义泛型委托以及Func、Action系统泛型委托

    1.匿名方法的概念:一个方法没有具体的名称,而只有关键字delegate.方法参数.方法体.这种方法是匿名方法. 匿名方法的好处:将具体方法和委托直接关联在一起,如果我们基于委托只需要一个方法的时候, ...

  3. 从 WinDbg 角度理解 .NET7 的AOT玩法

    一:背景 1.讲故事 前几天 B 站上有位朋友让我从高级调试的角度来解读下 .NET7 新出来的 AOT,毕竟这东西是新的,所以这一篇我就简单摸索一下. 二:AOT 的几个问题 1. 如何在 .NET ...

  4. java8 (jdk 1.8) 新特性——Lambda

    java8 (jdk 1.8) 新特性 --初步认识 1. 什么是lambda? 目前已知的是,有个箭头  -> 说一大段官方话,也没有任何意义 我们直接看代码: 之前我们创建线程是这样的 Ru ...

  5. i春秋Fuzz

    点开只有三个单词plz fuzz parameter 大概意思就是让我们疯狂尝试参数... 我们通过url尝试传入参数 ?user=123 ?name=123 ?username=123 ?id=12 ...

  6. qtcreator配置cmake+mingw开发环境

    环境准备 cmake 添加到PATH环境变量. mingw: 这里我用的mingw是Qt自带的,我将其添加到PATH环境变量中. 在cmd中执行 mingw32-make.exe 和 cmake查看命 ...

  7. 关于mysql数据库user表没有password字段

    解决 这个是因为mysql的版本问题,是mysql 5.7版本出现的,具体是mysql 5.7.x 开始变化的我不知道 新的字段变更为authentication_string 修改密码的方式还是和原 ...

  8. 30位以内随机产生时间戳加随机数id

    package com.zx.ps.web.gzdb; import java.text.SimpleDateFormat; import java.util.Date; public class c ...

  9. SpringMVC03:SSM整合

    一.搭建整合环境 1.ssm整合说明 2.搭建环境 二.Spring框架代码的编写 1.编写Spring框架(处理业务层) applicationContext.xml <?xml versio ...

  10. 2A锂电池充电管理IC,具有恒压/恒流充电模式

    PW4052 是一颗适用于单节锂电池的.具有恒压/恒流充电模式的充电管理 IC.该芯片采用开关型的工作模 式, 能够为单节锂电池提供快速. 高效且简单的充电管理解决方案. PW4052 采用三段式充电 ...