From e5454b769d44a34af423bf87ac8a740bf8c20341 Mon Sep 17 00:00:00 2001 From: Crunchy <3114200645@qq.com> Date: 星期二, 29 四月 2025 13:25:29 +0800 Subject: [PATCH] Merge branch 'dev' into dev_tides --- src/plugins/download.js | 158 ++++++++++++++++++++++++++++++++++++++-------------- 1 files changed, 115 insertions(+), 43 deletions(-) diff --git a/src/plugins/download.js b/src/plugins/download.js index 42acd00..17bcf96 100644 --- a/src/plugins/download.js +++ b/src/plugins/download.js @@ -1,79 +1,151 @@ -import axios from 'axios' -import {Loading, Message} from 'element-ui' -import { saveAs } from 'file-saver' -import { getToken } from '@/utils/auth' -import errorCode from '@/utils/errorCode' +import axios from "axios"; +import { Loading, Message } from "element-ui"; +import { saveAs } from "file-saver"; +import { getToken } from "@/utils/auth"; +import errorCode from "@/utils/errorCode"; import { blobValidate } from "@/utils/ruoyi"; +import Vue from "vue"; -const baseURL = process.env.VUE_APP_BASE_API +const baseURL = process.env.VUE_APP_BASE_API; let downloadLoadingInstance; export default { name(name, isDelete = true) { - var url = baseURL + "/common/download?fileName=" + encodeURIComponent(name) + "&delete=" + isDelete + var url = + baseURL + + "/common/download?fileName=" + + encodeURIComponent(name) + + "&delete=" + + isDelete; axios({ - method: 'get', + method: "get", url: url, - responseType: 'blob', - headers: { 'Authorization': 'Bearer ' + getToken() } + responseType: "blob", + headers: { Authorization: "Bearer " + getToken() }, }).then((res) => { const isBlob = blobValidate(res.data); if (isBlob) { - const blob = new Blob([res.data]) - this.saveAs(blob, decodeURIComponent(res.headers['download-filename'])) + const blob = new Blob([res.data]); + this.saveAs(blob, decodeURIComponent(res.headers["download-filename"])); } else { this.printErrMsg(res.data); } - }) + }); }, resource(resource) { - var url = baseURL + "/common/download/resource?resource=" + encodeURIComponent(resource); + var url = + baseURL + + "/common/download/resource?resource=" + + encodeURIComponent(resource); axios({ - method: 'get', + method: "get", url: url, - responseType: 'blob', - headers: { 'Authorization': 'Bearer ' + getToken() } + responseType: "blob", + headers: { Authorization: "Bearer " + getToken() }, }).then((res) => { const isBlob = blobValidate(res.data); if (isBlob) { - const blob = new Blob([res.data]) - this.saveAs(blob, decodeURIComponent(res.headers['download-filename'])) + const blob = new Blob([res.data]); + this.saveAs(blob, decodeURIComponent(res.headers["download-filename"])); } else { this.printErrMsg(res.data); } - }) + }); }, zip(url, name) { - var url = baseURL + url - downloadLoadingInstance = Loading.service({ text: "姝e湪涓嬭浇鏁版嵁锛岃绋嶅��", spinner: "el-icon-loading", background: "rgba(0, 0, 0, 0.7)", }) + var url = baseURL + url; + downloadLoadingInstance = Loading.service({ + text: "姝e湪涓嬭浇鏁版嵁锛岃绋嶅��", + spinner: "el-icon-loading", + background: "rgba(0, 0, 0, 0.7)", + }); axios({ - method: 'get', + method: "get", url: url, - responseType: 'blob', - headers: { 'Authorization': 'Bearer ' + getToken() } - }).then((res) => { - const isBlob = blobValidate(res.data); - if (isBlob) { - const blob = new Blob([res.data], { type: 'application/zip' }) - this.saveAs(blob, name) - } else { - this.printErrMsg(res.data); - } - downloadLoadingInstance.close(); - }).catch((r) => { - console.error(r) - Message.error('涓嬭浇鏂囦欢鍑虹幇閿欒锛岃鑱旂郴绠$悊鍛橈紒') - downloadLoadingInstance.close(); + responseType: "blob", + headers: { Authorization: "Bearer " + getToken() }, }) + .then((res) => { + const isBlob = blobValidate(res.data); + if (isBlob) { + const blob = new Blob([res.data], { type: "application/zip" }); + this.saveAs(blob, name); + } else { + this.printErrMsg(res.data); + } + downloadLoadingInstance.close(); + }) + .catch((r) => { + console.error(r); + Message.error("涓嬭浇鏂囦欢鍑虹幇閿欒锛岃鑱旂郴绠$悊鍛橈紒"); + downloadLoadingInstance.close(); + }); }, - saveAs(text, name, opts) { - saveAs(text, name, opts); + async saveAs(text, name, opts) { + if (typeof text === "string") { + try { + let state = /\.(jpg|jpeg|png|gif)$/i.test(text) // 鍒ゆ柇鏄惁涓哄浘鐗� + let url1 = '' + if (state) { + url1 = Vue.prototype.javaApi + '/img/' + text; + } else { + if (text.startsWith("/word/")) { + url1 = Vue.prototype.javaApi + text + } else if (text.startsWith("word/")) { + url1 = Vue.prototype.javaApi + '/' + text + } else { + url1 = Vue.prototype.javaApi + '/word/' + text + } + } + // 浣跨敤 fetch 鑾峰彇鏂囦欢 + const response = await fetch(url1); + if (!response.ok) { + throw new Error('鏂囦欢涓嬭浇澶辫触: ' + response.statusText); + } + // 灏嗘枃浠惰浆鎹负 Blob + const blob = await response.blob(); + // 浣跨敤 saveAs 淇濆瓨鏂囦欢 + saveAs(blob, name); + Message.success("鏁版嵁瀵煎嚭鎴愬姛"); + } catch (error) { + Message.error(error); + } + } else { + // 娴佷笅杞� + blobToText(text) + .then((result) => { + Message.error(result.msg); + }) + .catch(() => { + saveAs(text, name, opts); + Message.success("鏁版嵁瀵煎嚭鎴愬姛"); + }); + } }, async printErrMsg(data) { const resText = await data.text(); const rspObj = JSON.parse(resText); - const errMsg = errorCode[rspObj.code] || rspObj.msg || errorCode['default'] + const errMsg = errorCode[rspObj.code] || rspObj.msg || errorCode["default"]; Message.error(errMsg); - } -} + }, +}; +// 灏哹lob杞垚鏂囨湰 +function blobToText(blob) { + return new Promise((resolve, reject) => { + const fileReader = new FileReader(); + fileReader.readAsText(blob); + fileReader.onload = function () { + try { + const result = JSON.parse(this.result); + if (result && result["code"] !== 200) { + resolve(result); + } else { + reject(); + } + } catch (e) { + reject(); + } + }; + }); +} -- Gitblit v1.9.3