この記事では主に、PHPのcurl関数を使用してPostリクエストを送信する際の注意事項をサンプルコードと説明を通して詳しく紹介しています。必要に応じて、誰もがPHPを学習したり使用したりするのに一定の参考になります。編集者も一緒に学びましょう。
はじめに
数日前、私は仕事中に、ユーザーが特定のボタンをクリックすると、バックグラウンドで投稿リクエストが開始され、渡されたデータを受け入れます。最初、私の同僚は、会社のフレームワークによって公開的にカプセル化された http_request()
メソッドを使用してこのコードを送信しました。コードは次のとおりです。 http_request()
方法进行发送的,代码如下:
public function http_request( $url, $post = '', $timeout = 5 ){ if( empty( $url ) ){ return ; } $ch = curl_init(); curl_setopt($ch, CURLOPT_URL, $url); curl_setopt($ch, CURLOPT_HEADER, 0); curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1); curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, FALSE); curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, FALSE); if( $post != '' && !empty( $post ) ){ curl_setopt($ch, CURLOPT_POST, 1); curl_setopt($ch, CURLOPT_POSTFIELDS, $post); curl_setopt($ch, CURLOPT_HTTPHEADER, array('Content-Type: application/json', 'Content-Length: ' . strlen($post))); } curl_setopt($ch, CURLOPT_TIMEOUT, $timeout); $result = curl_exec($ch); curl_close($ch); return $result; }
一开始我并没有留意传递过来的数据是application/json
编码的json字符串,我在后台直接用接受application/x-www-form-urlencoded
编码格式的数据方式来取传递过来的数据(就是直接用的$_POST
方式获取的),结果当然没什么也没有取到了。后来,同事直接改了http_request()
方法,直接传递application/x-www-form-urlencoded
编码格式的数据过来,我这就没有做更改。
对于上面的问题,我一直纳闷当时为什么没有拿到传递过来的数据。
今天项目基本完工,研究了以下。
php中的curl()
函数进行post请求的时候,传递数据的格式可以有以下几种方式:
(1):由参数拼接而成的key=>value
键值对字符串。形如以下: name=xxx&age=23$sex=1
这种请求参数默认是按照application/x-www-form-urlencoded
进行编码的。
(2):由参数组成的key=>value
键值对数组(只能是一维数组,更高维度的数组会报错)。
形如以下格式:
[ name="xxx" , age = 23 , sex = 男 ]
这种请求参数默认是按照multipart/form-data
格式进行编码的。
上面说了,curl()
进行post请求的时候,只能传递一维数组作为传递的参数,那么如果想要传递多维数组需要怎么处理那?
有两种方式可以来处理,分别是下面的方式3以及方式4。
(3):将多维数组进行http_build_query()
进行处理,等到一个key=>value键值对格式的字符串。
如下面所示:
$data = [ "msg"=>"这是一条测试数据", "xxx" => "yyyy", "msg_data" => [ "name"=>"sunms", "age"=>23, "sex"=>"男", "content"=>[ 1,2,3 ] ], ];
将得到以下的字符串:
msg=这是一条测试数据&xxx=yyyy&msg_data[name]=sunms&msg_data[age]=23&msg_data[sex]=男&msg_data[content][0]=1&msg_data[content][1]=2&msg_data[content][2]=3
这种方式也是通过application/x-www-form-urlencoded进
行编码的,在接收方可以通过$_POST直接获取。
(4):将多维数组转换为json格式的字符串,对字符串进行application/json
格式编码,在接收方通过file_get_contents(“php://input”)
或者$GLOBALS[‘HTTP_RAW_POST_DATA']
的方式获取传递过来的json格式的字符串,然后将json格式的字符串转换为数组进行处理。
$data = []; $data_string = json_encode($data); ..... //设置header信息 curl_setopt($ch, CURLOPT_HTTPHEADER, array( 'Content-Type: application/json', 'Content-Length: ' . strlen($data_string)) );
注意:对于application/json
格式编码的数据,$_POST
是不能直接获取的,需要通过file_get_contents(“php://input”)
或者$GLOBALS[‘HTTP_RAW_POST_DATA']
rrreee
application/json
によってエンコードされた json 文字列です。application/x-www-form- でデータを受け入れることで、バックグラウンドで直接取得します。 urlencoded
エンコード形式では、当然、渡されたデータ ($_POST
メソッドを使用して直接取得) は何も取得されませんでした。その後、同僚は http_request()
メソッドを直接変更し、データを application/x-www-form-urlencoded
エンコード形式で直接渡しました。私は何も変更しませんでした。 上記の質問について、なぜあの時データを渡さなかったのかずっと疑問に思っていました。
PHP の curl()
関数がポストリクエストを行うとき、データの形式は次の方法で渡すことができます: (1): パラメータで構成される 。 key=>value
キーと値のペアの文字列。形式は次のとおりです: name=xxx&age=23$sex=1
application/x-www-form-urlencoded
に従ってエンコードされます。デフォルト。 (2): パラメーターで構成されるキーと値のペアの key=>value
配列 (1 次元配列のみにすることができ、高次元配列ではエラーが報告されます)。 次の形式です。
このリクエスト パラメータは、デフォルトでは
multipart/form-data
形式に従ってエンコードされます。 🎜🎜 上で述べたように、curl()
がポストリクエストを行うとき、渡されるパラメーターとして 1 次元配列のみを渡すことができます。それでは、多次元を渡したい場合はどうすればよいでしょうか。配列? 🎜🎜🎜対処方法としては、以下の方法3と方法4の2つがあります。 🎜🎜🎜(3): http_build_query()
で多次元配列を処理し、key=>value キーと値のペア形式の文字列を待ちます。 🎜🎜以下に示すように:🎜🎜🎜rrreee🎜🎜🎜🎜は次の文字列を取得します:🎜
🎜🎜rrreee🎜🎜🎜🎜この方法もコード化されています。 application/x-www-form-urlencoded
の場合、受信者は $_POST を通じて直接取得できます。 🎜🎜(4): 多次元配列を json 形式の文字列に変換し、その文字列を application/json
形式でエンコードし、 file_get_contents("php://input" on受信側は )
または $GLOBALS['HTTP_RAW_POST_DATA']
を実行して、渡された json 形式の文字列を取得し、その json 形式の文字列を配列に変換して処理します。 🎜
🎜🎜rrreee🎜🎜🎜🎜🎜注: 🎜🎜application/json
形式でエンコードされたデータの場合、$_POST は直接取得できません。file_get_contents("php://input")
または $GLOBALS['HTTP_RAW_POST_DATA']
を通じて取得する必要があります。 > 。 🎜🎜以上がこの記事の全内容です、皆様の学習のお役に立てれば幸いです。 🎜🎜🎜🎜🎜関連する推奨事項: 🎜🎜🎜🎜php🎜 1次元配列のループトラバーサルを実装する方法🎜🎜🎜🎜🎜 PHPとMYSQLを使用してページングナビゲーションのアイデアを実装する方法🎜🎜🎜🎜🎜🎜php🎜配列_reverse リターンイン逆順 配列の詳しい説明🎜🎜🎜🎜🎜🎜🎜
以上がPHPのcurl関数を使用してPostリクエストを送信する場合の注意点の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。