当前位置: 首页 > article >正文

登录163邮箱的滑块验证

登录163邮箱的滑块验证

登录163网易邮箱取数功能,查阅了很多博客的代码都不太稳定或者已失效,下面是经过修改的一个方案,成功率大概在90%以上

def get_verify(self, name='处理滑块移动'):
    max_distance = self.handle_picture()
    reality_distance = int((max_distance - 64) / 1.45)
    sleep(0.5)
    track_list = self.handle_tracks(reality_distance)
    # 获取滑块元素
    slider_handle = self.driver.find_element(By.XPATH, '//*[@class="yidun_slider"]')
    ActionChains(self.driver).click_and_hold(slider_handle).perform()
    for i in track_list:
        ActionChains(self.driver).move_by_offset(i, 0).perform()
    sleep(1)
    ActionChains(self.driver).release().perform()
  
def handle_picture(self):
    bg_img = re.findall(r'alt="验证码背景".*?src="(.*?)"', self.driver.page_source)[0]
    hk_img = re.findall(r'alt="验证码滑块".*?src="(.*?)"', self.driver.page_source)[0]
    with open('./bg_img.jpg', 'wb') as f:
        f.write(requests.get(bg_img).content)
        f.close()
    with open('./hk_img.png', 'wb') as f:
        f.write(requests.get(hk_img).content)
        f.close()
    # 读取背景图片和缺口图片
    bg_img = cv2.imread('./bg_img.jpg')  # 背景图片
    tp_img = cv2.imread('./hk_img.png')  # 缺口图片
    # 识别图片边缘
    bg_edge = cv2.Canny(bg_img, 100, 200)
    tp_edge = cv2.Canny(tp_img, 100, 200)
    # 转换图片格式
    bg_pic = cv2.cvtColor(bg_edge, cv2.COLOR_GRAY2RGB)
    tp_pic = cv2.cvtColor(tp_edge, cv2.COLOR_GRAY2RGB)
    # 缺口匹配
    res = cv2.matchTemplate(bg_pic, tp_pic, cv2.TM_CCOEFF_NORMED)
    min_val, max_val, min_loc, max_loc = cv2.minMaxLoc(res)  # 寻找最优匹配
    x = max_loc[0]  # 滑块在验证图片的x坐标(左边)
    # 绘制方框
    th, tw = tp_pic.shape[:2]
    tl = max_loc  # 左上角点的坐标
    br = (tl[0] + tw, tl[1] + th)  # 右下角点的坐标
    cv2.rectangle(bg_img, tl, br, (0, 0, 255), 2)  # 绘制矩形
    # cv2.imwrite(r'C:\test\out.jpg', bg_img)  # 保存在本地
    return int(br[0])
 
@staticmethod
def handle_tracks(distance):
    t = 0.1
    speed = 0
    current = 0
    mid = 3 / 5 * distance
    track_list = []
    while current < distance:
        if current < mid:
            # a = random.choice([1, 2, 3])
            a = 3
        else:
            # a = random.choice([-1, -2, -3])
            a = -4
        move_track = speed * t + 0.5 * a * t ** 2
        track_list.append(round(move_track))
        speed = speed + a * t
        current += move_track
    # 模拟人类来回移动了一小段
    end_track = [1, 0] * 10 + [0] * 10 + [-1, 0] * 10
    track_list.extend(end_track)
    offset = sum(track_list) - distance
    # 由于四舍五入带来的误差,这里需要补回来
    if offset > 0:
        track_list.extend(offset * [-1, 0])
    elif offset < 0:
        track_list.extend(offset * [1, 0])
    return track_list

http://www.kler.cn/news/364126.html

相关文章:

  • ruoyi域名跳转缓存冲突问题(解决办法修改:session名修改session的JSESSIONID名称)
  • 附录章节:SQL标准与方言对比
  • NVIDIA Jetson支持的神经网络加速的量化平台
  • STM32之OLED驱动函数
  • 什么是虚拟线程?Java 中虚拟线程的介绍与案例演示
  • CSS 网格布局
  • SQL实战测试
  • 【STM32 ADC】
  • 华为云容器引擎(CCE):赋能企业云原生转型
  • OpenHarmony镜像烧录bat脚本工具
  • 【Linux】-学习笔记01
  • A survey of loss functions for semantic segmentation——论文笔记
  • TCP 攻击为何在 DDoS 攻击中如此常见
  • SQL注入-联合查询
  • 通知服务刷新本地缓存的实现方案
  • sql-labs靶场第二十一关测试报告
  • 【ChatGPT】如何通过实例提升 ChatGPT 的回答质量
  • 技术成神之路:设计模式(二十三)解释器模式
  • 介绍 TensorFlow 的基本概念和使用场景(AI生成仅供参考)
  • 读数据工程之道:设计和构建健壮的数据系统19数据存储系统 (下)
  • 基于neo4j的疫情信息管理系统
  • 【WebSocket实战】——创建项目初始架构
  • Linux 设备树在 i.MX6U 上的应用与详解
  • 基于 Python 的自然语言处理系列(43):Question Answering
  • 架构设计(17)大数据框架Hadoop与基础架构CDH
  • 又是一年 1024