首页 > 代码库 > asp.net下载文件的几种方法
asp.net下载文件的几种方法
最近做东西遇到了下载相关的问题。在这里总结一下自己处理的方法。
1.以字节流的形式向页面输出数据以下载Excel为例子。
string path=Server.MapPath("文件路径");//这里的文件路径是相对路径 FileStream fs = new FileStream(path, FileMode.Open);//将文件读入到流,当然这里也可以是存在内存中的Excel 并不一定是存在服务器上的文件 byte[] bytes = new byte[(int)fs .Length]; fs .Read(bytes, 0, bytes.Length);//将流写入字节数组 fs .Close(); Response.ContentType ="application/ms-excel";//设置输入类型。这里的类型很多自行百度
//添加http头,这里将文件名进行编码防止乱码。 Response.AddHeader("Content-Disposition", "attachment; filename=" + HttpUtility.UrlEncode("文件下载后的名称", System.Text.Encoding.UTF8)); Response.BinaryWrite(bytes);//向客户端输出流。 Response.Flush(); Response.End();
2.WriteFile形式直接下载
这个方式需要服务器上存在相应的文件。
Response.Clear();
Response.ContentType ="application/octet-stream"; Response.AddHeader("Content-Disposition", "attachment; filename=" + HttpUtility.UrlEncode("文件下载后的名称", System.Text.Encoding.UTF8)); Response.WriteFile(“文件的路径和文件名”);//向客户端输出流。 Response.Flush(); Response.End();
//这种方法重要的地方是要获取文件在服务器上的路径。
3.利用服务器空间gridview或者datagrid
Response.ContentEncoding = System.Text.Encoding.UTF8; Response.AppendHeader("Content-Disposition", "attachment;filename=" + HttpUtility.UrlEncode("文件名", Encoding.UTF8).ToString()); Response.ContentType = "application /ms-excel"; this.EnableViewState = false; StringWriter tw = new StringWriter(); HtmlTextWriter hw = new HtmlTextWriter(tw); gvTM.RenderControl(hw);//这里的gvTM是页面gridview的一个实例化对象,已经有数据源。
//也可以不在页面上显示,GridView gv=new GridView(); gv.DataSource=new datatable(); gv.DataBind();这种方式也是可以的。 Response.Output.Write(tw.ToString()); Response.Flush(); Response.End();
asp.net下载文件的几种方法
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。