1. 程式人生 > >Python 通過打碼平臺實現驗證碼

Python 通過打碼平臺實現驗證碼

  在爬蟲時,經常遇到登入需要驗證碼的情況,簡單的驗證碼可以自己解決,複製的驗證碼需要藉助機器學習,有一定的難度。還有一個簡單的方案就是採用付費的打碼平臺。

  比如R若快(http://www.ruokuai.com/client),還有云打碼平臺(http://www.yundama.com/price.html)

  下面以R若快為例介紹打碼平臺的思路:

  R若快平臺需要註冊兩個使用者,一個是普通使用者,一個開發者使用者,

  

  

  

   

 

 

 

 

  1、首先驗證碼截圖,就是擷取網站上登入頁面的驗證碼圖片並儲存到本地

  2、呼叫打碼平臺的介面把驗證碼圖片傳送到打碼平臺並獲取到驗證碼結果。

  具體程式碼如下:

  

#!/usr/bin/env python
# coding:utf-8

import requests
from hashlib import md5


class RClient(object):

    def __init__(self, username='shaoks123', password='123456', soft_id='113452', soft_key='c0d07d796c8e470c92a126df60d61794'):
        self.username 
= username # self.password = md5(password).hexdigest() self.password = md5(password.encode("utf-8")).hexdigest() self.soft_id = soft_id self.soft_key = soft_key self.base_params = { 'username': self.username, 'password': self.password,
'softid': self.soft_id, 'softkey': self.soft_key, } self.headers = { 'Connection': 'Keep-Alive', 'Expect': '100-continue', 'User-Agent': 'ben', } def rk_create(self, im, im_type, timeout=60): """ im: 圖片位元組 im_type: 題目型別 """ params = { 'typeid': im_type, 'timeout': timeout, } params.update(self.base_params) files = {'image': ('a.jpg', im)} r = requests.post('http://api.ruokuai.com/create.json', data=params, files=files, headers=self.headers) return r.json() def rk_report_error(self, im_id): """ im_id:報錯題目的ID """ params = { 'id': im_id, } params.update(self.base_params) r = requests.post('http://api.ruokuai.com/reporterror.json', data=params, headers=self.headers) return r.json() def test(self,imagefile,im_type=1030): # im = open('E:\python36_crawl\Veriycode\code\code_823.png', 'rb').read() im = open(imagefile, 'rb').read() result = self.rk_create(im, im_type) print(result['Result']) return result['Result'] # if __name__ == '__main__': # rc = RClient() # im = open('E:\python36_crawl\Veriycode\code\code_823.png', 'rb').read() # result = rc.rk_create(im, 1030) # print(result['Result'])