freeBuf
主站

分类

漏洞 工具 极客 Web安全 系统安全 网络安全 无线安全 设备/客户端安全 数据安全 安全管理 企业安全 工控安全

特色

头条 人物志 活动 视频 观点 招聘 报告 资讯 区块链安全 标准与合规 容器安全 公开课

官方公众号企业安全新浪微博

FreeBuf.COM网络安全行业门户,每日发布专业的安全资讯、技术剖析。

FreeBuf+小程序

FreeBuf+小程序

实战:加密传输数据解密
2024-01-23 14:50:52

前言

下面将分享一些实际的渗透测试经验,帮助你应对在测试中遇到的数据包内容加密的情况。我们将以实战为主,技巧为辅,进入逆向的大门。

技巧

开局先讲一下技巧,掌握好了技巧,方便逆向的时候可以更加快速的找到关键函数位置!

后续也会有更多的实战会按照技巧去操作。

  • 关键词搜索一:在js代码没有混淆的情况下。我们可以直接进行关键词搜索,加密可以搜索encrypt,解密可以搜索decrypt。至于原因就是,无论是加密数据解密,还是明文数据进行加密,都必然会经过加密算法。

  • 关键词搜索二:如果第一种方法搜索不到需要的信息,可以尝试搜索 JSON.parse() 方法。加密数据通常是字符串格式的,解密后也是字符串格式的。在前端中,需要使用 JSON 格式而不是字符串格式的数据,因此必须进行反序列化(即将字符串转换为 JavaScript 对象)处理。

  • 关键词搜索三:api后端返回的是json键值对格式的,我们也可以去尝试搜索加密字符值的键去找到关键的加密位置。

正文

实战一:

在进入网址后,查看XHR请求时发现数据被加密了。尽管XHR中的数据是经过加密的,但在页面上却以明文形式呈现。因此可以初步判断,在前端渲染页面时,会对从后端传输下来的数据进行解密操作。

202401231414518.png

搜索JSON.parse时,找到了11个参数。在每一个包含JSON.parse的代码行下设置断点,然后刷新页面,断点被断在了18647行。

202401231414520.png

控制台中打印JSON.parse(v),你会发现明文数据就是v。所以这段代码是用来解密的函数。

202401231414521.png

y是解密后的参数,y是由v解析出来的,v的传参是d,d的传参是l,下断点发现l是加密字符串。Object(c.a)(l)表示对变量c.a执行函数调用,并将参数l传递给该函数。

202401231414522.png

将这段代码扣下来并且运行,报错没有没有找到Object(c.a)。

202401231414523.png

在控制台打印Object(c.a),直接进去函数内部扣代码

202401231414524.png

改写一下代码,l是传进去的加密字符串。

202401231414525.png

运行之后t报错,发现_keyStr未定义

202401231414526.png

全局搜索_keyStr发现是一个字符串,直接复制下来。

202401231414527.png

运行报错Object(c.b)未定义

202401231414528.png

将鼠标浮上Object(c.b)可以发现他是一个名字为d2的函数,进去js里面将d2函数抠出来并且替换掉函数名

202401231414529.png

202401231414531.png

改写函数名

202401231414532.png

运行报错_p未定义

202401231414533.png

全局搜索p发现这个变量很乏有太多重复的,不过初步判断是一个变量,我们可以在p后面加一个空格搜索。_p加空格只有7个,很快便找到了这个变量,发现他是一个字符串。将他扣进代码里面。

202401231414534.png

运行报错,_u_d函数未定义。

202401231414535.png

全局搜索_u_d,将其扣进代码里面

202401231414536.png

运行一下。

202401231414537.png

数据已经成功解密了。

实战二:

抓个包,数据包内容已经被加密了

202401231414538.png

从initiator进入到js文件里面

202401231414539.png

搜索解密关键词,发现第66752有个decrypt,把断点下在return那一行。

202401231414540.png

在66752下断点刷新,将返回的那段代码在控制台打印。发现是解密之后的数据,那么这一段函数肯定是解密函数

202401231414541.png

扣代码运行报错url2和text2未定义

202401231414542.png

去浏览器下断点补上两个未定义的参数,url2是一个固定的值

202401231414543.png

而text2是加密字符串。

202401231414544.png

运行之后报错cryptoJs未定义

202401231414545.png

将cryptoJs.exports在控制台上面打印出来,发现是加密库crypto,直接调库替换即可

202401231414546.png

运行报错,node.js里面的解码函数是btoa,将encode替换成btoa即可。

202401231414547.png

解密成功

202401231414548.png

结尾

部分数据代码已做脱敏处理。


# 渗透测试 # 数据解密 # 逆向技术
本文为 独立观点,未经允许不得转载,授权请联系FreeBuf客服小蜜蜂,微信:freebee2022
被以下专辑收录,发现更多精彩内容
+ 收入我的专辑
+ 加入我的收藏
相关推荐
  • 0 文章数
  • 0 关注者
文章目录