file_get_contents("php://input")用法

file_get_contents() 函数把整个文件读入一个字符串中。

php://input 是个可以访问请求的原始数据的只读流。 POST 请求的情况下,最好使用 php://input 来代替 $HTTP_RAW_POST_DATA,因为它不依赖于特定的 php.ini 指令。 而且,这样的情况下 $HTTP_RAW_POST_DATA 默认没有填充, 比激活 always_populate_raw_post_data 潜在需要更少的内存。 enctype="multipart/form-data" 的时候 php://input 是无效的。

 

1.php://input 可以读取http entity body中指定长度的值,由Content-Length指定长度,不管是POST方式或者GET方法提交过来的数据。但是,一般GET方法提交数据 时,http request entity body部分都为空。 


2.php://input 与$HTTP_RAW_POST_DATA读取的数据是一样的,都只读取Content-Type不为multipart/form-data的数据。


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


4PHP不能识别的Content-Type类型的时候,会将http请求包中相应的数据填入变量$HTTP_RAW_POST_DATA


5. 只有Coentent-Typemultipart/form-data的时候,PHP不会将http请求数据包中的相应数据填入php://input,否则其它情况都会。填入的长度,由Coentent-Length指定。 


6.只有Content-Typeapplication/x-www-data-urlencoded时,php://input数据才跟$_POST数据相一致。 


7.php://input数据总是跟$HTTP_RAW_POST_DATA相同,但是php://input比$HTTP_RAW_POST_DATA更凑效,且不需要特殊设置php.ini 

扫描二维码关注公众号,回复: 9069040 查看本文章

8.PHP会将PATH字段的query_path部分,填入全局变量$_GET。通常情况下,GET方法提交的http请求,body为空。

例子 1.phpfile_get_contents("php://input")或者$HTTP_RAW_POST_DATA可以接收xml数据

1 <?php
2 $xmldata = file_get_contents("php://input");
3 $data = (array)simplexml_load_string($xmldata);
4 ?>

这里的$data就是包含xml数据的数组,通过simplexml_load_string()解析xml数据

2.
微信支付回调验证

public function notify() 
{
  //获取微信返回的数据结果
  //php用file_get_contents("php://input")或者    $HTTP_RAW_POST_DATA可以接收xml数据
  $postData = file_get_contents("php://input");
  //将结果转换成数组
  $getData = $this->xmlstr_to_array($postData);              
}
//XXE漏洞需要在回调处理代码里面解析XML之前,加入禁用实体解析的代码 public function xmlstr_to_array($xmlstr)
{   libxml_disable_entity_loader(
true);//关键代码   //转换形式良好的 XML 字符串为 SimpleXMLElement 对象,然后输出对象的键和元素:   $xmlstring = simplexml_load_string($xmlstr, 'SimpleXMLElement', LIBXML_NOCDATA);   //第二个参数为true返回 array ,默认是false返回object   $val = json_decode(json_encode($xmlstring),true);   return $val; }

猜你喜欢

转载自www.cnblogs.com/murraybin/p/12293108.html