我做了类似的事情:
chrome.webRequest.onBeforeSendHeaders.addListener(function (details) {
for (var i = 0; i < details.requestHeaders.length; ++i)
{
if (details.requestHeaders[i].name.toLowerCase() === 'user-agent')
{
message.useragent = details.requestHeaders[i].value;
}
else if (details.requestHeaders[i].name.toLowerCase() === 'referer')
{
message.referrer = details.requestHeaders[i].value;
}
else if (details.requestHeaders[i].name.toLowerCase() === 'cookie')
{
message.cookies = details.requestHeaders[i].value;
console.log(details.requestHeaders[i].value);
}
}
return {
requestHeaders: details.requestHeaders
};
}, {
urls: [
'<all_urls>'
],
types: [
'main_frame',
'sub_frame',
'xmlhttprequest'
]
}, [
'blocking',
'requestHeaders'
]);
and on receiving response:
chrome.webRequest.onHeadersReceived.addListener(function (details) {
message.url = details.url;
// and some other details
...
但最近我发现有时存储的请求参数和存储的响应参数属于不同的请求响应对。那么,是否可以访问onHeadersReceived事件中的请求标头以防止不匹配。
答案 0 :(得分:3)
您可以使用requestId
字段将onBeforeSendHeaders
中保存的标题与onHeadersReceived
中保存的标题相匹配。
请求ID在浏览器会话中是唯一的。因此,它们可用于关联同一请求的不同事件。