python系列24:用python爬取ajax请求

1. 查看ajax发送请求的真实地址

使用F12打开chrome的开发者界面,然后执行一遍页面,我们能看到:
python系列24:用python爬取ajax请求_第1张图片
点击执行时间最长的ajax请求,我们就能看到真实的请求(headers里)和参数(payload里)了:
python系列24:用python爬取ajax请求_第2张图片
python系列24:用python爬取ajax请求_第3张图片

2. 请求代码

url:Header中的request url
headers:Header中的request headers
params:Payload中的Query String Parameters
data:Payload中的From Data
对比上面的两张图,爬取页面信息的代码如下:

import requests
from tqdm import tqdm
headers={'User-Agent': 'Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/102.0.5005.115 Safari/537.36',
        'Referer': 'https://www.jst-purple.com.cn/purple/index.php',
        'Content-Type': 'application/x-www-form-urlencoded; charset=UTF-8',
        'Cookie':'PHPSESSID=tr0n497tu1oslsnpgct8n03261'}

url = "https://www.jst-purple.com.cn/purple/ajax_show_search_product.php"
params = {'callback':'jQuery1111007706371456432315_1655294131309'}
# 这里一般用多线程去爬取网页
for i in tqdm(range(1,248)):
    rep=requests.post(url=url,params=params,data={"current_page":i},headers=headers)
    html = rep.text...

你可能感兴趣的:(python系列,python,ajax,爬虫)