使用 ASP.NET 和 C# 将二进制文件写入浏览器

本文将创建一个示例页面,演示如何使用 C# 从文件中检索二进制数据,然后将数据写出浏览器。 尽管此演示使用 Adobe Acrobat (.pdf) 文件,但可以将此过程应用于其他二进制文件格式。

原始产品版本: ASP.NET
原始 KB 数: 306654

要求

  • Microsoft .NET Framework
  • Windows
  • Internet 信息服务器 (IIS)

使用 Visual C# 创建 ASP.NET Web 应用程序

本部分演示如何创建名为 BinaryDemo 的新 ASP.NET Web 应用程序:

  1. 打开 Microsoft Visual Studio。
  2. 从“文件”菜单中,指向“新建”,然后选择“项目”。
  3. 在“所有语言”下选择“C#”,在“所有平台”下选择“Windows”,然后在模板列表中选择 ASP.NET Web 应用程序(.NET Framework)。
  4. “名称” 文本框中,键入 BinaryDemo。 在 “位置” 文本框中,键入服务器名称。 如果使用本地服务器,请将位置保留为 http://localhost.

将 PDF 文件添加到项目

若要设置项目,以便可以在“创建 ASPX”页部分中添加和运行代码,必须先将 Adobe Acrobat (.pdf) 文件添加到当前项目。

若要将 PDF 文件添加到 Visual Studio 中的项目,请执行以下步骤:

  1. 解决方案资源管理器中,右键单击项目节点,选择“添加,然后选择“现有项”。
  2. 浏览到系统上.pdf文件的位置。
  3. 选择以突出显示文件,然后选择“ 打开”。
  4. 在 Visual Studio 解决方案资源管理器中,右键单击该文件,然后选择“重命名”。 重命名.pdf文件,使其与以下代码中使用的文件名 Acrobat.pdf 匹配。

此外,请确保 Adobe Acrobat Reader 安装在查看.aspx页面的客户端计算机上,以便浏览器能够正确读取和呈现二进制数据。 可以从 Adobe 网站下载 Adobe Acrobat Reader

创建 ASPX 页

  1. 将名为 BinaryData.aspx 的新.aspx页添加到当前项目,如下所示:

    1. 解决方案资源管理器中,右键单击项目节点,选择“添加新>>Web 窗体”。

    2. 将页面 命名为BinaryData.aspx,然后选择“ 添加”。

      注意

      请确保将页面添加到与在上一部分中添加的.pdf文件位于同一级别的项目。 这非常重要,因为代码使用相对路径最初引用.pdf文件。

  2. 解决方案资源管理器中,右键单击BinaryData.aspx,然后选择“查看代码”。

  3. 突出显示以下代码,右键单击代码,然后选择“ 复制”。 在Page_Load代码隐藏页上的事件中,选择“编辑”菜单上的“粘贴以粘贴代码:

    private void Page_Load(object sender, System.EventArgs e)
    {
        //Set the appropriate ContentType.
        Response.ContentType = "Application/pdf";
        //Get the physical path to the file.
        string FilePath = MapPath("acrobat.pdf");
        //Write the file directly to the HTTP content output stream.
        Response.WriteFile(FilePath);
        Response.End();
    }
    
  4. 在“文件”菜单上,单击“全部保存”。

  5. “生成 ”菜单上,选择“ 生成”。

  6. 若要运行代码,请在解决方案资源管理器中右键单击BinaryData.aspx,然后选择“在浏览器中查看”。 如果系统提示,请选择“ 打开 ”以打开并在浏览器中呈现文件。

如果要使用上述代码来支持其他二进制文件类型,则必须修改字符串中的 ContentType 值,以便指定适当的文件格式。 此字符串的语法的格式为 type/subtype,其中 type 常规内容类别是 subtype 特定的内容类型。

有关受支持的内容类型的完整列表,请参阅 Web 浏览器文档或当前的 HTTP 规范。 以下列表概述了一些常见 ContentType 值:

  • text/HTML
  • image/GIF
  • image/JPEG
  • text/plain
  • Application/msword (对于 Word 文件)
  • Application/x-msexcel (对于 Excel 文件)

参考

有关详细信息,请访问以下网站:

有关本文的 Visual Basic .NET 版本,请参阅 使用 ASP.NET 和 Visual Basic .NET 将二进制文件写入浏览器。

第三方信息免责声明

本文中提到的第三方产品由 Microsoft 以外的其他公司提供。 Microsoft 不对这些产品的性能或可靠性提供任何明示或暗示性担保。