python selenium自动化登录之验证码识别
创始人
2025-05-29 12:40:18
0

1.通过定位元素截取图片的方法进行识别

#ocr识别原理:先根据验证码的class dl_yzm定位到验证码图片,然后将验证码截图保存,再使用ocr进行识别,读取出来验证码,填充到yzm_text中(使用IE浏览器不可用)

driver.find_element(By.CLASS_NAME, "dl_yzm").click()

yzmImage=driver.find_element(By.XPATH,"/html/body/div[@class='login_bg']/div[@class='login_main']/div[@class='login_box']/p[4]/span[@class='dl_yzm']/img/@src")#验证码图片

yzmImage.screenshot("yzm.png")#验证码截图,存为yzm.png

ocr=ddddocr.DdddOcr()(show_ad=False)

with open("yzm.png","rb") as fp:

image=fp.read()

catch=ocr.classification(image)#验证码返回给catch

print(catch)

driver.find_element(By.ID,"yzm_text").send_keys(catch)#将ocr识别出的验证码填到yzm_text

2.#另外一种办法通过坐标的方式截取验证码图片并识别

#截取当前页面

driver.save_screenshot('web_screen.png')

page_snap_obj=Image.open('web_screen.png')

#定位验证码

yzm=driver.find_element(By.CLASS_NAME,"dl_yzm")

location=yzm.location

size=yzm.size

left=location['x']

top=location['y']

right=left+size['width']

bottom=top+size['height']

yzm_obj=page_snap_obj.crop((left,top,right,bottom))

#保存截取的验证码图片,并识别验证码内容

yzm_obj.save('yzm.png')

ocr=ddddocr.DdddOcr(show_ad=False)

with open('yzm.png','rb') as fp:

img=fp.read()

catch=ocr.classification(img)

driver.find_element(By.ID, "yzm_text").send_keys(catch) # 将ocr识别出的验证码填到yzm_text

相关内容

热门资讯

AWSECS:访问外部网络时出... 如果您在AWS ECS中部署了应用程序,并且该应用程序需要访问外部网络,但是无法正常访问,可能是因为...
AWSElasticBeans... 在Dockerfile中手动配置nginx反向代理。例如,在Dockerfile中添加以下代码:FR...
银河麒麟V10SP1高级服务器... 银河麒麟高级服务器操作系统简介: 银河麒麟高级服务器操作系统V10是针对企业级关键业务...
北信源内网安全管理卸载 北信源内网安全管理是一款网络安全管理软件,主要用于保护内网安全。在日常使用过程中,卸载该软件是一种常...
AWR报告解读 WORKLOAD REPOSITORY PDB report (PDB snapshots) AW...
AWS管理控制台菜单和权限 要在AWS管理控制台中创建菜单和权限,您可以使用AWS Identity and Access Ma...
​ToDesk 远程工具安装及... 目录 前言 ToDesk 优势 ToDesk 下载安装 ToDesk 功能展示 文件传输 设备链接 ...
群晖外网访问终极解决方法:IP... 写在前面的话 受够了群晖的quickconnet的小水管了,急需一个新的解决方法&#x...
不能访问光猫的的管理页面 光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...
Azure构建流程(Power... 这可能是由于配置错误导致的问题。请检查构建流程任务中的“发布构建制品”步骤,确保正确配置了“Arti...