![Распространение Cloudfront с приложениями React и WordPress, размещенными на одном домене — как заставить браузеры с кэшированным приложением React отображать приложение WordPress?](https://rvso.com/image/769274/%D0%A0%D0%B0%D1%81%D0%BF%D1%80%D0%BE%D1%81%D1%82%D1%80%D0%B0%D0%BD%D0%B5%D0%BD%D0%B8%D0%B5%20Cloudfront%20%D1%81%20%D0%BF%D1%80%D0%B8%D0%BB%D0%BE%D0%B6%D0%B5%D0%BD%D0%B8%D1%8F%D0%BC%D0%B8%20React%20%D0%B8%20WordPress%2C%20%D1%80%D0%B0%D0%B7%D0%BC%D0%B5%D1%89%D0%B5%D0%BD%D0%BD%D1%8B%D0%BC%D0%B8%20%D0%BD%D0%B0%20%D0%BE%D0%B4%D0%BD%D0%BE%D0%BC%20%D0%B4%D0%BE%D0%BC%D0%B5%D0%BD%D0%B5%20%E2%80%94%20%D0%BA%D0%B0%D0%BA%20%D0%B7%D0%B0%D1%81%D1%82%D0%B0%D0%B2%D0%B8%D1%82%D1%8C%20%D0%B1%D1%80%D0%B0%D1%83%D0%B7%D0%B5%D1%80%D1%8B%20%D1%81%20%D0%BA%D1%8D%D1%88%D0%B8%D1%80%D0%BE%D0%B2%D0%B0%D0%BD%D0%BD%D1%8B%D0%BC%20%D0%BF%D1%80%D0%B8%D0%BB%D0%BE%D0%B6%D0%B5%D0%BD%D0%B8%D0%B5%D0%BC%20React%20%D0%BE%D1%82%D0%BE%D0%B1%D1%80%D0%B0%D0%B6%D0%B0%D1%82%D1%8C%20%D0%BF%D1%80%D0%B8%D0%BB%D0%BE%D0%B6%D0%B5%D0%BD%D0%B8%D0%B5%20WordPress%3F.png)
У меня есть домен, на котором размещен сайт React в контейнере s3 через Cloudfront. Также есть сайт WordPress, размещенный на поддомене этого домена, и в дистрибутиве Cloudfront для веб-приложения у меня есть два поведения, настроенных с шаблонами пути, en
которые en/*
настроены с поддоменом Wordpress в качестве источника.
Эта настройка, кажется, работает при посещении en/*
путей в режиме инкогнито и в браузерах, которые никогда не посещали основной домен. Однако в браузере, который посещал домен ранее, браузер отображает приложение React вместо страницы WordPress. Очистка кэша и жесткая перезагрузка заставляют его отображать страницу WordPress, но последующее обновление снова отображает веб-приложение. Это происходит очень последовательно.
Когда приложение React отображается по URL-адресу, который должен отображать приложение WordPress, я получаю следующий заголовок ответа:
x-cache: RefreshHit from cloudfront
Кроме того, хотя браузер, который никогда не посещал приложение React, будет правильно загружать приложение WordPress при посещении пути, начинающегося с /en
, после того как этот браузер посетил приложение React, пути, начинающиеся с , /en
больше не будут отображать приложение WordPress.
Что именно здесь происходит? И есть ли способ заставить его отображать приложение WordPress последовательно, без необходимости для пользователей полностью очищать кэш браузера? Есть ли способ очистить соответствующий элемент кэша с помощью javascript, чтобы я мог сделать это из приложения React, когда оно обнаруживает, что находится на одном из этих путей?
решение1
Проблема оказалась не связана с моей конфигурацией cloudfront или s3, а была вызвана тем, что service worker, запущенный приложением react, перехватывал все запросы к домену после своего запуска. Удаление service worker (что я смог сделать, так как он больше не нужен) решило проблему.