易盾滑块逆向分析

本篇文章仅用于交流与学习,严禁用于任何商业与非法用途!否则由此产生的一切后果均与作者无关!如有侵权,请联系作者本人进行删除。

感谢关注!您的关注和点赞就是我的动力

1.逆向目标

aHR0cHM6Ly9kdW4uMTYzLmNvbS90cmlhbC9qaWdzYXc=

2.逆向分析

先看发包请求,只有cb参数需要逆向,打断点跟栈

稍微找找一下,cb的生成位置就在这里

进入方法内,发现里面是混淆的,直接全扣补环境,把方法导出到全局,在python调用动态生成cb,

把图片下载到本地使用ddddocr识别,后面的验证接口也是需要这里的token的

下面看一下验证接口,data,cb需要逆向,cb上面已经说过,token也是上面的接口返回的

打断点跟栈,最后找到data的生成位置

先看d参数怎么来的,这里入参是一堆密文,很像是加密后的轨迹

这里的_0x1b7568a0_0x1e60(0x2d6)方法,调用方式跟上面生成cb的调用方式一样(后面大部分方法都是这样的),主要看看traceData是怎么来的

在解密方法这里打一个条件断点,当结果是traceData的时候断住

断住之后往上跟栈就找到了tracedata的生成位置

下面看p参数,比较简单,手动解混淆你就能清晰看到这里的生成逻辑

接着是f参数,_0x319bb4是token,_0x4d98f2是对明文轨迹进行了一些操作生成的,轨迹直接让ai帮你写就行

ext参数的生成逻辑也比较简单,也不多说了

轨迹代码

python 复制代码
def generateSlideTrack(distance):
    # 三次贝塞尔控制点
    P0 = {"x": 0, "y": 0}
    P1 = {"x": distance * 0.3, "y": 0}
    P2 = {"x": distance * 0.7, "y": 0}
    P3 = {"x": distance, "y": 0}

    track = []
    # 起始时间戳,贴近你给的样本(130~179)
    timestamp = random.randint(130, 179)
    # 轨迹点数量,保证足够密集
    sampleCount = max(60, int(distance * 1.2))

    # 三次贝塞尔计算函数
    def bezier3(t, p0, p1, p2, p3):
        k = 1 - t
        return {
            "x": k**3 * p0["x"] + 3 * k**2 * t * p1["x"] + 3 * k * t**2 * p2["x"] + t**3 * p3["x"],
            "y": k**3 * p0["y"] + 3 * k**2 * t * p1["y"] + 3 * k * t**2 * p2["y"] + t**3 * p3["y"]
        }

    for i in range(sampleCount + 1):
        t = i / sampleCount
        pt = bezier3(t, P0, P1, P2, P3)

        x = round(pt["x"])
        # ===================== Y 轴偏移加大 -3~3 =====================
        y = random.randint(-3, 3)

        # 时间戳递增 4~22ms,贴近样本节奏
        timestamp += random.randint(4, 22)

        track.append([x, y, timestamp, 1])

    # 最后一个点强制校准到目标距离
    if track:
        track[-1][0] = distance

    return track

3.逆向结果

相关推荐
ai_coder_ai1 小时前
如何在自动化脚本中实现定时操作?
java·前端·javascript
努力早日退休1 小时前
一个 9999px 引发的跨平台血案:小程序离屏隐藏元素的滚动兼容性问题
前端·javascript
常常有1 小时前
Redis:哨兵模式 (Sentinel)
redis·python·sentinel
Darling噜啦啦2 小时前
正则表达式实战指南:从手机号验证到模板引擎,5 个案例彻底搞懂 RegExp
javascript·面试
sugar__salt2 小时前
JS正则表达式与字符串高阶实战精讲
开发语言·javascript·正则表达式
程序员三藏2 小时前
接口测试用例设计
自动化测试·软件测试·python·测试工具·职场和发展·测试用例·接口测试
HjhIron2 小时前
从手机号校验到模板引擎:正则表达式的实战之旅
javascript
Hello馒头儿2 小时前
vue3+uniapp经典hook方式实现一个更多加载的列表组件
前端·javascript·vue.js
用户938515635072 小时前
前端必会:从 Fetch 到 DeepSeek,一篇搞懂 HTTP 请求的方方面面
javascript·架构