吾爱破解 - 52pojie.cn

 找回密码
 注册[Register]

QQ登录

只需一步,快速开始

查看: 2877|回复: 6
收起左侧

[Python 转载] 使用像素对比来完成Selenium滑块验证码的登录

  [复制链接]
QingYi. 发表于 2021-7-26 15:33
本帖最后由 QingYi. 于 2021-7-26 16:54 编辑

具体看源码吧,介绍就不说了,看源代码吧

拿到手之后要自己修改一下,很简单,可以拿来学习学习 不走打码平台(虽然打码平台也很便宜)


[Python] 纯文本查看 复制代码
import pickle
import random
import time

import settings
from services.common.base_service import BaseService
from selenium.webdriver.common.action_chains import ActionChains
import scrapy
from selenium import webdriver
import requests
import settings
from PIL import Image
from io import BytesIO


class BLoginService(BaseService):
    name = "zhihu"
    login_url = "https://passport.bilibili.com/login"

    # 截取你需要的图片 有缺口和无缺口的
    def crop_image(self, img_file_name):
        time.sleep(2)
        img = self.browser.find_element_by_css_selector('.geetest_canvas_img.geetest_absolute')

        location = img.location
        print("图片的位置:", location)

        size = img.size
        print("图片的大小:", size)

        top, bottom, left, right = location['y'], location['y'] + size['height'], location['x'], location['x'] + size[
            'width']
        print("验证码截图的位置:", left, top, bottom, right)

        screen_shot = self.browser.get_screenshot_as_png()
        screen_shot = Image.open(BytesIO(screen_shot))
        capt = screen_shot.crop((int(left), int(top), int(right), int(bottom)))
        capt.save(img_file_name)
        return capt

    # 初始化
    def __init__(self, settings):
        self.user_name = settings.Accounts[self.name]["username"]
        self.pass_word = settings.Accounts[self.name]["password"]
        self.browser = webdriver.Chrome(executable_path="yourself driver path")
 

    # 验证是否登录成功
    def check_login(self):
        try:
            self.browser.find_element_by_xpath('//class[contains(text(), "我的收藏夹")]')
            return True
        except Exception as e:
            return False

    # 像素比对 找到缺口位置像素,到时候直接滑动
    def compare_pixel(self, img1, img2, i, j):
        pixel1 = img1.load()[i, j]
        pixel2 = img2.load()[i, j]
        # 允许的偏差值
        dif = 60
        # RGB
        # 如果很相似的话应该不是缺口 false  否则差异很大的话就是True
        if abs(pixel1[0] - pixel2[0]) < dif and abs(pixel1[1] - pixel2[2]) < dif and abs(pixel1[2] - pixel2[2]) < dif:
            return False
        return True

    def login(self):
        try:
            # max window, because we need to slider captcha.  get position
            self.browser.maximize_window()
        except Exception as e:
            pass
        while not self.check_login():

            self.browser.get(self.login_url)
            name_ele = self.browser.find_element_by_css_selector("#login-username")
            pass_ele = self.browser.find_element_by_css_selector("#login-passwd")
            name_ele.send_keys(self.user_name)
            pass_ele.send_keys(self.pass_word)

            # 调出滑动验证码
            login_btn = self.browser.find_element_by_css_selector("a.btn.btn-login")
            login_btn.click()
            time.sleep(2)

            # 还原没有缺口的图片
            self.browser.execute_script('document.querySelectorAll("canvas")[3].style=""')
            # 截取验证码
            img1 = self.crop_image("cap1.png")
            # 显示有缺口的图片
            self.browser.execute_script('document.querySelectorAll("canvas")[3].style="display: none; opacity: 1;"')
            img2 = self.crop_image("cap2.png")

            # image1 = Image.open("cap1.png")
            # image2 = Image.open("cap2.png")

            # 拿到缺口图片的位置
            left = 60
            find = False
            # 60....width
            for i in range(60, img1.size[0]):
                if find:
                    break
                # j...height
                for j in range(img1.size[1]):
                    # 如果是True left = i
                    if self.compare_pixel(img1, img2, i, j):
                        left = i
                        find = True
                        break

            left -= 5
            print(left)

            # 滑动轨迹
            track = []
            # 当前位移
            current = 0
            # 减速阈值
            mid = left * 3 / 4
            # 间隔时间
            t = 0.1
            v = 0
            while current < left:
                if current < mid:
                    a = random.randint(2, 3)
                else:
                    a = - random.randint(6, 7)
                v0 = v
                # 当前速度
                v = v0 + a * t
                # 移动距离
                move = v0 * t + 1 / 2 * a * t * t
                # 当前位移
                current += move
                track.append(round(move))

            # 事件链去执行
            slider = self.browser.find_element_by_css_selector(".geetest_slider_button")
            ActionChains(self.browser).click_and_hold(slider).perform()
            for x in track:
                ActionChains(self.browser).move_by_offset(xoffset=x, yoffset=0).perform()

            time.sleep(0.5)
            ActionChains(self.browser).release().perform()
            time.sleep(5)

        # 保存cookie 下次直接登录,可以添加判断
        cookies = self.browser.get_cookies()
        print(cookies)
        cookie_dict = {}
        for cookie in cookies:
            cookie_dict[cookie['name']] = cookie['value']
        self.browser.close()
        return cookie_dict

    def check_ck(self, cookie_dict):
        pass


if __name__ == '__main__':
    import settings

    bb = BLoginService(settings)
    bb.login()

免费评分

参与人数 4吾爱币 +5 热心值 +3 收起 理由
FDSD + 1 我很赞同!
hj170520 + 2 + 1 我很赞同!
yuexx94 + 1 + 1 学习
20muou + 1 + 1 感谢分享

查看全部评分

发帖前要善用论坛搜索功能,那里可能会有你要找的答案或者已经有人发布过相同内容了,请勿重复发帖。

cxb2468 发表于 2021-7-26 16:37
新手  试了下 报错呀。 error.jpg
 楼主| QingYi. 发表于 2021-7-26 16:54
cxb2468 发表于 2021-7-26 16:37
新手  试了下 报错呀。

这是我写在一个文件里面的代码,拿到手之后要自己改一下。
hahaha123123 发表于 2021-7-28 14:26
只有午安 发表于 2021-11-16 10:40
本帖最后由 只有午安 于 2021-11-16 10:48 编辑

突然就看懂了,不过楼主这个不是bilibili的吧,
Jaybo 发表于 2021-11-16 10:54
谢谢分享
shengforever 发表于 2022-2-12 09:46
正好用到 赶紧看看下
您需要登录后才可以回帖 登录 | 注册[Register]

本版积分规则

返回列表

RSS订阅|小黑屋|处罚记录|联系我们|吾爱破解 - LCG - LSG ( 京ICP备16042023号 | 京公网安备 11010502030087号 )

GMT+8, 2024-11-25 07:34

Powered by Discuz!

Copyright © 2001-2020, Tencent Cloud.

快速回复 返回顶部 返回列表