本帖最后由 heisezhitong 于 2024-01-30 21:43 编辑
某文档一浏览某技术文档时,发现此文档需要验证码,而验证码需加入知识星球才能看到 data:image/s3,"s3://crabby-images/adaac/adaac9a422ada04049c4b3940bdaafaf951d1e3c" alt=""
于是先看看能不能破解咯,打开 F12 ,先随便输入个验证码,看看是不是动态验证的 data:image/s3,"s3://crabby-images/890e1/890e1753345da2b34bd9e68f160dde2eaa50dc19" alt=""
XHR 请求里有请求进行验证
data:image/s3,"s3://crabby-images/eb80b/eb80b6d65a55d2216b39e4f18c2343e22385b603" alt=""
根据此链接去打个断点看看 data:image/s3,"s3://crabby-images/06279/06279d6f32a9d86a820968b08ff5e0ae83774b2d" alt=""
重新输入验证码发起请求,接着分析代码 data:image/s3,"s3://crabby-images/90f7f/90f7fbbc9fd6177ffccdd0e413ff0c2597995f98" alt=""
这里很容易就知道,当 s 不等于 i 时代表验证码错误 我们只需要让 s==i 就可以 if (st.log("md5Input", s), != i) throw new Error("验证码错误!")
打个断点,看看他俩值是多少 data:image/s3,"s3://crabby-images/66685/66685fdda3741e12b1a93100f987ad81f77ca979" alt=""
右上角继续执行 data:image/s3,"s3://crabby-images/399e3/399e33a15be106bc8ff42b292879599bde7724b8" alt=""
i 就是 XHR 请求返回数据中的字段 description 的值
s 就是 y7.MD5(o).toString() ,o 就是输入的验证码
data:image/s3,"s3://crabby-images/8fee1/8fee128e4ec70461e9ab71edd0d50e68f43e8158" alt=""
我们只要把 s 的内容改成 "e74eb4201f9376041508fc2219a125e2" 就行了 作用域里直接替换就行了 data:image/s3,"s3://crabby-images/9333a/9333a3a8dcdd5a50e4afec842c00795fe0905789" alt=""
接着继续执行,提示文档解锁成功 data:image/s3,"s3://crabby-images/68812/68812266d7a30482c5466a989374c1cb0ce30ca2" alt=""
固定返回内容
验证码可能会定期更换,我们也可以更改接口的返回内容,这样就不用担心更换 使用一款拓展程序:Requestly: Open Source HTTPs Debugging Proxy data:image/s3,"s3://crabby-images/70659/706599ed7ecd8c071eb4802a6fab3bf8cc90145b" alt=""
添加一个 Modify API Response(修改API响应)的规则 直接返回我们自己想要的 data:image/s3,"s3://crabby-images/d230c/d230ce508fa14e40637d0ac57654f5dd6815d222" alt=""
某文档二浏览另一平台的文档,也是需要验证码 data:image/s3,"s3://crabby-images/5ba18/5ba1861fe8f563f538dcc0813094065bb7b55ee5" alt=""
随机输入一个验证码后,没有网络请求,可以断定验证码在本地 data:image/s3,"s3://crabby-images/df825/df825b0fe6f58407645d46c706cfe861d5d1c109" alt=""
停用缓存,重新刷新网页,搜索关键字:解锁验证码有误 data:image/s3,"s3://crabby-images/622de/622de698acf3e48bffbfae982581b7dcc30084ec" alt=""
去分析下代码 data:image/s3,"s3://crabby-images/d90f7/d90f737a751d3945ea68d2ab7597920e6c3f2c8b" alt=""
根据这块代码意思就是 输入框 id="unlockCode" 的值和 e 比较,存在也就是 >= 0 就设置 Cookies 否则就是验证码错误 所以 e 就是密码 data:image/s3,"s3://crabby-images/e40f7/e40f73ab483932e9dd9c3c1d5f99f542438cf600" alt=""
这个输入框也正好是 验证码 的输入框 data:image/s3,"s3://crabby-images/0edc0/0edc09ca84a88199fb8ebb4e7fba025c058d5189" alt=""
鼠标放过去就知道了密码 data:image/s3,"s3://crabby-images/c0ef4/c0ef4f0ac94fd88d48b54715f539801d8f9a199e" alt=""
注:若转载请注明大神论坛来源(本贴地址)与作者信息。
|