Angular Service Worker не кэширует почтовые запросы

Кто-нибудь знает, не кеширует ли сервисный работник angular почтовые запросы? Я интегрировал его в свое приложение, используя @angular 5.2.5, и он кэширует некоторые запросы, но некоторые из них являются сообщениями, а те, которые он не кэширует, даже если они соответствуют шаблону URL-адресов, который я указал. Вот мой ngsw-config.json

{
  "index": "/index.html",
  "assetGroups": [
    {
      "name": "app",
      "installMode": "prefetch",
      "resources": {
        "files": [
          "/favicon.ico",
          "/index.html"
        ],
        "versionedFiles": [
          "/*.bundle.css",
          "/*.bundle.js",
          "/*.chunk.js"
        ]
      }
    },
    {
      "name": "assets",
      "installMode": "lazy",
      "updateMode": "prefetch",
      "resources": {
        "files": [
          "/assets/**"
        ],
        "urls": [
          "**/fonts.googleapis.com/**/*",
          "**/www.gstatic.com/**/*"
        ]
      }
    }
  ],
  "dataGroups": [
    {
      "name": "api-performance",
      "urls": [
        "/api/attachments/*"
      ],
      "cacheConfig": {
        "maxSize": 200,
        "maxAge": "7d",
        "timeout": "10s",
        "strategy": "performance"
      }
    },
    {
      "name": "api-freshness",
      "urls": [
        "/api/*",
        "/api/**/*",
        "/api/**/**/*",
        "/api/**/**/**/*",
        "/api/views/*",
        "/api/app-structure",
        "/api/workflow/view",
        "/api/issues/*",
        "/.well-known",
        "/certs"
      ],
      "cacheConfig": {
        "maxSize": 200,
        "maxAge": "2d",
        "timeout": "10s",
        "strategy": "freshness"
      }
    }
  ]
}

Это добавлено только для тестирования, потому что / views не кэшируется и это почтовый запрос, и я попытался добавить whildcards для соответствия шаблону, но безуспешно "/api/*", "/api/**/*", "/api/**/**/*", "/api/**/**/**/*".

У меня проблемы с тестированием моего веб-сайта в производственной сборке с использованием Chrome, потому что для нашей внутренней производственной среды мы используем самоподписанную сертификацию. Кто-нибудь знает обходной путь для этого? Я попробовал этот ответ, но хром все еще показывает ошибки, и сервис-воркер не работает


person Nicu    schedule 25.05.2018    source источник


Ответы (2)


Angular Service Worker не кеширует запросы на публикацию, и это кажется мне правильным принципом проектирования. Если вы пытаетесь добавить запись в автономном режиме и хотите синхронизировать данные сервера при подключении к сети, вы можете попробовать использовать IndexedDb или PouchDb (база данных JavaScript, которая синхронизируется без проблем).

Вот несколько справочных статей, чтобы начать работу с PouchDB.

person Jeshwel    schedule 07.06.2018
comment
Кеш Service Worker не позволяет кэшировать запросы POST w3c.github.io/ServiceWorker/ # cache-put, так что это единственный путь вперед. - person JayChase; 22.11.2018

Это не проблема Angular, это связано с тем, как работают сервис-воркеры. На данный момент сервис-воркеры не кэшируют почтовые запросы. Следите за этим обсуждением для получения дополнительных сведений https://github.com/w3c/ServiceWorker/issues/977 < / а>

person Gabriel Vasile    schedule 30.07.2020