概要
PHP 7 において、下のコードの curl を使ってデータを POST するときに
400 Bad request エラーが返ってきてしまいます。
該当のソースコード
・api.php / ブラウザで読み込まれるページ
PHP
1// 2// api.php / ブラウザで最初に読み込まれます 3// 4<?php 5 $Recieve = array( 6 "foo" => "bar" 7 ); // 代わりのデータ。本来は file_get_contents("php://input") に置き換えます 8 $Url = "./out.php"; // out.php はページの下にあります。POST されたデータをログ出力するだけです 9 $User_Agent = "FilePost_API"; // 特に意味はありませんが user agent を指定しています 10 $Cuobj = curl_init($Url); 11 $Content = json_encode($Recieve); 12 echo $Content; 13 curl_setopt_array( 14 $Cuobj, 15 array ( 16 CURLOPT_URL => $Url, // 別に必要ないかもしれませんが... 17 CURLOPT_POST => True, 18 CURLOPT_POSTFIELDS => $Content, 19 CURLOPT_RETURNTRANSFER => True, // 返り値も取得したい 20 CURLOPT_FOLLOWLOCATION => true 21 ) 22 ); 23 $Result = curl_exec($Cuobj); 24 // 出力する 25 var_dump($Result); 26 var_dump(curl_error($Cuobj)); 27 curl_close($Cuobj); 28 29?>
・ out.php (POST データ送信先)
PHP
1// 2// out.php / api.php が このファイルにデータを POST します 3// ブラウザでは開きません 4// 5 <?php 6/* 7 ディレクトリ構成 8 localhost:/ 9 api.php 10 out.php 11 (これ以外は使わない) 12 PHP 7.1 13 14 期待する出力 は 15 api.php から out.php に POST した array( "foo" => "bar" ) が 16 ログに書き込まれる( serialize されるので形は違うが...。 ) 17*/ 18 $Raw = file_get_contents('php://input'); 19 $Recieve = json_decode($Raw,true); 20 echo serialize($Recieve); // 21 error_log(serialize($Recieve)); // 一応ログにも出力 22?>
期待する出力
- api.php をブラウザで開く
- api.php で curl をつかって out.php に**
$Request
のデータを POST し返り値を得る** - out.php が データを受け取って返り値を返す際に
error_log(serialize($Recieve))
によって php のログにserialize($Recieve)
の結果を出力する
実際の出力と問題
api.php を開いた際のブラウザのページとして ( api.php の curl_error による出力)
問題点として、
$Result = curl_exec($Cuobj);
を実行した際$Result
に bool(false) が格納される
(curl でのリクエストに失敗する)
- out.php が実行されないか POST できていない
があります。
試したこと
- テストは localhost で試していましたが 本番の環境に変えて(インターネット上)コードを実行しても出力は変わりませんでした。
- curl にHTTPヘッダを追加してもうまくいきませんでした (ヘッダの内容はスマホのため貼り付けられません、すいません)
- Chrome,Firefox,Vivaldi,IE,Edge の5ブラウザでテストしましたが同じ画面でした。
質問すること
可能であれば、「期待する出力」に近くなるようにするために、コードの中で修正すべき点や例を教えてください。
多少複雑なコードでもかまいません。
補足情報(FW/ツールのバージョンなど)
- XAMPP 7.2.7 / PHP 7.2.7
- OSは Windows 10 home 64bit で、 XAMPP 64-bit をインストールしています
- XAMPP の php.ini や apache.conf は編集していません。
- 使用したブラウザは以下の通りです(キャッシュ削除や Cookie の削除なども試しましたが結果は同じでした)
・Google Chrome
・Vivaldi
・Firefox
・Internet Explorer
・Microsoft Edge
- Apache の access.log によると、
・GET /api.php (ブラウザでの表示) は 200 OK を返している
・POST /out.php は 400 Bad Request を返している
ので api.php のコードか、まだブラウザに問題があるのかわかりません。
よろしくお願いします。




回答1件
あなたの回答
tips
プレビュー