$ GLOBALS [ “HTTP_RAW_POST_DATA”]跟$ _POST,的file_get_contents( 'PHP://输入') 差不多,用$ GLOBALS [ “HTTP_RAW_POST_DATA”]或的file_get_contents( 'PHP://输入')的情况大多是为了获取$ _POST无法接收的数据类型(如XML数据)
在$ GLOBALS [“HTTP_RAW_POST_DATA”]取不到值的情况下可以按以下方式排查:
1.用的file_get_contents( 'PHP://输入')。获取数据如果获取不到,则可能是数据传输错误,对请求进行捉包,分析数据。
2.如果的file_get_contents( 'PHP://输入')。有数据则查看的php.ini配置文件。
找到如下,如果没开启则开启
- always_populate_raw_post_data =on
注意:这种处理方式是在PHP版本较低的时候,在PHP-INI中才有的配置,当版本升级到7,或者更高的时候该机制就被。
下边归纳几种PHP获取后数据的方式:
RPC规定接收取值方式$ GLOBALS ['HTTP_RAW_POST_DATA'] ;
PHP默认识别的数据类型是应用程序/ x-www.form-urlencoded的标准的数据类型。
1,$ _ POST [ 'PARAMNAME']
只会接收Content-Type:application / x-www-form-urlencoded提交的数据,php会将http请求体相应数据会填入到数组$ _POST,填入到$ _POST数组中的数据是进行urldecode()解析的结果。(其实,除了该Content-Type,还有multipart / form-data表示数据是表单数据)
2,的file_get_contents( “PHP://输入”)
适用大多数类型的内容类型,php://输入允许读取POST的原始数据。和$ HTTP_RAW_POST_DATA比起来,它给内存带来的压力较小,并且不需要任何特殊的php.ini设置.php ://输入不能用于enctype =“multipart / form-data”。
3,$ GLOBALS [ 'HTTP_RAW_POST_DATA'];
总是产生$ HTTP_RAW_POST_DATA变量包含有原始的POST数据。此变量仅适用于识别MIME类型的数据时产生。$ HTTP_RAW_POST_DATA对于enctype =“multipart / form-data”表单数据不可用。
如果post过来的数据不是PHP能够识别的,你可以用$ GLOBALS ['HTTP_RAW_POST_DATA']来接收,比如text / xml或者soap等等。需要设置php.ini中的always_populate_raw_post_data值为On,PHP才会总把POST数据填入变量$ HTTP_RAW_POST_DATA。
1,Coentent-Type仅在取值为application / x-www-data-urlencoded和multipart / form- data两种情况下,PHP才会将http请求数据包中相应的数据填入全局变量$ _POST
2,PHP不能识别的Content-Type的类型的时候,会将HTTP请求包中相应的数据填入变量$ HTTP_RAW_POST_DATA
3,只有Coentent-Type不为multipart / form-data的时候,PHP不会将http请求数据包中的相应数据填入php:// input,否则其它情况都会。填入的长度,由Coentent-Length指定。
4,只有Content-Type为application / x-www-data-urlencoded时,php://输入数据才跟$ _POST数据相一致。
5,php://输入数据总是跟$ HTTP_RAW_POST_DATA相同,但是php://输入比$ HTTP_RAW_POST_DATA更凑效,且不需要特殊设置php.ini
6,PHP会将PATH字段的query_path部分,填入全局变量$ _GET。通常情况下,GET方法提交的HTTP请求,机身为空。
总之:
1,如果是application / x-www-form-urlencoded和multipart / form-data格式用$ _POST;
使用file_get_contents('php://input');
<?php
/ **
*微信php测试
*更新时间:20141008
* /
//定义您的令牌
定义(“TOKEN”,“weixinvip”);
$ wechatObj = new wechatCallbackapiTest();
$ wechatObj-> responseMsg();
// $ wechatObj->有效();
class WechatCallbackapiTest
{
public function valid()
{
$ echoStr = $ _GET [“echostr”];
//有效签名,选项
如果($ this-> checkSignature()){
echo $ echoStr;
出口;
}
}
public function responseMsg()
{
//获取发布数据,可能是由于不同的环境造成的
//修改前:$ postStr = $ GLOBALS [“HTTP_RAW_POST_DATA”];
$ postStr = file_get_contents('php:// input');
//提取发布数据
if(!empty($ postStr)){
$ postObj = simplexml_load_string($ postStr,'SimpleXMLElement',LIBXML_NOCDATA);
$ fromUsername = $ postObj-> FromUserName;
$ toUsername = $ postObj-> ToUserName;
$ keyword = trim($ postObj-> Content);
$ time = time();
$ textTpl =“<xml>
<ToUserName> <![CDATA [%s]]> </ ToUserName>
<FromUserName> <![CDATA [%s]]> </ FromUserName>
<CreateTime>%s </ CreateTime>
<MsgType> <![CDATA [%s]]> </ MsgType>
<Content> <![CDATA [%s]]> </ Content>
<FuncFlag>
{
$ msgType =“text”;
if($ keyword =='ok'){
$ contentStr =“要死啦”;
} else {
preg_match('/(\ d +)([+ - ])(\ d +)/ i',$ keyword,$ res);
如果($ res [2] =='+'){
$ result = $ res [1] + $ res [3];
($ res [2] ==' - '){
$ result = $ res [1] - $ res [3];
}
$ contentStr =“欢迎来到微信世界!结果是”。$ result;
}
$ resultStr = sprintf($ textTpl,$ fromUsername,$ toUsername,$ time,$ msgType,$ contentStr);
} else {
echo“Input something ...”;
}
} else {
echo“”;
出口;
}
}
私人函数checkSignature()
{
$ signature = $ _GET [“签名”];
$ timestamp = $ _GET [“timestamp”];
$ nonce = $ _GET [“nonce”];
$ token = TOKEN;
$ tmpArr = array($ token,$ timestamp,$ nonce);
sort($ tmpArr,SORT_STRING);
$ tmpStr = implode($ tmpArr);
$ tmpStr = sha1($ tmpStr);
if($ tmpStr == $ signature){
return true;
} else {
return false;
}
}
}
?>