云打码的简单使用举例

1.在云打码官网上下载"Python调用示例"

具体步骤如下:



2.下载完成后会发现代码中会用到appid,appkey,那么问题就来了,它们是什么?又是从哪里获得的呢?

appid:即为下图中的软件代码;appkey:即为下图中的通讯密钥.



3.利用云打码获取验证码并进行登录及验证验证码是否输入正确

大概流程:请求验证码网址(获取到验证码图片)->下载验证码到本地->获取验证码图片-->登录--->识别结果

下面附上完整代码:

#ydm.py

import json, time, requests

# 此文件是从云打码中下载的
class YDMHttp(object):

    apiurl = 'http://api.yundama.com/api.php'
    username = ''
    password = ''
    #开发者id
    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

# 此函数是自己写的
def shibie(file_name):
    # 普通用户的用户名和密码
    username = ''
    password = ''

    # # 开发者id和密钥
    appid = ''
    appkey = ''

    filename = file_name
    # 验证码类型
    codetype = ''
    timeout = 60

    # 检查
    if (username == 'username'):
        print('请设置好相关参数再测试')
    else:
        yundama = YDMHttp(username, password, appid, appkey)
        cid, result = yundama.decode(filename, codetype, timeout);
        return result


if __name__ == '__main__':
    # 普通用户的用户名和密码
    username = ''
    password = ''

    # 开发者id和密钥
    appid = ''
    appkey = ''

    filename = 'getimage.jpg'
    # 验证码类型
    codetype = ''
    timeout = 60

    # 检查
    if (username == 'username'):
        print('请设置好相关参数再测试')
    else:
        yundama = YDMHttp(username, password, appid, appkey)
        cid, result = yundama.decode(filename, codetype, timeout);
        print('cid: %s, result: %s' % (cid, result))

#yundama.py

import requests
from fake_useragent import UserAgent
from http.cookiejar import LWPCookieJar
from ydm import shibie


session = requests.Session()
session.cookies = LWPCookieJar(filename='ydm.txt')
# 其中参数ignore_discard=True表示即使cookies将被丢弃也把它保存下来,它还有另外一个参数igonre_expires表示当前数据覆盖(overwritten)原文件。
try:
    session.cookies.load('ydm.txt', ignore_discard=True, ignore_expires=True)
    print('本地cookie加载完成')
except Exception as e:
    print('')

ua = UserAgent()
headers = {
    'headers': ua.random,
}

#获取验证码图片


def get_captcha_image():
    content = session.get('http://www.yundama.com/index/captcha', headers=headers).content
    with open('captcha.jpg', 'wb') as f:
        f.write(content)

#登录


def login():
    get_captcha_image()

    # 验证码保存到本地以后,对验证码进行识别
    result = shibie('captcha.jpg')

    print('识别结果:', result)
    #获取开发者登陆时请求的url
    response = session.get('http://www.yundama.com/index/login?username='开发者账号'&password='开发者密码'&utype=1&vcode={}'.format(result))

    print(response.text)

    session.cookies.save(ignore_discard=True, ignore_expires=True)


def get_index():
    response = session.get('http://www.yundama.com/user')
    print(response.text)


if __name__ == '__main__':
    login()
    get_index()

那么问题来了?如何获取开发者登录时请求的url呢?

可以使用抓包工具抓取云打码登录时请求的url


4.运行yundama.pyde的结果如下


那么你如何得知结果:到底验证码输入是否正确呢?

你只需打开cmd.exe,按照下图操作即可




猜你喜欢

转载自blog.csdn.net/qq_38661599/article/details/80862175