20 changed files with 70 additions and 82 deletions
@ -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