某数美验证码分析
某数美接口更新了captchaUuid的算法,下面是算法的实现
function generateTimeFormat() {
let date = new Date(),
fn = function (arg1) {
return +arg1 < 10 ? '0' + arg1 : arg1.toString();
};
return ((date.getFullYear().toString() + fn(date.getMonth() + 1)) + fn(date.getDate()) + fn(date.getHours()) + fn(date.getMinutes())) + fn(date.getSeconds())
}
function getCaptchaUuid() {
let _0x3999d4 = 'ABCDEFGHJKMNPQRSTWXYZabcdefhijkmnprstwxyz2345678';
let _0x44acc9 = 48;
let _0x2931d8 = '';
for (let _0xfa = 0; _0xfa < 18; _0xfa++) {
_0x2931d8 += _0x3999d4.charAt(Math.floor(Math.random() * _0x44acc9));
}
return generateTimeFormat() + _0x2931d8;
}
滑块
滑块的难点主要在于 轨迹生成,但是随便百度一搜就能搜到,基本上通过率都是在90%以上
点选(图标,语序,空间,文字)
写到后面
数美的参数是动态的,好像每周都会更新,但是加密的方式都是不变的,总不能每次都要重新分析,这里我已经实现了动态的参数,检测到更新的时候就会把参数自动提取出来,只要不是大版本更新,基本上没什么问题
其实混淆并不是很难,通过AST还原之后很好分析,可以直接找出加密位置,直接扣下来js就行了
代码我放到Github上了
GitHub地址
声明
该文章仅作学习交流,如有侵权,请联系我删除♥♥:Code-Bin:♥♥