码迷,mamicode.com
首页 > Web开发 > 详细

asp.net下载文件的几种方法

时间:2014-12-24 17:52:36      阅读:163      评论:0      收藏:0      [点我收藏+]

标签:

最近做东西遇到了下载相关的问题。在这里总结一下自己处理的方法。

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下载文件的几种方法

标签:

原文地址:http://www.cnblogs.com/bboy-coco/p/4182887.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!