This documentation is archived and is not being maintained.

HttpResponse.WriteFile Method (String, Int64, Int64)

Writes the specified file directly to an HTTP response output stream.

Namespace:  System.Web
Assembly:  System.Web (in System.Web.dll)

public void WriteFile(
	string filename,
	long offset,
	long size
)

Parameters

filename
Type: System.String

The name of the file to write to the HTTP output stream.

offset
Type: System.Int64

The byte position in the file where writing will start.

size
Type: System.Int64

The number of bytes to write to the output stream.

ExceptionCondition
HttpException

offset is less than 0.

- or -

size is greater than the file size minus offset.

When this method is used with large files, calling the method might throw an exception. The size of the file that can be used with this method depends on the hardware configuration of the Web server. For more information, see article 812406, "PRB: Response.WriteFile Cannot Download a Large File" on the Microsoft Knowledge Base Web site.

The following example writes all the contents of a text file named Login.txt (which might contain literal text and HTML input controls) directly to the output stream.

String FileName;
 FileInfo MyFileInfo;
 long StartPos = 0, FileSize;

 FileName = "c:\\temp\\login.txt";
 MyFileInfo = new FileInfo(FileName);
 FileSize = MyFileInfo.Length;

 Response.Write("Please Login: <br>");
 Response.WriteFile(FileName, StartPos, FileSize);

Windows 7, Windows Vista, Windows XP SP2, Windows XP Media Center Edition, Windows XP Professional x64 Edition, Windows XP Starter Edition, Windows Server 2008 R2, Windows Server 2008, Windows Server 2003, Windows Server 2000 SP4, Windows Millennium Edition, Windows 98

The .NET Framework and .NET Compact Framework do not support all versions of every platform. For a list of the supported versions, see .NET Framework System Requirements.

.NET Framework

Supported in: 3.5, 3.0, 2.0, 1.1, 1.0
Show: