URLSession 缓存甚至在应用重启后
URLSession caching even after app restart
我刚刚遇到的事情完全改变了我在 iOS 中对 URLSession 缓存的印象。
我们正在达到一个只被击中过一次的终点。
重新启动应用程序不会再次到达端点。
删除应用程序会导致它再次到达端点...但只有一次。
响应的 header 包含...
Cache-Control public, max-age=1800
所以这取决于缓存。通过手动告诉 URLSession 忽略缓存,它会再次访问端点。
在文档中,它显示了缓存策略及其作为工作流程图的工作方式。
但是应用程序终止后缓存数据存储在哪里?该应用程序及其所有相关内容是否已从内存中删除?
URLSession 正在为其缓存系统使用 URLCache。它用于所有网络资源。您可以直接访问它或通过 URLSessionConfiguration 设置您自己的。 URLCache 的底层位置在文件系统上而不是在内存中。不过,有一种方法可以自己管理缓存。比方说,您的响应应该在设备上加密。有点不好的例子,但你明白了。 ;)
如果您需要对缓存进行更多控制,请阅读这篇文章manage cache programmatically。
我刚刚遇到的事情完全改变了我在 iOS 中对 URLSession 缓存的印象。
我们正在达到一个只被击中过一次的终点。
重新启动应用程序不会再次到达端点。
删除应用程序会导致它再次到达端点...但只有一次。
响应的 header 包含...
Cache-Control public, max-age=1800
所以这取决于缓存。通过手动告诉 URLSession 忽略缓存,它会再次访问端点。
在文档中,它显示了缓存策略及其作为工作流程图的工作方式。
但是应用程序终止后缓存数据存储在哪里?该应用程序及其所有相关内容是否已从内存中删除?
URLSession 正在为其缓存系统使用 URLCache。它用于所有网络资源。您可以直接访问它或通过 URLSessionConfiguration 设置您自己的。 URLCache 的底层位置在文件系统上而不是在内存中。不过,有一种方法可以自己管理缓存。比方说,您的响应应该在设备上加密。有点不好的例子,但你明白了。 ;)
如果您需要对缓存进行更多控制,请阅读这篇文章manage cache programmatically。