欢迎来到思维库

思维库

Python学习之如何使用云打码平台识别验证码?

时间:2025-11-04 19:27:00 出处:域名阅读(143)

  相关的学习门户网站在进行登录的时候,如果用户连续登录的何证码次数超过3次或者5次的时候,就会在登录页中动态生成验证码。使用通过验证码达到分流和反爬的云打效果。

  云打码平台处理验证码的码平实现流程:

Python学习之如何使用云打码平台识别验证码?

  1.对携带验证码的页面数据进行抓取

  2.可以将页面数据中验证码进行解析,验证码图片下载到本地

  3.可以将验证码图片提交给三方平台进行识别,台识返回验证码图片上的别验数据值

  云打码平台:

  1.在官网中进行注册(普通用户和开发者用户)

  2.登录开发者用户:

  1.实例代码的下载(开发文档-》调用实例及最新的DLL-》PythonHTTP实例下载)

  2.创建一个软件:我的软件-》添加新的b2b信息网软件

  3.使用示例代码中的源码文件中的代码进行修改,让其识别验证码图片中的学习数据值

  代码展示:

#该函数就调用了打码平台的相关的接口对指定的验证码图片进行识别,返回图片上的何证码数据值 def getCode(codeImg): # 云打码平台普通用户的用户名 username = bobo328410948 # 云打码平台普通用户的密码 password = bobo328410948 # 软件ID,开发者分成必要参数。使用登录开发者后台【我的云打软件】获得! appid = 6003 # 软件密钥,码平开发者分成必要参数。亿华云计算台识登录开发者后台【我的别验软件】获得! appkey = 1f4b564483ae5c907a1d34f8e2f2776c # 验证码图片文件 filename = codeImg # 验证码类型,学习# 例:1004表示4位字母数字,不同类型收费不同。请准确填写,否则影响识别率。在此查询所有类型 http://www.yundama.com/price.html codetype = 3000 # 超时时间,秒 timeout = 20 # 检查 if (username == username): print(请设置好相关参数再测试) else: # 初始化 yundama = YDMHttp(username, password, appid, appkey) # 登陆云打码 uid = yundama.login(); print(uid: %s % uid) # 查询余额 balance = yundama.balance(); print(balance: %s % balance) # 开始识别,图片路径,验证码类型ID,超时时间(秒),识别结果 cid, result = yundama.decode(filename, codetype, timeout); print(cid: %s, result: %s % (cid, result)) return result import requests from lxml import etree import json import time import re #1.对携带验证码的页面数据进行抓取 url = https://www.douban.com/accounts/login?source=movie headers = { User-Agent: Mozilla/5.0 (Linux; Android 6.0; Nexus 5 Build/MRA58N) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/70.0.3538.77 Mobile Safari/537.36 } page_text = requests.get(url=url,headers=headers).text #2.可以将页面数据中验证码进行解析,验证码图片下载到本地 tree = etree.HTML(page_text) codeImg_url = tree.xpath(//*[@id="captcha_image"]/@src)[0] #获取了验证码图片对应的二进制数据值 code_img = requests.get(url=codeImg_url,headers=headers).content #获取capture_id <img id="captcha_image" src="https://www.douban.com/misc/captcha?id=AdC4WXGyiRuVJrP9q15mqIrt:en&amp;size=s" alt="captcha" class="captcha_image"> c_id = re.findall(<img id="captcha_image".*?id=(.*?)&amp.*?>,page_text,re.S)[0] with open(./code.png,wb) as fp: fp.write(code_img) #获得了验证码图片上面的数据值 codeText = getCode(./code.png) print(codeText) #进行登录操作 post = https://accounts.douban.com/login data = { "source": "movie", "redir": "https://movie.douban.com/", "form_email": "15027900535", "form_password": "bobo@15027900535", "captcha-solution":codeText, "captcha-id":c_id, "login": "登录", } print(c_id) login_text = requests.post(url=post,data=data,headers=headers).text with open(./login.html,w,encoding=utf-8) as fp: fp.write(login_text)

b2b供应网

分享到:

温馨提示:以上内容和图片整理于网络,仅供参考,希望对您有帮助!如有侵权行为请联系删除!

友情链接: