CORS (Cross-Origin Resource Sharing) ヘッダーを使用すると、ブラウザーは 1 つのオリジンからリクエストを行うことができます(ドメインとポート) を別のオリジンに転送します。ブラウザで CORS エラーが発生した場合、通常、サーバーがリクエスト元からのリクエストを許可していないことを示します。
この場合、リクエストはデプロイされた Web アプリケーションから行われます。 Node アプリケーションは別のサーバーにデプロイされます。 Web アプリケーションが Node アプリケーションに対して POST リクエストを実行しようとすると、ブラウザは、応答に「Access-Control-Allow-Origin」ヘッダーがないことを示すエラーをログに記録します。このエラーは、多くの場合、5xx または 4xx HTTP ステータス コードに関連付けられています。5xx はサーバー側の問題を示し、4xx はリクエストの問題を示します。
この問題を解決するには、応答に CORS ヘッダーがない理由を示すメッセージがないかサーバー ログを確認することが重要です。さらに、curl や Postman などの別のツールを通じて POST リクエストを送信し、2xx ステータス コードをチェックして、POST リクエストが成功したことを確認することをお勧めします。
通常、CORS ヘッダーは追加されないことに注意することが重要です。サーバーはエラーの原因の特定を優先するため、5xx または 4xx エラーの応答に応答しません。エラーが解決され、サーバーが成功応答を返し始めると、意図したとおりに CORS ヘッダーが応答に含まれる可能性があります。
したがって、最良のアプローチは、5xx または 4xx の根本的な原因の解決に重点を置くことです。これには、Node アプリケーションが予期されたポートでリッスンしているか、Web アプリケーションからのリクエストが正しい形式であるかなどのエラーが含まれます。サーバーが成功コードで応答すると、CORS 構成は期待どおりに機能するはずです。
以上がCORS エラーが 5xx または 4xx コードとして現れるのはなぜですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。