使用Ceylon破解极验第三代滑块验证码


极验验证码通过拖动滑块到合适的位置来验证用户操作的真实性。本文将使用Ceylon编程语言,结合图像处理技术,演示如何破解这种验证码。Ceylon是一种面向对象的编程语言,旨在提高代码的可读性和可维护性。

一、环境准备
1. 安装Ceylon编译器
首先,需要安装Ceylon编译器。可以从官方安装指南获取安装方法。

2. 引入所需库
由于Ceylon没有直接的图像处理库,我们将使用Java的标准库来处理图像,结合java.awt和javax.imageio进行图片操作。

二、代码实现
1. 获取验证码图片
首先,我们需要下载验证码的背景图片和完整背景图片。我们将使用Java的URL和ImageIO类来完成这一任务。

ceylon

import java.net {
    URL
}
import java.nio.file {
    Paths, Files
}
import javax.imageio {
    ImageIO
}
import java.awt {
    image::BufferedImage
}

shared void downloadImage(String urlString, String savePath) {
    URL url = URL(urlString);
    value inputStream = url.openStream();
    value outputStream = Files.newOutputStream(Paths.get(savePath));
    outputStream.write(inputStream.readBytes());
    inputStream.close();
    outputStream.close();
}

shared void run() {
    downloadImage("https://static.geetest.com/pictures/gt/3999642ae/3999642ae.webp", "bg_image.webp");
    downloadImage("https://static.geetest.com/pictures/gt/3999642ae/bg/fbdb18152.webp", "full_bg_image.webp");
}
2. 图像处理
接下来,我们将图像加载进内存,并通过逐像素比较找出缺口位置。

ceylon

shared Integer? findGapPosition(BufferedImage image, BufferedImage fullImage) {
    for (x in 0..image.getWidth() - 1) {
        for (y in 0..image.getHeight() - 1) {
            if (image.getRGB(x, y) != fullImage.getRGB(x, y)) {
                return x;
            }
        }
    }
    return null;
}

shared void run() {
    value bgImage = ImageIO.read(Paths.get("bg_image.webp").toFile());
    value fullBgImage = ImageIO.read(Paths.get("full_bg_image.webp").toFile());

    value gapPosition = findGapPosition(bgImage, fullBgImage);
    if (exists gapPosition) {
        print("Gap position: ``gapPosition``");
    } else {
        print("Gap not found.");
    }
}
3. 模拟滑块拖动
Ceylon中没有原生的浏览器控制库,我们将使用JavaScript和Python相结合的方法来实现拖动操作。我们先用Python生成拖动轨迹:

python

# generate_tracks.py
import numpy as np

def bezier_curve(t):
    return 3 * t * (1 - t)**2 + 3 * (1 - t) * t**2 + t**3

def generate_tracks(distance):
    tracks = []
    for i in range(101):
        t = i / 100
        x = int(bezier_curve(t) * distance)
        tracks.append(x)
    return tracks

if __name__ == "__main__":
    import sys
    distance = int(sys.argv[1])
    tracks = generate_tracks(distance)
    print(tracks)
然后使用Python和Selenium控制浏览器完成滑块拖动:

python

# simulate_drag.py
from selenium import webdriver
import time
import subprocess
import json

gap_position = 100  # 从 Ceylon 程序获取

result = subprocess.run(['python3', 'generate_tracks.py', str(gap_position)], stdout=subprocess.PIPE)
tracks = json.loads(result.stdout.decode('utf-8'))

browser = webdriver.Chrome()
browser.get('https://account.ch.com/NonRegistrations-Regist')

knob = browser.find_element_by_class_name('gt_slider_knob')
actions = webdriver.ActionChains(browser)更多内容联系1436423940

actions.click_and_hold(knob).perform()
for track in tracks:
    actions.move_by_offset(track, 0).perform()
    time.sleep(0.02)
actions.release().perform()

browser.quit()
4. 集成Ceylon和Python脚本
在Ceylon程序中调用Python脚本来生成轨迹并模拟滑块拖动。

ceylon

import ceylon.process {
    ProcessBuilder
}

shared void run() {
    value gapPosition = 100; // 由图像处理代码获得

    ProcessBuilder(["python3", "generate_tracks.py", gapPosition.string])
        .start()
        .out.getStream().readAllLines().each((line) => print(line));

    ProcessBuilder(["python3", "simulate_drag.py"])
        .start()
        .waitForExit();
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值