selenium 超级鹰 通过携程滑块和汉字验证码

这篇具有很好参考价值的文章主要介绍了selenium 超级鹰 通过携程滑块和汉字验证码。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

超级鹰验证码识别,selenium,python

大概流程

1、进入页面点击同意按钮。
2、得到滑块和滑块区域的xpath
3、定位滑块,设置按住事件,进行拖动
4、xpath定位汉字图片,获取屏幕截图,保存本地
5、超级鹰识别图片返回汉字对应的坐标,移动至坐标位置进行点击。需注意selenium 4.3版本在移动坐标时有问题,建议使用4.0版本。
关于selenium 和超级鹰的用法不做详细步骤。文章来源地址https://www.toymoban.com/news/detail-739631.html

工具版本

selenium  4.0.0
谷歌浏览器和驱动版本   111.0.5563.111

代码记录

# coding = utf-8
import time
from selenium import webdriver
from selenium.webdriver.common.by import By
from selenium.webdriver.common.action_chains import ActionChains
from app.Chaojiying_Python.chaojiying import Chaojiying_Client
from selenium.webdriver.support.ui import WebDriverWait

USERNAME = 'xxxxxxxx'
PASSWORD = 'xxxxxxxx'
SOFTID = xxxxx
class XieCheng:
    def __init__(self):
        # 打开chrome浏览器
        self.d = webdriver.Chrome()
        self.chaojiying = Chaojiying_Client(USERNAME, PASSWORD,SOFTID)
        self.wait = WebDriverWait(self.d,20)
        self.action = ActionChains(self.d)  # 创建动作链对象
        self.d.maximize_window()
        self.d.implicitly_wait(10)
        self.action = ActionChains(self.d)
        self.url = 'https://passport.ctrip.com/user/reg/home'
    def open_url(self):
        # 打开携程网注册页面
        self.d.get(self.url)
        # 点击同意并继续
        self.d.find_element(By.XPATH, '//div[@class="pop_footer"]/a[@class="reg_btn reg_agree"]').click()
        # 定位到滑块按钮元素
        ele_button = self.d.find_element(By.XPATH, '//*[@id="slideCode"]/div[1]/div[2]')
        # 打印滑块按钮的宽和高
        print('滑块按钮的宽:', ele_button.size['width'])
        print('滑块按钮的高:', ele_button.size['height'])
        # 定位到滑块区域元素
        ele = self.d.find_element(By.XPATH, '//div[@class="cpt-bg-bar"]')
        # 打印滑块区域的宽和高
        print('滑块区域的宽:', ele.size['width'])
        print('滑块区域的高:', ele.size['height'])
        # 按住滑块不动
        self.action.click_and_hold(ele_button).perform()
        # 拖动滑块
        self.action.drag_and_drop_by_offset(ele_button, ele.size['width'], ele.size['height']).perform()
        # action.move_by_offset(xoffset=ele.size['width'], yoffset=0).perform()


    def downloadimg(self):

        img_element = self.d.find_element(By.XPATH,'//*[@id="slideCode-choose"]/div[2]')
        img_element.screenshot('img.png')
        return img_element

    def get_position(self):
        img_element = self.downloadimg()
        im = open('img.png', 'rb').read()  # 以二进制的方式读取验证码
        result = self.chaojiying.PostPic(im, 9005)['pic_str']  # 9005获取验证码3-5坐标字典,并取出坐标值
        print(result)
        for index in result.split('|'):  # 以"|"进行分割,得到一个列表,并循环出每一个字的坐标
            x = index.split(',')[0]  # 得到x轴的坐标
            y = index.split(',')[1]  # 得到y轴的坐标
            print(x,y)

            self.action.move_to_element_with_offset(img_element, int(x), int(y)).click().perform()
            # image:验证码的元素框;x:验证码的横轴;y:验证码的纵轴
        time.sleep(1)
        self.d.find_element(By.XPATH,'//*[@id="slideCode-choose"]/div[2]/div[4]/a').click()



if __name__ == '__main__':
    api = XieCheng()
    api.open_url()
    api.get_position()

到了这里,关于selenium 超级鹰 通过携程滑块和汉字验证码的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • selenium处理各类滑块验证码

    这种只要用鼠标点击并移动指定距离就可以完成验证(x轴) 这种是点击滑块会弹出白色方块和暗灰色方块,只要将白色方块移动覆盖暗灰色方块便能通过,白色方块是一张图片,暗灰色方块是通过style样式设计的,我们可以根据它们之间style的left计算差异值从而得到滑块滑动

    2024年02月16日
    浏览(51)
  • 使用opencv识别滑块验证

    对于某些简单的滑块,无需进行模型训练,可以使用opencv就能识别,比如: 有一种常用方法cv2.matchTemplate,可以将滑动的图案与背景图案进行模板匹配,这种方法适用于滑动图案与背景图片中目标位置有相同图案的情况。 但是本文想介绍的是另一种:背景中目标位置是空白的

    2024年03月10日
    浏览(38)
  • python+selenium尝试处理滑块验证

     效果如图:   处理思路: 1.打开滑动验证页面,这个用selenium一步一步走过去 2.将滑动验证码的整个图片保存下来 3.对图片的像素点进行分析,发现拼图处像素特征如下:   1).阴影起点处rgb的第一个值为0   2).阴影处的rgb三个值相加大部分小于某个临界值(minPix=400)   3).拼图阴影大

    2024年02月15日
    浏览(47)
  • 使用selenium解决滑块验证的问题

    使用自动化测试时有些网站会使用滑块来阻止,所以如何解决滑块问题已经成为自动化测试不可或缺的,今天以网易易盾网站的滑块举例:https://dun.163.com/trial/sense 要解决滑块问题的关键就是匹配滑块在背景图中的位置所以使用python中的numpy库来实现获取滑块在背景的坐标,获

    2024年02月12日
    浏览(34)
  • 用Selenium实现滑块验证码登录

    现在很多网站的登录,都采用了拖动图片滑块的验证码方式来进行验证登录,比如哔哩哔哩和京东等。在使用爬虫等自动化程序时,如何通过滑块验证,就成了需要解决的问题。 这里通过大名鼎鼎的ddddocr图片识别库,和模拟浏览器操作的selenium库来实现 安装浏览器driver 首先

    2024年01月22日
    浏览(40)
  • 使用selenium模拟登录解决滑块验证问题

    目录 1.登录入口 2.点击“账号密码登录” 3.输入账号、密码并点击登录 4.滑块验证过程 5.小结 本次主要是使用selenium模拟登录网页端的TX新闻,本来最开始是模拟请求的,但是某一天突然发现,部分账号需要经过滑块验证才能正常登录,如果还是模拟请求,需要的参数太多了

    2024年02月16日
    浏览(39)
  • selenium+opencv实现模拟登陆(滑块验证码)

    很多网站登录登陆时都要用到滑块验证码,在某些场景例如使用爬虫爬取信息时常常受到阻碍,想着用opencv的模板匹配试试能不能实现模拟登陆。本来觉得网上资料多应该还蛮容易,但实际上手还是搞了蛮久,在这里记录一下整个流程,网站无所谓主要是要有滑动验证码:

    2023年04月14日
    浏览(39)
  • OpenCV滑块验证码图像缺口位置识别

    在使用Selenium完成自动化爬虫时,许多网站为了防止机器人爬取数据会使用验证码(例如滑块验证码)。通过Selenium动作操作,爬虫可以模拟用户输入验证码或使用鼠标移动一定距离来处理验证码验证过程 完成这一流程的关键步骤有两步:识别出目标图像缺口的位置,操作滑

    2024年02月03日
    浏览(46)
  • python+selenium绕过滑块验证,实现自动登录

    实现taobao自动化登录,当用webdriver打开淘宝时,滑块验证一直失败,手动滑都会失败。因为淘宝会检测window.navigator.webdriver,控件检测到你是selenium进入,所以就会弹出滑块验证。只需要绕过检测就能实现自动登录 验证了两种方法可以跳过: 第一种是给浏览器加启动参数,开

    2024年02月12日
    浏览(48)
  • Python如何解决“滑块验证码”登录识别(3)

    前言 本文是该专栏的第24篇,后面会持续分享python的干货知识,记得关注。 做爬虫项目的时候,总是会遇到我们的冤家老朋友——验证码(图文验证码,点选验证码,滑块验证码)等。前面我有介绍过图文验证码和点选验证码,针对验证码这块, 后面我会持续更新这些 验证码

    2023年04月08日
    浏览(36)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包