【问题标题】:Firefox stored cached incomplete responseFirefox 存储缓存的不完整响应
【发布时间】:2015-07-07 12:07:36
【问题描述】:

我刚刚发现部分响应在我们客户的一台机器中被缓存为完整的,这导致整个网站无法使用。而且我完全不知道,那里可能出了什么问题。

那么在以下设置中可能出了什么问题?

在服务器端,我们正在运行一个 ASP.NET 应用程序。一个 IHttpHandler 处理对 javascript 文件的请求。它基本上会在请求文件时缩小文件并将结果写入响应流。它还会记录写入响应流的字符串的长度:

String javascript = /* Javascript is retrieved here */;
HttpResponse response = context.Response;
response.ContentEncoding = Encoding.UTF8;
response.ContentType = "application/javascript";
HttpCachePolicy cache = response.Cache;
cache.SetCacheability(HttpCacheability.Public);
cache.SetMaxAge(TimeSpan.FromDays(300));
cache.SetETag(ETag);
cache.SetExpires(DateTime.Now.AddDays(300));
cache.SetLastModified(LastModified);
cache.SetRevalidation(HttpCacheRevalidation.None);
response.Headers.Add("Vary", "Accept-Encoding");
Log.Info("{0} characters sent", javascript.length);
response.Write(javascript);
response.Flush();
response.End();

然后通常使用带有分块传输编码的 gzip 编码发送内容。对我来说似乎很简单。

不幸的是,我刚刚与一个用户进行了远程会话,其中只有大约 1/3 的文件在缓存中,这当然破坏了文件(15k 而不是 44k)。在缓存中,内容编码也设置为 gzip,所有通信都通过 https 进行。

在用户机器上打开源文件后,我只需按 Ctrl-F5 即可立即显示全部内容。

可能出了什么问题?

如果有问题,请在下面找到来自 Firefox 的缓存条目:

Cache entry information
key:    <resource-url>
fetch count:    49
last fetched:   2015-04-28 15:31:35
last modified:  2015-04-27 15:29:13
expires:    2016-02-09 14:27:05
Data size:  15998 B
Security:   This is a secure document.
security-info: (...)
request-method:     GET
request-Accept-Encoding:    gzip, deflate
response-head:  HTTP/1.1 200 OK
Cache-Control: public, max-age=25920000
Content-Type: application/javascript; charset=utf-8
Content-Encoding: gzip
Expires: Tue, 09 Feb 2016 14:27:12 GMT
Last-Modified: Tue, 02 Jan 2001 11:00:00 GMT
Etag: W/"0"
Vary: Accept-Encoding
Server: Microsoft-IIS/8.0
X-AspNet-Version: 4.0.30319
Date: Wed, 15 Apr 2015 13:27:12 GMT
necko:classified:   1

【问题讨论】:

  • 更新:一段时间后,我放弃了。缩小的 js 文件现在以唯一名称写入文件系统,并由 IIS 从那里直接提供服务。从那以后这个问题就没有发生过。

标签: asp.net-mvc http caching https


【解决方案1】:

您的客户端浏览器很可能正在缓存 JavaScript 文件,这意味着您的脚本的 src 不会改变。

例如,如果您要请求 myScripts

<script src="/myScripts.js">

然后,第一次,客户端会请求该文件,之后浏览器会读取其缓存。

您需要在脚本末尾附加某种唯一值,例如时间戳,这样即使浏览器缓存了文件,新的时间戳也会像新文件名一样。

客户端在按下 Ctrl+F5 后会收到新脚本,因为这是清空浏览器缓存的快捷方式。

MVC 有一个非常好的方法来执行此操作,它涉及附加一个唯一的代码,该代码在每次应用程序或其应用程序池重新启动时都会更改。查看MVC Bundling and Minification

希望这会有所帮助!

【讨论】:

  • 我已经完成了所有版本控制:对于特定的 URL,服务器将始终返回相同的 javascript。如果 Javascript 发生变化,则 script-tag 中的 src 也会发生变化。但不幸的是,客户端仍然只缓存了实际内容的三分之一(内容只是停在一个字符串的中间,而引号是打开的)。
猜你喜欢
  • 2012-05-09
  • 1970-01-01
  • 2017-06-14
  • 2015-06-01
  • 1970-01-01
  • 2018-11-23
  • 2013-12-08
  • 2013-09-05
  • 1970-01-01
相关资源
最近更新 更多