资讯专栏INFORMATION COLUMN

vue的axios组件如何与PHP后端交换数据

CloudwiseAPM / 1201人阅读

摘要:本文的目的在于探讨前后端数据交互,并给出不同的解决方案供大家参考。实际使用只需在配置文件配置其他配置其他组件配置以上就是前端处理和后端处理两种解决方案,可根据实际情况选择

一、前言

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



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

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

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/30754.html

相关文章

  • vueaxios组件如何PHP后端交换数据

    摘要:本文的目的在于探讨前后端数据交互,并给出不同的解决方案供大家参考。实际使用只需在配置文件配置其他配置其他组件配置以上就是前端处理和后端处理两种解决方案,可根据实际情况选择 一、前言 axios是vue项目中用来使用ajax技术来与后台交换数据的一个组件,在vue的作者推荐下,相当数量的vue前端开发人员开始使用它。但是在实际开发过程中,却时有出现后端接收不到前端post过来的数据的情况...

    韩冰 评论0 收藏0
  • VUE知识点集锦

    摘要:载入前后在阶段,实例的和都初始化了,但还是挂载之前为虚拟的节点,还未替换。类似于,不同在于提交的是,而不是直接变更状态可以包含任意异步操作。 vue基础 1、 router 路由与 a 标签的区别:https://www.jianshu.com/p/34b...2、 VUE双向绑定的原理: 答:VUE实现双向数据绑定的原理就是利用了 Object.defineProperty() 这个...

    APICloud 评论0 收藏0
  • VUE知识点集锦

    摘要:载入前后在阶段,实例的和都初始化了,但还是挂载之前为虚拟的节点,还未替换。类似于,不同在于提交的是,而不是直接变更状态可以包含任意异步操作。 vue基础 1、 router 路由与 a 标签的区别:https://www.jianshu.com/p/34b...2、 VUE双向绑定的原理: 答:VUE实现双向数据绑定的原理就是利用了 Object.defineProperty() 这个...

    Tecode 评论0 收藏0
  • 后端开发者Vue学习之路(五)

    摘要:由服务器提供的响应来自服务器响应的状态码来自服务器响应的状态信息服务器响应的头是为请求提供的配置信息所以请求返回后,我们可以通过来获取响应情况。拦截器拦截器拦截器用于拦截发起的请求或用于拦截返回的响应。目录 上节内容回顾 使用第三方组件库 如何发起请求 请求错误处理 请求带参 ...

    jay_tian 评论0 收藏0
  • 急速JavaScript全栈教程

    摘要:使用访问后端服务使用的美化组件的方法整合全栈服务其中的指的是。所幸是在这个教程内,你不需要学习太多就可以把案例跑起来。另外一个组件负责显示全部项目,并接受删除事件,删除指定的项目。它们分别是组件和组件这两个组件的代码实现,分别在文件和内。 自从一年前发布了Vuejs小书的电子书,也有些日子没有碰过它们了,现在因为项目的缘故,需要使用JavaScript全栈开发。所以,我得把这个全栈环境...

    xingqiba 评论0 收藏0

发表评论

0条评论

CloudwiseAPM

|高级讲师

TA的文章

阅读更多
最新活动
阅读需要支付1元查看
<