自动化验证码实现

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()
相关推荐
Dola_Zou6 分钟前
工业软件安全架构向模块化授权演进的解析
安全·自动化·安全架构·软件加密
ccchen8884 小时前
适配帝国CMS 8.0:全新帝国CMS免登录采集发布插件
经验分享·爬虫·php·帝国cms自动采集发布插件·帝国cms8.0·帝国cms自动采集插件·帝国cms采集发布模块
小鸡吃米…4 小时前
Python 网络爬虫 —— 环境设置
开发语言·爬虫·python
一水鉴天5 小时前
整体设计 定稿 的 整理 和完成20260320 之2:文档解析辅助工具编码实现手册 (豆包助手)
人工智能·架构·自动化
嫂子的姐夫5 小时前
041-全扣补环境:同花顺
爬虫·python·js逆向·逆向
爱写bug的野原新之助6 小时前
爬虫之补环境:加载原型链
前端·javascript·爬虫
海边的梦6 小时前
爬虫对抗:ZLibrary反爬机制实战分析 技术文章大纲
爬虫
进击的雷神6 小时前
主办方过滤、展位号模糊提取、多层级官网爬取、缅文编码解码——缅甸塑料展爬虫四大技术难关攻克纪实
网络·爬虫·python
core5126 小时前
多源车辆数据打通实战指南:从12123接口、爬虫获取电动自行车车辆信息到备案数据推送六合一平台
爬虫·电动自行车·12123·车辆信息·六合一·备案数据
芯跳加速6 小时前
AI 视频自动化学习日记 · 第三天
人工智能·学习·ai·自动化·音视频