跳至主要內容
版本:23.11.1

Page.setRequestInterception() 方法

啟用請求攔截會啟用 HTTPRequest.abort()HTTPRequest.continue()HTTPRequest.respond() 方法。這提供了修改頁面發出的網路請求的功能。

一旦啟用請求攔截,除非請求被繼續、回應或中止;或使用瀏覽器快取完成,否則每個請求都會暫停。

有關更多詳細信息,請參閱請求攔截指南

簽名

class Page {
abstract setRequestInterception(value: boolean): Promise<void>;
}

參數

參數

類型

說明

value

boolean

是否啟用請求攔截。

返回

Promise<void>

範例

一個簡單的請求攔截器範例,它會中止所有圖像請求

import puppeteer from 'puppeteer';
(async () => {
const browser = await puppeteer.launch();
const page = await browser.newPage();
await page.setRequestInterception(true);
page.on('request', interceptedRequest => {
if (
interceptedRequest.url().endsWith('.png') ||
interceptedRequest.url().endsWith('.jpg')
)
interceptedRequest.abort();
else interceptedRequest.continue();
});
await page.goto('https://example.com');
await browser.close();
})();