如何在Chrome扩展程序中的onHeadersReceived事件中访问请求标头

时间:2014-05-02 18:29:36

标签: javascript google-chrome google-chrome-extension http-headers

我做了类似的事情:

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事件中的请求标头以防止不匹配。

1 个答案:

答案 0 :(得分:3)

您可以使用requestId字段将onBeforeSendHeaders中保存的标题与onHeadersReceived中保存的标题相匹配。

  

请求ID在浏览器会话中是唯一的。因此,它们可用于关联同一请求的不同事件。