自动化验证码实现

1,字符型验证码

python 复制代码
from DrissionPage._pages.chromium_page import ChromiumPage

from ku.chaojiying.chaojiying import Chaojiying_Client

#创建浏览器对象

#这两行代码是谷歌浏览器
page=ChromiumPage()
page.get('链接')
user=page.ele('@name=user')
passw=page.ele('@name=pass')
passw=page.ele('@name=pass')
img=page.ele('@src=/include/code/code.php?u=1')
#保存图片
#img.save(path='图片',name='1.png')
chaojiying = Chaojiying_Client('', '', '')  # 用户中心>>软件ID 生成一个替换 96001
#保存图片后要打开图片
#im = open('图片/1.png', 'rb').read()  # 本地图片文件路径 来替换 a.jpg 有时WIN系统须要//

im=img.src()
str=chaojiying.PostPic(im, 1902)['pic_str']
imgtxt=page.ele('@name=imgtxt')

user.input('ycydynq')
passw.input('123456')
imgtxt.input(str)
button = page.ele('.login_form_input_submit')
button.click()

2、点击类型验证码

python 复制代码
import os
import re

from DrissionPage._configs.chromium_options import ChromiumOptions
from DrissionPage._functions.keys import Keys
from DrissionPage._pages.chromium_page import ChromiumPage

from ku.chaojiying.chaojiying import Chaojiying_Client
from  PIL import  Image
'''
点选型验证码     发给超级鹰的内容:图片+答案
调用超级㢈方法传入的是一个 字节数据,字节数据(图片数据),需要使用截图的方式保存一张图片(识别的图片+答案)
'''
#创建浏览器对象

#这两行代码是谷歌浏览器
page=ChromiumPage()
dir_name='图片'
if not os.path.exists(dir_name):
    os.mkdir(dir_name)
page.get('链接')
page.ele('.header-login-entry').click()
page.ele('@placeholder=请输入账号').input('aaaa')
page.ele('@placeholder=请输入密码').input('aaaa')
page.ele('.btn_primary ').click()

page.wait(2,3)
while True:
    geetest_widget=page.ele('.geetest_widget')

    geetest_widget.get_screenshot(path='图片',name="3.png")
    page.wait(2)
    img=Image.open('图片/3.png')
    img=img.resize((318,408))
    img.save('图片/3.png')



    # 进行验证码验证
    chaojiying = Chaojiying_Client('', '', '')  # 用户中心>>软件ID 生成一个替换 96001
    # 保存图片后要打开图片
    im = open('图片/3.png', 'rb').read()  # 本地图片文件路径 来替换 a.jpg 有时WIN系统须要//

    res = chaojiying.PostPic(im, 9004)
    print(res)
    pos=res['pic_str']
    posarr=pos.split('|')
    for poss in posarr:
        xy=poss.split(',')
        x=int(xy[0])
        y=int(xy[1])

        page.actions.move_to(geetest_widget, x, y).click()
    page.wait(2)
    page.ele('.geetest_commit_tip').click()
    page.wait(1)
    geetest_panel_next=page.ele('.geetest_panel_next')
    #print(geetest_panel_next)
    #通过style属性值为display:none   结束循环
    if geetest_panel_next.attr('style') == 'display: none;':
        print('验证成功')
        break
    # #print(geetest_widget)

    #通过字符串中 是否有验证成功  来判断是否要结束循环
    # str_jeguo=page.ele(geetest_widget).text
    # #print(str_jeguo)
    # if  '成功'  in str_jeguo:
    #     print('验证成功')
    #
    # jieguo=re.findall('验证成功',str_jeguo)
    # if  jieguo:
    #     print('验证成功')
    # else:
    #     print('验证不成功')

3、滑块验证码

python 复制代码
import os

from DrissionPage._elements.chromium_element import ChromiumElement
from DrissionPage._functions.keys import Keys
from DrissionPage._pages.chromium_page import ChromiumPage
from PIL import Image

from ku.chaojiying.chaojiying import Chaojiying_Client

page=ChromiumPage()
page.get('链接')

page.ele('.wx-des').click()
page.ele('.account-title-item password-item').click()
page.ele('@placeholder=手机号(无需区号)/帐号').input('15895144996')
page.ele('@placeholder=请输入密码').input('123456')
page.wait(1)
page.ele('.ss-checkbox__original').click()
page.ele('@data-sensors=登录_登录页_点击登录').click()
page.wait(5)
dir_name='图片'
if not os.path.exists(dir_name):
    os.mkdir(dir_name)

#print(page.html)         获取网页源代码

#当前滑块是由iframe标签组成
#page对象无法获取iframe标签内的内容
#先得到内置页面对象
iframe=page.get_frame('#tcaptcha_iframe_dy')
#如果需要获取iframe下的所有内容,都要通过iframme获取


tcImgArea=iframe.ele('#slideBg')
iframe.get_screenshot(path='图片',name='小鹅通.png')
img=Image.open('图片/小鹅通.png')
img=img.resize((360,360))
img.save('图片/小鹅通.png')

# 进行验证码验证
chaojiying = Chaojiying_Client('', '', '')  # 用户中心>>软件ID 生成一个替换 96001
# 保存图片后要打开图片
with open('图片/小鹅通.png', 'rb') as f:  # 本地图片文件路径 来替换 a.jpg 有时WIN系统须要//
    im=f.read()
res = chaojiying.PostPic(im, 9101)
print(res)
xy=res['pic_str'].split(',')
x=int(xy[0])

#要移动的x值
x=x-32-30        #下拉到左边的距离32   滑块图长60.714     除以2   30



#滑块实现
'''
1、按住滑块标签不动
2、移动x的值
3、松开
'''
ac=iframe.actions
ac.hold('.tc-fg-item tc-slider-normal')
ac.move(offset_x=x)
ac.release()


#关闭浏览器
#page.quit()
相关推荐
专注API从业者9 小时前
淘宝商品详情 API 与爬虫技术的边界:合法接入与反爬策略的技术博弈
大数据·数据结构·数据库·爬虫
Agent产品评测局10 小时前
企业数据处理自动化落地,抓取分析全流程实现方案 —— 2026企业级智能体选型与技术路径深度解析
运维·人工智能·ai·自动化
牛奶咖啡1310 小时前
DevOps自动化运维实践_ansible-playbook的应用
自动化·云计算·ansible·devops·playbook·playbook的常见使用示例·playbook变量主机命令
Gofarlic_OMS10 小时前
装备制造企业Fluent许可证成本分点典型案例
java·大数据·开发语言·人工智能·自动化·制造
北京耐用通信11 小时前
无缝衔接·高效传输——耐达讯自动化CC-Link IE转Modbus TCP核心解决方案
网络·人工智能·物联网·网络协议·自动化·信息与通信
Agent产品评测局11 小时前
互联网行业自动化平台选型,运营全流程提效指南:2026企业级智能体架构与实战全解析
运维·人工智能·ai·chatgpt·架构·自动化
ZC跨境爬虫11 小时前
Scrapy工作空间搭建与目录结构解析:从初始化到基础配置全流程
前端·爬虫·python·scrapy·自动化
深蓝电商API12 小时前
分布式爬虫在海淘数据采集中的应用
爬虫·反向海淘
小白学大数据12 小时前
Scrapy 分布式爬虫:大规模采集汽车之家电车评论
开发语言·分布式·爬虫·scrapy
三思守心12 小时前
从 0 到 1 搭建自动化内容工厂:深度测评楼兰AI及其在全平台发帖中的表现
运维·服务器·自动化