Edit

Share via


Use ASP.NET and C# to write binary files to the browser

This article creates a sample page that demonstrates how to use C# to retrieve binary data from a file and then write the data out to the browser. Although this demonstration uses an Adobe Acrobat (.pdf) file, you can apply this procedure to other binary file formats.

Original product version:   ASP.NET
Original KB number:   306654

Requirements

  • Microsoft .NET Framework
  • Windows
  • Internet Information Server (IIS)

Use Visual C# to create an ASP.NET web application

This section demonstrates how to create a new ASP.NET web application named BinaryDemo:

  1. Open Microsoft Visual Studio.
  2. From the File menu, point to New, and then select Project.
  3. Select C# under All languages, Windows under All platforms, and then select ASP.NET Web Application(.NET Framework) in the templates list.
  4. In the Name text box, type BinaryDemo. In the Location text box, type the server name. If you're using the local server, leave the location as http://localhost.

Add the PDF file to the project

To set up your project so that you can add and run the code in the Create the ASPX page section, you must first add an Adobe Acrobat (.pdf) file to your current project.

To add the PDF file to the project in Visual Studio, follow these steps:

  1. In Solution Explorer, right-click the project node, select Add, and then select Existing Item.
  2. Browse to the location of a .pdf file on your system.
  3. Select to highlight the file, and then select Open.
  4. In Visual Studio Solution Explorer, right-click the file, and then select Rename. Rename the .pdf file so that it matches the file name Acrobat.pdf that is used in the code that follows.

In addition, ensure that Adobe Acrobat Reader is installed on the client computer from which the .aspx page is viewed so that the browser can properly read and render the binary data. You can download the Adobe Acrobat Reader from Adobe Web site.

Create the ASPX page

  1. Add a new .aspx page named BinaryData.aspx to the current project as follows:

    1. In Solution Explorer, right-click the project node, select Add > New Item > Web Form.

    2. Name the page BinaryData.aspx, and then select Add.

      Note

      Make sure that your page is added to the project at the same level as the .pdf file that you added in the previous section. This is very important because the code uses the relative path to initially reference the .pdf file.

  2. In the Solution Explorer, right-click BinaryData.aspx, and then select View Code.

  3. Highlight the following code, right-click the code, and then select Copy. In the Page_Load event on the code-behind page, select Paste on the Edit menu to paste the code:

    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. On the File menu, select Save All.

  5. On the Build menu, select Build.

  6. To run the code, right-click BinaryData.aspx in Solution Explorer, and then select View In Browser. If you're prompted, select Open to open and render the file in the browser.

If you want to use the preceding code to support other binary file types, you must modify the value in the ContentType string so that it specifies the appropriate file format. The syntax of this string is formatted as type/subtype, where type is the general content category and subtype is the specific content type.

For a full list of supported content types, refer to your web browser documentation or the current HTTP specification. The following list outlines some common ContentType values:

  • text/HTML
  • image/GIF
  • image/JPEG
  • text/plain
  • Application/msword (for Word files)
  • Application/x-msexcel (for Excel files)

References

For more information, visit below sites:

For a Visual Basic .NET version of this article, see Write binary files to the browser by using ASP.NET and Visual Basic .NET.

Third-party information disclaimer

The third-party products that this article discusses are manufactured by companies that are independent of Microsoft. Microsoft makes no warranty, implied or otherwise, about the performance or reliability of these products.