AppCache 삭제 준비

Chrome 85에서는 기본적으로 AppCache 지원이 삭제됩니다. 대부분의 개발자는 지금 AppCache에서 이전해야 하며 더 이상 기다려서는 안 됩니다.

이전 공지사항에 따라 Chrome 및 기타 Chromium 기반 브라우저에서 AppCache 지원이 삭제됩니다. 개발자는 더 이상 기다리지 말고 지금 AppCache에서 이전하는 것이 좋습니다.

현재 브라우저에서 널리 지원되는 서비스 워커는 AppCache에서 제공했던 오프라인 환경을 제공하는 대안을 제공합니다. 마이그레이션 전략을 참고하세요.

타임라인

Chrome 출시 일정의 최근 변경사항으로 인해 이러한 단계의 시기가 달라질 수 있습니다. 이 타임라인을 최신 상태로 유지하려고 노력하겠지만, 지금은 특정 주요 이벤트를 기다리지 말고 최대한 빨리 AppCache에서 이전하세요.

'지원 중단'된 기능은 여전히 존재하지만 사용을 권장하지 않는 경고 메시지를 기록합니다. '삭제된' 기능은 더 이상 브라우저에 존재하지 않습니다.

비보안 컨텍스트에서 지원 중단 Chrome 50 (2016년 4월)
비보안 컨텍스트에서 삭제 Chrome 70 (2018년 10월)
보안 컨텍스트의 지원 중단 Chrome 79 (2019년 12월)
AppCache 범위 제한 Chrome 80 (2020년 2월)
'리버스' 오리진 트라이얼 시작 Chrome 84 (2020년 7월)
오리진 트라이얼을 선택한 경우를 제외하고 보안 컨텍스트에서 삭제 Chrome 85 (2020년 8월)
출처 트라이얼 완료 시 모든 사용자의 보안 컨텍스트에서 완전히 삭제 2021년 10월 5일 (대략 Chrome 95)

오리진 트라이얼

타임라인에 삭제 예정인 두 가지 마일스톤이 표시됩니다. Chrome 85부터는 Chrome에서 AppCache를 기본적으로 사용할 수 없습니다. AppCache에서 이전하는 데 추가 시간이 필요한 개발자는 '역방향' 오리진 트라이얼가입하여 웹 앱의 AppCache 사용 가능 시간을 연장할 수 있습니다. 오리진 트라이얼은 Chrome 84에서 시작되며 (Chrome 85의 기본 삭제에 앞서) 2021년 10월 5일 (대략 Chrome 95)까지 활성화됩니다. 이 시점에는 오리진 트라이얼에 등록한 사용자를 포함한 모든 사용자의 AppCache가 완전히 삭제됩니다.

'역방향' 오리진 트라이얼에 참여하려면 다음 단계를 따르세요.

  1. 출처의 토큰을 요청합니다.
  2. HTML 페이지에 토큰을 추가합니다. 다음과 같은 두 가지 방법이 있습니다.
    • 각 페이지의 헤드에 origin-trial <meta> 태그를 추가합니다. 예를 들면 <meta http-equiv="origin-trial" content="TOKEN_GOES_HERE">입니다.
    • 또는 Origin-Trial HTTP 헤더가 포함된 응답을 반환하도록 서버를 구성합니다. 결과 응답 헤더는 다음과 같이 표시됩니다. Origin-Trial: TOKEN_GOES_HERE
  3. AppCache 매니페스트에 동일한 토큰을 추가합니다. 매니페스트의 새 필드를 통해 다음 형식으로 이를 실행합니다.
ORIGIN-TRIAL:
TOKEN_GOES_HERE

(ORIGIN-TRIAL과 토큰 사이에 새 줄이 있어야 합니다.)

토큰이 여러 위치에 필요한 이유는 무엇인가요?

동일 출처 트라이얼 토큰은 다음 항목과 연결되어야 합니다.

  • AppCache를 사용하는 모든 HTML 페이지
  • ORIGIN-TRIAL 매니페스트 필드를 통해 모든 AppCache 매니페스트

이전에 오리진 트라이얼에 참여한 적이 있다면 HTML 페이지에만 토큰을 추가했을 수 있습니다. AppCache '역방향' 오리진 트라이얼은 토큰을 각 AppCache 매니페스트와 연결해야 한다는 점에서 특별합니다.

HTML 페이지에 오리진 트라이얼 토큰을 추가하면 웹 앱 내에서 window.applicationCache 인터페이스를 사용할 수 있습니다. 토큰과 연결되지 않은 페이지는 window.applicationCache 메서드와 이벤트를 사용할 수 없습니다. 토큰이 없는 페이지는 AppCache에서 리소스를 로드할 수 없습니다. Chrome 85부터는 AppCache가 없는 것처럼 동작합니다.

AppCache 매니페스트에 오리진 트라이얼 토큰을 추가하면 각 매니페스트가 여전히 유효함을 나타냅니다. Chrome 85부터 ORIGIN-TRIAL 필드가 없는 매니페스트는 형식이 잘못된 것으로 처리되며 매니페스트 내의 규칙이 무시됩니다.

오리진 트라이얼 배포 시기 및 물류

'리버스' 오리진 트라이얼은 Chrome 84에서 공식적으로 시작되지만 지금 오리진 트라이얼에 등록하고 HTML 및 AppCache 매니페스트에 토큰을 추가할 수 있습니다. 웹 앱의 잠재고객이 Chrome 84로 점진적으로 업그레이드되면 이미 추가한 토큰이 적용됩니다.

AppCache 매니페스트에 토큰을 추가한 후 about://appcache-internals를 방문하여 Chrome (버전 84 이상)의 로컬 인스턴스가 오리진 트라이얼 토큰을 매니페스트의 캐시된 항목과 올바르게 연결했는지 확인합니다. 오리진 트라이얼이 인식되면 매니페스트와 연결된 Token Expires: Tue Apr 06 2021... 필드가 해당 페이지에 표시됩니다.

인식된 토큰을 보여주는 about://appcache-internals 인터페이스

삭제 전 테스트

가능한 한 빨리 AppCache에서 마이그레이션하는 것이 좋습니다. 웹 앱에서 AppCache 삭제를 테스트하려면 about://flags/#app-cache 플래그를 사용하여 삭제를 시뮬레이션하세요. 이 플래그는 Chrome 84부터 사용할 수 있습니다.

마이그레이션 전략

현재 브라우저에서 널리 지원되는 서비스 워커는 AppCache에서 제공하는 오프라인 환경의 대안을 제공합니다.

AppCache의 전체 인터페이스를 복제하지는 않지만 서비스 워커를 사용하여 AppCache의 일부 기능을 복제하는 polyfill이 제공됩니다. 특히 window.applicationCache 인터페이스나 관련 AppCache 이벤트를 대체하지는 않습니다.

더 복잡한 경우에는 Workbox와 같은 라이브러리를 사용하면 웹 앱용 최신 서비스 워커를 쉽게 만들 수 있습니다.

서비스 워커와 AppCache는 상호 배타적입니다.

이전 전략을 수립할 때 Chrome에서는 서비스 워커의 제어 하에 로드되는 페이지에서 AppCache 기능을 사용 중지한다는 점에 유의하세요. 즉, 특정 페이지를 제어하는 서비스 워커를 배포하는 즉시 해당 페이지에서 AppCache를 더 이상 사용할 수 없습니다.

따라서 서비스 워커를 조금씩 마이그레이션하지 않는 것이 좋습니다. 캐싱 로직의 일부만 포함하는 서비스 워커를 배포하는 것은 실수입니다. AppCache를 사용하여 '격차를 해소'할 수 없습니다.

마찬가지로 AppCache 삭제 전에 서비스 워커를 배포한 후 이전 AppCache 구현으로 롤백해야 하는 경우 해당 서비스 워커를 등록 해제해야 합니다. 특정 페이지의 범위에 등록된 서비스 워커가 있는 한 AppCache는 사용되지 않습니다.

크로스 플랫폼 스토리

AppCache 삭제 계획에 관해 자세히 알아보려면 특정 브라우저 공급업체에 문의하시기 바랍니다.

모든 플랫폼의 Firefox

Firefox는 버전 44 (2015년 9월)에서 AppCache를 지원 중단했으며 2019년 9월부터 베타 및 야간 빌드에서 지원을 삭제했습니다.

iOS 및 macOS 기반 Safari

Safari는 2018년 초에 AppCache를 지원 중단했습니다.

iOS의 Chrome

iOS용 Chrome은 다른 플랫폼의 Chrome과 다른 브라우저 엔진인 WKWebView를 사용하므로 특별한 경우입니다. 현재 서비스 워커는 WKWebView를 사용하는 iOS 앱에서 지원되지 않으며 Chrome의 AppCache 삭제 공지사항에는 iOS용 Chrome의 AppCache 사용 가능 여부가 포함되지 않습니다. 웹 앱에 Chrome for iOS 사용자가 많은 경우 이 점을 염두에 두세요.

Android WebView

Android 애플리케이션의 일부 개발자는 Chrome WebView를 사용하여 웹 콘텐츠를 표시하며 AppCache를 사용할 수도 있습니다. 하지만 WebView의 경우 오리진 트라이얼을 사용 설정할 수 없습니다. 이에 따라 Chrome WebView는 Chrome 90에서 최종 삭제가 이루어질 때까지 오리진 트라이얼 없이 AppCache를 지원합니다.

자세히 알아보기

다음은 AppCache에서 서비스 워커로 이전하는 개발자를 위한 몇 가지 리소스입니다.

기사

도구

도움 받기

특정 도구를 사용하는 중에 문제가 발생하면 해당 도구의 GitHub 저장소에서 문제를 여세요.

html5-appcache 태그를 사용하여 Stack Overflow에서 AppCache에서 마이그레이션하는 방법에 관한 일반적인 질문을 할 수 있습니다.

Chrome의 AppCache 삭제와 관련된 버그가 발생하면 Chromium 문제 추적기를 사용하여 신고하세요.

Smithsonian Institution Archives, Acc. 11-007, Box 020, Image No. MNH-4477.