在 Firebug 中,请求标头具有以下条目:
Accept-Encoding: gzip, deflate
但是没有:
Content-Encoding: 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 Temporary Compressed Files
如此处指定:在 IIS 8 windows 8 中设置 gzip
我已确保在 Windows 功能 > Internet 信息服务 > WWW 服务 > 性能功能中启用了静态和动态压缩
我也试过这个人的方法:
IIS 7.5 Compression 创建压缩文件但返回非压缩文件
编辑 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:
所以我只是尝试根据以下答案启用跟踪: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 文件吗?
未解决