某音_signature,分析过程
2022-01-26 本文已影响0人
苦海飘摇
首先想到的是通过搜索
data:image/s3,"s3://crabby-images/49124/49124398657aa936d0b748ac89ff0d50bf533601" alt=""
如上图无果
然后加条件断点
data:image/s3,"s3://crabby-images/b58bd/b58bd3045aef9dc5a4057e91139e104d0a63b59d" alt=""
XHR断点都不懂的小白请自行百度,这里不再做解释。
data:image/s3,"s3://crabby-images/8057e/8057e2465a5525d18173d07b9e8617fc6adfeb60" alt=""
此时变量i中已经包含了_signature,我们shift + f11 向前查找
data:image/s3,"s3://crabby-images/a5e6d/a5e6dcf9472f1bafcd8b316560bf6c951edb590a" alt=""
继续跟踪发现在 G函数中的arguments中有三个属性,(请求方法,请求路径,布尔值)这里的请求url是还没有_signature的
data:image/s3,"s3://crabby-images/b1bde/b1bde88c69fb7215f568dd84ab2e627c08a01403" alt=""
此时发现其监控了鼠标操作,只要该处打断点鼠标一移动就会陷入无限debug。针对这种情况我们将断点改为条件断点。
首先找到针对那些路由会有_signature
data:image/s3,"s3://crabby-images/d6ed7/d6ed72c8a87c39144ff5870183a88e2860c1ab82" alt=""
分析其代码很明显就是
window.byted_acrawler.init
其对"/business_api/shop", "/business_api/author", "/business_api/inst", "/insight_api"
这些路径进行了签名我这里将断点改为了
f变量包含/business_api/author
时才断下。这是屏蔽断点的时候,console直接输出结果
data:image/s3,"s3://crabby-images/d6878/d6878e731d1fcd8c5f4ea618ea4987f8cd81c6c9" alt=""
这是加断点的时候,console不会直接输出结果,而是进入调试状态
data:image/s3,"s3://crabby-images/b5e61/b5e614aac8cf123a493596b550eceb9d15e77a9c" alt=""
经多次单步调试,发现其检测的环境在该位置
data:image/s3,"s3://crabby-images/3355d/3355d53ddcb527d9ff529988af263aabd5ed89c0" alt=""
data:image/s3,"s3://crabby-images/4e03c/4e03c277846d147fef79b2d32b4bf1d8e3b463c8" alt=""
data:image/s3,"s3://crabby-images/7c018/7c0189c37c18e28264754fc8fe78c132764656e6" alt=""
还有很多,这里就不一一列举了