HTTP ステータス コード リクエストが 2 回発生する理由と解決策を理解する
要約: HTTP ステータス コードは、クライアントとサーバー間の通信プロセスにおける重要な応答識別子です。 HTTPプロトコルを使用したネットワーク通信では、二重リクエストが発生することが多く、ネットワークの負荷が増大するだけでなく、データの重複送信を引き起こす可能性があります。この記事では、2 回リクエストが行われる理由を調査し、問題を解決する方法を検討します。
HTTPステータスコードとは、サーバーの応答結果を識別するための仕組みであり、リクエスト結果を3桁の数字で分類して記述します。一般的なステータス コードには、200 (要求成功)、404 (要求されたリソースが見つからない)、および 500 (サーバー内部エラー) があります。
ただし、ネットワーク通信に HTTP プロトコルを使用すると、リクエストが 2 つ存在することがわかります。つまり、1 つのリクエストを送信した後、サーバーは 2 つのリクエストを受信します。この状況はネットワーク伝送に問題があると考えられがちですが、実際には他の原因がある可能性があります。
2.1 ブラウザのプリロード
ユーザー エクスペリエンスを向上させるために、最新のブラウザはページのプリロードを実行することがよくあります。ユーザーが Web ページにアクセスすると、ブラウザーは特定のアルゴリズムに基づいて、ユーザーがクリックする可能性のある他の Web ページをプリロードします。このように、ユーザーが実際にリンクをクリックすると、ブラウザは事前にページのコンテンツを取得してリクエストを送信します。したがって、ネットワーク監視ツールに 2 つのリクエストが表示される場合があります。
2.2 リダイレクト
リダイレクトはサーバーの一般的な動作です。サーバーがリクエストを処理できない場合、多くの場合、リクエストは別の適切なページにリダイレクトされます。リダイレクト プロセス中に、ブラウザは新しいターゲット アドレスにリクエストを送信するため、複数のリクエストが発生します。
2.3 キャッシュの無効化
キャッシュ メカニズムは、ネットワーク送信量を削減し、パフォーマンスを向上させるためにブラウザとサーバーの間で使用されます。ブラウザは必要なコンテンツをキャッシュ内で見つけることができない場合、最新のデータを取得するためにサーバーにリクエストを再度送信します。この状況では、リクエストが重複する可能性があります。
3.1 ブラウザのプリロードの制御
ブラウザのプリロードによって発生する繰り返しリクエストの問題については、ブラウザのプリロード動作を制御して解決できます。これは、Web ページのヘッダー タグに次のコードを追加することで実現できます。
これにより、ブラウザのプリロード機能が無効になり、不要なリクエストが削減されます。
3.2 キャッシュを適切に設定する
キャッシュ メカニズムを適切に設定すると、リクエストの繰り返し送信を効果的に減らすことができます。適切な有効期限と ETag およびその他の識別子を設定することにより、ブラウザーは一定期間内にキャッシュからデータを直接取得し、複数のリクエストを回避できます。
3.3 POST リクエストの使用
POST リクエストは GET リクエストに比べてキャッシュされにくいです。 GET リクエストの代わりに POST リクエストを使用できる場合は、サーバーが受信するリクエストの数を減らすことができます。もちろん、POST リクエストを使用する場合は、リクエストの合理性とセキュリティに注意を払う必要があります。
以上がHTTP ステータス コード リクエストが繰り返される原因と解決策を調べるの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。