GZip用于Coldfusion输出的字符串导致浏览器中的“内容编码错误”

时间:2010-09-12 05:39:26

标签: java coldfusion gzip

我正在尝试在变量中GZip内容输出到浏览器。首先,我将这个变得非常简单,而不用担心不支持gzip的浏览器。此外,我通过研究我可以在网上找到的几种方法把它放在一起。其中一些人可能正在阅读这个问题。

<cfsavecontent variable="toGZIP"><html><head><title>Test</title></head><body><h1>Fear my test</h1></body></html></cfsavecontent>

<cfscript>
ioOutput = CreateObject("java","java.io.ByteArrayOutputStream");
gzOutput = CreateObject("java","java.util.zip.GZIPOutputStream");

ioOutput.init();
gzOutput.init(ioOutput);

gzOutput.write(toGZIP.getBytes("UTF-8"), 0, Len(toGZIP.getBytes()));

gzOutput.finish();
gzOutput.close();
ioOutput.flush();
ioOutput.close();

toOutput=ioOutput.toString("UTF-8");
</cfscript>

<cfcontent reset="yes" /><cfheader name="Content-Encoding" value="gzip"><cfheader name="Content-Length" value="#ArrayLen( toOuptut.getBytes() )#" ><cfoutput>#toOuptut#</cfoutput><cfabort />

但我在Firefox(以及Chrome和Safari)中收到错误

  

内容编码错误

     

您尝试查看的页面无法显示,因为它使用的是无效或不受支持的压缩形式。

有人有什么想法吗?

操作系统:Mac OX-X Snow Leopard
CF:9-Dev
网络服务器:Apache


<cfsavecontent variable="toGZIP"><html><head><title>Test</title></head><body><h1>Fear my test</h1></body></html></cfsavecontent>

<cfscript>
ioOutput = CreateObject("java","java.io.ByteArrayOutputStream");
gzOutput = CreateObject("java","java.util.zip.GZIPOutputStream");

ioOutput.init();
gzOutput.init(ioOutput);

gzOutput.write(toGZIP.getBytes(), 0, Len(toGZIP.getBytes()));

gzOutput.finish();
gzOutput.close();
ioOutput.flush();
ioOutput.close();

toOutput=ioOutput.toByteArray();
</cfscript>

<cfheader name="Content-Encoding" value="gzip"><cfheader name="Content-Length" value="#ArrayLen(toOutput)#" ><cfcontent reset="yes" variable="#toOutput#" /><cfabort />

3 个答案:

答案 0 :(得分:4)

以下行看起来完全错误:

toOutput=ioOutput.toString("UTF-8");

使用UTF8对GZip流进行编码。结果是垃圾数据。如果ColdFusion有选项,最好将GZip数据设置为二进制。如果只能设置字符串,那么您需要一个不会更改任何字节的编码。例如iso1。

答案 1 :(得分:1)

您是否有理由手动让Web服务器(IIS或Apache)处理此问题?它们都支持GZip编码,可能比你的手动过程更快,更好。

答案 2 :(得分:0)

请注意,您在代码中遇到语法错误:toOuptut而不是toOutput

不幸的是,我不是Java专家,也不能说出究竟是什么问题。但是当我尝试使用wget将内容保存到文件中时,它不包含压缩二进制文件,而是包含源HTML。这可能意味着与gzOutput相关的处理不会产生正确的输出。

BTW,验证GZip的浏览器支持非常简单。您可以查看Accept-Encoding标题,如下所示:

<cfif FindNoCase("gzip", cgi.HTTP_ACCEPT_ENCODING)>
    <!--- prepare the gzipped text --->
</cfif>