我的博客:acsec.xyz 微信公众号: Ac sec
一.概述
我们有时候在爬取jsp动态网站时,发现爬取的数据是不完整的。这时候我们就要获取浏览器F12里面的Network数据包,这样才能得到完整的数据。下面我们用python的Selenium模块配合Browsermob-Proxy抓取Network数据包。
二.环境
1.python3.10
2.pycharm2021.1
3.Browsermob-Proxy2.1.4
下载地址:
https://github.com/lightbody/browsermob-proxy/releases/tag/browsermob-proxy-2.1.4
4.Chrome和对应版本的chromedriver.exe
三.爬取
1.使用百度搜索python,查看network包
data:image/s3,"s3://crabby-images/ca5c3/ca5c3d7de9b4c90cf5b127ee121eeacaf6488fc5" alt="在这里插入图片描述"
2.我们一般是要拿url和response部分
data:image/s3,"s3://crabby-images/58625/58625598b40cfdbb206e2e8d02158f144a4349ec" alt="在这里插入图片描述"
data:image/s3,"s3://crabby-images/70a8b/70a8b1c802cb02c3a8afb31fa67ba07fc505ebb2" alt="在这里插入图片描述"
3.我们上代码。
import time
import json
import re
import requests
from browsermobproxy import Server
from selenium import webdriver
from selenium.webdriver.chrome.options import Options
def main():
BMPserver = Server(r'.\browsermob-proxy-2.1.4\bin\browsermob-proxy.bat')
BMPserver.start()
BMPproxy = BMPserver.create_proxy()
chrome_options = Options()
chrome_options.add_argument('--ignore-certificate-errors')
chrome_options.add_argument('--proxy-server={}'.format(BMPproxy.proxy))
brosver = webdriver.Chrome(options=chrome_options)
url = "https://www.baidu.com/"
BMPproxy.new_har("video",options={'captureContent': True,'captureContent': True})
brosver.get(url)
brosver.find_element_by_xpath('//*[@id="kw"]').send_keys("python")
brosver.find_element_by_xpath('//*[@id="su"]').click()
json_data = BMPproxy.har
for entry in json_data['log']['entries']:
entry_url = entry['request']['url']
print(entry_url)
main()
? 这里是通过browsermob-proxy进行代理,抓取network数据包,工作原理和fiddler差不多。抓到的数据会以json格式输出,然后通过循环把需要的内容(url、response)打印出来
4.json文件格式 data:image/s3,"s3://crabby-images/6565c/6565cea5afec96d05baf621500a33268a1528e3c" alt="在这里插入图片描述"
data:image/s3,"s3://crabby-images/722a6/722a6cd3d1e2dc120eeaa924e51360d907832569" alt="在这里插入图片描述"
5.上面代码输出结果
data:image/s3,"s3://crabby-images/42077/420777d917f2aad93a1268bcbfc79809d6f97816" alt="在这里插入图片描述"
6.同理,改变参数可以获取其他数据。在这里我们会发现response部分进行了编码,但是不影响,当你用python打印出来的时候,它会自动解码。
|