vue+axios通过formdata提交参数和上传文件
demo.vue 文件
<template>
<div class="demo">
<input v-model="importForm.month" type="text" name="month"/>
<input ref="importFile" type="file" name="importFile" @change="handleFileChange" />
<button @click="handleConfimImport">确认导入</button>
</div>
</template> <script>
export default {
name: 'profitLossTree',
components: {},
data(){
return {
importForm: {
month: '',
importFile: '',
},
}
},
computed: {},
watch: {},
methods: { //导入文件改变
handleFileChange(){
console.log(this.$refs.importFile.files[0]);
this.importForm.importFile = this.$refs.importFile.files[0];
// console.log(this.importForm, '改变');
},
// 确认导入
handleConfimImport(name){
/* //提取到 post_formData 方法中
// vue 中使用 window.FormData(),否则会报 'FormData isn't definded'
//创建一个FormData对象,然后通过append() 方法向对象中添加键值对
let formData = new window.FormData();
formData.append("month", this.importForm.month);
formData.append("importFile", this.importForm.importFile);
console.log('formData', formData); //formData中的参数是隐式的直接看不到, 可以通过formData 实例的get方法获取
console.log('formData--month', formData.get('month'));
console.log('formData--importFile', formData.get('importFile'));
this.$post_formData( '/profitLossController/importDataNew',
formData
).then( res => {
this.$Message.success('导入成功!');
}) .catch( error => {
this.$Message.error("请求数据出错");
});
}
*/ this.$post_formData('/profitLossController/importDataNew', {
'month': this.importForm.month ,
'importFile': this.importForm.importFile
}).then( res => {
this.$Message.success('导入成功!');
}) .catch( error => {
this.$Message.error("请求数据出错");
});
},
mounted(){ }
};
</script> <style scoped> </style>
对axios进行封装的http.js文件
import axios from 'axios';
import property from './property'; //引用基础配置文件
import util from './util'; //引用刚才我们创建的util.js文件,并使用getCookie方法
import qs from 'qs';
import Cookies from 'js-cookie';
// axios 配置
axios.defaults.timeout = 30000;
axios.defaults.baseURL = util.api; //这是调用数据接口
axios.defaults.withCredentials = true;
axios.defaults.headers = {
'Content-Type': 'application/json' //设置跨域头部
}; // http request 拦截器,通过这个,我们就可以把Cookie传到后台
axios.interceptors.request.use(
config => {
const token = Cookies.get('user'); //获取Cookie
if (token) {
config.headers.token = token;
// config.params = {'token': token}; //后台接收的参数,后面我们将说明后台如何接收
/**
* 原axios封装的时候对所有的请求请求 进行 JSON 转换,会破坏掉 formdata 提交数据,
* 所以可以通过axios.create() 创建一个新的实例(axiosInstanceNew)进行 formdata提交,见下
*/
config.data = JSON.stringify(config.data);
//将get请求的参数进行序列化,主要处理数组传值问题
config.paramsSerializer = function(params) {
return qs.stringify(params, {indices: false});
}
} else {
if (!util.oneOf(config.url, property.noTokenUrl)) {
location.reload();
}
}
return config;
},
err => {
return Promise.reject(err);
}
); // http response 拦截器
axios.interceptors.response.use(
response => {
//response.data.errCode是我接口返回的值,如果值为2,说明Cookie丢失,然后跳转到登录页,这里根据大家自己的情况来设定
// if(response.data.errCode == 2) {
// router.push({
// path: '/login',
// query: {redirect: router.currentRoute.fullPath} //从哪个页面跳转
// })
// }
return response;
},
error => {
switch (error.response.status) {
case 401:
Cookies.remove('user');
if (!util.oneOf(error.config.url.substring(util.api.length), property.noTokenUrl)) {
location.reload();
}
break;
// case 404:
//
// break;
// case 500:
//
// break;
default:
alert(`请求出错!请求状态码:${error.response.status}。`);
}
return error;
// if(error.response.status == 401){
// //this.$Message.error('32131');
// //util.delCookie('user');
// Cookies.remove('user')
// location.reload();
// }else{
// alert("请求出错!");
// }
//return Promise.reject(error.response.data)
}); export default axios;
// -------------------------------
//创建新的axios
//创建一个新的axios实例
const axiosInstanceNew = axios.create({
baseURL: util.api,
timeout: 30000,
withCredentials: true
}); //新axios实例拦截
// http request 拦截器,通过这个,我们就可以把Cookie传到后台
axiosInstanceNew.interceptors.request.use( config => {
const token = Cookies.get('user'); //获取Cookie
if (token) {
config.headers.token = token;
//将get请求的参数进行序列化,主要处理数组传值问题
config.paramsSerializer = function(params) {
return qs.stringify(params, {indices: false});
}
} else {
if (!util.oneOf(config.url, property.noTokenUrl)) {
location.reload();
}
}
return config;
},
err => {
return Promise.reject(err);
}
); // 新 http response 拦截器
axiosInstanceNew.interceptors.response.use( response => {
//response.data.errCode是我接口返回的值,如果值为2,说明Cookie丢失,然后跳转到登录页,这里根据大家自己的情况来设定
// if(response.data.errCode == 2) {
// router.push({
// path: '/login',
// query: {redirect: router.currentRoute.fullPath} //从哪个页面跳转
// })
// }
return response;
}, error => {
switch (error.response.status) {
case 401:
Cookies.remove('user');
if (!util.oneOf(error.config.url.substring(util.api.length), property.noTokenUrl)) {
location.reload();
}
break;
// case 404:
//
// break;
// case 500:
//
// break;
default:
alert(`请求出错!请求状态码:${error.response.status}。`);
}
return error;
// if(error.response.status == 401){
// //this.$Message.error('32131');
// //util.delCookie('user');
// Cookies.remove('user')
// location.reload();
// }else{
// alert("请求出错!");
// }
//return Promise.reject(error.response.data)
}); /**
* post 请求方法
* @param url
* @param data
* @returns {Promise}
*/
export function post (url, data = {}) {
axios.defaults.withCredentials = true;
return new Promise((resolve, reject) => {
axios.post(url, data)
.then(response => { resolve(response.data);
}, err => { reject(err);
});
});
}
/**
* post 请求方法 提交格式为 formdata
* @param url
* @param data
* @returns {Promise}
*/
export function post_formData (url, data = {}) { // vue 中使用 window.FormData(),否则会报 'FormData isn't definded'
//创建一个FormData对象,然后通过append() 方法向对象中添加键值对
// let formData = new window.FormData();
let formData = new FormData(); //这里是 .js文件
for ( let key in data ){
formData.append( key, data[key]);
} const options = {
method: 'POST',
// headers: { 'content-type': 'application/x-www-form-urlencoded' },
headers: { 'Content-type': 'multipart/form-data' },
// data: qs.stringify(data),
data: formData,
url,
};
return axiosInstanceNew(options);
}
说明:注意上面代码有这行注释的地方
在main.js中挂载到了vue实例原型上
import { post, post_formData } from './libs/http';
Vue.prototype.$post_formData = post_formData;
这样基本上就可以了。请求时参数直接传入一个对象就可以了。
vue+axios通过formdata提交参数和上传文件的更多相关文章
- vue axios使用form-data的形式提交数据的问题
vue axios使用form-data的形式提交数据vue axios request payload form data由于axios默认发送数据时,数据格式是Request Payload,而并 ...
- .Net使用HttpClient以multipart/form-data形式post上传文件及其相关参数
前言: 本次要讲的是使用.Net HttpClient拼接multipark/form-data形式post上传文件和相关参数,并接收到上传文件成功后返回过来的结果(图片地址,和是否成功).可能有很多 ...
- Ajax上传数据和上传文件(三种方式)
Ajax向后端发送数据可以有三种方式:原生Ajax方式,jQuery Ajax方式,iframe+form 方式(伪造Ajax方式) <!DOCTYPE html> <html la ...
- php 下 html5 XHR2 + FormData + File API 上传文件
FormData的作用: FormData对象可以帮助我们自动的打包表单数据,通过XMLHttpRequest的send()方法来提交表单.当然FormData也可以动态的append数据.FormD ...
- [实战]MVC5+EF6+MySql企业网盘实战(12)——新建文件夹和上传文件
写在前面 之前的上传文件的功能,只能上传到根目录,前两篇文章实现了新建文件夹的功能,则这里对上传文件的功能进行适配. 系列文章 [EF]vs15+ef6+mysql code first方式 [实战] ...
- vue axios 与 FormData 结合 提交文件 上传文件
---再利用Vue.axios.FormData做上传文件时,遇到一个问题,后台虽然接收到请求,但是将文件类型识别成了字符串,所以,web端一直报500,结果是自己大意了. 1.因为使用了new F ...
- vue+axios实现移动端图片上传
在利用vue做一些H5页面时,或多或少会遇到有图片上传的操作,主要是运用html5里面的input[type=file]来实现,传递到后端的数据是以二进制的格式传递,所以上传图片的请求与普通的请求稍微 ...
- element ui axios使用formdata提交数据
axios({ //formdata提交 headers: { 'Content-Type': 'application/x-www-form-urlencoded' }, transformRequ ...
- 传统表单提交文件上传,以及FormData异步ajax上传文件
传统的文件上传: 只用将form表单的entype修改成multipart/form-data,然后就可以进行文件上传,这种方式常用并且简单. 以下是另一种方式FormData,有时候我们需要ajax ...
随机推荐
- Leetcode: Most Stones Removed with Same Row or Column
On a 2D plane, we place stones at some integer coordinate points. Each coordinate point may have at ...
- snmpwalk 安装与使用详解-windows下
snmpwalk是SNMP的一个工具,它使用SNMP的GETNEXT请求查询指定OID(SNMP协议中的对象标识)入口的所有OID树信息,并显示给用户.通过snmpwalk也可以查看支持SNMP协议( ...
- (待续)【转载】 DeepMind发Nature子刊:通过元强化学习重新理解多巴胺
原文地址: http://www.dataguru.cn/article-13548-1.html -------------------------------------------------- ...
- Qt编写气体安全管理系统18-数据库设置
一.前言 作为一个管理系统,数据库肯定是不可或缺的,Qt内置的sqlite数据库已经是够用的,而且本人亲测数据量能支持亿级别,而不是像网上很多人说的千万级别,我模拟过一亿多条数据,依然能够很好的查询, ...
- Hello log4net——做一个实用好用的log4net的demo(转)
log4net使用指南 (对配置解释比较全面细致,建议做完demo后多看) Log4Net使用详解(周公)——点击打开链接 Log4Net使用详解(续)周公——点击打开链接 点击打开链接 点击打开链 ...
- Java学习,从入门到放弃(二)Linux配置mvn
其实网上的教程很多,随便拿一个,比如:https://www.cnblogs.com/chuijingjing/p/10430649.html 但在实践过程中,发现可能需要将JAVA_HOME也加到 ...
- 服务发现框架选型,Consul还是Zookeeper还是etcd
背景 本文并不介绍服务发现的基本原理.除了一致性算法之外,其他并没有太多高深的算法,网上的资料很容易让大家明白上面是服务发现. 想直接查看结论的同学,请直接跳到文末. 目前,市面上有非常多的服务发现工 ...
- Winsock.简单TCP
PS:vs2017 编译C++代码 支持 XP:项目属性-->链接器-->系统-->需要的最小版本--> 输入 "5.1" 1.ZC:测试:c向s 发送长度 ...
- 关于Form、ModelForm的一些操作(持续更新)
1.前端循环:后端传到前端的form是可以循环的,以此获得想要展示的元素 <form method="post" class="form-horizontal&qu ...
- linux抓取top命令中数据的方法
top在linux中是一个非常直观的命令,可以清晰地看到各进程对资源的使用情况. 但是如果你想从top命令展示中提取某些数据出来,如果想当然地使用这句命令: top|grep xxx 就会被卡住, ...