XMLHttpRequest 发送 post 请求,php 接收不到数据的解决方案


方案一:Content-Type: "application/json"

首先,我们先看下,XMLHttpRequest 请求头的默认编码方式是什么。

JS 部分

复制代码var xhr = new plus.net.XMLHttpRequest(); xhr.onreadystatechange = function() { if( xhr.readyState==4 && xhr.status==200 ) { console.log(xhr.responseText); } } var json = { name: "Eric", password: "123456" }; xhr.open("POST","http://www.xxx.com/api.php"); xhr.send(JSON.stringify(json)); // post 数据只能是字符串

PHP 部分

复制代码<?php  
    // 返回请求头的编码方式和 name 的值 $header = $_SERVER["CONTENT_TYPE"]; $name = $_POST["name"]; echo '{"header":"'.$header.'","name":"'.$name.'"}'; ?>

返回结果:{"header":"text/plain;charset=utf-8","name":""}
很显然,$_POST["name"] 没有取到数据。


虽然他说的是 mui.ajax 方式,但是思路都是一样的,然后,我修改了下代码。

JS 部分

复制代码var xhr = new plus.net.XMLHttpRequest(); xhr.onreadystatechange = function() { if( xhr.readyState==4 && xhr.status==200 ) { console.log(xhr.responseText); } } var json = { name: "Eric", password: "123456" }; xhr.open("POST","http://www.xxx.com/api.php"); xhr.setRequestHeader("Content-Type","application/json;charset=utf-8"); xhr.send(JSON.stringify(json)); // post 数据只能是字符串

PHP 部分

复制代码<?php  
    // 返回请求头的编码方式和 name 的值 $input = file_get_contents('php://input'); $object = json_decode($input); $name = $object->name; echo '{"header":"'.$_SERVER["CONTENT_TYPE"].'","name":"'.$name.'"}'; ?>

返回结果:{"header":"application/json;charset=utf-8","name":"Eric"}
很显然,数据已经接收到,这种方案确实有效。

虽然确实能解决问题,但我最终没有采用的原因是:
①. 不够直接,它不是通过 $_POST[] 方式获取的数据,后台需要对数据进行解析,无形中增加了工作量
②. 旧项目迁移不友好,如果旧项目之前采用的是 $_POST[] 方式,后台接口改动会很大

.

方案二:Content-Type: "application/x-www-form-urlencoded"

首先,后台(php)使用 $_POST[] 获取数据,需要满足两个条件:

  • 设置请求头,Content-Type: "application/x-www-form-urlencoded"
  • 请求数据必须序列化,比如,name=Eric&password=123456

直接上代码:

JS 部分

复制代码var xhr = new plus.net.XMLHttpRequest(); xhr.onreadystatechange = function() { if( xhr.readyState==4 && xhr.status==200 ) { console.log(xhr.responseText); } } xhr.open("POST","http://www.xxx.com/api.php"); xhr.setRequestHeader("Content-Type","application/x-www-form-urlencoded;charset=utf-8"); xhr.send("name=Eric&password=123456");

PHP 部分

复制代码<?php  
    $header = $_SERVER["CONTENT_TYPE"]; $name = $_POST["name"]; echo '{"header":"'.$header.'","name":"'.$name.'"}'; ?>

返回结果:{"header":"application/x-www-form-urlencoded;charset=utf-8","name":"Eric"}


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM