基于打码平台的验证码破解思想

本文探讨了基于打码平台的验证码破解思路,详细介绍了利用人工智能和图像处理技术来识别复杂验证码的过程,包括预处理、特征提取和模式识别等关键步骤。
摘要由CSDN通过智能技术生成
from selenium import webdriver
from selenium.webdriver.common.by import By

from PIL import Image  #用于截取图片
from chaojiying import Chaojiying_Client #打码平台的包


driver = webdriver.Chrome()
url = 'https://www.chaojiying.com/user/login/'
driver.get(url)
# 截图整个网页
driver.get_screenshot_as_file('full_page.png')
# 定位验证码图片在页面的位置
img=driver.find_element(By.XPATH,'/html/body/div[3]/div/div[3]/div[1]/form/div/img')
# 验证码图片的坐标{'x': 666, 'y': 291}
location=img.location  #这里获得的只是验证码图片的左,上边界
# 要获取整个验证码那就要获取他的右边和下班的坐标才能行
# size的属性是heigh和width  {'height': 50, 'width': 180}
size=img.size

# 验证码的坐标(左,上,右,下)
left=location['x']
top=location['y']
right=location['x']+size['width']
bot=location['y']+size['height']
# 验证码图片的坐标
loc = (left,top,right,bot)
# 打开页面图片
page_pic=Image.open('full_page.png')
# 传入验证码图片的坐标,截取验证码图片
yzm_pic=page_pic.crop(loc)
# 保存
yzm_pic.save('yzm_pic.png')

# 下面是打码平台的使用基本上看平台
yz=Chaojiying_Client(username='账号',password='密码',soft_id='软件id')
pic=open('yzm_pic.png','rb').read()
result=yz.PostPic(pic,'1004')

# result的结果为:{'err_no': 0, 'err_str': 'OK',
# 'pic_id': '3108421574452100001',
# 'pic_str': 'rgpm', 'md5': '3228b6828090fd1dde4817fd0d607374'}
print(result['pic_str'])

#基本思想
# 1截图整个页面
# 2定位验证码图片的位置四个角的坐标
# 3从整个页面中截取出验证码图片
# 交给打码平台输出结果
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值