4

我一直在尝试在 IIS 托管网站中使用服务工作者来缓存网站的一些静态内容。该站点是使用 Windows 身份验证的内部应用程序。我已经能够毫不费力地注册和运行服务工作者,但是一旦我打开缓存并开始将文件添加到缓存中,promise 就会因授权失败而失败。返回的 HTTP 结果是 401 Unauthorized。这是前几个请求的通常响应,直到浏览器和服务器能够协商授权。

我将很快发布一些有助于解释的代码。

编辑

var staticCacheName = 'app-static-v1';
console.log("I AM ALIVE");
this.addEventListener('install', function (event) {
    console.log("AND I INSTALLED!!!!");
    var urlsToCache = [
        //...many js files to cache
        '/scripts/numeral.min.js?version=2.2.0',
        '/scripts/require.js',
        '/scripts/text.js?version=2.2.0',
        '/scripts/toastr.min.js?version=2.2.0',
    ];


    event.waitUntil(
        caches.open(staticCacheName).then(function (cache) {
            cache.addAll(urlsToCache);
        }).catch(function (error) {
            console.log(error);
        })
    );
});
4

1 回答 1

18

这只是一个猜测,因为缺少代码,但如果你正在做类似的事情:

caches.open('my-cache').then(cache => {
  return cache.add('page1.html'); // Or caches.addAll(['page1.html, page2.html']);
});

您正在利用将字符串传递给/时发生的隐式Request 对象创建(参见第 6.4.4.4.1 节) 。创建的对象使用默认凭据模式,即.cache.add()cache.addAll()Request'omit'

相反,您可以做的是显式构造一个Request包含您喜欢的凭据模式的对象,在您的情况下可能是'same-origin'

caches.open('my-cache').then(cache => {
  return cache.add(new Request('page1.html', {credentials: 'same-origin'}));
});

如果您有一堆 URL 将数组传递给cache.addAll(),您可以.map()将它们传递给对应的Requests 数组:

var urls = ['page1.html', 'page2.html'];
caches.open('my-cache').then(cache => {
  return cache.addAll(urls.map(url => new Request(url, {credentials: 'same-origin'})));
});
于 2016-07-13T19:14:27.083 回答