ご覧いただきありがとうございます!
KOMOJUという決済代行システムを利用してECサイトを練習で作成しています。
コンビニ支払いや銀行支払いの際に、webhookを利用するのですが、なぜかPOSTのリクエストがGETとみなされてエラーが表示されます。
環境
さくらレンタルサーバー(スタンダード)
SSL:SNI SSL
PHP:v7.4.14
Laravel:v7.30.4
//Header情報 X-Komoju-ID: 英数字 X-Komoju-Signature: 英数字 X-Komoju-Event: payment.captured User-Agent: Komoju-Webhook Content-Type: application/json
//発生するエラーメッセージ(POSTMAN/KOMOJU共に確認) Symfony\Component\HttpKernel\Exception\MethodNotAllowedHttpException: The GET method is not supported for this route. Supported methods: POST. in file /home/tm-apptime/www/yamada_web/vendor/laravel/framework/src/Illuminate/Routing/AbstractRouteCollection.php on line 117
php
1api.php 2use Illuminate\Http\Request; 3use Illuminate\Support\Facades\Route; 4 5Route::group(['middleware' => ['api']], function(){ 6 Route::post('/payment/captured', 'CaptureController@captured'); 7});
php
1<?php 2CaptureController 3namespace App\Http\Controllers; 4 5use Illuminate\Http\Request; 6use Log; 7use App\Models\Order; 8 9class CaptureController extends Controller 10{ 11 12 public function captured(Request $request) { 13 $test = getallheaders(); 14 $length = $request->header('Content-Length'); 15 $body = $data = json_decode(file_get_contents('php://input'), true); 16 Log::info('app.requests', ['body' => $body, 'method' => $request->method(), 'length' => $length]); 17 } 18 19}
php
1Kernel.phpのapimiddleware 2protected $middlewareGroups = [ 3 'web' => [ 4 //省略... 5 ], 6 'api' => [ 7 'throttle:60,1', 8 \Illuminate\Routing\Middleware\SubstituteBindings::class, 9 ], 10 ];
試したこと
①キャッシュクリア系全般
linux
1composer dump-autoload 2php artisan clear-compiled 3php artisan optimize 4php artisan config:cache
②試しにGETにしてみる
→エラーはなくなるが、案の定bodyの中身がなくなり、$request->getContent()の中身が空っぽになる
SSLは問題なくできており、サイト内(同ホスト)のAjaxでの通信などはうまくいっています。
当初書き方などに問題があるのかなと思いきや、ローカルではログにbodyが表示されています。。。(KOMOJUのbodyと同じ内容)
外部サービスからのアクセス時にやはり問題が生じているのかなと思っていますが、同じご経験などあればぜひ教えていただきたいです。
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。