php post get content-type,content-type - java访问php接口问题,$_POST默认接收的contentType是?...
背景
現在java需要訪問我的php接口
我這邊直接$_POST取值
測試工具是mac下的,我不太清楚,是HTTP服務測試工具,填我的api地址,參數,然后訪問類型Post/Get,然后線程數什么的,然后開始跑,其中有一個選項是使用multipart/form-data,如果勾上就很快。
php端
我這邊php其實就走的普通方法,差不多這樣:
function check_username(){
$username = $_POST['username'];
$result = _check_username($username);
return json($result);
}
java端
用的封裝的類庫,好像HttpClient之類的,我只知道默認的請求的ContentType是application/x-www-form-urlencode的
問題
用測試工具發現
如果是contentType是application/x-www-form-urlencode訪問,需要好長時間,平均幾秒鐘
如果是multipart/form-data則非常快,幾十毫秒就完了
為什么會出現這種情況啊?
我用$_GET['username']也是可以取到的,application/x-www-form-urlencode這個本質上是不是就是Get請求啊?
回復內容:
背景
現在java需要訪問我的php接口
我這邊直接$_POST取值
測試工具是mac下的,我不太清楚,是HTTP服務測試工具,填我的api地址,參數,然后訪問類型Post/Get,然后線程數什么的,然后開始跑,其中有一個選項是使用multipart/form-data,如果勾上就很快。
php端
我這邊php其實就走的普通方法,差不多這樣:
function check_username(){
$username = $_POST['username'];
$result = _check_username($username);
return json($result);
}
java端
用的封裝的類庫,好像HttpClient之類的,我只知道默認的請求的ContentType是application/x-www-form-urlencode的
問題
用測試工具發現
如果是contentType是application/x-www-form-urlencode訪問,需要好長時間,平均幾秒鐘
如果是multipart/form-data則非常快,幾十毫秒就完了
為什么會出現這種情況啊?
我用$_GET['username']也是可以取到的,application/x-www-form-urlencode這個本質上是不是就是Get請求啊?
默認的普通表單POST是application/x-www-form-urlencode,上傳文件的表單是multipart/form-data。
兩種方式由于用不同的編碼解碼方法,使得前者適合傳數據量少的鍵值對,后者適合傳二進制文件。
于瀏覽器來講,對兩種方式支持的都很好,而且HTML5中加入了FormData,可以很方便的構造multipart/form-data請求表單。
于PHP來講,兩者從Apache或nginx等服務器到$_POST中的大變量之間,大致的生命周期都是一樣的,只有send——parse這一步做的工作不同。
兩者雖說存在一定的效率差距,但出現up主說的這種兩個數量級的差距,還是非常罕見的。
所以我覺得出現這種問題,你用瀏覽器測一下,或者在java訪問日志和php響應日志里看一下實際的效率,而不是測試工具(不清楚你用的是什么測試工具),看下問題到底是出在java構造請求,還是php解析請求并返回時,還是中間的網絡上等原因
能貼一下你的代碼嗎?你這樣大家完全不能回答
你可以用wireshark抓一下報文嗎?
先確定你的報文是不是很大?
你的php的是apache ,還是fpm還是fastcgi ?
能再補充詳細點嗎?
本文原創發布php中文網,轉載請注明出處,感謝您的尊重!
與50位技術專家面對面20年技術見證,附贈技術全景圖總結
以上是生活随笔為你收集整理的php post get content-type,content-type - java访问php接口问题,$_POST默认接收的contentType是?...的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 扩频技术matlab仿真,基于Simul
- 下一篇: php errorcode,php中pd