Эта страница ошибок не так проста для управления Drupal. Обычно он создается 500 ответами от сервера. Но мне удалось сделать это на одном из моих сайтов с помощью работника службы .
- Создать пользовательскую страницу HTML для вашей новой страницы 500 error spla sh .
- Создание базового c работника службы, который кэширует эту страницу и возвращает ее в случае ошибки 500.
Пример:
const filesToCache = [
'/500.html'
];
const staticCacheName = '0.0';
self.addEventListener('install', event => {
event.waitUntil(
caches.open(staticCacheName)
// Cache all of the configured files.
.then(cache => {
return cache.addAll(filesToCache);
})
// Force an update of the service worker, if need be.
.then(function() {
return self.skipWaiting();
})
);
});
// Delete outdated cache.
self.addEventListener('activate', event => {
const cacheWhitelist = [staticCacheName];
event.waitUntil(
caches.keys().then(cacheNames => {
return Promise.all(
cacheNames.map(cacheName => {
if (cacheWhitelist.indexOf(cacheName) === -1) {
return caches.delete(cacheName);
}
})
);
})
);
});
// Serve appropriate error pages from cache.
self.addEventListener('fetch', event => {
event.respondWith(
caches.match(event.request)
.then(response => {
if (response) {
return response;
}
return fetch(event.request)
.then(response => {
if (response.status === 500) {
return caches.match('/500.html');
}
return caches.open(staticCacheName)
});
})
);
});
Добавьте работника службы в
<body>
вашего
html.html.twig
файла вашей темы (или другого сопоставимого места):
<script>
if ('serviceWorker' in navigator) {
window.addEventListener('load', () => {
navigator.serviceWorker.register('/service-worker.js')
.then(swReg => {
console.log('Service Worker is registered', swReg);
})
.catch(err => {
console.error('Service Worker Error', err);
});
});
}
</script>