你所不知道的 POST
你所不知道的 POST
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
服务端代码
输出
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.1Cache-Control: no-cachePostman-Token: f7640c52-6667-b4e8-aee8-02b0e1656969Content-Type: multipart/form-data; boundary=----WebKitFormBoundary7MA4YWxkTrZu0gW----WebKitFormBoundary7MA4YWxkTrZu0gWContent-Disposition: form-data; name="name"lionis----WebKitFormBoundary7MA4YWxkTrZu0gWContent-Disposition: form-data; name="sex"man----WebKitFormBoundary7MA4YWxkTrZu0gWContent-Disposition: form-data; name="avater"; filename=""Content-Type: ----WebKitFormBoundary7MA4YWxkTrZu0gW
服务端代码
输出
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.1Content-Type: application/jsonCache-Control: no-cachePostman-Token: 9e0c339b-a6b0-c534-5c62-63ef8dc887c4{ "user": "xieyuandong", "sex": "man"}
服务端代码
输出
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就好了。
关键字:http, post, php
版权声明
本文来自互联网用户投稿,文章观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处。如若内容有涉嫌抄袭侵权/违法违规/事实不符,请点击 举报 进行投诉反馈!