婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > Python中常見的反爬機制及其破解方法總結(jié)

Python中常見的反爬機制及其破解方法總結(jié)

熱門標簽:騰訊地圖標注沒法顯示 商家地圖標注海報 地圖標注自己和別人標注區(qū)別 ai電銷機器人的優(yōu)勢 孝感營銷電話機器人效果怎么樣 聊城語音外呼系統(tǒng) 打電話機器人營銷 南陽打電話機器人 海外網(wǎng)吧地圖標注注冊

一、常見反爬機制及其破解方式

封禁IP,使用cookie等前面文章已經(jīng)講過

現(xiàn)在主要將下面的:

​ ~ 驗證碼
​ —> 文字驗證碼 —> OCR(光學文字識別)—> 接口 / easyocr
​ 程序自己解決不了的問題就可以考慮使用三方接口(付費/免費)
​ —> 行為驗證碼 —> 超級鷹
​ ~ 手機號+短信驗證碼
​ —> 接碼平臺
​ ~ 動態(tài)內(nèi)容
​ —> JavaScript逆向 —> 找到提供數(shù)據(jù)的API接口
​ —> 手機抓接口 —> 抓包工具(Charles / Fiddler)
​ —> Selenium直接模擬瀏覽器操作獲取動態(tài)內(nèi)容
​ ~ find_element_by_xxx / find_elements_by_xxx
​ ~ page_source —> 獲取包含動態(tài)內(nèi)容的網(wǎng)頁源代碼
​ —> JavaScript加密和混淆技術(shù) —> 讀懂JavaScript是反反爬的前提
​ ~ 字體反爬 / 內(nèi)容來自于摳圖
​ —> 例子

bytes —> 不變字節(jié)串 —> 二進制 —> BytesIO
str —> 不變字符串 —> 可閱讀的字符 —> StringIO

二、調(diào)用三方API接口數(shù)據(jù)(天行數(shù)據(jù))

import requests

for page in range(1, 6):
    response = requests.get(
        'http://api.tianapi.com/topnews/index',
        params={
            'key': 'd5eace66dccd771e36767ce3563efa09',
            'page': page,
            'num': 20,
            'word': '華為',
            'src': '人民日報'
        }
    )
    result = response.json()
    for news in result['newslist']:
        print(news['title'])
        print(news['url'])

三、OCR(光學文字識別)庫

python 自帶的easyocr庫

import easyocr
reader = easyocr.Reader(['ch_sim', 'en'], gpu=False)
print(reader.readtext('./files/captcha.jpg', detail=0))

例子:阿里云郵箱自動登陸

import io

import easyocr

from PIL import Image
from selenium import webdriver
from selenium.webdriver.common.by import By
from selenium.webdriver.support import expected_conditions
from selenium.webdriver.support.wait import WebDriverWait

browser = webdriver.Chrome()
browser.set_window_size(1280, 960)
browser.get('http://mail.1000phone.com/')
# 隱式等待(下面的方法在工作時如果取不到就等10秒)
browser.implicitly_wait(10)
# 顯式等待
wait = WebDriverWait(browser, 10)
wait.until(expected_conditions.presence_of_element_located((By.CSS_SELECTOR, '.login_panel_iframe')))
iframe1 = browser.find_element_by_css_selector('.login_panel_iframe')
# 記錄iframe1的位置(相對位置)
x1, y1 = iframe1.location['x'], iframe1.location['y']
# Chrome對象的switch_to屬性的frame方法,可以從頁面切換到iframe中
browser.switch_to.frame(iframe1)
iframe2 = browser.find_element_by_css_selector('#ding-login-iframe')
x2, y2 = iframe2.location['x'], iframe2.location['y']
browser.switch_to.frame(iframe2)
username_input = browser.find_element_by_css_selector('#username')
# 模擬用戶輸入
username_input.send_keys('xx@1000phone.com')
password_input = browser.find_element_by_css_selector('#password')
password_input.send_keys('xxxxx!!')
# 創(chuàng)建一個等待對象
wait = WebDriverWait(browser, 10)
wait.until(expected_conditions.element_to_be_clickable((By.CSS_SELECTOR, '#login_checkcode_ico')))
captcha_img = browser.find_element_by_css_selector('#login_checkcode_ico')
# WebElement對象的size屬性代表元素寬度和高度,location屬性代表元素在窗口中的位置
size, location = captcha_img.size, captcha_img.location
x3, y3, width, height = location['x'], location['y'], size['width'], size['height']
# 截取整個瀏覽器窗口的圖片獲得圖片的二進制數(shù)據(jù)
image_data = browser.get_screenshot_as_png()
# bytes(只讀字節(jié)串) ----> io.BytesIO(可寫字節(jié)串)---> getvalue() ---> bytes
# str(只讀字符串) ----> io.StringIO(可寫字符串)---> getvalue() ---> str
browser_image = Image.open(io.BytesIO(image_data))
# 從截圖上剪裁出驗證碼的圖片
x, y = x1 + x2 + x3, y1 + y2 + y3
# Windows系統(tǒng)的寫法 ---> 如果截圖有問題就把坐標寫死
# print(x, y, width, height)
checkcode_image = browser_image.crop((x * 1.25, y * 1.25, (x + width) * 1.25, (y + height) * 1.25))
# macOS系統(tǒng)的寫法
# checkcode_image = browser_image.crop((x * 2, y * 2, (x + width) * 2, (y + height) * 2))
checkcode_image.save('result.png')
# 通過easyocr做光學文字識別
reader = easyocr.Reader(['en'], gpu=False)
code = reader.readtext('result.png', detail=0)[0]
# 將識別出的驗證碼輸入文本框
checkcode_input = browser.find_element_by_css_selector('#login_checkcode')
checkcode_input.send_keys(code)
login_button = browser.find_element_by_css_selector('#login_submit_btn')
# 模擬用戶點擊
login_button.click()

四、第三方打碼平臺(超級鷹打碼平臺)

補充:需要使用python 自帶pillow庫

"""
Pillow庫 ---> PIL ---> Python Image Library
"""
from PIL import Image, ImageFilter

# 加載圖像
guido_image = Image.open('guido.jpg')
# 剪裁
guido_image.crop((80, 40, 310, 350)).show()
# 濾鏡
guido_image.filter(ImageFilter.CONTOUR).show()
# 縮略圖
guido_image.thumbnail((125, 185))
# 顯示圖像
guido_image.show()

編寫超級鷹打碼平臺類

from hashlib import md5

import requests


class ChaojiyingClient:

    def __init__(self, username, password, soft_id):
        self.username = username
        password = password.encode('utf8')
        self.password = md5(password).hexdigest()
        self.soft_id = soft_id
        self.base_params = {
            'user': self.username,
            'pass2': self.password,
            'softid': self.soft_id,
        }
        self.headers = {
            'Connection': 'Keep-Alive',
            'User-Agent': 'Mozilla/4.0 (compatible; MSIE 8.0; Windows NT 5.1; Trident/4.0)',
        }

    def post_pic(self, image_data, code_type):
        """
        image_data: 圖片字節(jié)
        code_type: 驗證碼類型 參考 http://www.chaojiying.com/price.html
        """
        params = {
            'codetype': code_type,
        }
        params.update(self.base_params)
        files = {'userfile': ('ccc.jpg', image_data)}
        response = requests.post(
            url='http://upload.chaojiying.net/Upload/Processing.php',
            data=params,
            files=files,
            headers=self.headers
        )
        return response.json()

    # 超級鷹錯誤反饋函數(shù)(僅用于給超級鷹平臺反饋)
    def report_error(self, im_id):
        """
        im_id:報錯題目的圖片ID
        """
        params = {
            'id': im_id,
        }
        params.update(self.base_params)
        r = requests.post('http://upload.chaojiying.net/Upload/ReportError.php', data=params, headers=self.headers)
        return r.json()


if __name__ == '__main__':
    chaojiying = ChaojiyingClient('賬戶', '密碼x', 'ID')  # 用戶中心>>軟件ID 生成一個替換 96001
    with open('img.png', 'rb') as file:
        image_data = file.read()  # 本地圖片文件路徑 來替換 a.jpg 有時WIN系統(tǒng)須要//
        print(chaojiying.post_pic(image_data, 1902))  # 1902 驗證碼類型  官方網(wǎng)站>>價格體系 3.4+版 print 后要加()

例子:使用超級鷹進行阿里云郵箱自動登陸

import io

import easyocr

from PIL import Image
from selenium import webdriver
from selenium.webdriver.common.by import By
from selenium.webdriver.support import expected_conditions
from selenium.webdriver.support.wait import WebDriverWait

from chaojiying import ChaojiyingClient

browser = webdriver.Chrome()
browser.set_window_size(1280, 960)
browser.get('http://mail.1000phone.com/')
# 隱式等待(下面的方法在工作時如果取不到就等10秒)
browser.implicitly_wait(10)
# 顯式等待
wait = WebDriverWait(browser, 10)
wait.until(expected_conditions.presence_of_element_located((By.CSS_SELECTOR, '.login_panel_iframe')))
iframe1 = browser.find_element_by_css_selector('.login_panel_iframe')
# 記錄iframe1的位置(相對位置)
x1, y1 = iframe1.location['x'], iframe1.location['y']
# Chrome對象的switch_to屬性的frame方法,可以從頁面切換到iframe中
browser.switch_to.frame(iframe1)
iframe2 = browser.find_element_by_css_selector('#ding-login-iframe')
x2, y2 = iframe2.location['x'], iframe2.location['y']
browser.switch_to.frame(iframe2)
username_input = browser.find_element_by_css_selector('#username')
# 模擬用戶輸入
username_input.send_keys('xxxx.com')
password_input = browser.find_element_by_css_selector('#password')
password_input.send_keys('xxxx!!')
# 創(chuàng)建一個等待對象
wait = WebDriverWait(browser, 10)
wait.until(expected_conditions.element_to_be_clickable((By.CSS_SELECTOR, '#login_checkcode_ico')))
captcha_img = browser.find_element_by_css_selector('#login_checkcode_ico')
# WebElement對象的size屬性代表元素寬度和高度,location屬性代表元素在窗口中的位置
size, location = captcha_img.size, captcha_img.location
x3, y3, width, height = location['x'], location['y'], size['width'], size['height']
# 截取整個瀏覽器窗口的圖片獲得圖片的二進制數(shù)據(jù)
image_data = browser.get_screenshot_as_png()
# bytes(只讀字節(jié)串) ----> io.BytesIO(可寫字節(jié)串)---> getvalue() ---> bytes
# str(只讀字符串) ----> io.StringIO(可寫字符串)---> getvalue() ---> str
browser_image = Image.open(io.BytesIO(image_data))
# 從截圖上剪裁出驗證碼的圖片
x, y = x1 + x2 + x3, y1 + y2 + y3
# Windows系統(tǒng)的寫法 ---> 如果截圖有問題就把坐標寫死
# print(x, y, width, height)
checkcode_image = browser_image.crop((x * 1.25, y * 1.25, (x + width) * 1.25, (y + height) * 1.25))
# macOS系統(tǒng)的寫法
# checkcode_image = browser_image.crop((x * 2, y * 2, (x + width) * 2, (y + height) * 2))
checkcode_image.save('result.png')
# 通過超級鷹打碼平臺打碼
chaojiying = ChaojiyingClient('賬戶', '密碼', 'ID')
with open('result.png', 'rb') as file:
    image_data = file.read()
    result_dict = chaojiying.post_pic(image_data, 1902)
# 將識別出的驗證碼輸入文本框
checkcode_input = browser.find_element_by_css_selector('#login_checkcode')
checkcode_input.send_keys(result_dict['pic_str'])
login_button = browser.find_element_by_css_selector('#login_submit_btn')
# 模擬用戶點擊
login_button.click()

五、通過接碼平臺接收手機驗證碼(隱私短信平臺)

通過隱私短信平臺接收驗證碼(免費)

import re

import bs4
import requests

pattern = re.compile(r'\d{4,6}')

resp = requests.get('https://www.yinsiduanxin.com/china-phone-number/verification-code-16521686439.html')
soup = bs4.BeautifulSoup(resp.text, 'html.parser')
# print(resp.text)
td = soup.select_one('body > div.container > div:nth-child(4) > div:nth-child(3) > div.main > div.layui-row > table > tbody > tr:nth-child(1) > td:nth-child(2)')
results = pattern.findall(td.text)
print(results[0])

到此這篇關(guān)于Python中常見的反爬機制及其破解方法總結(jié)的文章就介紹到這了,更多相關(guān)Python反爬機制及其破解內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • python 常見的反爬蟲策略
  • Python常見反爬蟲機制解決方案
  • python解決網(wǎng)站的反爬蟲策略總結(jié)
  • python中繞過反爬蟲的方法總結(jié)
  • Python反爬蟲技術(shù)之防止IP地址被封殺的講解
  • Python爬蟲和反爬技術(shù)過程詳解

標簽:楊凌 六盤水 聊城 牡丹江 迪慶 揚州 南寧 撫州

巨人網(wǎng)絡(luò)通訊聲明:本文標題《Python中常見的反爬機制及其破解方法總結(jié)》,本文關(guān)鍵詞  Python,中,常見,的,反爬,機制,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《Python中常見的反爬機制及其破解方法總結(jié)》相關(guān)的同類信息!
  • 本頁收集關(guān)于Python中常見的反爬機制及其破解方法總結(jié)的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    国产精品99久久不卡二区| 亚洲日本在线a| 狂野欧美性猛交blacked| 欧美成人精品3d动漫h| 美女视频黄 久久| 精品国产免费人成电影在线观看四季| 老司机精品视频一区二区三区| 精品久久一区二区三区| 国产精品亚洲专一区二区三区| 国产精品久久久久久久久免费桃花 | 色综合一区二区三区| 亚洲色图欧洲色图婷婷| 欧美在线不卡一区| 美女视频一区在线观看| 国产嫩草影院久久久久| 97久久久精品综合88久久| 亚洲国产精品影院| 久久综合狠狠综合久久综合88| 懂色av中文字幕一区二区三区| 亚洲欧美欧美一区二区三区| 欧美一区二区三区在| 国产精品99久久久久久有的能看| 最新久久zyz资源站| 在线成人免费观看| 国产成人精品亚洲777人妖| 亚洲综合精品久久| 精品久久久久久久人人人人传媒| 91亚洲精品乱码久久久久久蜜桃| 日韩av不卡在线观看| 国产精品丝袜黑色高跟| 日韩一区二区电影| 91麻豆精品视频| 青青草一区二区三区| 亚洲欧美日韩一区二区三区在线观看| 欧美一级夜夜爽| 91看片淫黄大片一级| 国内精品自线一区二区三区视频| 亚洲精品你懂的| 久久久五月婷婷| 欧美日韩国产电影| 99在线精品一区二区三区| 美女高潮久久久| 亚洲欧美激情小说另类| 久久久国产精华| 欧美一级夜夜爽| 欧美性受xxxx黑人xyx性爽| 国产不卡免费视频| 久久99精品久久久久| 亚洲bt欧美bt精品| 18欧美乱大交hd1984| 久久久精品天堂| 日韩免费性生活视频播放| 精品视频一区二区三区免费| 99国产欧美另类久久久精品| 国产一区二区三区免费在线观看| 日本免费新一区视频 | 亚洲女厕所小便bbb| 欧美精品一区二区三区蜜桃 | 亚洲精品视频一区二区| 中文字幕av资源一区| 国产清纯白嫩初高生在线观看91 | 精品在线播放免费| 丝袜a∨在线一区二区三区不卡| 亚洲色图第一区| 亚洲欧洲成人av每日更新| 中文字幕第一区二区| 国产欧美日韩麻豆91| 久久综合丝袜日本网| 日韩欧美www| 日韩视频在线观看一区二区| 69堂亚洲精品首页| 91精品国产综合久久香蕉麻豆| 精品视频色一区| 欧美区视频在线观看| 337p亚洲精品色噜噜| 欧美蜜桃一区二区三区| 欧美电影一区二区| 欧美精品乱码久久久久久| 欧美日韩国产高清一区二区 | 欧美一级在线观看| 日韩免费一区二区| 久久久久国产一区二区三区四区 | 色综合天天综合网国产成人综合天| 99综合影院在线| 色哟哟一区二区在线观看| 欧美影院一区二区| 在线成人小视频| 26uuu国产一区二区三区| 国产三级三级三级精品8ⅰ区| 欧美经典三级视频一区二区三区| 综合久久久久久| 亚洲精品国久久99热| 午夜精品久久久久久久蜜桃app| 日本v片在线高清不卡在线观看| 另类小说欧美激情| 成人中文字幕合集| 欧美系列在线观看| 精品久久久久久久久久久久包黑料| 久久久久99精品一区| 亚洲女同女同女同女同女同69| 亚洲综合自拍偷拍| 精品一二三四在线| 91麻豆精品国产自产在线观看一区 | 欧美日韩精品电影| 欧美日韩精品电影| 久久久亚洲精品石原莉奈| 中文字幕日韩一区| 日韩在线播放一区二区| 国产老肥熟一区二区三区| a亚洲天堂av| 日韩欧美高清在线| 亚洲乱码国产乱码精品精98午夜| 日韩精品视频网站| 成人美女视频在线观看| 欧美精品久久久久久久多人混战 | 捆绑调教一区二区三区| eeuss鲁一区二区三区| 91麻豆精品国产91久久久| 中文字幕一区二区三区四区 | 一本色道久久综合亚洲91| 欧美精品v国产精品v日韩精品| 久久久www免费人成精品| 亚洲综合在线第一页| 国产夫妻精品视频| 91麻豆精品国产91| 亚洲精品日韩专区silk| 国产91精品欧美| 日韩精品一区二区三区四区| 一级特黄大欧美久久久| 粉嫩嫩av羞羞动漫久久久| 欧美一区二区三区系列电影| 亚洲人吸女人奶水| 国产.欧美.日韩| 欧美电影免费观看高清完整版| 亚洲综合一区二区| 成人激情免费电影网址| 久久婷婷久久一区二区三区| 午夜精品久久久久影视| 91色乱码一区二区三区| 中文字幕高清一区| 国产九色sp调教91| 精品国产三级电影在线观看| 五月婷婷激情综合| 在线日韩一区二区| 亚洲欧洲精品一区二区精品久久久| 国产一区二区三区在线观看免费| 欧美一级爆毛片| 三级欧美在线一区| 欧美精品v日韩精品v韩国精品v| 一区二区三区在线看| 91性感美女视频| 亚洲人成人一区二区在线观看| 国产91丝袜在线观看| 国产亚洲精品中文字幕| 国产成人免费高清| 国产日韩精品视频一区| 国产一区二区三区精品视频| 精品国产电影一区二区| 国产在线精品一区二区不卡了| 精品国产伦一区二区三区免费| 精品一区二区三区的国产在线播放| 日韩欧美国产午夜精品| 久久国产乱子精品免费女| 精品免费日韩av| 国产福利一区二区三区视频 | 久久噜噜亚洲综合| 国产一区二区三区高清播放| 精品欧美乱码久久久久久| 国产一区二区在线视频| 欧美老年两性高潮| 亚洲综合一区二区三区| 一本久道久久综合中文字幕| 亚洲女子a中天字幕| 色婷婷综合五月| 亚洲午夜精品网| 欧美一区二区女人| 极品尤物av久久免费看| 国产精品午夜久久| 91浏览器打开| 午夜久久久久久电影| 欧美一区在线视频| 国产麻豆视频精品| 亚洲欧美另类久久久精品2019| 欧美性猛交xxxxxx富婆| 美女视频第一区二区三区免费观看网站| 精品久久久久久久一区二区蜜臀| 国产成人啪免费观看软件| 亚洲天堂2014| 欧美精品一卡二卡| 国产福利一区二区三区在线视频| 亚洲色图第一区| 欧美成人一区二区三区在线观看 | 亚洲色图欧美偷拍| 欧美人与禽zozo性伦| 国产精品一区久久久久| 亚洲九九爱视频| 精品美女在线播放| 色婷婷综合久久| 国产一区二区三区蝌蚪| 精品久久久久香蕉网|