У меня есть базовый сервисный работник, который возвращает автономную страницу, когда нет подключения к интернету.Везде, где веб-сайт возвращает перенаправление 302, сайт будет поврежден из-за работника службы, независимо от того, находится ли он в сети в автономном режиме.
Работник службы:
'use strict';
var cache_key = 'offline_cache_v18';
this.addEventListener('install', event => {
event.waitUntil(
caches.open(cache_key).then(function(cache) {
return cache.addAll([
'/offline.html'
]);
})
);
});
this.addEventListener('fetch', event => {
if (event.request.mode === 'navigate' || (event.request.method === 'GET' && event.request.headers.get('accept').includes('text/html')) ) {
event.respondWith(
fetch(event.request.url).catch(error => {
return caches.match('/offline.html');
})
);
} else {
event.respondWith(caches.match(event.request).then(function (response) {
return response || fetch(event.request);
}));
}
});
Страница, которая разрывает работника службы:
<?php header('Location: /'); ?>
Ожидаемый результат: страницы загружаются как обычно, кроме случаев, когда они отключены, гдеoffline.html должен быть представлен.
Фактический результат: сайт не загружается полностью на страницах, которые отвечают перенаправлением 302, ссылаясь на «Этот сайт не доступен».Консоль также сообщает: «FetchEvent привел к сетевому ответу об ошибке: перенаправленный ответ был использован для запроса, режим перенаправления которого не« следует ». '
Попытка: проверка кода ответа с помощью response.status,и также попытался переключить код для использования библиотеки «workbox».Также пробовал {redirect: 'follow'} параметры, но теперь он выглядит достаточно продвинутым для чего-то такого простого.Похоже, что во всех руководствах по автономной странице есть такая же ошибка.