ServiceWorker 阻止任何外部资源
ServiceWorker blocks any external resource
我已经在我的一些 Web 应用程序上实现了 ServiceWorker 以利用离线功能和与 ServiceWorkers 相关的其他一些好东西。现在,一切正常,直到我添加了一些外部嵌入式脚本。我在我的网络应用程序中添加了大约 3 个外部脚本。其中一些获取广告并将其显示在我的应用程序上,其中一些用于收集分析。
但是,令我惊讶的是,当启用 ServiceWorkers 时,每个外部脚本都会失败,并在控制台中抛出以下错误
我不确定为什么会这样?我是否必须在 ServiceWorker 中以某种方式缓存这些脚本?任何帮助将不胜感激。
这是我添加到我的应用程序中的 ServiceWorker 代码。
importScripts('js/cache-polyfill.js');
var CACHE_VERSION = 'app-v18';
var CACHE_FILES = [
'/',
'index.html',
'js/app.js',
'js/jquery.min.js',
'js/bootstrap.min.js',
'css/bootstrap.min.css',
'css/style.css',
'favicon.ico',
'manifest.json',
'img/icon-48.png',
'img/icon-96.png',
'img/icon-144.png',
'img/icon-196.png'
];
self.addEventListener('install', function (event) {
event.waitUntil(
caches.open(CACHE_VERSION)
.then(function (cache) {
console.log('Opened cache');
return cache.addAll(CACHE_FILES);
})
);
});
self.addEventListener('fetch', function (event) {
event.respondWith(
caches.match(event.request).then(function(res){
if(res){
return res;
}
requestBackend(event);
})
)
});
function requestBackend(event){
var url = event.request.clone();
return fetch(url).then(function(res){
//if not a valid response send the error
if(!res || res.status !== 200 || res.type !== 'basic'){
return res;
}
var response = res.clone();
caches.open(CACHE_VERSION).then(function(cache){
cache.put(event.request, response);
});
return res;
})
}
self.addEventListener('activate', function (event) {
event.waitUntil(
caches.keys().then(function(keys){
return Promise.all(keys.map(function(key, i){
if(key !== CACHE_VERSION){
return caches.delete(keys[i]);
}
}))
})
)
});
以下是我为解决该问题所做的工作。
我尝试在 fetch
事件侦听器中使用 Navigator.onLine API 检查应用程序是否在线,如果它在线,则提供来自服务器和 ServiceWorker
否则。这样,应用程序在线时请求就不会被阻止,从而解决了这个特定问题。
下面是我的实现方式。
self.addEventListener('fetch', function (event) {
let online = navigator.onLine;
if(!online){
event.respondWith(
caches.match(event.request).then(function(res){
if(res){
return res;
}
requestBackend(event);
})
)
}
});
您还可以在此处查看整个 ServiceWorker 脚本:https://github.com/amitmerchant1990/notepad/blob/master/sw.js
我已经在我的一些 Web 应用程序上实现了 ServiceWorker 以利用离线功能和与 ServiceWorkers 相关的其他一些好东西。现在,一切正常,直到我添加了一些外部嵌入式脚本。我在我的网络应用程序中添加了大约 3 个外部脚本。其中一些获取广告并将其显示在我的应用程序上,其中一些用于收集分析。
但是,令我惊讶的是,当启用 ServiceWorkers 时,每个外部脚本都会失败,并在控制台中抛出以下错误
我不确定为什么会这样?我是否必须在 ServiceWorker 中以某种方式缓存这些脚本?任何帮助将不胜感激。
这是我添加到我的应用程序中的 ServiceWorker 代码。
importScripts('js/cache-polyfill.js');
var CACHE_VERSION = 'app-v18';
var CACHE_FILES = [
'/',
'index.html',
'js/app.js',
'js/jquery.min.js',
'js/bootstrap.min.js',
'css/bootstrap.min.css',
'css/style.css',
'favicon.ico',
'manifest.json',
'img/icon-48.png',
'img/icon-96.png',
'img/icon-144.png',
'img/icon-196.png'
];
self.addEventListener('install', function (event) {
event.waitUntil(
caches.open(CACHE_VERSION)
.then(function (cache) {
console.log('Opened cache');
return cache.addAll(CACHE_FILES);
})
);
});
self.addEventListener('fetch', function (event) {
event.respondWith(
caches.match(event.request).then(function(res){
if(res){
return res;
}
requestBackend(event);
})
)
});
function requestBackend(event){
var url = event.request.clone();
return fetch(url).then(function(res){
//if not a valid response send the error
if(!res || res.status !== 200 || res.type !== 'basic'){
return res;
}
var response = res.clone();
caches.open(CACHE_VERSION).then(function(cache){
cache.put(event.request, response);
});
return res;
})
}
self.addEventListener('activate', function (event) {
event.waitUntil(
caches.keys().then(function(keys){
return Promise.all(keys.map(function(key, i){
if(key !== CACHE_VERSION){
return caches.delete(keys[i]);
}
}))
})
)
});
以下是我为解决该问题所做的工作。
我尝试在 fetch
事件侦听器中使用 Navigator.onLine API 检查应用程序是否在线,如果它在线,则提供来自服务器和 ServiceWorker
否则。这样,应用程序在线时请求就不会被阻止,从而解决了这个特定问题。
下面是我的实现方式。
self.addEventListener('fetch', function (event) {
let online = navigator.onLine;
if(!online){
event.respondWith(
caches.match(event.request).then(function(res){
if(res){
return res;
}
requestBackend(event);
})
)
}
});
您还可以在此处查看整个 ServiceWorker 脚本:https://github.com/amitmerchant1990/notepad/blob/master/sw.js