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();

 

郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。