【发布时间】:2016-11-10 01:28:45
【问题描述】:
在 Firebug 中,请求标头具有以下条目:
Accept-Encoding: gzip, deflate
但是没有:
内容编码:gzip
在响应标头中。
无论我尝试过什么,按照 SO 和其他网站上的一些答案,似乎都没有任何效果!静态文件和动态文件都没有被压缩,或者至少如果它们没有内容编码 - gzip 值会在响应标头中返回。
这是我的 web.config 设置的示例:
<urlCompression doDynamicCompression="true" doStaticCompression="true" dynamicCompressionBeforeCache="true" />
<httpCompression directory="%SystemDrive%\inetpub\temp\IIS Temporary Compressed Files" minFileSizeForComp="150" staticCompressionIgnoreHitFrequency="true">
<remove name="gzip" />
<scheme name="gzip" dll="%Windir%\system32\inetsrv\gzip.dll" staticCompressionLevel="8" dynamicCompressionLevel="8" />
</httpCompression>
我忽略了点击频率staticCompressionIgnoreHitFrequency="true"
我已确认 IIS 实际上正在压缩我可以在以下位置看到的文件:
C:\inetpub\temp\IIS 临时压缩文件
此处指定:set up gzip in IIS 8 windows 8
我已确保在 Windows 功能 > Internet 信息服务 > WWW 服务 > 性能功能中启用了静态和动态压缩
我也试过这个人的方法:
IIS 7.5 Compression creates compressed file but returns the non-compressed one
编辑 1:
IIS 版本是 10,但我也在 IIS 8.5 上试过这个
编辑 2:
我现在还尝试了在此链接中找到的各种配置文件:
https://github.com/h5bp/server-configs-iis/ 提供了一些看起来像“最佳实践”的 web.config 文件。
未解决
编辑 3:
根据@Nkosi 的输入,我创建了一个全新的 Asp.net MVC 应用程序,并使用我尝试过的所有这些选项对其进行了配置。
这是我从 Fiddler 那里得到的原始标题:
HTTP/1.1 200 OK
Transfer-Encoding: chunked
Content-Type: text/javascript; charset=UTF-8
Expires: Wed, 20 Jul 2016 18:22:47 GMT
Last-Modified: Wed, 20 Jul 2016 18:22:47 GMT
Server: Microsoft-HTTPAPI/2.0
Date: Wed, 20 Jul 2016 18:22:47 GMT
如您所见,没有 Content-Encoding:Gzip
未解决
编辑 4:
我已经尝试过将代码添加到 Global.asax 部分中的 BeginRequest 事件的这种方法:https://stackoverflow.com/a/27185575/392591
未解决
编辑 5:
所以我只是尝试根据这个答案启用跟踪 SO:https://stackoverflow.com/a/33182525/392591
没有失败,但我确实注意到在跟踪文件的底部有一个名为 GENERAL_RESPONSE_HEADERS 的部分,它提供了以下内容:
Cache-Control: private
Content-Type: text/html; charset=utf-8
Content-Encoding: gzip
Server: Microsoft-IIS/10.0
X-AspNetMvc-Version: 5.2
X-AspNet-Version: 4.0.30319
X-Powered-By: My Little Pony
X-UA-Compatible: IE=Edge,chrome=1
这适用于每个静态类型文件。
但是我刚刚在跟踪文件中发现了以下内容:
8. STATIC_COMPRESSION_START 08:04:03.552
9. STATIC_COMPRESSION_NOT_SUCCESS Reason="NOT_FREQUENTLY_HIT" 08:04:03.552
10. STATIC_COMPRESSION_END 08:04:03.552
由于不经常命中的原因压缩不成功...奇怪,因为我肯定将忽略命中频率选项设置为真!
所以我刚刚进入 IIS 管理器并在服务器上将忽略命中频率设置为 true(即 applicationHost.config)并将跟踪文件输出更改为以下内容:
8. STATIC_COMPRESSION_START 08:19:17.489
9. STATIC_COMPRESSION_SUCCESS 08:19:17.489
10. STATIC_COMPRESSION_END 08:19:17.489
我返回并在 applicationHost.config 中将其关闭,然后它又返回静态压缩不成功,所以这肯定会有所作为。但是,当我查看 FireBug 时,它仍然交付未压缩的文件并且没有 GZIP 内容编码响应标头。
我在失败的请求跟踪中注意到的另一个有趣的一点是最后两个整体 GENERAL_FLUSH_RESPONSE_END 和 GENERAL_REQUEST_END 两者都显示我的 Bootstrap.css 文件发送了 17903 个字节,大约 18kb,与我在我的文件中看到的压缩版本相匹配IIS 临时压缩文件文件夹。所以文件正在物理上被压缩,根据失败的请求跟踪它正在发送正确的内容......但是浏览器会选择完整的 117kb 文件吗?
未解决
【问题讨论】:
-
我使用的是 IIS10,而我的 web.config 只有
<urlCompression doDynamicCompression="true" doStaticCompression="true" dynamicCompressionBeforeCache="false" />。当我测试从浏览器(Firefox、IE11、Edge、Google Chrome)到简单 MVC 应用程序的请求时。请求都有Accept-Encoding: gzip, deflate,响应返回Content-Encoding:gzip -
见this。也许您需要在服务器上启用 gzip 功能。
-
@LucasSegers - 该功能肯定已启用。
-
我遇到了同样的问题,失败的请求跟踪显示文件已被正确压缩。 GENERAL_FLUSH_RESPONSE_START 中显示了正确的响应标头,GENERAL_REQUEST_END 中显示了正确的大小,但浏览器仍在获取完整文件。
-
我遇到了同样的问题。有答案吗?
标签: asp.net iis http-compression iis-10