Nginxのアクセス制限とセキュリティ設定
Nginx は、軽量、高い同時実行性、柔軟な構成などの特徴を備えた高性能 Web サーバーおよびリバース プロキシであり、実稼働環境で広く使用されています。ただし、構築プロセスが比較的簡単な分、セキュリティ上の問題があり、Nginxにはアクセス制限やセキュリティ設定が必要です。
1. アクセス制限
- IP 制限
Nginx は、allow ディレクティブと Deny ディレクティブを構成することで IP アドレスへのアクセスを制限できます。たとえば、特定の IP アドレスのみに Nginx へのアクセスを許可するには、次のコードを nginx.conf ファイルに追加します。
location / { deny all; allow 192.168.1.100; allow 10.0.0.0/8; allow 172.16.0.0/12; allow 192.168.0.0/16; }
上記のコード スニペットは、すべてのリクエストを拒否し、IP アドレス 192.168 を許可することを意味します。 .1.100 と 10.0 の連続した .0.0/8、172.16.0.0/12、192.168.0.0/16 リクエスト。設定ファイルの http ディレクティブを使用して、グローバルな許可ルールと拒否ルールを設定することもできます。
- ユーザー エージェントの制限
ユーザー エージェントは、ブラウザなどの HTTP クライアントによって送信される識別文字列で、訪問者であるかどうかを判断するために使用できます。彼自身、または自動化されたプログラム。 Nginx は、if ディレクティブと $http_user_agent 変数を設定することでユーザー エージェントを制限できます。例:
if ($http_user_agent ~* (wget|curl)) { return 403; }
このコードは、ユーザー エージェントに wget またはcurl 文字列が含まれている場合、403 エラー コードが返されることを意味します。 。
- リファラーの制限
リファラーは HTTP リクエスト ヘッダーのフィールドで、現在のリクエストの送信元アドレスを示します。 Nginx は、if ディレクティブと $http_referer 変数を設定することでリファラーを制限できます。例:
if ($http_referer ~* (baidu.com|google.com)) { return 403; }
このコードの意味は、リファラーに baidu.com または google.com 文字列が含まれている場合、403 エラーが発生するということです。コードが返されます。
2. セキュリティ設定
- HTTPS 保護
HTTPS は、データが送信プロセス中に SSL/TLS 暗号化アルゴリズムが使用されます。 HTTPS を有効にするには、次のコードを Nginx 構成ファイルに追加します。
server { listen 443 ssl; ssl_certificate /path/to/cert.crt; ssl_certificate_key /path/to/cert.key; ... }
ここで、 ssl_certificate
と ssl_certificate_key
は、SSL 証明書と秘密キーを使用して暗号化を実装します。 HTTPSプロトコルの機能。
- ファイル ディレクトリへのアクセスを制限
Nginx は、デフォルトで /etc/nginx/html
にあるすべてのファイルとサブディレクトリを Web サイトのルート ディレクトリに公開します。 , そのため、ファイル ディレクトリへのアクセスを制限する必要があります。次のコードを nginx.conf 構成ファイルに追加して、ディレクトリ アクセスを制限できます。
location / { root /path/to/root; index index.html; autoindex off; location ~* .(jpg|jpeg|png|gif|ico|css|js)$ { expires 1d; add_header Cache-Control "public"; } }
上記のコードは、Web サイトのルート ディレクトリを /path/to/root に指定し、autoindex 機能をオフにすることを意味します。ファイル タイプとキャッシュ ポリシーを設定します。
- セキュリティ ログ
攻撃を適時に検出するために、Nginx のログ機能を有効にすることをお勧めします。次のコードを nginx.conf 構成ファイルに追加して、アクセス ログを記録できます。
http { access_log /var/log/nginx/access.log; ... }
ここで、access_log
は、Nginx アクセス ログのストレージ パスです。ログはローカル ファイルに保存したり、ELK などのログ分析ツールを使用して分析したりできます。
概要
Nginx のアクセス制限とセキュリティ設定は、Web アプリケーションのセキュリティにとって非常に重要です。アクセスは、IP 制限、ユーザー エージェント制限、リファラー制限などの手段によって制限できます。 Web アプリケーションのセキュリティは、HTTPS を有効にし、ファイル ディレクトリおよびセキュリティ ログへのアクセスを制限することによって向上できます。ただし、これらの対策はWebアプリケーションのセキュリティを向上させるだけであり、安全性を完全に保証するものではないため、ソフトウェアの定期的なバージョンアップや脆弱性への適時修正などの対策がWebアプリケーションのセキュリティを確保するために必要となります。
以上がNginxのアクセス制限とセキュリティ設定の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック









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

Linuxでは、次のコマンドを使用して、nginxが起動されるかどうかを確認します。SystemCTLステータスNGINXコマンド出力に基づいて、「アクティブ:アクティブ(実行)」が表示された場合、NGINXが開始されます。 「アクティブ:非アクティブ(dead)」が表示されると、nginxが停止します。

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

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

NGINXサーバーを起動するには、異なるオペレーティングシステムに従って異なる手順が必要です。Linux/UNIXシステム:NGINXパッケージをインストールします(たとえば、APT-GetまたはYumを使用)。 SystemCtlを使用して、NGINXサービスを開始します(たとえば、Sudo SystemCtl Start NGinx)。 Windowsシステム:Windowsバイナリファイルをダウンロードしてインストールします。 nginx.exe実行可能ファイルを使用してnginxを開始します(たとえば、nginx.exe -c conf \ nginx.conf)。どのオペレーティングシステムを使用しても、サーバーIPにアクセスできます

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

Nginxクロスドメインの問題を解決するには2つの方法があります。クロスドメイン応答ヘッダーの変更:ディレクティブを追加して、クロスドメイン要求を許可し、許可されたメソッドとヘッダーを指定し、キャッシュ時間を設定します。 CORSモジュールを使用します。モジュールを有効にし、CORSルールを構成して、ドメインクロスリクエスト、メソッド、ヘッダー、キャッシュ時間を許可します。

質問への回答:304変更されていないエラーは、ブラウザがクライアントリクエストの最新リソースバージョンをキャッシュしたことを示しています。解決策:1。ブラウザのキャッシュをクリアします。 2.ブラウザキャッシュを無効にします。 3.クライアントキャッシュを許可するようにnginxを構成します。 4.ファイル許可を確認します。 5.ファイルハッシュを確認します。 6. CDNまたは逆プロキシキャッシュを無効にします。 7。nginxを再起動します。
