这篇文章主要介绍了关于如何让vue的axios组件和PHP后端交换数据,有着一定的参考价值,现在分享给大家,有需要的朋友可以参考一下
一、前言
axios是vue项目中用来使用ajax技术来与后台交换数据的一个组件,在vue的作者推荐下,相当数量的vue前端开发人员开始使用它。但是在实际开发过程中,却时有出现后端接收不到前端post过来的数据的情况。以PHP语言开发的后台为例,PHP原生的预定义变量$_POST就无法接收(因为解析失败)。本文的目的在于探讨前后端数据交互,并给出不同的解决方案供大家参考。
二、目前$_POST可接收的数据形式
Form Data
这种数据形式其实就是键值对,例如id:1,如果有多组键值对并且有嵌套的情况,则如下
role-name:tarole-desc:xxxxxxxxxid:2cloud[cla]:001cloud[cla_baijia]:001cloud[cla_gongkai]:001local[soft5]:001local[soft6]:001mgmt[mgmt-clouditems]:01
PHP服务端接收到的数据其实是这样子的
role-name=ta&role-desc=xxxxxxxxx&id=2&cloud%5Bcla%5D=001&cloud%5Bcla_baijia%5D=001&cloud%5Bcla_gongkai%5D=001&local%5Bsoft-5%5D=001&local%5Bsoft-6%5D=001&mgmt%5Bmgmt-clouditems%5D=01
是不是与url的参数特别像?
这种键值对的数据被称为QueryString,浏览器的原生 form 表单发送这种数据时会把请求头设为application/x-www-form-urlencoded。
QueryString就能被PHP的$_POST成功解析
经典的前端库jQuery下的jQuery ajax 的 serialize()方法和param()方法就是为把数据转化为QueryString而提供的解决方案,前者转化表单数据,后者转化JSON数据。
而且jQuery的ajax请求中会判断传入的数据形式,隐式调用param()方法来转化json数据,所以使用者只需直接提供json数据即可成功把数据成功提交到后台,需要显式(手动)调用param()方法的机会不多。jq默认的发送的请求头也是application/x-www-form-urlencoded,大多数情况下并不需要使用者手动设置。
回到我们的axios中,axios默认发送的请求头为application/json,简单来说,它默认就是会把json传到后端,并不转化为QueryString。
三、解决方法
1、前端把数据转化为QueryString
引入qs库,调用stringify方法
<template> <p> <input type="button" name="login" value="数据提交" @click="post"> </p></template><script>import axios from "axios"import qs from "qs"var json={ "role-name": "ta", "role-desc": "xxxxxxxxx", "id": 2, "cloud": { "cla": "001", "cla_baijia": "001&q<strong>+本文来源gao@daima#com搞(%代@#码网</strong><pre>搞代gaodaima码
uot;, "cla_gongkai": "001" }, "local": { "soft-5": "001", "soft-6": "001" }, "mgmt": { "mgmt-clouditems": "01" } };export default { methods:{ post(){ axios.post("http://localhost/web/index.php/admin/login/login",json,{ //配置`transformRequest` ,在向服务器发送前,修改请求数据,axios会根据修改后的数据,自动设置请求头 transformRequest:[function(data){ return qs.stringify(data);//把数据转化为QueryString }] }).then(res=>{ console.log(res); }) } }}</script>