某数美验证码逆向分析

发布于:2023-05-22 ⋅ 阅读:(196) ⋅ 点赞:(0)

某数美验证码分析

某数美接口更新了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地址
在这里插入图片描述

本文含有隐藏内容,请 开通VIP 后查看