parent
02b95f95a8
commit
ded99502ae
@ -0,0 +1,48 @@ |
|||||||
|
import { saveAs } from 'file-saver' |
||||||
|
import axios from 'axios' |
||||||
|
import { getToken } from '@/utils/auth' |
||||||
|
|
||||||
|
const baseURL = process.env.VUE_APP_BASE_API |
||||||
|
|
||||||
|
export default { |
||||||
|
name(name, isDelete = true) { |
||||||
|
var url = baseURL + "/common/download?fileName=" + encodeURI(name) + "&delete=" + isDelete |
||||||
|
axios({ |
||||||
|
method: 'get', |
||||||
|
url: url, |
||||||
|
responseType: 'blob', |
||||||
|
headers: { 'Authorization': 'Bearer ' + getToken() } |
||||||
|
}).then(res => { |
||||||
|
const blob = new Blob([res.data]) |
||||||
|
this.saveAs(blob, decodeURI(res.headers['download-filename'])) |
||||||
|
}) |
||||||
|
}, |
||||||
|
resource(resource) { |
||||||
|
var url = baseURL + "/common/download/resource?resource=" + encodeURI(resource); |
||||||
|
axios({ |
||||||
|
method: 'get', |
||||||
|
url: url, |
||||||
|
responseType: 'blob', |
||||||
|
headers: { 'Authorization': 'Bearer ' + getToken() } |
||||||
|
}).then(res => { |
||||||
|
const blob = new Blob([res.data]) |
||||||
|
this.saveAs(blob, decodeURI(res.headers['download-filename'])) |
||||||
|
}) |
||||||
|
}, |
||||||
|
zip(url, name) { |
||||||
|
var url = baseURL + url |
||||||
|
axios({ |
||||||
|
method: 'get', |
||||||
|
url: url, |
||||||
|
responseType: 'blob', |
||||||
|
headers: { 'Authorization': 'Bearer ' + getToken() } |
||||||
|
}).then(res => { |
||||||
|
const blob = new Blob([res.data], { type: 'application/zip' }) |
||||||
|
this.saveAs(blob, name) |
||||||
|
}) |
||||||
|
}, |
||||||
|
saveAs(text, name, opts) { |
||||||
|
saveAs(text, name, opts); |
||||||
|
} |
||||||
|
} |
||||||
|
|
@ -1,42 +0,0 @@ |
|||||||
import axios from 'axios' |
|
||||||
import { getToken } from '@/utils/auth' |
|
||||||
|
|
||||||
const mimeMap = { |
|
||||||
xlsx: 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet', |
|
||||||
zip: 'application/zip' |
|
||||||
} |
|
||||||
|
|
||||||
const baseUrl = process.env.VUE_APP_BASE_API |
|
||||||
export function downLoadZip(str, filename) { |
|
||||||
var url = baseUrl + str |
|
||||||
axios({ |
|
||||||
method: 'get', |
|
||||||
url: url, |
|
||||||
responseType: 'blob', |
|
||||||
headers: { 'Authorization': 'Bearer ' + getToken() } |
|
||||||
}).then(res => { |
|
||||||
resolveBlob(res, mimeMap.zip) |
|
||||||
}) |
|
||||||
} |
|
||||||
/** |
|
||||||
* 解析blob响应内容并下载 |
|
||||||
* @param {*} res blob响应内容 |
|
||||||
* @param {String} mimeType MIME类型 |
|
||||||
*/ |
|
||||||
export function resolveBlob(res, mimeType) { |
|
||||||
const aLink = document.createElement('a') |
|
||||||
var blob = new Blob([res.data], { type: mimeType }) |
|
||||||
// //从response的headers中获取filename, 后端response.setHeader("Content-disposition", "attachment; filename=xxxx.docx") 设置的文件名;
|
|
||||||
var patt = new RegExp('filename=([^;]+\\.[^\\.;]+);*') |
|
||||||
var contentDisposition = decodeURI(res.headers['content-disposition']) |
|
||||||
var result = patt.exec(contentDisposition) |
|
||||||
var fileName = result[1] |
|
||||||
fileName = fileName.replace(/\"/g, '') |
|
||||||
aLink.style.display = 'none' |
|
||||||
aLink.href = URL.createObjectURL(blob) |
|
||||||
aLink.setAttribute('download', fileName) // 设置下载文件名称
|
|
||||||
document.body.appendChild(aLink) |
|
||||||
aLink.click() |
|
||||||
URL.revokeObjectURL(aLink.href);//清除引用
|
|
||||||
document.body.removeChild(aLink); |
|
||||||
} |
|
Loading…
Reference in new issue