博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
vue的axios组件如何与PHP后端交换数据
阅读量:6818 次
发布时间:2019-06-26

本文共 1716 字,大约阅读时间需要 5 分钟。

一、前言

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 的 和就是为把数据转化为QueryString而提供的解决方案,前者转化表单数据,后者转化JSON数据。

而且jQuery的ajax请求中会判断传入的数据形式,隐式调用param()方法来转化json数据,所以使用者只需直接提供json数据即可成功把数据成功提交到后台,需要显式(手动)调用param()方法的机会不多。jq默认的发送的请求头也是application/x-www-form-urlencoded,大多数情况下并不需要使用者手动设置。

回到我们的axios中,axios默认发送的请求头为application/json,简单来说,它默认就是会把json传到后端,并不转化为QueryString。

三、解决方法

1、前端把数据转化为QueryString

引入qs库,调用stringify方法

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'            ],            // 其他配置        ],        //其他组件配置    ]

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

转载地址:http://fpdzl.baihongyu.com/

你可能感兴趣的文章
HotSpot运行时概览#2
查看>>
Go结构体标签表达式v1.0发布,参数校验杀手锏
查看>>
对react中setState的总结
查看>>
[回炉计划]-实现一个图片预加载
查看>>
正则表达式
查看>>
360前端星计划学习-html
查看>>
专注dApp高效执行和高并发的下一代公有链
查看>>
ONE-sys 整合前后端脚手架 koa2 + pm2 + vue-cli3.0 + element
查看>>
携带更方便功能全 iPone与Apple Watch球形尿袋
查看>>
行为型模式:策略模式
查看>>
实现批量数据增强 | keras ImageDataGenerator使用
查看>>
太忙女友消息未及时回复,分手吗?python微信自动消息帮你谈恋爱
查看>>
Java 多线程NIO学习
查看>>
命名实体识别
查看>>
动态切换的动态代理
查看>>
电商项目(下)
查看>>
vue 数字滚动递增效果
查看>>
vue2.0中父子,兄弟组件的传值2
查看>>
Spring Boot注解常用!!!看了就可以开发大量项目了
查看>>
音频编码 Audio Converter
查看>>