Response.ContentType :控制输出的文件类型
2008-11-23 11:17
459 查看
服务器送给客户端的数据包类型可以是text/html文本,也可以是gif/jpeg图形文件,所以每次传输前,我们都必须告知客户端将要传输的文件类型,一般默认情况下为“Text/Html”类型。
<% Response.ContentType = "text/HTML" %>
<% Response.ContentType = "image/GIF" %>
<% Response.ContentType = "image/JPEG" %>
<% Response.ContentType = "text/plain" %>
<% Response.ContentType = "image/JPEG" %>
<% Response.ContentType = "application/x-cdf" %>
用于作为文本内容返回而不是已解释的 HTML 语句
Response.ContentType = "text/plain"
你可以注意到:页面提供下载,页面中的ASP内容被解释执行了的
程序文件以XLS文件被提供下载
Response.ContentType = "application/vnd.ms-excel"
实现歌曲连续播放
response.ContentType="audio/x-pn-realaudio"
response.write 输出的时候,由于定义了response.ContentType 所以输出歌曲地址的时候会自动调用符合相应格式的软件来播放歌曲,不过前提是播放歌曲的软件必须先安装的。
以上文章转贴自http://www.w269.com/infow269/1145w2691.htm
这里我想讨论一下,这么也东东。
Q:如何利用ContentType 来,在服务器上提供一个.xls后缀的文件点击下载而不是直接在浏览器中打开。(注意:于上程序文件以XLS文件被提供下载有所不同)
Response.ContentType = "application/x-download",让整个程序文件点击下载了。怎么办好呢???
A:解决方案1. 利用Response.WriteFile的文件输出操作
具体在按钮点击事件中添加一下代码
private void btnDownload_Click(object sender, System.EventArgs e)
{
string DownloadFileName=Server.MapPath("file.xls");
string filepath = DownloadFileName;
// Identify the file name.
string filename = System.IO.Path.GetFileName(filepath);
Response.Clear();
// Specify the Type of the downloadable file.
Response.ContentType = "application/octet-stream";
// Set the Default file name in the FileDownload dialog box.
Response.AddHeader("Content-Disposition", "attachment; filename=" + filename);
Response.Flush();
// Download the file.
Response.WriteFile(filepath);
}
以上代码也适合用于小于100MB的小文件下载
如果是大于100MB的大文件下载可以用Response.FileStream 。
C#代码如下:(将 DownloadFileName 替换为大于 100 MB 的文件的名称。)
System.IO.Stream iStream = null;
// Buffer to read 10K bytes in chunk:
byte[] buffer = new Byte[10000];
// Length of the file:
int length;
// Total bytes to read:
long dataToRead;
// Identify the file to download including its path.
string filepath = "DownloadFileName";
// Identify the file name.
string filename = System.IO.Path.GetFileName(filepath);
try
{
// Open the file.
iStream = new System.IO.FileStream(filepath, System.IO.FileMode.Open,
System.IO.FileAccess.Read,System.IO.FileShare.Read);//用文件流来处理
// Total bytes to read:
dataToRead = iStream.Length;
Response.ContentType = "application/octet-stream";//问题就在这里,解决百M关口
Response.AddHeader("Content-Disposition", "attachment; filename=" + filename);
// Read the bytes.
while (dataToRead > 0)
{
// Verify that the client is connected.
if (Response.IsClientConnected)
{
// Read the data in buffer.
length = iStream.Read(buffer, 0, 10000);
// Write the data to the current output stream.
Response.OutputStream.Write(buffer, 0, length);
// Flush the data to the HTML output.
Response.Flush();
buffer= new Byte[10000];
dataToRead = dataToRead - length;
}
else
{
//prevent infinite loop if user disconnects
dataToRead = -1;
}
}
}
catch (Exception ex)
{
// Trap the error, if any.
Response.Write("Error : " + ex.Message);
}
finally
{
if (iStream != null)
{
//Close the file.
iStream.Close();
}
}
参考:PRB:Response.WriteFile 无法下载大文件
http://support.microsoft.com/default.aspx?scid=kb;zh-cn;812406#2
<% Response.ContentType = "text/HTML" %>
<% Response.ContentType = "image/GIF" %>
<% Response.ContentType = "image/JPEG" %>
<% Response.ContentType = "text/plain" %>
<% Response.ContentType = "image/JPEG" %>
<% Response.ContentType = "application/x-cdf" %>
用于作为文本内容返回而不是已解释的 HTML 语句
Response.ContentType = "text/plain"
<% Response.ContentType = "text/plain" Response.write(now()&"会被执行么?") %> |
程序文件以XLS文件被提供下载
Response.ContentType = "application/vnd.ms-excel"
<% Response.ContentType = "application/vnd.ms-excel" Response.write("本页面调试会出现下载对话框提供下载,保存类型为XLS") %> |
response.ContentType="audio/x-pn-realaudio"
<% dim ramstr ramstr="" set rs=server.createobject("adodb.recordset") sql="XXXXXXXXXXX" rs.open sql,conn,1,3 'conn已定义 do while not rs.eof ramstr=ramstr&rs("url")&vbCrLf rs.movenext loop rs.close response.ContentType="audio/x-pn-realaudio" 'response.ContentType="audio/x-mpegurl" response.write ramstr %> |
以上文章转贴自http://www.w269.com/infow269/1145w2691.htm
这里我想讨论一下,这么也东东。
Q:如何利用ContentType 来,在服务器上提供一个.xls后缀的文件点击下载而不是直接在浏览器中打开。(注意:于上程序文件以XLS文件被提供下载有所不同)
Response.ContentType = "application/x-download",让整个程序文件点击下载了。怎么办好呢???
A:解决方案1. 利用Response.WriteFile的文件输出操作
具体在按钮点击事件中添加一下代码
private void btnDownload_Click(object sender, System.EventArgs e)
{
string DownloadFileName=Server.MapPath("file.xls");
string filepath = DownloadFileName;
// Identify the file name.
string filename = System.IO.Path.GetFileName(filepath);
Response.Clear();
// Specify the Type of the downloadable file.
Response.ContentType = "application/octet-stream";
// Set the Default file name in the FileDownload dialog box.
Response.AddHeader("Content-Disposition", "attachment; filename=" + filename);
Response.Flush();
// Download the file.
Response.WriteFile(filepath);
}
以上代码也适合用于小于100MB的小文件下载
如果是大于100MB的大文件下载可以用Response.FileStream 。
C#代码如下:(将 DownloadFileName 替换为大于 100 MB 的文件的名称。)
System.IO.Stream iStream = null;
// Buffer to read 10K bytes in chunk:
byte[] buffer = new Byte[10000];
// Length of the file:
int length;
// Total bytes to read:
long dataToRead;
// Identify the file to download including its path.
string filepath = "DownloadFileName";
// Identify the file name.
string filename = System.IO.Path.GetFileName(filepath);
try
{
// Open the file.
iStream = new System.IO.FileStream(filepath, System.IO.FileMode.Open,
System.IO.FileAccess.Read,System.IO.FileShare.Read);//用文件流来处理
// Total bytes to read:
dataToRead = iStream.Length;
Response.ContentType = "application/octet-stream";//问题就在这里,解决百M关口
Response.AddHeader("Content-Disposition", "attachment; filename=" + filename);
// Read the bytes.
while (dataToRead > 0)
{
// Verify that the client is connected.
if (Response.IsClientConnected)
{
// Read the data in buffer.
length = iStream.Read(buffer, 0, 10000);
// Write the data to the current output stream.
Response.OutputStream.Write(buffer, 0, length);
// Flush the data to the HTML output.
Response.Flush();
buffer= new Byte[10000];
dataToRead = dataToRead - length;
}
else
{
//prevent infinite loop if user disconnects
dataToRead = -1;
}
}
}
catch (Exception ex)
{
// Trap the error, if any.
Response.Write("Error : " + ex.Message);
}
finally
{
if (iStream != null)
{
//Close the file.
iStream.Close();
}
}
参考:PRB:Response.WriteFile 无法下载大文件
http://support.microsoft.com/default.aspx?scid=kb;zh-cn;812406#2
相关文章推荐
- 如何用Response.ContentType控制输出的文件类型及相关讨论
- Response.ContentType 控制输出文件类型(讨论下载文件问题)
- Response.ContentType :控制输出的文件类型
- Response.ContentType 控制输出文件类型
- [讨论]Response.ContentType 控制输出文件类型(讨论下载文件问题)
- 使用Response.ContentType 来控制下载文件的类型
- Response.ContentType 控制输出文件类型(讨论下载文件问题)
- Response.ContentType 控制输出文件类型(讨论下载文件问题)
- ContentType控制输出的类型是否区分大小写
- Response.ContentType定义输出类型
- Servlet文件下载例子详解及response的contentType类型大全
- Servlet文件下载例子详解及response的contentType类型大全
- Servlet文件下载例子详解及response的contentType类型大全
- HttpServletResponse response(中文乱码、文件下载、定时刷新、控制缓存、重定向、注意事项)
- Web文件的ContentType类型大全
- 从文件中读取数据、控制输出格式
- Web文件的ContentType类型大全
- 输出该目录下指定类型文件(.cs, .java)的个数、文件的总行数、空行数、注释行数、代码行数
- Response.ContentType 类型详解