検索
ホームページ運用・保守NginxNginx を使用して IP ブラックリストを実装する方法

インターネットの急速な発展に伴い、ネットワーク セキュリティがますます重要な問題になっています。悪意のある攻撃やフィッシング事件は時折発生し、Web サイトやユーザーに大きな脅威をもたらします。したがって、効果的なネットワーク セキュリティ防御システムを確立することが重要です。

Nginx は、高パフォーマンスの Web サービスを提供するだけでなく、リバース プロキシの役割も果たす人気の Web サーバー ソフトウェアです。 Nginx は、管理者が Web サーバーとアプリケーションを保護するのに役立つ豊富なモジュールも提供します。重要な機能の 1 つは、管理者が特定の IP アドレスからのアクセスを制限するのに役立つ IP ブラックリストです。

以下では、Nginx で IP ブラックリストを実装する方法について説明します。

ステップ 1: IP アドレス アクセスを無効にする

Nginx 構成では、管理者はアクセスを無効にする IP アドレスのセットを定義できます。これは、「deny」ディレクティブと IP アドレスのリストを使用して実現できます。たとえば、次の設定では 2 つの IP アドレス 192.168.1.2 と 192.168.1.3 へのアクセスが禁止されます。

location / {
  deny 192.168.1.2;
  deny 192.168.1.3;
  # ... other configuration directives
}

location ブロックで複数の拒否ディレクティブを使用して、複数の IP アドレスへのアクセスを防ぐことができます。

ステップ 2: 特定の IP アクセスを許可する

管理者は、IP アドレスを無効にするだけでなく、特定の IP アドレスからのアクセスを許可するように Nginx を構成することもできます。これは、「allow」ディレクティブと IP アドレスのリストを使用して実現できます。たとえば、次の設定では 2 つの IP アドレス 192.168.1.4 と 192.168.1.5 へのアクセスが許可されます。

location / {
  deny all;
  allow 192.168.1.4;
  allow 192.168.1.5;
  # ... other configuration directives
}

deny ディレクティブと同様に、location ブロックで複数のallow ディレクティブを使用して、複数の IP へのアクセスを許可できます。アドレス。

ステップ 3: 変数を使用して IP アドレス リストを管理する

実際のアプリケーションでは、管理者が IP アドレス リストを動的に管理する必要がある場合があります。構成をより柔軟にするために、変数を使用して IP アドレスのリストを管理できます。次の例は、変数を使用して IP アドレスのリストを定義する方法を示しています。

map $remote_addr $deny_ip {
  192.168.1.2 1;
  192.168.1.3 1;
  default 0;
}

上記の例では、「map」ディレクティブはリモート IP アドレスを $deny_ip 変数にマップします。 IP アドレスが 192.168.1.2 または 192.168.1.3 リストにある場合、$deny_ip 変数は 1 に設定されます。それ以外の場合、$deny_ip 変数は 0 に設定されます。

次に、Nginx 構成で $deny_ip 変数を使用して、アクセスが禁止されているかどうかを判断できます。次の例は、$deny_ip 変数を使用して、禁止された IP アドレスへのアクセスをブロックする方法を示しています。

location / {
  if ($deny_ip) {
    return 403;
  }
  # ... other configuration directives
}

$deny_ip 変数が 1 の場合、Nginx は 403 Forbidden 応答コードを返します。

概要

Nginx は、サーバーのパフォーマンスを確保しながら豊富なセキュリティ機能を提供できる強力な Web サーバー ソフトウェアです。 NginxのIPブラックリスト機能を利用することで、管理者は特定のIPアドレスからのアクセスを禁止し、Webサーバーのセキュリティを確保することができます。同時に、変数を使用すると、構成がより柔軟になり、管理が容易になります。上記の手順を使用すると、管理者は Nginx に IP ブラックリスト機能を簡単に実装できます。

以上がNginx を使用して IP ブラックリストを実装する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
Nginxユニット:さまざまなプログラミング言語をサポートしますNginxユニット:さまざまなプログラミング言語をサポートしますApr 16, 2025 am 12:15 AM

Nginxunitは複数のプログラミング言語をサポートし、モジュラー設計を通じて実装されています。 1。言語モジュールの読み込み:構成ファイルに従って対応するモジュールをロードします。 2。アプリケーションの起動:呼び出し言語が実行されたときにアプリケーションコードを実行します。 3。リクエスト処理:リクエストをアプリケーションインスタンスに転送します。 4。応答返品:処理された応答をクライアントに返します。

nginxとapacheを選択する:あなたのニーズに合った適切nginxとapacheを選択する:あなたのニーズに合った適切Apr 15, 2025 am 12:04 AM

NginxとApacheには独自の利点と短所があり、さまざまなシナリオに適しています。 1.Nginxは、高い並行性と低リソース消費シナリオに適しています。 2。Apacheは、複雑な構成とリッチモジュールが必要なシナリオに適しています。コア機能、パフォーマンスの違い、ベストプラクティスを比較することで、ニーズに最適なサーバーソフトウェアを選択するのに役立ちます。

nginxを開始する方法nginxを開始する方法Apr 14, 2025 pm 01:06 PM

質問:nginxを開始する方法は?回答:nginxスタートアップnginx検証nginxはnginxを開始しました他のスタートアップオプションを自動的に開始

Nginxが開始されるかどうかを確認する方法Nginxが開始されるかどうかを確認する方法Apr 14, 2025 pm 01:03 PM

nginxが開始されるかどうかを確認する方法:1。コマンドラインを使用します:SystemCTLステータスnginx(Linux/unix)、netstat -ano | FindStr 80(Windows); 2。ポート80が開いているかどうかを確認します。 3.システムログのnginx起動メッセージを確認します。 4. Nagios、Zabbix、Icingaなどのサードパーティツールを使用します。

nginxを閉じる方法nginxを閉じる方法Apr 14, 2025 pm 01:00 PM

NGINXサービスをシャットダウンするには、次の手順に従ってください。インストールタイプを決定します:Red Hat/Centos(SystemCtl Status Nginx)またはDebian/Ubuntu(Service Nginx Status)サービスを停止します:Red Hat/Centos(SystemCtl Stop Nginx)またはDebian/Ubuntu(Service Nginx Stop)無効自動起動(オプション):Debuntos/Centos/Centos/Centos/Centos/Centos (syst

Windowsでnginxを構成する方法Windowsでnginxを構成する方法Apr 14, 2025 pm 12:57 PM

Windowsでnginxを構成する方法は? nginxをインストールし、仮想ホスト構成を作成します。メイン構成ファイルを変更し、仮想ホスト構成を含めます。 nginxを起動またはリロードします。構成をテストし、Webサイトを表示します。 SSLを選択的に有効にし、SSL証明書を構成します。ファイアウォールを選択的に設定して、ポート80および443のトラフィックを許可します。

nginx403エラーを解く方法nginx403エラーを解く方法Apr 14, 2025 pm 12:54 PM

サーバーには、要求されたリソースにアクセスする許可がなく、NGINX 403エラーが発生します。ソリューションには以下が含まれます。ファイル許可を確認します。 .htaccess構成を確認してください。 nginx構成を確認してください。 SELINUXアクセス許可を構成します。ファイアウォールルールを確認してください。ブラウザの問題、サーバーの障害、その他の可能なエラーなど、他の原因をトラブルシューティングします。

Linuxでnginxを開始する方法Linuxでnginxを開始する方法Apr 14, 2025 pm 12:51 PM

Linuxでnginxを開始する手順:nginxがインストールされているかどうかを確認します。 systemctlを使用して、nginxを開始してnginxサービスを開始します。 SystemCTLを使用して、NGINXがシステムスタートアップでNGINXの自動起動を有効にすることができます。 SystemCTLステータスNGINXを使用して、スタートアップが成功していることを確認します。 Webブラウザのhttp:// localhostにアクセスして、デフォルトのウェルカムページを表示します。

See all articles

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

mPDF

mPDF

mPDF は、UTF-8 でエンコードされた HTML から PDF ファイルを生成できる PHP ライブラリです。オリジナルの作者である Ian Back は、Web サイトから「オンザフライ」で PDF ファイルを出力し、さまざまな言語を処理するために mPDF を作成しました。 HTML2FPDF などのオリジナルのスクリプトよりも遅く、Unicode フォントを使用すると生成されるファイルが大きくなりますが、CSS スタイルなどをサポートし、多くの機能強化が施されています。 RTL (アラビア語とヘブライ語) や CJK (中国語、日本語、韓国語) を含むほぼすべての言語をサポートします。ネストされたブロックレベル要素 (P、DIV など) をサポートします。

AtomエディタMac版ダウンロード

AtomエディタMac版ダウンロード

最も人気のあるオープンソースエディター

EditPlus 中国語クラック版

EditPlus 中国語クラック版

サイズが小さく、構文の強調表示、コード プロンプト機能はサポートされていません

PhpStorm Mac バージョン

PhpStorm Mac バージョン

最新(2018.2.1)のプロフェッショナル向けPHP統合開発ツール

WebStorm Mac版

WebStorm Mac版

便利なJavaScript開発ツール