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-urlencoded和multipart/form-data两种情况下,PHP才会将http请求数据包中相应的数据填入全局变量$_POST
4,PHP不能识别的Content-Type类型的时候,会将http请求包中相应的数据填入变量$HTTP_RAW_POST_DATA
5. 只有Coentent-Type为multipart/form-data的时候,PHP不会将http请求数据包中的相应数据填入php://input,否则其它情况都会。填入的长度,由Coentent-Length指定。
6.只有Content-Type为application/x-www-data-urlencoded时,php://input数据才跟$_POST数据相一致。
7.php://input数据总是跟$HTTP_RAW_POST_DATA相同,但是php://input比$HTTP_RAW_POST_DATA更凑效,且不需要特殊设置php.ini
8.PHP会将PATH字段的query_path部分,填入全局变量$_GET。通常情况下,GET方法提交的http请求,body为空。
例子 1.php用file_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; }
file_get_contents("php://input")用法
原文:https://www.cnblogs.com/murraybin/p/12293108.html