Nginx の realip モジュールの使い方の基礎学習

Nginx の realip モジュールの使い方の基礎学習

序文

nginx モジュールには、公式とサードパーティの 2 種類があります。nginx のインストール情報を表示するには、コマンド nginx -V を使用し、--with nginx 起動時の読み込みに関する次のモジュール情報を確認できます。

realipモジュール

目的:ローカル Nginx がリバース プロキシ バックエンドにある場合、ユーザーの実際の IP アドレスを取得できます。

使用方法: realip 関数では、Nginx が ngx_http_realip_module モジュールを追加する必要がありますが、これはデフォルトではコンパイルされません。追加する必要がある場合は、コンパイル時に --with-http_realip_module オプションを追加して有効にしてください。

リアリップスコープ

set_real_ip_from、real_ip_header、real_ip_recursive はすべて、http、サーバー、およびロケーション ゾーン構成で使用できます。

いくつかの realip パラメータの説明

  • set_real_ip_from: リバースプロキシサーバーを設定します。つまり、サーバーのIPを信頼します。
  • real_ip_header X-Forwarded-For: ユーザーの実際の IP アドレスは、X-Forwarded-For リクエスト ヘッダーにあります。
  • リアルIP再帰:
    • off: real_ip_headerで指定されたHTTPヘッダーの最後のIPが実際のIPとして使用されます。
    • on: real_ip_headerで指定されたHTTPヘッダーの最後のIPが信頼されたサーバーではない場合、実際のIPとして扱われます。

http ヘッダーの X-Forwarded-For、X-Real-IP、およびリモート アドレスの説明

X-Forwarded-For は HTTP リクエスト ヘッダーにあり、HTTP リクエストの終了時の実際の IP アドレスを示すために使用される HTTP の拡張ヘッダーです。

形式は次のとおりです。

X-Forwarded-For: クライアント、プロキシ1、プロキシ2

Nginx プロキシは通常、次のように構成されます。

proxy_set_header ホスト $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;

説明する:

  • X-Forwarded-For: Nginx が追加しますが、先頭部分は nginx が受信したリクエスト ヘッダーから取得されるため、この部分はあまり信頼できません。 IP 形式に準拠したもののみを使用できます。そうでない場合、XSS または SQL インジェクションの脆弱性が発生しやすくなります。
  • リモート アドレス: HTTP プロトコルには IP の概念がありません。リモート アドレスは TCP 接続から取得され、サーバーとの TCP 接続を確立するデバイスの IP を示します。したがって、リモート アドレスを偽造することはできません。
  • X-Real-IP: HTTP プロキシは、TCP 接続を確立するデバイスの IP アドレスを示すために使用されます。このデバイスは、別のプロキシの場合もあれば、実際の要求側の場合もあります。

Realip関数の例

以下に簡単なアーキテクチャ図を示します。

仮定1:

1. Nginx が realip モジュールを使用しない場合、2 番目の Nginx の X-Forwarded-For リクエストは 1.1.1.1 ですが、remote_addr アドレスは 2.2.2.2 です。このとき、アプリケーション サービスは X-Forwarded-For フィールドを通じてユーザーの実際の IP を取得できます。ただし、ここにはリスクがあります。中間に複数の層のリバース プロキシ サービスがある場合、一意のユーザーの実際の IP を取得することは不可能になります。

2. Nginx が realip モジュールを使用し、次のように設定されている場合、Nginx は X-Forwarded-For の最後の IP (2.2.2.2) を実際の IP として取得します。最後に、アプリケーション サービスによって取得されるアドレスも 2.2.2.2 ですが、実はこれはユーザーの IP ではありません。

2.2.2.2 から実際の IP を設定します。
2.2.2.3 から set_real_ip_from; 
real_ip_header X-Forwarded-For; 
real_ip_recursive をオフ;

3. Nginx が realip モジュールを使用し、次のように設定されている場合、2.2.2.2 は信頼できるサーバー IP であるため、Nginx は前方検索を続行し、1.1.1.1 が信頼できるサーバー IP ではないことを検出すると、それを実際の IP と見なします。しかし、実際には 1.1.1.1 はユーザーの IP です。最後に、アプリケーション サービスはユーザーの固有の実際の IP も取得します。

2.2.2.2 から実際の IP を設定します。
2.2.2.3 から set_real_ip_from; 
real_ip_header X-Forwarded-For; 
real_ip_recursive オン;

要約する

Nginx 基礎学習における realip モジュールの使用に関するこの記事はこれで終わりです。Nginx realip モジュールの使用に関する詳細については、123WORDPRESS.COM の以前の記事を検索するか、以下の関連記事を引き続き参照してください。今後とも 123WORDPRESS.COM をよろしくお願いいたします。

以下もご興味があるかもしれません:
  • Nginx レベルで基本的なユーザー認証を構成する手順を完了します。
  • Nginxの基本についての簡単な紹介
  • Nginx の基本 - Gzip 設定ガイド
  • Nginx サーバーの基本的なセキュリティ構成といくつかのセキュリティのヒント
  • nginxの基本設定の説明
  • nginxの基礎を学ぶ

<<:  mysql-8.0.19-winx64 をインストールしてログインするための初心者向けチュートリアル (初心者必読)

>>:  JavaScript 関数呼び出し、適用、バインド メソッドのケース スタディ

推薦する

Windows での MySQL 8.0.11 インストール チュートリアル

この記事は、WindowsでのMySQL 8.0.11のインストールチュートリアルを記録しています。...

Vue で v-if と v-for を一緒に使用することが推奨されない理由の詳細な説明

この記事では主に、v-if と v-for を一緒に使用することが推奨されない理由を紹介します。詳細...

Linux で top コマンドを使用する際のヒント

まず、top のいくつかのフィールドの意味を紹介します。 VIRT:仮想メモリ使用量1. プロセスが...

CSS のオーバーフロー:hidden エラーの解決方法

失敗の原因今日、カルーセルを書いていたときに、overflow;hidden; が失敗する可能性があ...

JS で async await をエレガントに使用する方法

目次jQuery の $.ajax Webpack時代の始まり約束について深く考えるネストをなくすj...

JavaScriptを使用して独自のAjax関数を定義する

ネイティブJSによって開始されたネットワークリクエストは、クエリ文字列の形でサーバーに送信されるため...

MySql 5.6.35 winx64 インストール詳細チュートリアル

注: データベースのバージョンの問題により、プロジェクトの起動時にエラーは発生しませんでしたが、デー...

HTML は Double 11 クーポン取得を実装します (クーポン取得ページを開く時間を設定します)

さっそく、コードを直接投稿します。具体的なコードは次のとおりです。 <!DOCTYPE htm...

HTML ページはダーク モードの実装をサポートします

2019年から、AndroidとiOSの両方のプラットフォームでダークモードが使用され始めました。も...

親要素を基準にCSSの位置を絶対的に設定する方法についての簡単な説明

ご存知のとおり、CSS の絶対位置はデフォルトでドキュメントに応じて設定されます。たとえば、posi...

Vue2/vue3 ルーティング権限管理方法の例

1. Vueルーティングの権限制御には一般的に2つの方法がありますa. ルーティングメタ情報(メタ)...

共通要素のデフォルトのマージンとパディング値に関する議論

今日は、さまざまなブラウザでのデフォルト要素のマージン値が何であるかという問題について説明しました。...

HTML 要素 noscript の使用の紹介

noscript の定義と使用法noscript 要素は、スクリプトが実行されない場合の代替コンテン...

MySQL のインデックスとデータ テーブルを管理する方法

目次テーブルの競合を見つけて修正するインデックス統計の更新テーブルの競合を見つけて修正するデータ テ...

MySQL パスワード変更方法の概要

MySQL 5.7 より前のバージョンのパスワードを変更する方法:方法1: SET PASSWORD...