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