Java +Selenium 框架如何解决滑动验证码问题? - V2EX
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
tiRolin
V2EX    Java

Java +Selenium 框架如何解决滑动验证码问题?

  •  
  •   tiRolin 2023-07-19 13:28:38 +08:00 2722 次点击
    这是一个创建于 860 天前的主题,其中的信息可能已经有所发展或是发生改变。

    我想实现这个网站的爬虫功能: https://www.cnhnb.com/hangqing/cdlist-0-0-0-0-0-1/?k=%E6%9F%91%E6%A9%98

    但是这个网站在爬取时会出滑块验证码需要验证的问题,我检索工具中找答案,但是基本都是使用 Python 来解决的,我不怎么会把那里的 Python 代码转化到 Java 代码,用 GPT 也转不了(会出现各种预期之外的代码问题),还有一个方式是先获取原图像和滑块的缺口图像然后再对图像进行处理,但是我验证码的 HTML 代码里没有 src 我也不知道怎么通过什么下载出来,这招对我来说也不行

    各位想知道那个滑块验证码的具体样子只要进入我的网址多翻几页就可以看到了

    我真的什么办法都尝试过了,我真没办法所以我来问问各位,有懂的大佬能不能记一下,在下感激不尽啊

    12 条回复    2023-08-14 10:36:33 +08:00
    forQ
        1
    forQ  
       2023-07-19 13:48:19 +08:00
    试试这个能不能避免出现滑块验证码 stealth.min.js
    htfy2020
        2
    htfy2020  
       2023-07-19 14:30:04 +08:00
    你可以进入这个网页的触屏版,https://m.cnhnb.com/hangqing/cdlist-0-0-0-0-0-1/?k=%E6%9F%91%E6%A9%98 ,向下滑动会访问这个 API 获取数据 https://appapi.cnhnb.com/market-platform/api/market/statistics/pc/arealist ,你可以通过 Selenium 发送 API 请求,改变 pageNum 与 pageSize 参数即可。这样好像不会出现验证码
    yagamil
        3
    yagamil  
       2023-07-19 14:33:05 +08:00
    滑块最简单的是使用图形比对的方式找缺口了。
    pzistart
        4
    pzistart  
       2023-07-19 16:09:49 +08:00
    识图 api 网站,找图片到缺口的距离。调用工具包模拟操作鼠标滑动指定距离。
    mysunshinedreams
        5
    mysunshinedreams  
       2023-07-19 16:13:08 +08:00
    之前我也做过类似的东西,采用的是 puppeteer ,然后模拟鼠标滑动,记住起始位置和结束位置,然后滑动滑块
    Ib3b
        6
    Ib3b  
       2023-07-19 16:42:47 +08:00
    简单分析了下 js ,应该是用了一个通用的混淆,然后是 CryptoJS 加密,核心代码是这块
    ```Javascript
    (CryptoJS[_0x2997('0xb7', 'S$@X')]['Utf' + '8'])
    , _0x48fa31 = new Date()[_0x2997('0x26d', '@B6g') + 'Tim' + 'e']()
    , _0x273bcf = CryptoJS[_0x2997('0x3b5', 'WTif')][_0x2997('0x32', 'PQm$') + _0x2997('0x1bf', 'L9ro') + 't'](String(_0x48fa31) + _0x47cf5e, _0x56ef51[_0x2997('0x48a', '75LK')], {
    'iv': _0x56ef51['iv'],
    'mode': _0x56ef51[_0x2997('0x49f', '8lh@') + 'e'],
    'padding': _0x56ef51[_0x2997('0x2d3', 'IXXq') + 'din' + 'g']
    })[_0x2997('0x373', 'V(jI') + _0x2997('0x3a3', '7leE') + 'ng']();
    _0x578069[_0x2997('0x3da', 'Actw') + 'x']({
    'headers': {
    'Time': _0x48fa31
    },
    'url': _0x2997('0x409', 'd6bo') + _0x2997('0x31', 'Fi#I') + _0x2997('0x2ab', 'cfM4') + _0x2997('0x404', 'akbu') + _0x2997('0x190', 'akbu') + 'ver' + _0x2997('0x1e0', '9lRr') + '/?c' + 'ode' + '=' + _0x273bcf,
    ```
    加密结果是_0x273bcf 这个变量。
    总结下整体难度不高,花点时间可以搞搞 js 反混淆,用协议方式请求。
    但我看即使过了这个验证后面也要求登录才能拿到数据,感觉没必要做
    c2const
        7
    c2const  
       2023-07-19 16:55:10 +08:00
    跟语言关系不大,验证码问题,滑块得识图然后模拟操作就行了 :)
    滑块识图,复杂的需要付费接口、AI/人工识别;基本的自己做个图像二值化,然后找缺口的特征就可以了 :)
    模拟操作,可以调 js 模拟,也可以操作系统应用层的键鼠模拟 :)
    gg1025
        8
    gg1025  
       2023-07-19 17:02:04 +08:00
    简单的拼图滑块可以用 opencv
    mmdsun
        9
    mmdsun  
       2023-07-19 17:04:15 +08:00
    python 可以的 Java 肯定可以,Selenium 框架不区分语言的。
    把你找到的代码贴出来看看? 就是 Python 代码转化到 Java 代码失败的那个
    tiRolin
        10
    tiRolin  
    OP
       2023-08-03 10:26:25 +08:00
    @c2const 我这里域间的问题是我没有办法将图片下载过来就是,我看了很多教程也是说的对图片进行处理,但是这个网址似乎给图片做了加密,导致我无法通过 HTML 下载到图片,没有图片后续的处理方式也是无从谈起,目前我遇上最大的问题就是这个,我不知道该怎么获取到滑块验证码的图片
    tiRolin
        11
    tiRolin  
    OP
       2023-08-03 10:35:04 +08:00
    @Ib3b 大佬,能稍微指指路吗?你光说这些我不太明白,你的核心代码我在验证码的 HTML 上没找到,CryptoJS 加密的话那我是要对其进行解密然后来破解验证码吗?
    要不你告诉我该去使用什么技术或者给个学习网址或者关键词什么的,我自己去搜索学习,正好你也说难度不高,那或许我正好能解决不是
    Ib3b
        12
    Ib3b  
       2023-08-14 10:36:33 +08:00
    @tiRolin 做爬虫的话可以,前端可以学习下 js ,后期学逆向、加密。针对这个 case ,你可以搜一下 sojson 反混淆
    关于     帮助文档     自助推广系统     博客     API     FAQ     Solana     5815 人在线   最高记录 6679       Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 25ms UTC 02:05 PVG 10:05 LAX 18:05 JFK 21:05
    Do have faith in what you're doing.
    ubao msn snddm index pchome yahoo rakuten mypaper meadowduck bidyahoo youbao zxmzxm asda bnvcg cvbfg dfscv mmhjk xxddc yybgb zznbn ccubao uaitu acv GXCV ET GDG YH FG BCVB FJFH CBRE CBC GDG ET54 WRWR RWER WREW WRWER RWER SDG EW SF DSFSF fbbs ubao fhd dfg ewr dg df ewwr ewwr et ruyut utut dfg fgd gdfgt etg dfgt dfgd ert4 gd fgg wr 235 wer3 we vsdf sdf gdf ert xcv sdf rwer hfd dfg cvb rwf afb dfh jgh bmn lgh rty gfds cxv xcv xcs vdas fdf fgd cv sdf tert sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf shasha9178 shasha9178 shasha9178 shasha9178 shasha9178 liflif2 liflif2 liflif2 liflif2 liflif2 liblib3 liblib3 liblib3 liblib3 liblib3 zhazha444 zhazha444 zhazha444 zhazha444 zhazha444 dende5 dende denden denden2 denden21 fenfen9 fenf619 fen619 fenfe9 fe619 sdf sdf sdf sdf sdf zhazh90 zhazh0 zhaa50 zha90 zh590 zho zhoz zhozh zhozho zhozho2 lislis lls95 lili95 lils5 liss9 sdf0ty987 sdft876 sdft9876 sdf09876 sd0t9876 sdf0ty98 sdf0976 sdf0ty986 sdf0ty96 sdf0t76 sdf0876 df0ty98 sf0t876 sd0ty76 sdy76 sdf76 sdf0t76 sdf0ty9 sdf0ty98 sdf0ty987 sdf0ty98 sdf6676 sdf876 sd876 sd876 sdf6 sdf6 sdf9876 sdf0t sdf06 sdf0ty9776 sdf0ty9776 sdf0ty76 sdf8876 sdf0t sd6 sdf06 s688876 sd688 sdf86