IIS7 - 在ASP中指定内容长度标头会导致"连接重置"错误

Mis*_*mbu 7 iis iis-7 asp-classic content-length

我正在将一系列网站从现有的IIS5服务器迁移到全新的IIS7 Web服务器.其中一个页面从数据库中的blob中提取数据文件并将其提供给最终用户:

Response.ContentType = rs("contentType")
Response.AddHeader "Content-Disposition", "attachment;filename=" & Trim(rs("docName"))&rs("suffix")' let the browser know the file name
Response.AddHeader "Content-Length", cstr(rs("docsize"))' let the browser know the file size
Run Code Online (Sandbox Code Playgroud)

在新的IIS7安装中进行测试,我在Internet Explorer和Firefox中都出现"连接重置"错误.如果删除Content-Length标头,则文档会正确提供(但用户将无法获得有用的进度条).

关于如何纠正这个问题的任何想法; 无论是服务器配置选项还是通过代码?

编辑1:多做了一些试验和错误.如果"启用缓冲"和"启用分块编码"都为假,则请求将成功.如果其中任何一个启用,则会发生错误.

编辑2:更多试验和错误测试; 事实证明,文本文件可以正常使用脚本; 只有二​​进制文件(图像,pdf等)才会失败.否则仍然完全无能为力.

Bok*_*ius 8

正如其他地方已经提到的:http://en.wikipedia.org/wiki/Chunked_transfer_encoding

它使用Transfer-Encoding HTTP响应头代替Content-Length头,否则协议将需要该头.由于未使用Content-Length标头,因此服务器在开始向客户端(通常是Web浏览器)发送响应之前不需要知道内容的长度.在知道该内容的总大小之前,Web服务器可以开始使用动态生成的内容传输响应.

在IIS7中,默认情况下启用此功能:http://technet.microsoft.com/en-us/library/cc730855(v = ws.10) .aspx

要为万维网发布服务启用HTTP 1.1分块传输编码,请使用以下语法:

appcmd set config/section:asp/enableChunkedEncoding:True | False

True启用HTTP 1.1分块传输编码,而False禁用HTTP 1.1分块传输编码.默认值是true.

我们有同样的问题,我们的解决方案:删除AddHeader"Content-Length"

  • 同样的问题和解决方案.对于它的价值,您可以将"内容长度"更改为"内容大小"并且它将起作用,尽管客户端可能无法识别(现已弃用)标头. (2认同)