一、前言

axios是vue项目中用来使用ajax技术来与后台交换数据的一个组件,在vue的作者推荐下,相当数量的vue前端开发人员开始使用它。但是在实际开发过程中,却时有出现后端接收不到前端post过来的数据的情况。以PHP语言开发的后台为例,PHP原生的预定义变量$_POST就无法接收(因为解析失败)。本文的目的在于探讨前后端数据交互,并给出不同的解决方案供大家参考。

二、目前$_POST可接收的数据形式

Form Data

这种数据形式其实就是键值对,例如id:1,如果有多组键值对并且有嵌套的情况,则如下

role-name:ta

role-desc:xxxxxxxxx

id:2

cloud[cla]:001

cloud[cla_baijia]:001

cloud[cla_gongkai]:001

local[soft5]:001

local[soft6]:001

mgmt[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方法

import axios from "axios"

import qs from "qs"

var json={

"role-name": "ta",

"role-desc": "xxxxxxxxx",

"id": 2,

"cloud": {

"cla": "001",

"cla_baijia": "001",

"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);

})

}

}

}

2、PHP后端使用php://input获取原始数据

在前端不做任何改变的情况下,因为预定义变量$_POST无法解析,php后端只能使用php://input获取原始的数据,然后再转化为想要的数据形式。

如果PHP后台使用原生开发,则可自定义一个函数处理每次请求的数据。

如果PHP后台使用特定的框架开发,则要看框架本身是否支持处理php://input,简单的一个测试方法就是在框架的源代码全文搜索php://input,如果能搜到,则有支持,否则不支持,需要自己扩展相关的处理代码。

以PHP框架yii2.0为例,全文搜索vendor目录,可知在yiisoft->yii2->web->Request.php的494行有相关处理代码。

实际使用只需在配置文件web.php配置

'components' => [

'request' => [

'parsers' => [

'application/json' => 'yii\web\JsonParser'

],

// 其他配置

],

//其他组件配置

]

以上就是前端处理和后端处理两种解决方案,可根据实际情况选择

vue怎么和php交互,vue的axios组件如何与PHP后端交换数据相关推荐

  1. vue如何和PHP交互,VUE中如何使用Vue-resource完成交互

    本篇文章主要介绍了VUE中使用Vue-resource完成交互,内容挺不错的,现在分享给大家,也给大家做个参考. 本文介绍了VUE中使用Vue-resource完成交互,分享给大家,具体如下 使用vu ...

  2. vue搭建项目、创建登录页面和后台交互之引入axios

    目录 1. 搭建项目 1.1 使用vue-cli创建项目 1.2 通过npm安装element-ui 1.3 导入组件 2 创建登录页面 2.1 创建登录组件 2.2 引入css(css.txt) 2 ...

  3. axios vue 回调函数_前端Vue 面试题大全

    点蓝色字关注"程序员报刊" 「  学习 新闻 招聘 」 vue的底层原理? vue组件之间的通信? JS中判断数据类型的方法有几种? 最常见的判断方法:typeof 判断已知对象类 ...

  4. Vue前端如何与后端进行数据交互

    1.安装 npm install axios --save 2.在main.js文件引入 import Axios from 'axios';//后台交互 Vue.prototype.$http=Ax ...

  5. Vue中的前后台交互

    先安装axios npm install axios 然后在vue页面中进行编码: import axios from 'axios';export default {name: 'App',comp ...

  6. 从壹开始前后端分离 [ Vue2.0+.NET Core2.1] 二十二║Vue实战:个人博客第一版(axios+router)...

    前言 今天正式开始写代码了,之前铺垫了很多了,包括 6 篇基础文章,一篇正式环境搭建,就是为了今天做准备,想温习的小伙伴可以再看看<Vue 基础入门+详细的环境搭建>,内容很多,这里就暂时 ...

  7. [vue] 你有使用做过vue与原生app交互吗?说说vue与ap交互的方法

    [vue] 你有使用做过vue与原生app交互吗?说说vue与ap交互的方法[vue] 你有使用做过vue与原生app交互吗?说说vue与ap交互的方法 我的做法就是让app在webview把app的 ...

  8. H5 vue实现百度下拉列表交互操作示例

    给大家分享一篇关于vue实现百度下拉列表交互操作示例的详细介绍,希望对同学们学习HTML5开发有所帮助,下面我们一起来看一下吧. www.jb51.net vue百度下拉列表 .gray{ backg ...

  9. Vue第二天学习总结—— Vue全家桶之组件化开发(组件化开发思想、组件注册、Vue调试工具用法、组件间数据交互传递、组件插槽、基于组件的案例——购物车)

    (一) 组件化开发思想 1. 现实中的组件化思想体现 组件化即是对某些可以进行复用的功能进行封装的标准化工作 标准:要想组件能够成功组合在一起,每个组件必须要有标准 分治:将不同的功能封装到不同的组件 ...

最新文章

  1. 3.1 A Historical Perspective 历史观点
  2. 软考自查:多媒体基础知识
  3. FPGA优化之高扇出
  4. 从TimeQuest角度看set_max_delay
  5. 系统管理模块_部门管理_设计(映射)本模块中的所有实体并总结设计实体的技巧_懒加载异常问题_树状结构...
  6. Android开发 ----------怎样真机调试?
  7. java如何识别tiled地图_Egret学习-TiledMap使用
  8. Windows - 通过注册表编辑器来删除多余盘符
  9. Shell入门:掌握Linux,OS X,Unix的Shell环境
  10. 数据 3 分钟 | ShardingSphere 核心团队获融资、巨杉数据库发布湖仓一体架构多款产品...
  11. image 微信小程序flex_第三天学习微信小程序开发总结
  12. 海康sdk java示例_调用海康SDK
  13. rtklib-RINEX文件读取-rinex.c解析(一)
  14. MPU6050读取实验
  15. java理论笔试题_Java基础笔试题及答案
  16. 阿里云服务器可以做什么?阿里云服务器十大应用场景
  17. 「目前全网唯一2万字长文」从JS上下文到Chromium源码的极限拉扯!!兄弟姐妹们接好了!!...
  18. 一文看懂25个神经网络模型,神经网络模型结构图
  19. 计算机二级c语言考点解析,2017年计算机二级C语言考点解析
  20. NTFS分区结构及图片文档结构

热门文章

  1. 计算机存储单位 t后面的单位,数据存储计量单位除了B、K、M、G、T,还有什么?怎么换算?...
  2. SOLIDWORKS Electrical和CAD电气版有啥区别?
  3. 服务器定时自动备份MySQL数据库
  4. android AppCompat, splash启动白屏(黑屏)全屏,去掉状态栏,以及splash与虚拟按键遮挡
  5. C# 给视频添加水印
  6. 上海的211大学中计算机,上海这所211大学太低调,实力强悍却易被忽略,本地中等生可“捡漏”...
  7. omap3530 linux串口驱动,LINUX下OMAP3530接MT9P031的摄像头驱动调试 给力的一周
  8. 腾讯的微生活、阿里淘点点、饿了吗相关前景分析
  9. leetcode_买股票的最佳时机----Python
  10. 在Android studio里写一个Flutter程序