asp.net(c#)文件下载实现代码
程序员文章站
2024-03-09 13:05:53
复制代码 代码如下: using system; using system.data; using system.configuration; using system.w...
复制代码 代码如下:
using system;
using system.data;
using system.configuration;
using system.web;
using system.web.security;
using system.web.ui;
using system.web.ui.webcontrols;
using system.web.ui.webcontrols.webparts;
using system.web.ui.htmlcontrols;
using system.io;
public partial class _default : system.web.ui.page
{
protected void page_load(object sender, eventargs e) { }
//transmitfile实现下载
protected void button1_click(object sender, eventargs e)
{
/* 微软为response对象提供了一个新的方法transmitfile来解决使用response.binarywrite 下载超过400mb的文件时导致aspnet_wp.exe进程回收而无法成功下载的问题。 代码如下: */
response.contenttype = "application/x-zip-compressed"; response.addheader("content-disposition", "attachment;filename=z.zip");
string filename = server.mappath("download/z.zip"); response.transmitfile(filename);
}
//writefile实现下载
protected void button2_click(object sender, eventargs e)
{
/* using system.io; */
string filename = "asd.txt";//客户端保存的文件名
string filepath = server.mappath("download/aaa.txt");//路径
fileinfo fileinfo = new fileinfo(filepath);
response.clear();
response.clearcontent();
response.clearheaders();
response.addheader("content-disposition", "attachment;filename=" + filename); response.addheader("content-length", fileinfo.length.tostring());
response.addheader("content-transfer-encoding", "binary");
response.contenttype = "application/octet-stream";
response.contentencoding = system.text.encoding.getencoding("gb2312");
response.writefile(fileinfo.fullname);
response.flush();
response.end();
}
//writefile分块下载
protected void button3_click(object sender, eventargs e)
{
string filename = "aaa.txt";//客户端保存的文件名
string filepath = server.mappath("download/aaa.txt");//路径
system.io.fileinfo fileinfo = new system.io.fileinfo(filepath);
if (fileinfo.exists == true)
{
const long chunksize = 102400;//100k 每次读取文件,只读取100k,这样可以缓解服务器的压力
byte[] buffer = new byte[chunksize];
response.clear();
system.io.filestream istream = system.io.file.openread(filepath);
long datalengthtoread = istream.length;//获取下载的文件总大小
response.contenttype = "application/octet-stream";
response.addheader("content-disposition", "attachment; filename=" + httputility.urlencode(filename)); while (datalengthtoread > 0 && response.isclientconnected)
{
int lengthread = istream.read(buffer, 0, convert.toint32(chunksize));//读取的大小 response.outputstream.write(buffer, 0, lengthread);
response.flush();
datalengthtoread = datalengthtoread - lengthread;
}
response.close();
}
}
//流方式下载
protected void button4_click(object sender, eventargs e)
{
string filename = "aaa.txt";//客户端保存的文件名
string filepath = server.mappath("download/aaa.txt");//路径 //以字符流的形式下载文件
filestream fs = new filestream(filepath, filemode.open);
byte[] bytes = new byte[(int)fs.length]; fs.read(bytes, 0, bytes.length);
fs.close();
response.contenttype = "application/octet-stream"; //通知浏览器下载文件而不是打开 response.addheader("content-disposition", "attachment; filename=" + httputility.urlencode(filename, system.text.encoding.utf8));
response.binarywrite(bytes);
response.flush();
response.end();
}
}
/*
这里提供4种常用下载方式 以供参考导读:
本文通过一个实例向大家介绍用c#进行internet通讯编程的一些基本知识。我们知道.net类包含了请求/响应层、应用协议层、传输层等层次。在本程序中,我们运用了位于请求/响应层的webrequest类以及webclient类等来实现高抽象程度的internet通讯服务。本程序的功能是完成网络文件的下载。
实现原理
程序实现的原理比较简单,主要用到了webclient类和filestream类。其中webclient类处于system.net名字空间中,该类的主要功能是提供向uri标识的资源发送数据和从uri标识的资源接收数据的公共方法。我们利用其中的downloadfile()方法将网络文件下载到本地。然后用filestream类的实例对象以数据流的方式将文件数据写入本地文件。这样就完成了网络文件的下载。
实现步骤
首先,打开visual studio.net,新建一个visual c#windows应用程序的工程,不妨命名为“mygetcar”。接着,布置主界面。我们先往主窗体上添加如下控件:两个标签控件、两个文本框控件、一个按钮控件以及一个状态栏控件。
设置各控件属性如下:
控件类型 控件名称 属性类型 属性值 主窗体 form1 text属性 文件下载器 标签控件 label1 text属性 文件地址: textalign属性 middleright label2 text属性 另存到: textalign属性 middleright 文本框控件 srcaddress text属性 (空) taraddress text属性 (空) 按钮控件 start flatstyle属性 flat text属性 开始下载 状态栏控件 statusbar text属性 (空)
其他属性可为默认值,最终的主窗体如下图所示:
完成主窗体的设计,我们接着完成代码的编写。
在理解了基本原理的基础上去完成代码的编写是相当容易。程序中我们主要用到的是webclient类,不过在我们调用webclient类的实例对象前,我们需要用webrequest类的对象发出对统一资源标识符(uri)的请求。
复制代码 代码如下:
try { webrequest myre=webrequest.create(urladdress); }
catch(webexception exp){
messagebox.show(exp.message,"error");
}
这是一个try-catch语句,try块完成向uri的请求,catch块则捕捉可能的异常并显示异常信息。其中的urladdress为被请求的网络主机名。 在请求成功后,我们就可以运用webclient类的实例对象中的downloadfile()方法实现文件的下载了。其函数原型如下: public void downloadfile( string address, string filename); 其中,参数address为从中下载数据的 uri,filename为要接收数据的本地文件的名称。 之后我们用openread()方法来打开一个可读的流,该流完成从具有指定uri的资源下载数据的功能。其函数原型如下: public stream openread(string address); 其中,参数address同上。 最后就是新建一个streamreader对象从中读取文件的数据,并运用一个while循环体不断读取数据,只到读完所有的数据。
还有在使用以上方法时,你将可能需要处理以下几种异常:
● webexception:下载数据时发生错误。
● uriformatexception:通过组合 baseaddress、address 和 querystring 所构成的 uri 无效。
这部分的代码如下:(client为webclient对象,在本类的开头处声明即可)
复制代码 代码如下:
statusbar.text = "开始下载文件...";
client.downloadfile(urladdress,filename);
stream str = client.openread(urladdress);
streamreader reader = new streamreader(str);
byte[] mbyte = new byte[100000];
int allmybyte = (int)mbyte.length;
int startmbyte = 0;
statusbar.text = "正在接收数据...";
while(allmybyte>0){
int m = str.read(mbyte,startmbyte,allmybyte);
if(m==0)
break;
startmbyte+=m;
allmybyte-=m;
}
完成了文件数据的读取工作后,我们运用filestream类的实例对象将这些数据写入本地文件中:
filestream fstr = new filestream(path,filemode.openorcreate,fileaccess.write); fstr.write(mbyte,0,startmbyte);
*/