Toggle navigation
首页
[
Markdown
]
0.说明 大叔 : 翔逼 我们要做一个微信公众号哦。我来教你大概的流程好不好?(开启装逼模式中 ) 翔逼 :好啊,快讲快讲。(无限期待中 ) 大叔 :你知道 application/x-www-form-urlencoded是什么嘛? 翔逼 :啊咧咧? 大叔 :你知道 php 怎么获得 raw? 翔逼 :啊咧咧? 大叔 :用下面这种方法来实现。 echo file_get_contents(“php://input”); 翔逼 :啊咧咧? 翔逼 :php://input是什么东西? 大叔 :嘿嘿,自己去了解吧。 1.无情浪子 POST 编故事 POST平常看起来人畜无害,但是有句话说的好。最可怕的不是鬼怪,而是人心(Content-Type)。POST在明面上,只有一个老婆叫做application/x-www-form-urlencoded,其实他一共有好几个伴侣。 ``` 键值妹:application/x-www-form-urlencoded 文件妹:multipart/form-data 多胞胎:raw text/plain text/html text/xml application/json application/xml application/javascirpt ``` 2.辨别真心 Content-Type 0.说明 我们想知道POST心里装着的人是谁怎么办呢,这次请出感情专家 postman 来帮忙。 1.application/x-www-form-urlencoded 截图 报文 POST HTTP/1.1Host: 127.0.0.1Cache-Control: no-cachePostman-Token: 4f2704aa-81e6-be22-4c36-8787ba945a22Content-Type: application/x-www-form-urlencodedname=lionis&sex=man 服务端代码 ``` <?php var_dump($_POST); 输出 array(2) { [“name”]=> string(6) “lionis” [“sex”]=> string(3) “man”} ``` 结论 application/x-www-form-urlencoded是常用的表单发包方式,普通的表单提交,默认都是通过这种方式。 对于PHP用$_POST获得键值对。 2.multipart/form-data 截图 报文 POST HTTP/1.1Host: 127.0.0.1 Cache-Control: no-cache Postman-Token: f7640c52-6667-b4e8-aee8-02b0e1656969 Content-Type: multipart/form-data; boundary=----WebKitFormBoundary7MA4YWxkTrZu0gW ----WebKitFormBoundary7MA4YWxkTrZu0gW Content-Disposition: form-data; name="name"lionis ----WebKitFormBoundary7MA4YWxkTrZu0gW Content-Disposition: form-data; name=“sex"man ----WebKitFormBoundary7MA4YWxkTrZu0gW Content-Disposition: form-data; name=“avater”; filename=”"Content-Type: ----WebKitFormBoundary7MA4YWxkTrZu0gW 服务端代码 ``` <?php var_dump($_POST); var_dump($_FILES); 输出 array(2) { [“name”]=> string(6) “lionis” [“sex”]=> string(3) “man”}array(1) { [“avater”]=> array(5) { [“name”]=> string(36) “0CD0A5235EDCDAAB4AFE05B25695E696.png” [“type”]=> string(9) “image/png” [“tmp_name”]=> string(45) “/Applications/XAMPP/xamppfiles/temp/phpeFfc9e” [“error”]=> int(0) [“size”]=> int(9485) } } ``` 结论 multipart/form-data 用在发送文件的POST包。对于PHP用$_FILE获取文件内容,用$_POST获得键值对。 3.row 截图 报文 POST HTTP/1.1Host: 127.0.0.1 Content-Type: application/json Cache-Control: no-cache Postman-Token: 9e0c339b-a6b0-c534-5c62-63ef8dc887c4 { “user”: “xieyuandong”, “sex”: “man” } 服务端代码 ``` <?php var_dump(file_get_contents(‘php://input’)); 输出 string(47) "{ "user": "xieyuandong", "sex“: "man" }” ``` 结论 raw可以上传json,xml,文本等等。对于PHP用php://input获得内容。 3.$_POST vs php://input vs HTTP_RAW_POST_DATA 1.$_POST 可以获 Content-Type 为 application/x-www-form-urlencoded 或者 multipart/form-data 的请求。 2.HTTP_RAW_POST_DATA $POST不能获取的方式,都会存储在HTTP_RAW_POST_DATA,用$GLOBALS[‘HTTP_RAW_POST_DATA’] 接收。给内存带来的压力较大,并且需要 php.ini 设置。 3.php://input 允许读取 POST 的原始数据。给内存带来的压力较小,并且不需要 php.ini 设置。不能用于 enctype=“multipart/form-data”。 4.结论 在php 7中已经取消了HTTP_RAW_POST_DATA,我们平时使用$POST和php://input就好了。
[
Html
]