python爬虫之处理验证码

云打码实现处理验证码

处理验证码,我们需要借助第三方平台来帮我们处理,个人认为云打码处理验证码的准确度还是可以的

首先第一步,我们得先注册一个云打码的账号,普通用户和开发者用户都需要注册一下

然后登陆普通用户,登陆之后的界面是这样的,

你需要有几分才可以使用它.

第二步登陆开发者用户:

然后点击开发文档

进入之后点击下载python相关的模块

下载之后我们解压之后发现是里面有三个文件:

这里以python3的代码为例:

import http.client, mimetypes, urllib, json, time, requests

######################################################################

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

######################################################################

# 用户名
username    = ‘username‘

# 密码
password    = ‘password‘                            

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

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

# 图片文件
filename    = ‘getimage.jpg‘                        

# 验证码类型,# 例:1004表示4位字母数字,不同类型收费不同。请准确填写,否则影响识别率。在此查询所有类型 http://www.yundama.com/price.html
codetype    = 1004

# 超时时间,秒
timeout     = 60                                    

# 检查
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))

######################################################################

原装代码

  

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

  

#该函数就调用了打码平台的相关的接口对指定的验证码图片进行识别,返回图片上的数据值
def getCode(codeImg):
    # 云打码平台普通用户的用户名
    username    = ‘baijinshuo‘

    # 云打码平台普通用户的密码
    password    = ‘bjs146531‘                            

    # 软件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&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)

  

原文地址:https://www.cnblogs.com/wqzn/p/10458726.html

时间: 2024-11-06 07:12:21

python爬虫之处理验证码的相关文章

python爬虫中图形验证码的处理

使用python爬虫自动登录时,遇到需要输入图形验证码的情况,一个比较简单的处理方法是使用打码平台识别验证码. 使用过两个打码平台,打码兔和若快,若快的价格更便宜,识别率相当.若快需要注册两个帐号:开发者帐号与用户帐号,用户帐号用于发送识别请求,开发者帐号可以注册软件id,并于识别请求进行绑定,可以参与识别收入的分成返现. 获取图形验证码目前发现的有两种方式: 0x01 在抓包中可以直接获得图片:发送get请求可以直接获取图片(png或jpg格式),这种情况可以使用request.get()返回

python爬虫之获取验证码登陆

#--coding:utf-8#author:wuhao##这里我演示的就是本人所在学校的教育系统#import urllib.requestimport urllib.parseimport reimport shutilimport http.cookiejar class LoginJust(): def __init__(self,url,url1,url2,header,account,pwd): self.url=url self.url1=url1 self.url2=url2 s

python爬虫解决手机验证码问题

一.安卓手机安装tasker软件增强工具 官网:https://tasker.joaoapps.com/ 网上也有中文版的,自行搜索 1.打开tasker界面,点击右下加号 2.点击配置文件类型,选择事件 3.选择事件类型,点击电话 4.点击收到短信 5.在发件人和内容中填写过滤条件,比如:10086发来的,内容是验证码,然后直接点击左上角的返回按钮自动保存 6.然后新建任务,给任务起一个名字保存 7.选择操作类别网络 8.选择http post方法 9.主要填写服务器ip和port,路径就是你

python爬虫scrapy框架——人工识别登录知乎倒立文字验证码和数字英文验证码(2)

操作环境:python3 在上一文中python爬虫scrapy框架--人工识别登录知乎倒立文字验证码和数字英文验证码(1)我们已经介绍了用Requests库来登录知乎,本文如果看不懂可以先看之前的文章便于理解 本文将介绍如何用scrapy来登录知乎. 不多说,直接上代码: import scrapy import re import json class ZhihuSpider(scrapy.Spider): name = 'zhihu' allowed_domains = ['www.zhi

Python爬虫验证码一键式自动识别、免费短信接收、包含一些转码、解密、时间戳转换

验证码一键式自动识别.免费短信接收.包含一些转码.解密.时间戳转换.IP查询.HASH.自动解密等功能, 喜欢就 star 以表支持 下载 Python爬虫代码下载 声明 此项目以研究学习.减轻测试量为目的,禁止用于非法用途. 软件有可能会被杀毒软件误杀,设置信任即可. 功能树 验证码自动识别服务 API调用方法查看 免费短信接收器 正则匹配测试 一键获取免费代理 IP IP 查询 时间戳转换与获取 转码 URL 编码互转 简体-繁体互转 Base64.utf8.gb2312.Unicode.中

转载:用python爬虫抓站的一些技巧总结

原文链接:http://www.pythonclub.org/python-network-application/observer-spider 原文的名称虽然用了<用python爬虫抓站的一些技巧总结>但是,这些技巧不仅仅只有使用python的开发可以借鉴,我看到这篇文章的时候也在回忆自己做爬虫的过程中也用了这些方法,只是当时没有系统的总结而已,谨以此文为鉴,为以前的爬虫程序做一个总结. 转载原文如下: 学用python也有3个多月了,用得最多的还是各类爬虫脚本:写过抓代理本机验证的脚本,

[Python爬虫] Selenium爬取新浪微博客户端用户信息、热点话题及评论 (上)

一. 文章介绍 前一篇文章"[python爬虫] Selenium爬取新浪微博内容及用户信息"简单讲述了如何爬取新浪微博手机端用户信息和微博信息. 用户信息:包括用户ID.用户名.微博数.粉丝数.关注数等. 微博信息:包括转发或原创.点赞数.转发数.评论数.发布时间.微博内容等. 它主要通过从文本txt中读取用户id,通过"URL+用户ID" 访问个人网站,如柳岩: http://weibo.cn/guangxianliuya 因为手机端数据相对精简简单,所以采用输

Python 爬虫-Scrapy爬虫框架

2017-07-29 17:50:29 Scrapy是一个快速功能强大的网络爬虫框架. Scrapy不是一个函数功能库,而是一个爬虫框架.爬虫框架是实现爬虫功能的一个软件结构和功能组件集合.爬虫框架是一个半成品,能够帮助用户实现专业网络爬虫.  一.Scrapy框架介绍 5+2结构,5个主要模块加2个中间件. (1)Engine:控制所有模块之间的数据流:根据条件触发事件.不需要用户修改 (2)Downloader:根据请求下载网页.不需要用户修改 (3)Scheduler:对所有爬取请求进行调

Python爬虫入门案例:获取百词斩已学单词列表

百词斩是一款很不错的单词记忆APP,在学习过程中,它会记录你所学的每个单词及你答错的次数,通过此列表可以很方便地找到自己在记忆哪些单词时总是反复出错记不住.我们来用Python来爬取这些信息,同时学习Python爬虫基础. 首先来到百词斩网站:http://www.baicizhan.com/login 这个网站是需要登录的,不过还好没验证码,我们可以先看下在登录过程中浏览器POST了哪些数据.打开浏览器开发工具(F12),以Chrome浏览器为例,记录登录过程中浏览器的Network情况: 我