Chrome WebRequest API:如何屏蔽"设置Cookie"?

时间:2017-12-18 01:12:13

标签: google-chrome-extension firefox-webextensions

我需要阻止来自某个域的所有Cookie。 (我无法使用内容设置API,因为FireFox还不支持它)

我现在没有取得很大的成功,我想知道我是否朝着正确的方向前进?

使用WebRequest API,我添加了一个监听器

onHeadersReceived

并确保我的函数返回了一个promise,然后我按照这样的方式浏览了标题:

function modifyHeaders(headers: HttpHeader[]) {
    headers.forEach((header: HttpHeader) => {
        if (header.name === "set-cookie") {
            /* makeExpire sets "Expires= sometimeInThePast" */ 
            header.value = makeExpire(header.value!)
        }
    })
}

modifyHeaders(headers);
return { responseHeaders: headers }

这似乎是最低的开销方式,但到目前为止它似乎没有用。我想我可能会走错路了。

1 个答案:

答案 0 :(得分:1)

function onHeadersReceived(details) {
    if (details.responseHeaders) {
        return {
            responseHeaders: details.responseHeaders.filter((x) => {
                return x.name.toLowerCase() !== 'set-cookie';
            })
        };
    }
    return {};
}
browser.webRequest.onHeadersReceived.addListener(onHeadersReceived, { urls: ["<all_urls>"] }, ["responseHeaders", "blocking"]);