久久福利_99r_国产日韩在线视频_直接看av的网站_中文欧美日韩_久久一

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

selenium-python。如何捕獲網(wǎng)絡(luò)流量的響應(yīng)

瀏覽:3日期:2022-08-07 09:28:00
如何解決selenium-python。如何捕獲網(wǎng)絡(luò)流量的響應(yīng)?

您可以訪問(wèn)瀏覽器或chromedriver日志,它們?cè)诰W(wǎng)絡(luò)響應(yīng)方面略有不同。稱為瀏覽器日志,稱為performance驅(qū)動(dòng)程序日志driver。它們返回一個(gè)類似json的對(duì)象,您可以解析該對(duì)象以使用其中的Network方法提取事件:

{’level’: ’INFO’, ’message’: ’{'message':{'method':'Page.frameStoppedLoading','params':{'frameId':'FB10764A3ABF7FFC83110C39C5F7BF77'}},'webview':'C2D13BD13CF743B6D0695B35E9CC935C'}’, ’timestamp’: 1538607113832}, {’level’: ’INFO’, ’message’: ’{'message':{'method':'Page.frameDetached','params':{'frameId':'FB10764A3ABF7FFC83110C39C5F7BF77'}},'webview':'C2D13BD13CF743B6D0695B35E9CC935C'}’, ’timestamp’: 1538607113838}, {’level’: ’INFO’, ’message’: ’{'message':{'method':'Network.requestwillBeSent','params':{'documentURL':'https://stackoverflow.com/questions/52633697/selenium-python-how-to-capture-network-traffics-response','frameId':'C2D13BD13CF743B6D0695B35E9CC935C','hasUserGesture':false,'initiator':{'type':'other'},'loaderId':'5331BFDC4F466FCED920CFC9F033D2EC','request':{'headers':{'Upgrade-Insecure-Requests':'1','User-Agent':'Mozilla/5.0 (Windows NT 6.1; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/69.0.3497.100 Safari/537.36'},'initialPriority':'VeryHigh','method':'GET','mixedContentType':'none','referrerPolicy':'no-referrer-when-downgrade','url':'https://stackoverflow.com/questions/52633697/selenium-python-how-to-capture-network-traffics-response'},'requestId':'5331BFDC4F466FCED920CFC9F033D2EC','timestamp':104499.729,'type':'Document','wallTime':1538607113.838206}},'webview':'C2D13BD13CF743B6D0695B35E9CC935C'}’, ’timestamp’: 1538607113839},...}

您需要啟用登錄DesiredCapabilities,然后使用JSON模塊進(jìn)行解析:

import jsonfrom selenium import webdriverfrom selenium.webdriver.common.desired_capabilities import DesiredCapabilitiescaps = DesiredCapabilities.CHROMEcaps[’loggingPrefs’] = {’performance’: ’ALL’}driver = webdriver.Chrome(desired_capabilities=caps)driver.get(’https://stackoverflow.com/questions/52633697/selenium-python-how-to-capture-network-traffics-response’)def process_browser_log_entry(entry): response = json.loads(entry[’message’])[’message’] return responsebrowser_log = driver.get_log(’performance’) events = [process_browser_log_entry(entry) for entry in browser_log]events = [event for event in events if ’Network.response’ in event[’method’]]

我不知道是否可以使用此方法訪問(wèn)響應(yīng)數(shù)據(jù)本身,但是可以獲取響應(yīng)的URL。

解決方法

我正在使用pythonDjango創(chuàng)建一個(gè)Web應(yīng)用程序。我正在使用selenium來(lái)啟動(dòng)無(wú)頭瀏覽器(phantomjs)并單擊幾次,直到到達(dá)特定頁(yè)面。我希望捕獲網(wǎng)絡(luò)流量并獲得特定網(wǎng)絡(luò)呼叫的響應(yīng)。該網(wǎng)絡(luò)調(diào)用實(shí)際上包含一個(gè)html文檔作為其響應(yīng)。

有什么辦法可以做到這一點(diǎn)?

標(biāo)簽: Python 編程
相關(guān)文章:
主站蜘蛛池模板: 亚洲国产中文字幕 | 一道本一区二区三区 | 黑人巨大精品欧美一区二区免费 | 亚洲精区 | 欧美大片在线看免费观看 | 国产三级在线免费观看 | 在线观看亚洲 | 久久亚洲一区二区三区四区 | 欧美国产精品一区二区 | 男人天堂视频网 | 亚洲国产精品人人爽夜夜爽 | 亚洲www. | 91久久久久 | 精品一区二区三区免费 | 亚洲精久 | 欧州一区二区 | 中文字幕 亚洲一区 | 精久视频 | 欧美成人免费在线观看 | 久久精品一区二区三区四区 | 在线观看亚洲大片短视频 | 成人久久18免费观看 | 日韩一区二区福利 | 欧美精品欧美精品系列 | 欧美日韩综合视频 | 一区在线免费观看 | 欧洲成人午夜免费大片 | 国产艹 | 欧美成在线视频 | 欧美一级艳片视频免费观看 | 国产精品一区二区三区四区 | 久久精品久久精品 | 亚洲精品二区 | 91久久极品| 中文字幕高清在线 | 亚洲精品在线视频 | 精品国产区 | 免费成人在线网站 | 日韩av免费在线观看 | 手机亚洲第一页 | 国产精品久久久久久久久免费桃花 |