问答
发起
提问
文章
攻防
活动
Toggle navigation
首页
(current)
问答
商城
实战攻防技术
漏洞分析与复现
NEW
活动
摸鱼办
搜索
登录
注册
Java代码审计初试
本文为Java代码审计入门的一篇文章,学习SSM框架的开源代码审计
审计环境 ---- ```js jdk 7u80 Tomcat 7 Maven 3.6.3 ``` 下载源码后,导入数据库,IDEA导入项目,并修改数据库配置信息 data:image/s3,"s3://crabby-images/b6918/b691818cb542e9c132381576b01c392350bbf118" alt="1.png" 配置Tomcat运行,即可访问系统 data:image/s3,"s3://crabby-images/77267/77267c9b959a611778497d0dd9c0e855ffb8bfbe" alt="2.png" 结构分析 ---- 开始审计前,先看看网站文件和结构 - src/main/java:存放java代码的目录 - src/main/resources:存放资源的目录,包括properties、spring、springmvc、mybatis等配置文件 - src/main/webapp:存放网站的JSP、html、xml等web应用源代码 可以看出是一个SSM架构(即Spring+Spring MVC+MyBatis) data:image/s3,"s3://crabby-images/9d57d/9d57d921cc4cf628b9214307c8f3413b5b220cd3" alt="3.png" 然后看一下几个文件: - pom.xml:Maven的主要配置文件。在这个文件中,可以看到当前项目用了哪些组件以及组件的版本,如果使用了存在漏洞的组件版本,可以快速发现。 - web.xml:Tomcat启动时会自动加载web.xml中的配置,文件中配置了Filter、Listener、Servlet。主要关注Filter过滤器,查看网站的过滤措施。 - applicationContext.xml:Spring的全局配置文件。其中也会包含对其他的配置文件的引用。 - spring-mvc.xml:其中会有静态资源映射、拦截器配置、文件上传限制等配置 ### pom.xml data:image/s3,"s3://crabby-images/bb02a/bb02af7589d0f1a02091db45b3a3d26147f9d0cc" alt="4.png" 搜索发现该版本log4j存在CVE-2019-17571反序列化漏洞,寻找漏洞处触发点,搜索SocketNode类,发现项目中没有调用。 所以即使项目使用了存在漏洞版本的组件,也不代表就一定存在相应漏洞 ### web.xml 只配置了两个filter过滤器,一个是配置了对字符进行编码,另一个是使页面具有统一布局,没有看到对XSS和sql注入的过滤器。 data:image/s3,"s3://crabby-images/dae80/dae8030a77deb8185ed780adda6fd5d745a8d1f5" alt="5.png" ### applicationContext.xml data:image/s3,"s3://crabby-images/77704/77704b5de4dc6fb7d704bc9475e82871b0b3f4f7" alt="6.png" ### spring-mvc.xml 配置了拦截的路径、上传文件的大小 data:image/s3,"s3://crabby-images/d4eec/d4eec65cb2e69726b8fad3e0d26d19ba9dbc5b48" alt="7.png" 源码审计 ---- ### SQL注入审计 已经知道项目使用的是Mybatis,所以SQL语句会有两种定义方式,一个是使用注解的方式,一个是在Mapper.xm文件中编写。 参数拼接也有两种常用的方式,即${}和#{},#{}是采用预编译的方式,${}是采用简单的拼接。 然后Mybatis框架下易产生SQL注入漏洞的情况主要分为三种,like、 in和 order by 语句。 所以根据以上信息,在xml文件中搜索${(当然也可以去搜索这些语句来寻找审计参数是否可控) data:image/s3,"s3://crabby-images/38aff/38aff8ac247bbb643acbd767d217133f7434e6fa" alt="8.png" ### 后台SQL注入 在ArticleMapper.xml中,发现存在用 in 语句并使用${}方式传参 data:image/s3,"s3://crabby-images/1da3f/1da3f4167ebc68cb8b1045b6aba9beee7f6199bd" alt="9.png" 然后找到该mapper对应的实现类 data:image/s3,"s3://crabby-images/a8766/a8766a87db25255710890e2c5a3c2e7f329267b0" alt="10.png" 然后找到类调用的地方,确定请求路径和传参方式,请求路径为/admin/article/delete,参数是通过articelId传入 data:image/s3,"s3://crabby-images/58806/588067715dd8058877d272a9d0764699cbb248d0" alt="11.png" data:image/s3,"s3://crabby-images/1c515/1c515c52a415a3544b4b960868ef508994973a45" alt="12.png" #### 漏洞验证 `/admin/article/delete?articelId=1` sqlmap跑一下 data:image/s3,"s3://crabby-images/882cc/882cc7061cb5ba417aebc16a929fa8b38bd2ba23" alt="13.png" ### 前台SQL注入 同样在CourseFavoritesMapper.xml中找到${}传参语句 data:image/s3,"s3://crabby-images/2d6f2/2d6f2c37e868d3b51f7bd93154376826a466863a" alt="14.png" 然后找到调用该mapper的地方 data:image/s3,"s3://crabby-images/c9da8/c9da884c92b00df13a3699fb98c0f9195a5b1d4b" alt="15.png" 路径为/uc/deleteFaveorite/{ids},{ids}直接输入参数即可,格式如图 data:image/s3,"s3://crabby-images/397d7/397d7efe7ca7f62f9930de4cc6438df654571e18" alt="16.png" #### 漏洞验证: 前台登录后抓包,放到sqlmap跑一下 data:image/s3,"s3://crabby-images/5c16b/5c16b07e7cc9e1c5eae5d415d0d38e7999815553" alt="17.png" 其他还有几处也存在sql注入,漏洞成因都差不多,这里就不多写了。 ### XSS审计 审计XSS要点是定位用户的输入输出,梳理数据交互以及前端展示的过程。找到一个对应的输入输出的地方后,根据现有的安全措施(编码、过滤器)判断是否存在绕过的可能。 在结构分析时,已经知道web.xml中并没有发现对xss的过滤,接下来就需要分析在代码中是否存在过滤。 首先看看插入过程中是否存在过滤 data:image/s3,"s3://crabby-images/aa0cc/aa0cc518fecd771b664ca385d37322ee8828080a" alt="18.png" 抓包查看路由请求 data:image/s3,"s3://crabby-images/cc187/cc187a53aa00f0521fd8451c7d37cd2e66279ed7" alt="19.png" 全局搜索路由关键字,定位到控制器QuestionsController.java addQuestions()方法,接收的传参的为Questions类,然后判断用户是否登录,然后调用了sevice层中的addQuestions()方法 data:image/s3,"s3://crabby-images/7bd58/7bd58ce23b6b04e1ae270990807a3070b44bea3a" alt="20.png" 查看Questions类的属性中有哪些是String类型的,可以在这些属性中插入XSS语句 data:image/s3,"s3://crabby-images/4bd8c/4bd8c32ee3d9646181101473bb229cbeec67c327" alt="21.png" 查看它的实现类,调用questionsDao的addQuestions()方法 data:image/s3,"s3://crabby-images/388ad/388adb73b570a2874df13028b9a79cd3ce2d8b44" alt="22.png" 跟进addQuestions()方法,是一个Service data:image/s3,"s3://crabby-images/27c91/27c9152b1070e490f84539e0db6a908725075d97" alt="23.png" 继续跟进,调用insert插入数据库中 data:image/s3,"s3://crabby-images/6955f/6955f3855033f7921a668023547c38df9c9b186c" alt="24.png" 根据insert中的信息找到对应的Mapper查看,将数据插入到edu\_question表中 data:image/s3,"s3://crabby-images/668fc/668fcdfd67698b9b6643b16329733de67aaaa1ea" alt="25.png" 在整个插入数据的过程中,都没有对数据进行过滤 接着看输出部分,访问问答页面时触发XSS data:image/s3,"s3://crabby-images/34877/34877b583fe7ff4dd34ff656a5a9b1b5f1a98ea5" alt="26.png" 根据路由questions/list定位到jsp文件 data:image/s3,"s3://crabby-images/9fcba/9fcba64f2f9b111602843581729d8d5ab6049af2" alt="27.png" 搜索.title、.content data:image/s3,"s3://crabby-images/f06c3/f06c3ab083193c9854fff0624ea928fbf701cb5c" alt="28.png" 发现标题处直接拼接数据库中的值输出,而内容处使用了<c:out>标签包裹,<c:out>标签是直接对代码进行输出而不当成js代码执行。所以标题处存在XSS,内容处不存在。 ### 文件上传 全局搜索upload、uploadfile等寻找上传功能点 data:image/s3,"s3://crabby-images/89e81/89e81e4b2aa958024f9a513bcce7c1ad579594c9" alt="29.png" fileType从逗号处分割,存入type中,后续与上传文件后缀对比。 如果fileType中包含了ext则返回true,然后用取反,所以fileType中必须要包含ext,否则直接返回错误。随后获取文件路径,进行文件上传。 这里注意fileType是从请求中传入参数获取的,所以在上传时,只要在fileType传入jsp、jspx,就可以成功上传 data:image/s3,"s3://crabby-images/dea50/dea5038683fc5f546fce8972a668f9ee53b6167c" alt="30.png" #### 漏洞验证: 构造上传数据包,成功上传 data:image/s3,"s3://crabby-images/2e109/2e1099e59e4580d295f592570a9b4924b708f3bd" alt="31.png" 连接webshell data:image/s3,"s3://crabby-images/fbdad/fbdad70e4adb30f3614cd30e08f3ef58542e5eab" alt="32.png" ### 越权漏洞 注册账号进入用户中心,点击更改个人信息抓包发现userid,可能存在越权漏洞 data:image/s3,"s3://crabby-images/f5246/f52466fcd3a3f4094b5346b5ea772766eafe257d" alt="33.png" 在项目中全局搜索/updateUser,找到UserController data:image/s3,"s3://crabby-images/702b5/702b5d90c6762524e5d565f1115e109b96e994ff" alt="34.png" 直接调用了userService的updateUser接口 data:image/s3,"s3://crabby-images/2b3bf/2b3bf0d5b4a6f275216399ee411bbf7f2de8be7c" alt="35.png" 进入接口实现类 data:image/s3,"s3://crabby-images/0fe10/0fe1081e02758f9ed41452c5ddebd0d949a511a3" alt="36.png" 继续跟进,最终跟到UserDaoImpl的updateUser方法 data:image/s3,"s3://crabby-images/9b02e/9b02e7347cb59e5585462037a029bc82d42d3b07" alt="37.png" 直接引用UserMapper的updateUser进行更新 data:image/s3,"s3://crabby-images/ae657/ae65736590244e6a90f78757426f474d4f37c9f0" alt="38.png" 整个流程没有任何的权限校验,没有判断 userId 与当前用户的关系,所以只要修改为其他用户id,就可以修改其他的用户信息 #### 漏洞验证 注册两个账号 第一个账号test1 data:image/s3,"s3://crabby-images/b7349/b734967e93c2982b3b4a73b4a6186ee04a83b28e" alt="39.png" 用户id为70 data:image/s3,"s3://crabby-images/ec741/ec74111bb43cde76c75cae2105df4d7584464661" alt="40.png" 第二个账号test2 data:image/s3,"s3://crabby-images/8cd3b/8cd3b8514c8bbeb055c5e2a87f6f732832fcd743" alt="41.png" 用户id为71 data:image/s3,"s3://crabby-images/45cf8/45cf85ca00c5afb13262fcae48c1fb096ecc4672" alt="42.png" 在登录test2的情况下,抓包修改userId为70,并修改userName data:image/s3,"s3://crabby-images/ac98f/ac98f06369f41b11ba56cc3b9c6b7326d9052856" alt="43.png" 然后登录test1账号,发现个人信息被修改 data:image/s3,"s3://crabby-images/fdaca/fdaca913002bc2c7c3972ec21f3acd2f3264ad38" alt="44.png" 总结 -- 本文涉及漏洞有限,审计漏洞也不够全面,主要是学习SSM框架的代码审计过程记录,在审计中意识到某些漏洞单纯通过白盒的方式难以发现,所以想要让审计更加全面,还需黑白结合的方式。
发表于 2024-01-16 09:00:02
阅读 ( 5523 )
分类:
代码审计
5 推荐
收藏
0 条评论
请先
登录
后评论
Cl0wnkey
6 篇文章
×
发送私信
请先
登录
后发送私信
×
举报此文章
垃圾广告信息:
广告、推广、测试等内容
违规内容:
色情、暴力、血腥、敏感信息等内容
不友善内容:
人身攻击、挑衅辱骂、恶意行为
其他原因:
请补充说明
举报原因:
×
如果觉得我的文章对您有用,请随意打赏。你的支持将鼓励我继续创作!