某验通杀js版,流程各个验证码那对应的js分析,你确定不进来看看(点选and通杀)?

你只管努力,剩下的交给天意。

文章只提供学习,如有侵权请立即联系我。

前言
某验官网:官网
总体来说某验的验证码配合js总共分为三套

总体来说就分为这三种,当前了点选还分了文字,语序,图标,九空格,空间其略有变化的九宫格其他的一模一样可以使用同一套js解决。

通杀
这里就说一下空间推理的以及九空格的,具有代表性的其他没啥变化,然后会整合前面的两个无感滑动的,进行统一操作

在这里插入图片描述

先请求一下gtchallenge

url_startCaptcha = f"https://www.geetest.com/api/user/show/register-space?t={int(time.time()*1000)}"

大家看这个操作估计也熟悉了吧,老一套,aet还原。然后找w值的位置。在这里插入图片描述

在这里插入图片描述
老规矩对比一下源码和还原后的代码。在这里插入图片描述

在这里插入图片描述
在这里插入图片描述
ok那我们在线上继续debugger这个w值,看看是不是这里,呕吼没错就是这里。
在这里插入图片描述

在这里插入图片描述
然后根据调用栈向上找看看传入的这两个值是什么。

这个东西很奇怪,不知道是什么也不像是坐标也不像是加密的字符,后面一个参数我们可以看到是时间相减应该就是点击所用的时间。(这里不做演示了大家自己看一下就好)
在这里插入图片描述

在这里插入图片描述
ok我们在这个生成很奇怪的地方debugger一下看看它到底做了,什么才生成的这个字符。
在这里插入图片描述
点击去看看里面做了什么不为人知的事情-、-

根据我们还原的代码以及线上调试的结果可以看到这应该就是坐标,不过他为什么这么大呢?道理我都懂!但是它为什么着大呢?

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
既然知道你是坐标的化身,而且还是点击坐标点生成来的,那么我们就可以嘿嘿嘿嘿。
在这里插入图片描述

根据这两个名字在你的js文件里搜索一下。
在这里插入图片描述
搜索到这两个值是在这里给赋值的。
在这里插入图片描述
我们在这里的debugger一下。
在这里插入图片描述

查看调用栈,这两个值是不是跟我们想要值很像。在这里插入图片描述

在这里插入图片描述
好,结合我们的还原的代码再看看。
在这里插入图片描述
在这里插入图片描述
就是相当于当前你点击的位置的坐标除以333.375 *10000 就是获取到那个很大的数字,这个完成之后其实大部分浪费时间的工作就已经完成了,后续就是整合代码。

接下来我们看看生成请求的参数还需要什么。

这个是o是轨迹生成的如果你需要自己生成也可以搞搞,其实极验并没有验证个轨迹写死就行了。
在这里插入图片描述

在这里插入图片描述
还有就是ep里面的值存在坐标不过是相对游览器的位置。
在这里插入图片描述
其他的值没有什么太大的变化还是缺什么补什么就好了。
在这里插入图片描述

小彩蛋:他们其实执行了根据验证码类型执行了不同的click函数,也就是说上面的这个代码可以通用文字点选,语序点选,图标点选,九宫格,空间推理

在这里插入图片描述
九宫格是这样的–相对于当前九个格子的xy点。
在这里插入图片描述
在这里插入图片描述
ep的值一样不变还是相对游览器的xy坐标
在这里插入图片描述
至此其实已经完成了,没有什么很难得操作了(相信细心的朋友已经发现了)
滑动的和点选的其实用的这几个函数是一摸一样的
在这里插入图片描述
还有rp的值
在这里插入图片描述
以及aeskey
在这里插入图片描述
tt的值都是一样的
在这里插入图片描述
滑动的可以和点选的整合到一起,无感的也有这几个函数不过不大一样,如果你有兴趣可以进行整合。
在这里插入图片描述

切记生成
a_这两个字符串的时候aeskey一定要是一样的,不然会报无法解析。
在这里插入图片描述
还有生成RSAkey的时候会报错window没有这个方法,你可以如下图引入一下这个包,当然他是需要用node安装。
在这里插入图片描述

const crypto = require('crypto');
var window = global;
window.crypto = crypto;
window.crypto.getRandomValues = crypto.randomFillSync;
var navigator = {
    appCodeName: "Mozilla",
    appName: "Netscape",
    appVersion: "5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/83.0.4103.116 Safari/537.36",
    connection: {onchange: null, effectiveType: "4g", rtt: 100, downlink: 5.5, saveData: false},
    cookieEnabled: true,
    doNotTrack: null,
    geolocation: {},
    hardwareConcurrency: 4,
    language: "zh-CN",
    languages: ["zh-CN", "zh"],
    maxTouchPoints: 0,
    mediaCapabilities: {},
    mediaSession: {metadata: null, playbackState: "none"},
    mimeTypes: {},
    onLine: true,
    permissions: {},
    platform: "Win32",
    plugins: {},
    product: "Gecko",
    productSub: "20030107",
    userActivation: {hasBeenActive: false, isActive: false},
    userAgent: "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/83.0.4103.116 Safari/537.36",
    vendor: "Google Inc.",
    vendorSub: "",
    webkitPersistentStorage: {},
    webkitTemporaryStorage: {},
    javaEnabled: function () {
        return false
    }
};

全完成来看看我融合的无感,滑动,点选代码吧。
在这里插入图片描述
点选的坐标轨迹不是我写的所以打上马赛克吧。

在这里插入图片描述

在这里插入图片描述
在这里插入图片描述
0.0其实还是可以再进行代码处理删除掉无用的代码的,太懒了,懒得操作了,留给大家尝试吧
在这里插入图片描述

如有错误的地方请及时联系我-

总结一下无感,滑动,点选无感的js相对滑动点选稍稍难一点(因为是两次请求一次传aeskey,一次去验证参数,还要eval),滑动的js不难不过却添加了轨迹的验证,点选的是最简单的只需要传坐标就好了。

只会js就够了吗???不不不,这只是开始而已,接下来会说一下验证码部分,滑动的已经在上篇文章里说过了,那么接下来就是点选类型的。

1.项目代码功能经验证ok,确保稳定可靠运行。欢迎下载使用! 2.主要针对各个计算机相关专业,包括计科、信息安全、数据科学与大数据技术、人工智能、通信、物联网等领域的在校学生、专业教师或企业员工使用。 3.项目具有丰富的拓展空间,不仅可作为入门进阶,也可直接作为毕设、课程设计、大作业、初期项目立项演示等用途。 4.当然也鼓励大家基于此进行二次开发。在使用过程中,如有问题或建议,请及时私信沟通。 5.期待你能在项目中找到乐趣和灵感,也欢迎你的分享和反馈! 【资源说明】 基于yolov5的极验空间推理验证码模型训练python源码+标注好的数据集+项目说明.zip 测试接口 接口随时都可能会关掉,如果不通就是被我关掉了。 测试接口:`http://49.234.3.186:8888/index` 限制每天500次请求,每小时100次请求,每分钟60次请求。(总计) ### GET请求参数 参数 | 值 | ---- | ---- | gt | c9428d9361cd70d26e28d7cd780ec640 | challenge | 9a5d3a1db9dadbaa867f6a34a5512740 | ### 请求成功示例 ```json { "msg":[], "result":"success", "score":"1", "validate":"ac00fdb3bc74b012c3b82cca057675fa" #使用challenge和validate一起提交验证即可 } ``` ## 验证码问题求解思路 训练模型比较简单,我自己标记了100张图的标签,可以直接训练,也可以直接用我训练好的权重文件`best.pt`,训练了大概700次左右,感觉效果还是不错的,我认为比较麻烦的部分还是分析问题找出符合条件的物体,我写出的逻辑识别成功率大概在80%,暂时不公开逻辑。 `请点击在黄色圆柱体后面的黄色物体。`判断前后左右,可以根据物体底部的xy坐标。 `请点击与绿色物品有相同大小的球。`判断相同大小,可以对比符合条件的物体的二维面积,最相近的可以认为相同大小。
评论 10
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值