最近做东西遇到了下载相关的问题。在这里总结一下自己处理的方法。
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();