php 云打码返回值,云打码示例

验证码处理:

- 1.手动识别验证码

- 2.云打码平台自动识别验证码

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

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

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

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

- 云打码平台:

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

- 2.登录开发者用户:

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

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

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

云打码普通用户

#该函数就调用了打码平台的相关的接口对指定的验证码图片进行识别,返回图片上的数据值

def getCode(codeImg):

# 云打码平台普通用户的用户名

username = '用户'

# 云打码平台普通用户的密码

password = '密码'

# 软件ID,开发者分成必要参数。登录开发者后台【我的软件】获得!

appid = 6003

# 软件密钥,开发者分成必要参数。登录开发者后台【我的软件】获得!

appkey = 'xxxxxxxxxxx'

# 验证码图片文件

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

'captcha'

c_id = re.findall('',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": "用户名",

"form_password": "用户密码",

"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)

登录功能代码自己示例

import request

from lxml import etree

import json

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

url='https://epass.icbc.com.cn/regist/regist_index.jsp?StructCode=1'

agent = 'Mozilla/5.0 (Macintosh; Intel Mac OS X 10_12_0) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/69.0.3497.100 Safari/537.36'

headers = {

'User-Agent': agent,

}

proxy={

"http":"121.8.98.196:80",

}

page_text = request.get(url=url,proxies=proxy,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

# 获取captcha-id

'captcha'

c_id = re.findall('',page_text,re.S)[0] # 获取img中id的值

with open('./code.png', 'wb') as fp:

fp.write(code_img)

# 获得了验证码图片上面的数据值

codeText = getCode('./code.png')

# 进行登录操作

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':'登录',

}

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)

云打码py3

class YDMHttp:

apiurl = 'http://api.yundama.com/api.php'

username = ''

password = ''

appid = ''

appkey = ''

def __init__(self, username, password, appid, appkey):

self.username = username

self.password = password

self.appid = str(appid)

self.appkey = appkey

def request(self, fields, files=[]):

response = self.post_url(self.apiurl, fields, files)

response = json.loads(response)

return response

def balance(self):

data = {'method': 'balance', 'username': self.username, 'password': self.password, 'appid': self.appid, 'appkey': self.appkey}

response = self.request(data)

if (response):

if (response['ret'] and response['ret'] < 0):

return response['ret']

else:

return response['balance']

else:

return -9001

def login(self):

data = {'method': 'login', 'username': self.username, 'password': self.password, 'appid': self.appid, 'appkey': self.appkey}

response = self.request(data)

if (response):

if (response['ret'] and response['ret'] < 0):

return response['ret']

else:

return response['uid']

else:

return -9001

def upload(self, filename, codetype, timeout):

data = {'method': 'upload', 'username': self.username, 'password': self.password, 'appid': self.appid, 'appkey': self.appkey, 'codetype': str(codetype), 'timeout': str(timeout)}

file = {'file': filename}

response = self.request(data, file)

if (response):

if (response['ret'] and response['ret'] < 0):

return response['ret']

else:

return response['cid']

else:

return -9001

def result(self, cid):

data = {'method': 'result', 'username': self.username, 'password': self.password, 'appid': self.appid, 'appkey': self.appkey, 'cid': str(cid)}

response = self.request(data)

return response and response['text'] or ''

def decode(self, filename, codetype, timeout):

cid = self.upload(filename, codetype, timeout)

if (cid > 0):

for i in range(0, timeout):

result = self.result(cid)

if (result != ''):

return cid, result

else:

time.sleep(1)

return -3003, ''

else:

return cid, ''

def report(self, cid):

data = {'method': 'report', 'username': self.username, 'password': self.password, 'appid': self.appid, 'appkey': self.appkey, 'cid': str(cid), 'flag': '0'}

response = self.request(data)

if (response):

return response['ret']

else:

return -9001

def post_url(self, url, fields, files=[]):

for key in files:

files[key] = open(files[key], 'rb');

res = requests.post(url, files=files, data=fields)

return res.text

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值