php ajax传递的json数据,在 php 中如何接收 ajax 提交的 json 数据

今天用 angular 中的 $resource 给 php 发送 json 数据时,发现服务端用$_POST没法接收,代码如下:

1

2

3

4

5

6

7

8

9

10

11

12

13

14angular.module('app.controllers', [])

.controller("SigninCtrl", [

'$scope'

'Login'

($scope, Login) ->

loginInfo =

key: md5 "xxxxxx"

$scope.login = ->

angular.extend loginInfo, "user_name": $scope.user_name, "password": $scope.password

Login.post loginInfo, (resp) ->

debugger

])

上面的请求头和请求体分别是:

1

2

3

4Content-Type:application/json;charset=UTF-8

body: {

"key":"276963ad39cbdd8fb960718981aedf0c","user_name":"wcj","password":"123456"

}

究其原因是,Coentent-Type 仅在取值为 application/x-www-data-urlencoded 和 multipart/form-data 两种情况下,PHP 才会将 http 请求数据包中相应的数据填入全局变量$_POST

PHP 不能识别的 Content-Type 类型的时候,会将 http 请求包中相应的数据填入变量 $HTTP_RAW_POST_DATA,而 php://input 允许读取 POST 的原始数据,和 $HTTP_RAW_POST_DATA 比起来,它给内存带来的压力较小,并且不需要任何特殊的 php.ini 设置。但 php://input 不能用于 enctype=”multipart/form-data”。

那么在php中,我们可以根据检查请求头的 Content-Type 是否为 application/json 来选择不同的解析方式:

1

2

3

4$postdata = file_get_contents("php://input");

$request = json_decode($postdata);

$user_name = $request->email;

$password = $request->password;

上面代码通过 file_get_contents 函数获取请求的原始数据,然后再通过 json_decode 解析出我们想要的数据。此外可以通过以下函数获取 http 请求头信息以判断 Content-Type 的值:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19function getallheaders(){

foreach ($_SERVER as $name => $value) {

if (substr($name, 0, 5) == 'HTTP_') {

$headers[str_replace(' ', '-', ucwords(strtolower(str_replace('_', ' ', substr($name, 5)))))] = $value;

}

if (isset($_SERVER['PHP_AUTH_DIGEST'])) {

$header['AUTHORIZATION'] = $_SERVER['PHP_AUTH_DIGEST']);

} elseif (isset($_SERVER['PHP_AUTH_USER']) && isset($_SERVER['PHP_AUTH_PW'])) {

$header['AUTHORIZATION'] = base64_encode($_SERVER['PHP_AUTH_USER'] . ':' . $_SERVER['PHP_AUTH_PW']));

}

if (isset($_SERVER['CONTENT_LENGTH'])) {

$header['CONTENT-LENGTH'] = $_SERVER['CONTENT_LENGTH'];

}

if (isset($_SERVER['CONTENT_TYPE'])) {

$header['CONTENT-TYPE'] = $_SERVER['CONTENT_TYPE'];

}

}

return $headers;

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值