问答
发起
提问
文章
攻防
活动
Toggle navigation
首页
(current)
问答
商城
实战攻防技术
漏洞分析与复现
NEW
活动
摸鱼办
搜索
登录
注册
第一次java代码审计供新手学习
学习java审计的尝试
前言 -- 因为也是第一次审计java的cms 可能也有很多解释的不对的地方望师傅们指出 ### 环境搭建 源码:<https://www.ujcms.com/uploads/jspxcms-9.0.0-release-src.zip> 下载之后解压 data:image/s3,"s3://crabby-images/a398d/a398da8c68e859c0f7c7be598a5fe541d0bebaf9" alt="image.png" 然后用idea导入 先创建数据库导入数据库文件 data:image/s3,"s3://crabby-images/0a2f5/0a2f54fce662a1671a8435130728e899876dc702" alt="image.png" 然后导入源码 data:image/s3,"s3://crabby-images/f8aeb/f8aeb187fff9e135192f743f02c70c0956c36c7c" alt="image.png" data:image/s3,"s3://crabby-images/b574d/b574d515b765d6dc2e97f5a62f1ae386d31a5cf1" alt="image.png" 然后配置好数据库连接 data:image/s3,"s3://crabby-images/a0aac/a0aac17624f4df3b11d54bbd50c9eb23222f2c7c" alt="image.png" 加载maven依赖 根据本地数据库版本情况 记得调整数据库依赖版本 data:image/s3,"s3://crabby-images/b9494/b9494f25adc2f8cff7b4cfae4e6403875e9647f6" alt="image.png" 然后启动 因为是springboot 直接启动就行 data:image/s3,"s3://crabby-images/efd22/efd2200574e3c9daa4d7ddede09a23a910a85c50" alt="image.png" 后台地址:<http://127.0.0.1:8080/cmscp/index.do> 因为刚开始代码也那么多就没有直接看代码 先熟悉熟悉有什么功能点 #### XSS 随便进入了一篇文章 然后评论 data:image/s3,"s3://crabby-images/d57ee/d57eecd7e8a91584b672286ab248368aedad813a" alt="image.png" 这里发现是没有xss的 但是后面来到“我的空间” data:image/s3,"s3://crabby-images/9f2e5/9f2e59363b280459ecbc59263168546ac61c84cf" alt="image.png" 点击评论的时候 data:image/s3,"s3://crabby-images/2e044/2e04406ebdcd05ce94137e826b7ea09d272eb606" alt="image.png" data:image/s3,"s3://crabby-images/567a6/567a6a27c2c4567af2d170f158f1cbc0331f8ddf" alt="image.png" 这里触发了xss 这里相当于是黑盒摸到的 单既然是审计 就要从代码来看 重新回到评论的地方 评论进行抓包 看看请求的路径是什么 先找到入口 data:image/s3,"s3://crabby-images/e19aa/e19aa74b9c6528d6b80bc7edfed8bb414eefa995" alt="image.png" 然后回到idea搜索comment\_submit data:image/s3,"s3://crabby-images/4d6c6/4d6c615c9b0a74d7ef0d91f4d1b0d601eec7a33d" alt="image.png" 然后在这里打上断点 data:image/s3,"s3://crabby-images/483b6/483b6e3b79e4cdb4cd240fbab78e7ef1fa47f613" alt="image.png" data:image/s3,"s3://crabby-images/33bd9/33bd9d545ae702534ffb6ba538b9c8510c25e541" alt="image.png" 然后一步一步放 跟进submit data:image/s3,"s3://crabby-images/e7d12/e7d127becd0fc49ec91ea3fc81ff394f1ac2e447" alt="image.png" 主要是看传进来的text的走向 到这里text的值都没有变化 data:image/s3,"s3://crabby-images/7e0a1/7e0a1dc78d4182a20d85753a50a459be3ea3fd07" alt="image.png" 然后来到最下面这里是save操作 data:image/s3,"s3://crabby-images/4f7af/4f7afae5499b4ee00654d06b2d9b8a1353e5661e" alt="image.png" data:image/s3,"s3://crabby-images/8e303/8e303540e11b2223c0e2a049c7ffbae398e09568" alt="image.png" 这里也是直接进行存储 说明存入的时候是没有进行过滤的 那最开始没弹 肯定就是输入的问题了 因为摸到弹的情况 直接根据弹的情况来分析为什么回弹 先找到弹的页面的代码 因为路径有一个space 所以搜索space data:image/s3,"s3://crabby-images/dd63f/dd63fa0c7bd00189bdc49bbba77eb9dd6d89cddb" alt="image.png" 打上断点 进行调试 data:image/s3,"s3://crabby-images/e086b/e086b531502606bea85e35822a2f11ed688b9d09" alt="image.png" data:image/s3,"s3://crabby-images/84ea6/84ea6c20f6aae063c598154a70daa925ed9c2ac7" alt="image.png" data:image/s3,"s3://crabby-images/e6b28/e6b28144d01f4064ffcf98d3ba54e9f30f07a295" alt="image.png" data:image/s3,"s3://crabby-images/6ddb0/6ddb018abc48517c9cffbcf54ba9b39f9b1f7990" alt="image.png" 这里最后返回了一个模板 发现这个是一个html 搜索这个html data:image/s3,"s3://crabby-images/ac3db/ac3db698362fedc99014974917e112e9c1cd8e58" alt="image.png" 通过pom.xml data:image/s3,"s3://crabby-images/00650/00650f715ecc87a4e5aaced9a3b29d84b74f3e0d" alt="image.png" 是freemarker模板 先搜搜这玩意是咋转义的 data:image/s3,"s3://crabby-images/01838/01838f28ecd40b6e9f325bce858f38240bc07c39" alt="image.png" 看到一个熟悉的 data:image/s3,"s3://crabby-images/059b0/059b0c1cfaab24b56c09bb527dd5e579526a7e1f" alt="image.png" 这个页面这里有填写这个 但是最终还是弹了 说明有漏网之鱼的页面 通过查找 发现一个没有写这个的页面 data:image/s3,"s3://crabby-images/f177e/f177e8a40374531a3eb3db6ed75449f287b7525e" alt="image.png" data:image/s3,"s3://crabby-images/1ea53/1ea531919314266ae20b193d397108b22aa86031" alt="image.png" 搜索 看看哪里用到了这俩 data:image/s3,"s3://crabby-images/662d3/662d35563c4c472df13f866a90325c302278d7e6" alt="image.png" 刚还这里的type=comment对应上之前访问时候的type data:image/s3,"s3://crabby-images/a87ea/a87eac027095f9250167145d9010d2c10dbb3e88" alt="image.png" 所以访问这个页面的时候能触发xss payload没有进行任何过滤 这个页面也没有进行转义 #### SSRF 在审计ssrf的时候 一般都是搜索关键函数 ```php URL.openConnection() URL.openStream() HttpClient.execute() HttpClient.executeMethod() HttpURLConnection.connect() HttpURLConnection.getInputStream() HttpServletRequest() BasicHttpEntityEnclosingRequest() DefaultBHttpClientConnection() BasicHttpRequest() ``` ##### 第一处 直接在idea里面搜索 data:image/s3,"s3://crabby-images/eda3a/eda3a64a55bfd00b69db689465abeb4ca2ef6186" alt="image.png" 然后一个一个点进去分析 找到这里 data:image/s3,"s3://crabby-images/09f88/09f887d6262ab902583f9231f57fc37891c2086b" alt="image.png" 会进行连接 然后我们往上分析这个src的来源 data:image/s3,"s3://crabby-images/0ce10/0ce101a2df358d05ab38e584518fa24c4dd54bc0" alt="image.png" 发现这里是从请求中获取source\[\]参数来的 说明这个是我们所能控制的 data:image/s3,"s3://crabby-images/df827/df82741fc49d78202e373e69f8213c1d35849f19" alt="image.png" 在往上看 根据函数名能够大概猜出是编辑器图片相关的函数 看看哪里调用了这个函数 data:image/s3,"s3://crabby-images/32302/32302277ef672704d69603c762ec7ccb8a312117" alt="image.png" data:image/s3,"s3://crabby-images/05865/058653bf9e10e2de2420dca88e994bc4d0aac512" alt="image.png" 在uploadcontroller下 继续跟进ueditorCatchImage函数 看看那里调用 data:image/s3,"s3://crabby-images/9456a/9456a8c61c965561b04296dd216d9a86a467a968" alt="image.png" 发现在同一页的66行找到 也找到这个路由是在ueditor.do下 data:image/s3,"s3://crabby-images/83e1b/83e1b06619d4f8ee447ba24f2066be157d624503" alt="image.png" 最上面controller 是core 所以路径是/core/ueditor.do?action=catchimage 进行测试 data:image/s3,"s3://crabby-images/60864/6086417698aa80684a4a7f296ccc54502a85e091" alt="image.png" data:image/s3,"s3://crabby-images/b88c4/b88c4a1ebdcb32278ca7ff65f6a86a4bc2f24a08" alt="image.png" data:image/s3,"s3://crabby-images/f460d/f460d62bb26e422ec91ece3296cddcb1475582bd" alt="image.png" 但因为是在back下 所以是一个后台的洞 通过后面的代码可以看到 似乎是对一个图片的操作 直接就进行断点看看这里是到底执行了什么 data:image/s3,"s3://crabby-images/6e242/6e242c9213504b8e94fd16417b54e3163e201e5f" alt="image.png" **测试**: data:image/s3,"s3://crabby-images/8706a/8706a291df974e621537941bf6950cb98f9ddc64" alt="image.png" 传入了一个jpg地址 但这个地址是不存在的 来到断点的地方 data:image/s3,"s3://crabby-images/8dc48/8dc4844672437743f535a1937a8197a60580a5a5" alt="image.png" 这里获取到source的值存入数组 data:image/s3,"s3://crabby-images/725a7/725a7b1054d349fd5e10544be598465a2e3f478f" alt="image.png" 这里获得后缀 data:image/s3,"s3://crabby-images/651b9/651b9d172d1734c05555ed39009a8b494bd80308" alt="image.png" 这里判断请求的是不是图片 因为我们传入的是不存在也就不是 到这里也就直接结束了 在此输入一个存在的链接 data:image/s3,"s3://crabby-images/54a5c/54a5c19fc7da2a5706124f407c82994c5800865c" alt="image.png" data:image/s3,"s3://crabby-images/3429f/3429fcd4235dbc313a8e6c5c4c3389ad23e97e9b" alt="image.png" 跟到这里是重新设置文件名 data:image/s3,"s3://crabby-images/799f1/799f19589f646d05eedece779b6a2b76d2b418ab" alt="image.png" 然后读取输入流 data:image/s3,"s3://crabby-images/38a61/38a616807dda243f2959aea24cf8cec5fdf13edc" alt="image.png" 然后跟进这里创建文件对象 data:image/s3,"s3://crabby-images/26dc3/26dc30210c9ec24435c1c317801185aab07bf128" alt="image.png" 然后这里直接保存文件 中间也没有任何过滤操作 就判断了是不是图片 然后就保存了文件 data:image/s3,"s3://crabby-images/6e435/6e4350e785c2a57c048e6fa52b4f96be90358165" alt="image.png" 相当于这里就是一个进行 图片请求然后保存到本地的操作 data:image/s3,"s3://crabby-images/1cd13/1cd134213c72a59dc5896237c4ad9a612bebfeed" alt="image.png" 那么这里是不是可以进行svg的xss呢 尝试一些 **测试**: 先创建一个svg xss data:image/s3,"s3://crabby-images/7a749/7a749d6ab21a916ea5a71384b54981111c41bb27" alt="image.png" data:image/s3,"s3://crabby-images/cff20/cff200e215ec5f26b89a2ff29716f7eefdd1f494" alt="image.png" data:image/s3,"s3://crabby-images/4f95c/4f95ca5f2e1ae520df1dc1af240ef2bc12ed4289" alt="image.png" ##### 第二处 继续搜索ssrf的关键函数HttpClient.execute() data:image/s3,"s3://crabby-images/e8abc/e8abcd04863d88f81af4be8936f22211a8510942" alt="image.png" 然后查看哪里调用了这个函数 data:image/s3,"s3://crabby-images/c06de/c06de48e97d7dc29f9a5036d9147fb4815809486" alt="image.png" 继续跟进 data:image/s3,"s3://crabby-images/c042b/c042bb83ce3734bc3c9c2133393ab19f99047ce6" alt="image.png" 发现在这里进行的调用以及url的传入 而且这个url是 可控的 往上找到控制层 data:image/s3,"s3://crabby-images/6817e/6817e1ba558a7373774fa170f7bbc535ae634136" alt="image.png" 最后拼接 进行测试 > [http://192.168.1.2:8080/cmscp/ext/collect/fetch\_url.do?url=http://127.0.0.1:8080](http://192.168.1.2:8080/cmscp/ext/collect/fetch_url.do?url=http://127.0.0.1:8080) data:image/s3,"s3://crabby-images/c8378/c83782329b5c2e5d079eb6c9c72ab3831e76c36c" alt="image.png" 直接能访问到服务 最后在页面找到位置 data:image/s3,"s3://crabby-images/a7087/a70872a27224c9c8f2c64d38a48249c06ed27d5f" alt="image.png" data:image/s3,"s3://crabby-images/fb07d/fb07d1bfbd9835dd19b1c32bbc6119ba6c5651ed" alt="image.png" #### RCE ##### 第一处 在逛后台的时候 发现上传的地方 可以任意上传东西 但是直接jsp这些传上去访问直接下载 无法利用 但是在上传zip的时候会自动解压 这就有意思了 于是乎 先抓包抓到路由 然后全局搜索 data:image/s3,"s3://crabby-images/59b64/59b64e5bb300db3bd88281e71457a0bccd815687" alt="image.png" data:image/s3,"s3://crabby-images/7f471/7f4713792c11381585bf9e91327e370f7ca9f1bd" alt="image.png" 然后跟进来 data:image/s3,"s3://crabby-images/20210/202100430b884cc761903c355ea773fe3044abd5" alt="image.png" 这里调用了这个zipupload 继续跟进 data:image/s3,"s3://crabby-images/48a76/48a760cb2b9c76249cd3e6dd49615de35fb6e5f4" alt="image.png" 经过简单代码跟进 发现 这一步才开始对参数进行利用 data:image/s3,"s3://crabby-images/36406/364061fc9579c84fe2d03bd88d7c97d79ce5645f" alt="image.png" data:image/s3,"s3://crabby-images/20782/2078247c942779fbabf494b5dcd0a412e4684154" alt="image.png" 经过初步判断这个函数的作用是将zip里面的文件取出来 然后存入到文件夹里面 具体是不是 利用断点来进行详细的分析 data:image/s3,"s3://crabby-images/f150e/f150e358dadcaa98e2ac52c3585b961209e7ba30" alt="image.png" 这里是将传进来的文件先写入了临时文件 然后将临时文件和一个路径传入到zip函数 继续跟进 data:image/s3,"s3://crabby-images/72e67/72e67e905372958eb1e90bd39fda339bf1b14875" alt="image.png" 先判断传入的路径是不是文件夹 不是就直接报错 然后看下面 定义了一些相关变量 data:image/s3,"s3://crabby-images/45af6/45af62af6e261cb6014a3c3e105fe0a8d9f474df" alt="image.png" 这里创建了一个zipfile文件对象 目标正式传入的zip文件的临时存储文件 data:image/s3,"s3://crabby-images/f2c3e/f2c3ea5e56a713ed197ceab95532ece427d757de" alt="image.png" 这一步一个就是获取了文件的相关信息 data:image/s3,"s3://crabby-images/1ee6e/1ee6ed0c0f41110ecede1cdaeef7b079fc70a5ef" alt="image.png" data:image/s3,"s3://crabby-images/11db7/11db755dcc4c0c97c10a943ae9181de2579ce056" alt="image.png" data:image/s3,"s3://crabby-images/5db9e/5db9e296abfea9b537fc7809d2c9db829a306287" alt="image.png" 然后走到这一步就直接将文件写入到文件里面 其中也没有任何的过滤 所以我们哪怕是文件里面放入jsp一句话也可以 先试试 data:image/s3,"s3://crabby-images/f5681/f5681aba2757b54b3c5743a3393a8f52c7b93c39" alt="image.png" data:image/s3,"s3://crabby-images/66678/66678af99c8f95b0cd96a17f260854819fd0e44f" alt="image.png" jsp文件访问不到 发现在uploads前面竟然多了一个/jsp 其他类型文件直接下载 但是文件又确实存在 那说明肯定是拦截器之类的 data:image/s3,"s3://crabby-images/01d4a/01d4af05b29a644b4178e7f49abc005ecfd8a550" alt="image.png" 经过搜索 找到这里 在这里打上断点 data:image/s3,"s3://crabby-images/eb999/eb99911d884be79deac1e86ee872e794c19edb4a" alt="image.png" data:image/s3,"s3://crabby-images/fd378/fd378609eec824cb53f41348432ca4f0b6f1b861" alt="image.png" 访问之后 确实是走到这里来了 所以直接jsp文件无法利用 那么这里 既然存入文件的过程没有什么过滤 直接利用跨目录的方式写一个war包到 但是这里前提得用tomcat搭建 因为我之前直接用的springboot的 重新切换到tomcat - jspxcms安装包(部署到Tomcat):<https://www.ujcms.com/uploads/jspxcms-9.0.0-release.zip> data:image/s3,"s3://crabby-images/a15ae/a15ae1fefd07a9882f7dd5d99271ab7967855ce7" alt="image.png" 也是有安装手册的 根据手册把配置文件改了 然后启动tomcat data:image/s3,"s3://crabby-images/ce7cb/ce7cba1d9e43b973baa83e5a41028859fe83b5b0" alt="image.png" 然后来到上传的地方 data:image/s3,"s3://crabby-images/c830a/c830a514a1e21a72eedda55e1f1e206cfeed33ef" alt="image.png" 先准备恶意的zip包 把一句话打包成war包 data:image/s3,"s3://crabby-images/034c3/034c33a4c52624d4a1953859134cb471b6ccae04" alt="image.png" 然后把war包压缩 这里得用到脚本来 ```php import zipfile file = zipfile.ZipFile('shell.zip','w',zipfile.ZIP_DEFLATED) with open('test.war','rb') as f: data = f.read() file.writestr('../../../test.war',data) file.close() ``` data:image/s3,"s3://crabby-images/17a9e/17a9ed655e9fdceb3c901b359a896f7f0d224fd7" alt="image.png" 然后上传 data:image/s3,"s3://crabby-images/68720/687207b662c38a061e4b74e6f6d2b9f776cfc164" alt="image.png" data:image/s3,"s3://crabby-images/93a4a/93a4a42fc51f05226afb8f09ed873949d2d4cc56" alt="image.png" data:image/s3,"s3://crabby-images/6ce07/6ce07fc9f0106cb0fe7da05df0efe6214de63c32" alt="image.png" 冰蝎连接 data:image/s3,"s3://crabby-images/bba0a/bba0a294b2446304e925fd1ad587bdcce2bac65d" alt="image.png" ##### 第二处 在pom.xml中发现该系统用的shiro版本是1.3.2 data:image/s3,"s3://crabby-images/5884b/5884b6fbd7f378492d903d07e620cc7195e8d2bb" alt="image.png" data:image/s3,"s3://crabby-images/12ed8/12ed80645ff131d0f7987e658c298f8d7d194c13" alt="image.png" 符合shiro-721的条件 现在版本符合了 就需要寻找构造链了 data:image/s3,"s3://crabby-images/b77d5/b77d5973f47b35a7d5bc9a5d65acc148d69cdc16" alt="image.png" 这是该系统的 和ysoserial的利用链的版本有些差异 但能不能用 先测试一下 要了一个payload 然后利用exp脚本 开始爆破 <https://github.com/inspiringz/Shiro-721> data:image/s3,"s3://crabby-images/d8277/d8277d90182726edff51cb0d3a9881152af46c43" alt="image.png" 爆破的时间有点久 data:image/s3,"s3://crabby-images/819b6/819b64fe386faab2f22a8a52b973547a2400aba2" alt="image.png" 然后把cookie复制 我们来执行 data:image/s3,"s3://crabby-images/ddacb/ddacb7000e45309827f11d1733808a435b98c7e7" alt="image.png" data:image/s3,"s3://crabby-images/8eb69/8eb69e05be589548362c73dc756ca0555b5737b5" alt="image.png" 反序列化的细节就不在这篇文章叙述了 请听下回分解 参考:<https://www.freebuf.com/articles/others-articles/229928.html> JAVA代码审计入门篇
发表于 2022-12-29 09:00:01
阅读 ( 11269 )
分类:
代码审计
4 推荐
收藏
0 条评论
请先
登录
后评论
永安寺
8 篇文章
×
发送私信
请先
登录
后发送私信
×
举报此文章
垃圾广告信息:
广告、推广、测试等内容
违规内容:
色情、暴力、血腥、敏感信息等内容
不友善内容:
人身攻击、挑衅辱骂、恶意行为
其他原因:
请补充说明
举报原因:
×
如果觉得我的文章对您有用,请随意打赏。你的支持将鼓励我继续创作!