axios.post简单封装

简单学习了以下axios数据传输,习惯性对请求进行了以下封装,以下为封装好的代码(相关js文件的引入不谈)

/**
 * 账号登陆登陆
 * 
 * @param url
 *            方法名
 * @param data
 *            参数
 * @param success
 *            成功回调函数
 * @returns
 */
function doPostLogin(url, data, success) {
	axios.post(
		SERVER_HOST + url,
		data,
		{
			headers: {
				'Content-Type': 'application/x-www-form-urlencoded',
				'Authorization': '***********'
			}
		}).then(function (response) {
			// 成功回调函数
			success(response.data)
		}).catch(function (error) {
			console.log(error)
    });
}

因为后端使用了Spring Security进行安全验证,所以请求头中包含Authorization信息,实际开发中根据个人需要添加,SERVER_HOST为全局变量,即系统访问前缀,在本文中的值为'http://127.0.0.1:8001/'
现在看一下如何调用这个方法:

/**
 * 点击登陆按钮
 * 
 * @returns
 */
function loginSubmit(){
	var data={
		username:‘18812345678’,
		password:‘123456’
	}
	var url = "login/login"
	console.log(data)
	doPostLogin(url,data,loginSuc);
}

/**
 * 登陆成功回调函数
 * 
 * @param data
 *            后端返回值
 * @returns
 */
function loginSuc(data){
	console.log(data)
	console.log("登陆成功")
}

首先,以上方式封装是没有问题的,但是如果这样调用后端无法获取到data里面的参数!!

正常情况下(ajax)这种方式是没有问题的,但是实际上这里存在问题,原因就出现在请求头的'Content-Type': 'application/x-www-form-urlencoded',中,以axios传递此类参数和ajax传递此类参数请求信息是不同的,这个可以F12自己试验一下,现在说一下正确的方式

/**
 * 点击登陆按钮
 * 
 * @returns
 */
function loginSubmit(){
	let data="username="+‘18812345678’+"&password="+‘123456’
	var url = "login/login"
	console.log(data)
	doPostLogin(url,data,loginSuc);
}

将参数data转成字符串即可,这样后端就可以获取到请求中的数据。
当然,以上操作基于后端request.getParameter获取参数

如果你要使用json传输数据可以参考以下封装:

/**
 * post请求
 * 
 * @param url
 *            方法名
 * @param data
 *            参数
 * @param success
 *            成功回调函数
 * @returns
 */
function doPost(url, data, success) {
	axios.post(
		SERVER_HOST + url,
		data,
		{
			headers: {
				'Content-Type': 'application/json;charset=UTF-8',
				'Authorization': AUTH_TOKEN
			}
		}).then(function (response) {
			// 成功回调函数
			success(response.data)
		}).catch(function (error) {
			console.log(error)
    });
}

调用方式

/**
 * 发送短信验证码
 * 
 * @returns
 */
function sendSms() {
	var data = {
		mobile : ‘18812345678’
	}
	var url = "code/sms"
	doPost(url, data, sendSmsSuc)
}
/**
 * 短信发送成功回调函数
 * 
 * @param data
 *            返回值
 * @returns
 */
function sendSmsSuc(data) {
	console.log(data)
}

如有高见,欢迎留言!

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
axios.create是axios提供的一个方法,用于创建一个新的axios实例。通过创建实例,我们可以对axios的请求进行二次封装,以满足具体项目的需求。具体而言,我们可以在创建实例时传入一些配置参数,如baseURL、timeout等,来定制请求的基础地址和超时时间。这样,在项目中使用这个新创建的axios实例进行请求时,就会自动使用这些配置参数。 通过axios.create方法创建的实例,可以使用和axios一样的各种请求方法,如get、post、put、delete等。同时,我们也可以在创建实例时,传入一些默认的配置参数,来统一处理请求拦截和响应拦截等操作。这样,我们可以在实例上添加拦截器,对请求和响应进行处理,实现一些额外的功能,比如添加请求头、处理错误等。 总结来说,axios.create方法是用来创建一个新的axios实例,通过这个实例可以对请求进行二次封装,实现一些定制化的需求。我们可以在创建实例时传入配置参数,来定义基础地址和超时时间等信息,并且可以在实例上添加拦截器来处理请求和响应。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [axios封装](https://blog.csdn.net/ZDM_9999/article/details/127999432)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* *3* [axios 的理解和使用 axios.create(对axios请求进行二次封装) 拦截器 取消请求(axios.CancelToken)](https://blog.csdn.net/weixin_42448623/article/details/104773280)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值