网站首页 > 知识剖析 正文
为什么和第三方平台对接接口的时候,在接收http请求数据包时,一般都是用file_get_contents("php://input"),而不是用$_POST呢?
file_get_contents:将整个文件读入一个字符串
在用php写接口的时候,通常会将请求的数据通过json的形式发送到指定的请求地址处,此时的file_get_contents(‘php://input’)主要是用来获取请求的原始数据。和 $HTTP_RAW_POST_DATA 比起来,php://input给内存带来的压力较小,并且不需要任何特殊的 php.ini 设置。
注意两点:
数据的提交方式应为POST
php://input 不能用于接收enctype="multipart/form-data"表单提交的数据
1、举一个简单示例:
提交表单
<form action="" method="POST">
姓名: <input type="text" name="name" value="tom" /><br />
年龄:<input type="text" name="age" value="22" /><br />
<input type="submit" value="Submit" />
</form>
后端控制器通过file_get_contents(‘php://input’),获取请求原始数据流
<?php
$content = file_get_contents('php://input', 'r');
echo $content;
//输出name=tom&age=22
?>
2、在项目应用中,如摄像头拍照,上传保存,就可以用到php://input。客户端拍照后,把图片流传送到服务端,服务端使用file_get_getcontents(‘php://input’)就能获取到图片流。
$_POST
$_POST只能接收Content-Type: application/x-www-form-urlencoded提交的数据,php会将http请求body相应数据填入到数组_POST中,_POST数组中的数据是进行urldecode()解析的结果。除了该Content-Type,还有 multipart/form-data类型的表单数据也可以用$_POST接收。
四种常见的提交数据方式,分别如下:
定义和用法
enctype 属性规定在发送到服务器之前应该如何对表单数据进行编码。默认地,表单数据会编码为 "application/x-www-form-urlencoded"。就是说,在发送到服务器之前,所有字符都会进行编码(空格转换为 "+" 加号,特殊符号转换为 ASCII HEX 值)。
enctype属性值
Content-Type值 描述
application/x-www-form-urlencoded 在发送前编码所有字符(默认)
multipart/form-data
不对字符编码。
在使用包含文件上传控件的表单时,必须使用该值。
text/plain 空格转换为 "+" 加号,但不对特殊字符编码。
text/xml
一种使用 HTTP 作为传输协议,XML 作为编码方式的远程调用规范。
总结:
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://input数据才跟$_POST数据相一致。
5、如果不能获取的时候,比如Coentent-Type为text/xml、application/json、soap,请使用 file_get_contents('php://input');
原文链接:https://blog.csdn.net/qq15577969/article/details/113934324
猜你喜欢
- 2025-01-23 CSS selector 小知识学习分享(css知识点整理)
- 2025-01-23 别再写jsp了,Thymeleaf它不香吗?
- 2025-01-23 手把手带你快速入门jQuery(建议收藏!!!)
- 2025-01-23 (一)熟练HTML5+CSS3,每天复习一遍
- 2025-01-23 6个常见的PHP安全性攻击(6个常见的php安全性攻击类型)
- 2025-01-23 SpringMVC 中的参数还能这么传递?涨姿势了
- 2025-01-23 ABB机器人二次开发:使用Web网页读取机器人系统信息的操作方法
- 2025-01-23 重新认识受控和非受控组件(受控和非受控react)
- 2025-01-23 总结几个移动端H5软键盘的大坑【实践】
- 2025-01-23 Java 中的 AI:使用 Spring Boot 和 LangChain 构建 ChatGPT 克隆
- 04-26workerman 自定义的协议如何解决粘包拆包
- 04-26Everything 在应急响应中的使用
- 04-26后端开发干货:PHP源码阅读技巧
- 04-26php8属性注解使用教程
- 04-26PHP 中不可能存在的 XXE
- 04-26PHP-FPM 学习记录
- 04-26【玩法悉知】:领地战玩法全解析!
- 04-26PHP实现URL编码、Base64编码、MD5编码的方法
- 最近发表
- 标签列表
-
- xml (46)
- css animation (57)
- array_slice (60)
- htmlspecialchars (54)
- position: absolute (54)
- datediff函数 (47)
- array_pop (49)
- jsmap (52)
- toggleclass (43)
- console.time (63)
- .sql (41)
- ahref (40)
- js json.parse (59)
- html复选框 (60)
- css 透明 (44)
- css 颜色 (47)
- php replace (41)
- css nth-child (48)
- min-height (40)
- xml schema (44)
- css 最后一个元素 (46)
- location.origin (44)
- table border (49)
- html tr (40)
- video controls (49)