国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術(shù)文章
文章詳情頁

.netcore+vue 實現(xiàn)壓縮文件下載功能

瀏覽:23日期:2022-11-18 16:04:07

一.前言

目前接觸的項目中,給定的需求是將系統(tǒng)內(nèi)所有用戶的數(shù)據(jù)整理好,并保存到文件夾內(nèi),目的主要是防止用戶在實施人員已配置好的基礎(chǔ)上由于不熟悉系統(tǒng),導(dǎo)致的誤刪或者誤操作。減少實施人員的配置工作。我首先想到的就是將數(shù)據(jù)導(dǎo)入到Excel中,并以各個用戶的名稱命名文件夾做好分類。

vue下實現(xiàn)Excel導(dǎo)入這個我們見的比較多了,當(dāng)時我也確實實現(xiàn)了下載Excel的功能,但是后續(xù)發(fā)現(xiàn)保存的文件都在服務(wù)器上,那就有一個問題了,實施人員是通過頁面點擊的一鍵保存按鈕,數(shù)據(jù)也確實保存了,但是卻是在服務(wù)器上,如果想實時看到數(shù)據(jù)呢,是不是還要去服務(wù)器上拷貝一份下來。相對來講確實比較繁瑣,所以整理了下載壓縮文件到本地的功能,一起看一下怎么實現(xiàn)的吧。

1.1.net core 壓縮文件

思路是在后臺將文件夾整體壓縮為zip格式的壓縮包,并返回文件流到前端,然后前端接收文件流實現(xiàn)瀏覽器下載的功能。

后端代碼,將

public async Task<FileStreamResult> DownloadFiles(DownLoadModel input) { if (!Directory.Exists(input.pathUrl)) {throw new UserFriendlyException('當(dāng)前要下載的文件夾不存在或已刪除'); } var zipFileUrl = _configurationRoot['downLoadUrlConf:downloadZipFileUrl']; if (File.Exists(zipFileUrl)) {File.Delete(zipFileUrl); } ZipHelper.CreateZip(input.pathUrl, zipFileUrl); var memoryStream = new MemoryStream(); using (var stream = new FileStream(zipFileUrl, FileMode.Open)) {await stream.CopyToAsync(memoryStream); } memoryStream.Seek(0, SeekOrigin.Begin); return new FileStreamResult(memoryStream, 'application/octet-stream');//文件流方式,指定文件流對應(yīng)的ContenType。 }

public static class ZipHelper { /// <summary> /// 壓縮文件 /// </summary> /// <param name='sourceFilePath'></param> /// <param name='destinationZipFilePath'></param> public static void CreateZip(string sourceFilePath, string destinationZipFilePath) { if (sourceFilePath[sourceFilePath.Length - 1] != System.IO.Path.DirectorySeparatorChar)sourceFilePath += System.IO.Path.DirectorySeparatorChar; ZipOutputStream zipStream = new ZipOutputStream(File.Create(destinationZipFilePath)); zipStream.SetLevel(6); // 壓縮級別 0-9 CreateZipFiles(sourceFilePath, zipStream, sourceFilePath); zipStream.Finish(); zipStream.Close(); } /// <summary> /// 遞歸壓縮文件 /// </summary> /// <param name='sourceFilePath'>待壓縮的文件或文件夾路徑</param> /// <param name='zipStream'> /// <param name='staticFile'></param> private static void CreateZipFiles(string sourceFilePath, ZipOutputStream zipStream, string staticFile) { Crc32 crc = new Crc32(); string[] filesArray = Directory.GetFileSystemEntries(sourceFilePath); foreach (string file in filesArray) {if (Directory.Exists(file)) //如果當(dāng)前是文件夾,遞歸{ CreateZipFiles(file, zipStream, staticFile);}else //如果是文件,開始壓縮{ FileStream fileStream = File.OpenRead(file); byte[] buffer = new byte[fileStream.Length]; fileStream.Read(buffer, 0, buffer.Length); string tempFile = file.Substring(staticFile.LastIndexOf('') + 1); ZipEntry entry = new ZipEntry(tempFile); entry.DateTime = DateTime.Now; entry.Size = fileStream.Length; fileStream.Close(); crc.Reset(); crc.Update(buffer); entry.Crc = crc.Value; zipStream.PutNextEntry(entry); zipStream.Write(buffer, 0, buffer.Length);} } } }

其中CreateZip方法傳入一個源文件的路徑,一個目標(biāo)文件的路徑,這里我的目標(biāo)文件設(shè)置在appsetting.json里是個臨時路徑,只為前端當(dāng)次下載使用。這樣我們就在后臺將數(shù)據(jù)以壓縮包的形式壓縮好,并返回數(shù)據(jù)流給前端了。

1.2 vue 下載壓縮文件

<el-button icon='el-icon-download' size='mini' type='primary' @click='downloadFile' >下載文件到本地</el-button>

downloadFile() { this.loading = true; let postData = { pathUrl: this.filePathMag }; AjaxHelper.post(this.downLoadUrl, postData, { responseType: 'blob', }).then((res) => { // 處理返回的文件流 const content = res.data; const blob = new Blob([content], { type: 'application/zip' }); const fileName = this.tenant.name + '配置信息.zip'; if ('download' in document.createElement('a')) { // 非IE下載 const elink = document.createElement('a'); elink.download = fileName; elink.style.display = 'none'; elink.href = URL.createObjectURL(blob); document.body.appendChild(elink); elink.click(); URL.revokeObjectURL(elink.href); // 釋放URL 對象 document.body.removeChild(elink); } else { // IE10+下載 navigator.msSaveBlob(blob, fileName); } this.loading = false; }); },

之前下載Excel時,我們傳入后端的content-type為'application/json;application/octet-stream',經(jīng)過測試發(fā)現(xiàn)壓縮文件不能使用這種content-type,所以我們?nèi)サ袅恕A硗饩褪莄onst blob = new Blob([content], { type: 'application/zip' });這行代碼,如果不加,雖然也能下載,但是下載后的壓縮包卻無法打開,提示壓縮不正確或壓縮包已損壞。

好了,到此壓縮文件的下載就完成了,由于我也是第一次遇到壓縮文件的下載,經(jīng)過摸索終于解決了問題??雌饋硪脖容^簡單,你學(xué)會使用了嗎?

總結(jié)

到此這篇關(guān)于.netcore+vue 實現(xiàn)壓縮文件下載的文章就介紹到這了,更多相關(guān)vue 實現(xiàn)壓縮文件下載內(nèi)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標(biāo)簽: Vue
相關(guān)文章:
主站蜘蛛池模板: 在线人成精品免费视频 | 毛片网站免费在线观看 | 特级毛片aaaa免费观看 | 国内精品久久久久久久久久影视 | 成人免费影视网站 | 国产日韩亚洲不卡高清在线观看 | 亚洲日本一区二区三区高清在线 | 欧美成人手机视频免费播放 | 国产成人一区二区视频在线观看 | a一级毛片录像带 录像片 | 日韩精品网| 女人又黄的视频网站 | 亚洲成年人专区 | 欧美激情久久久久久久久 | 精品一区二区三区在线观看l | 色欲麻豆国产福利精品 | 九九九国产在线 | 综合久久精品 | 欧美另类在线观看 | 午夜在线精品不卡国产 | 奇米第四狠狠777高清秒播 | 亚洲国产一区二区三区最新 | 欧美日韩精品一区三区 | 亚洲影院手机版777点击进入影院 | 一区国严二区亚洲三区 | 中文字幕天堂最新版在线网 | 免费高清不卡毛片在线看 | 三级毛片免费 | 亚洲精品国产一区二区在线 | 免费观看欧美一级高清 | 手机在线精品视频每日更新 | 欧美性性性性性色大片免费的 | 国产一级爱做片免费观看 | 亚洲精品亚洲一区二区 | 日韩精品一区二区三区视频 | 欧美日韩一区二区视频图片 | 欧美成人艳星在线播放 | 国产婷婷一区二区三区 | 精产网红自拍在线 | 一级不卡毛片免费 | 国产裸体美女视频全黄 |