ASP.NET多文件批量打包下载

需求:

支持文件批量下载。现在有很多小图片需要批量下载。

不在服务器打包下载。因为下载的文件可能很大,比如超过5G,打包的话服务器耗时比较长。而且下载的人比较多,很容易会造成服务器磁盘空间不足。

支持大文件断点下载。比如下载10G的文件。

PC端全平台支持。Windows,macOS,Linux

全浏览器支持。ie6,ie7,ie8,ie9,ie10,ie11,edge,firefox,chrome,safari

支持文件夹结构下载。不希望在服务器打包,而是直接下载文件夹,下载后在本地文件夹结构和服务器保持一致。

支持从URL中下载文件。

支持JSON数据结构。

 

先放一段打包的代码。在小项目或局域网的一两个的项目中,这种打包下载方式没有太大的问题。但是在人数较多的项目中(比如超过100,或者是达到1000人)这种方式会占用较多的服务器资源,造成IO性能下降

Default.aspx:

<%@ Page Language=”C#” CodeFile=”Default.aspx.cs” Inherits=”_Default” %>

  <!DOCTYPE html PUBLIC “-//W3C//DTD XHTML 1.0 Transitional//EN” “http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd”>

  <htmlxmlns=“http://www.w3.org/1999/xhtml”>

   

    <headrunat=“server”>

      <title>图片打包下载</title></head>

   

    <body>

      <formid=“form1”runat=“server”>

        <p>

          <asp:Button ID=”PackDown” runat=”server” Text=”打包下载” OnClick=”PackDown_Click” /></p>

        <asp:GridView ID=”GridView1″ runat=”server” Width=”500px” CellPadding=”8″ CellSpacing=”1″>

          <Columns>

            <asp:TemplateField HeaderText=”<inputtype=” checkbox “/>” InsertVisible=”False”>

              <ItemTemplate>

                <asp:CheckBox ID=”CheckBox1″ runat=”server” /></ItemTemplate>

              <ItemStyle HorizontalAlign=”Center” /></asp:TemplateField>

            <asp:TemplateField HeaderText=”文件列表” InsertVisible=”False”>

              <EditItemTemplate>

                <asp:Label ID=”Label1″ runat=”server” Text=’<%# eval_r(“Name”) %>‘></asp:Label>

              </EditItemTemplate>

              <ItemTemplate>

                <asp:Label ID=”Label1″ runat=”server” Text=’<%# Bind(“Name”) %>‘></asp:Label>

              </ItemTemplate>

            </asp:TemplateField>

          </Columns>

        </asp:GridView>

      </form>

    </body>

 

  </html>

 

Default.aspx.cs:

using System;

using System.Collections.Generic;

using System.Linq;

using System.Web;

using System.Web.UI;

using System.Web.UI.WebControls;

using System.IO;

using Ionic.Zip;

 

publicpartialclass _Default: System.Web.UI.Page {

    protectedvoid Page_Load(object sender, EventArgs e){

        if(!Page.IsPostBack){

            BindFilesList();

        }

    }

 

    void BindFilesList(){

        List < System.IO.FileInfo > lstFI =new List < System.IO.FileInfo >();

        string[] files = System.IO.Directory.GetFiles(“d:\\webroot”);

        foreach(var s in files){

            lstFI.Add(new System.IO.FileInfo(s));

        }

 

        GridView1.DataSource = lstFI;

        GridView1.DataBind();

    }

 

    protectedvoid PackDown_Click(object sender, EventArgs e){

        Response.Clear();

        Response.ContentType =“application/zip”;

        Response.AddHeader(“content-disposition”,“filename=DotNetZip.zip”);

        using(ZipFile zip =new ZipFile(System.Text.Encoding.Default))//解决中文乱码问题

        {

            foreach(GridViewRow gvr in GridView1.Rows){

                if(((CheckBox) gvr.Cells[0].Controls[1]).Checked){

                    zip.AddFile(“d:\\webroot\\”+(gvr.Cells[1].Controls[1]as Label).Text,“”);//AddFile()第二个参数填写时不打包路径

                }

            }

 

            zip.Save(Response.OutputStream);//输出到浏览器下载

        }

 

        Response.End();

    }

}

 

新代码

 

批量下载多个文件

$(“#btn-down-files”).click(function () {

    if (downer.Config[“Folder”] == “”) { downer.open_folder(); return; }

    var urls = [

        { fileUrl: “http://res2.ncmem.com/res/images/ie11.png” }

        , { fileUrl: “http://res2.ncmem.com/res/images/up6.1/down.png” }

        , { fileUrl: “http://res2.ncmem.com/res/images/firefox.png” }

        , { fileUrl: “http://res2.ncmem.com/res/images/edge.png” }

        , { fileUrl: “http://res2.ncmem.com/res/images/up6.1/cloud.png” }

        , { fileUrl: “http://res2.ncmem.com/res/images/home/w.png” }

        , { fileUrl: “http://res2.ncmem.com/res/images/img.png” }

    ];

    downer.app.addUrls(urls);

});

 

批量下载文件,服务器不需要打包,直接提供URL就可以批量下载。下载后用户可以直接使用,不需要解压,提高工作效率。

$(“#btn-down-json”).click(function () {

    if (downer.Config[“Folder”] == “”) { downer.open_folder(); return; }

    var fd = {

        nameLoc: 图片列表”

        , files: [

            { fileUrl: “http://res2.ncmem.com/res/images/ie11.png” }

            , { fileUrl: “http://res2.ncmem.com/res/images/up6.1/down.png” }

            , { fileUrl: “http://res2.ncmem.com/res/images/firefox.png” }

            , { fileUrl: “http://res2.ncmem.com/res/images/edge.png” }

            , { fileUrl: “http://res2.ncmem.com/res/images/up6.1/cloud.png” }

            , { fileUrl: “http://res2.ncmem.com/res/images/home/w.png” }

            , { fileUrl: “http://res2.ncmem.com/res/images/img.png” }

        ]

    };

    downer.app.addJson(fd);

});

 

实现效果:

 

网上示例:http://blog.ncmem.com/wordpress/2019/08/28/net文件批量下载/