使用axios怎么封装一个上传文件请求?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。
axios 和 ajax 都支持异步请求,两者使用方法大同小异,在此使用 axios 上传文件的请求。使用的时候只需要在响应的 vue 组件中引入就可以。
import Vue from 'vue';
import VueCookie from 'vue-cookie';
import axios from 'axios';
// import toastr from '../assets/toastr.min';
// Vue.use(axios)
let http = {};
// let _baseURL = '/vpaas'
let _baseURL = 'http://localhost:8080/vpaas'
let ContentType = "application/json";
let uploadFileType = "multipart/form-data";
http.baseURL = _baseURL;
/**
* 上传文件的请求
* @param url
* @returns {AxiosPromise}
*/
http.uploadFile = function (url, data) {
let config = {
//请求的接口,在请求的时候,如axios.get(url,config);这里的url会覆盖掉config中的url
url: url,
//基础url前缀
baseURL: _baseURL,
transformResponse: [function (data1) {
var data = data1;
if (typeof data1 == "string") {
data = JSON.parse(data1);
}
//这里提前处理返回的数据;
if (data.message && (data.data === 'login.invalid.token')) {
window.localStorage.removeItem("access-user");
alert("超时请重新登陆");
window.location.href = '/';
}
return data;
}],
//请求头信息
headers: {'access-user': window.localStorage.getItem('access-user'), 'Content-Type': uploadFileType},
//跨域请求时是否需要使用凭证
withCredentials: true,
// 返回数据类型
responseType: 'json', //default
};
return axios.post(url, data, config);
};
看完上述内容是否对您有帮助呢?如果还想对相关知识有进一步的了解或阅读更多相关文章,请关注亿速云行业资讯频道,感谢您对亿速云的支持。
亿速云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。