获取事件未接收请求标头

Iva*_*žić 5 javascript service-worker service-worker-events

似乎服务工作者内部的fetch事件没有收到请求头,尽管在MDN文档中有说明:

您可以通过调用FetchEvent返回的Request对象的参数来检索有关每个请求的大量信息:

event.request.url
event.request.method
event.request.headers
event.request.body

从主线程获取资源的代码:

fetch(`${companyConfig.base}ticket-scanner/config`, {
    headers: {
        'X-Nsft-Locale' : `en`,
        'X-Nsft-Id': `1`,
    },
}).then((response) => {
    return response.json();
}).then((data) => {...})
Run Code Online (Sandbox Code Playgroud)

在SW文件中获取事件处理程序:

self.addEventListener('fetch', function(event) {
  event.respondWith(
    caches.match(event.request, {cacheName : CACHE_NAME})
        .then(function(response) {
            if(response) {
                return response;
            }
            console.log(event.request.headers); //Log out headers
            return fetch(event.request).then(function(response){
                return response;
            }).catch(function(err){
                console.error(err);
            })
        })
    )
});
Run Code Online (Sandbox Code Playgroud)

每个fetch事件的日志标题都会给我一个空对象:

标题{}

这阻止我缓存此特定请求,该请求仅需要这两个标头.证书不是必需的.我错过了什么吗?

Jef*_*ick 6

Headers接口是可迭代的,支持.get()访问,以及.has()存在检查.

您可以利用其中的任何一个来阅读您关心的值.

const request = new Request('https://example.com', {
  headers: {
    'x-header-1': 'header 1 value',
    'x-header-2': 'header 2 value',
  }
});

for (const [header, value] of request.headers) {
  console.log(`${header}: ${value} (via iterator)`);
}

console.log(`'x-header-1' is ${request.headers.get('x-header-1')}`);

console.log(`'x-header-2' ${request.headers.has('x-header-2') ? 'exists' : 'does not exist'}`);
Run Code Online (Sandbox Code Playgroud)