使用Ionic Zip Extract显示下载文件对话框

时间:2013-07-26 05:47:47

标签: c# asp.net

我正在使用Ionic zip,我已经制作了zip文件并希望下载并自动提取。 我已经实现了Extracting功能,我在网页上有一个按钮,点击它会解压缩zip文件并将其下载到我在Code中提供的Path,下面是我的代码

String TargetDirectory = @"C:\";
            using (ZipFile zip = ZipFile.Read(Server.MapPath(ConfigurationManager.AppSettings["zipfiles"] + filename)))
            {
                zip.ExtractExistingFile = ExtractExistingFileAction.OverwriteSilently;
                zip.Password = password;
                zip.ExtractAll(TargetDirectory);
            }

此代码工作正常,我想在单击按钮时显示“下载对话框”,并在用户从“对话框”中选择的路径上提取文件。我怎样才能做到这一点?

1 个答案:

答案 0 :(得分:0)

我们也面临这个特殊的问题,我们的问题是我们有多个文件要压缩,而在zip之后,它的大小大约是2GB左右。

我们如何整理出来。 1.我们有一个下载链接 2.用户点击它 我们展示了一个有进度轮的弹出窗口 我们在后台用不同的线程处理Zip。 (必须仅为此用户创建Zip) 5.一切正常后,我们会向用户显示下载链接 6.用户可以在任何他想要的地方下载。

我不确定这是否对您有所帮助,但它对我们有用。

编辑添加一些代码: 我们使用JQuery

实现了这一目标
// Action for download zip link
            $(".downloadZip").click(function () {
                var jqXhr;
                $("a.downloadZipAction").attr("href", "/GetFile?fileName=yourfile.Zip");
                $(".ZipDownLoadBox").show();
                $(".downloadingZip").show();
                $(".DownloadZipLink").addClass("hide");
                var dialogBox = $("#dialogZip").dialog({
                    modal: true,
                    width: '400px',
                    zIndex: 99999,
                    close: function (event, ui) {
                        jqXhr.abort();
                    },
                    open: function () {
                        jqXhr = $.post('@Url.Action("DownloadZip")', { uuid: $("#fileName").val() }, function (data) {
                            $(".ui-icon-gripsmall-diagonal-se").remove();
                            $(".downloadingZip").hide();
                            $(".DownloadZipLink").removeClass("hide");
                            $(".downloadZipAction").click(function () {
                                $(dialogBox).dialog("close");
                            });
                        });
                    }
                });
            });