我正在尝试使用存储在 MSSQL varbinary(MAX) 字段中的 PDF 回复客户。该响应通过 http 连接在我的本地主机和测试服务器上工作,但在通过 https 连接的生产服务器上不起作用。我只使用了一个简单的 BinaryWrite(下面的代码)。
byte[] displayFile = DatabaseFiles.getPdfById(id);
Response.ContentType = "application/pdf";
Response.BinaryWrite(displayFile);
这里没有什么花哨的。只需抓取二进制数据,设置内容类型,然后写回客户端。为了以这种方式通过 https 进行响应,是否需要做任何特别的事情?
编辑:不起作用,我的意思是我在浏览器中得到一个空白文档。Acrobat 无法在浏览器中加载。
编辑:我刚刚注意到这个问题只发生在 IE 7 中。PDF 在 Firefox 3 中正确加载。我们的客户端专门使用 IE 7(比我说服他们升级的 IE 6 更好......哈哈)。
编辑:尝试添加标题“content-disposition”以使文件充当附件。浏览器无法在 SSL 下加载,并出现 IE 错误“Internet Explorer 无法从 ProductionServer.net 下载 displayFile.aspx”。(代码如下)
byte[] displayFile = DatabaseFiles.getPdfById(id);
Response.Clear();
Response.AddHeader("content-disposition", String.Format("attachment;filename={0}", fileName));
Response.ContentType = "application/pdf";
Response.BinaryWrite(displayFile);
编辑:如果在生产服务器上通过 http 查看文件,浏览器会显示 PDF 的代码,就像通过记事本查看它一样。(例如 %PDF-1.4 %âãÏÓ 6 0 obj <> endobj xref 6 33 ...等)