React Router を使用する場合、URL を更新または手動で入力すると、「Cannot GET /resource」などのエラーが発生することがあります。この問題は、サーバー側とクライアント側のルーティングの違いに起因します。
従来の Web アプリケーションでは、URL はサーバーによって解釈されていました。表示する適切なコンテンツを決定します。 React Router によって導入されたクライアント側ルーティングでは、URL は最初にブラウザによって解釈され、その後 React Router はサーバーにリクエストを行わずにローカルでページ遷移を処理します。
ただし、これは、ユーザーが URL を手動で入力または更新すると、サーバーはどのページを表示すべきかを認識できず、前述のエラーが発生します。
この問題を解決するには、サーバー側とクライアント側の両方のルーティングを構成する必要があります。
ハッシュ履歴の代わりにブラウザ履歴を使用すると、 URL は http://example.com/#/resource のようになります。ハッシュ (#) の後の部分はサーバーによって無視されるため、サーバーはインデックス ページで応答します。その後、React Router は #/resource 部分を処理し、正しいコンテンツを表示します。
欠点:
このアプローチでは、すべてのリクエストを Index.html にリダイレクトするキャッチオール ルートをサーバー上に作成します。これは、ハッシュ履歴と同様の効果を提供しますが、よりクリーンな URL になります。
欠点:
重要なルートに特定のスクリプトを作成することで、包括的なアプローチを拡張します。これにより、一部のコンテンツがサーバー上でレンダリングされ、SEO が向上します。
欠点:
サーバー側とクライアント側の両方で Node.js を使用して、同じ JavaScript コードを実行します。これにより、クライアント側のページ遷移中に生成されるのと同じマークアップがサーバーで生成されるようになります。
欠点:
適切なアプローチは、特定のニーズによって異なります。
以上がReact Router で「Cannot GET /resource」エラーを解決する方法は?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。