banner
moeyy

moeyy

一条有远大理想的咸鱼。
github
mastodon
email

Nginxはウェブサイトにユーザー認証の設定(Basic HTTP認証)を追加します。

説明:ngx_http_auth_basic_moduleモジュールは、訪問者が正しいユーザーパスワードを入力しない限り、webコンテンツにアクセスできないようにします。ウェブ上の一部のコンテンツは他の人に知られたくないが、一部の人には見せたい場合、nginxhttp authモジュールとApache http authはどちらも良い解決策です。

image

ここでは、Jun さんのLNMPを例にとります。デフォルトでは、nginxにはngx_http_auth_basic_moduleモジュールがすでにインストールされています。

Nginx 認証設定の例#

1. 認証ファイルの生成

** 注意:** ここではアカウント:test、パスワード:123456を使用しています。認証ファイルのパスを覚えておいてください。

2. ウェブサイトの conf ファイルの設定

** 注意:** 必ずauth_basic_user_fileのパスを注意してください。そうしないと、403 エラーが繰り返し表示されます。

3. Nginx の再起動

LNMP で Nginx ディレクトリにアクセス認証のユーザー名とパスワードを設定する#

時には、Apacheのように特定のディレクトリにアクセス認証を追加する必要があります。通常、Apacheではhtpasswdを使用して追加しますが、htpasswdapache2-utilsに含まれており、一般的なLNMPのワンクリックインストールパッケージや独自にコンパイルしてインストールしたLNMPにはインストールされていません。

1. htpasswd ファイルの作成
次のコマンドを実行します:

指示に従ってユーザー名、パスワード、および認証ファイル名を入力します。スクリプトは認証ファイルを自動的に生成します。スクリプトが返すファイルパスを記録してください。例:/usr/local/nginx/conf/vpser.net.auth

2. Nginx に auth 認証設定を追加
以下は、特定のドメインのsoftディレクトリを例にとります。ドメインのserverセクションに次のコードを追加します:

Authorized users onlyはメッセージですが、自分が表示させたいメッセージに変更できます。auth_basic_user_fileの後ろには、htpasswd.shスクリプトが返すファイルのパスを入力する必要があります。上記の指示に従って設定を変更した後、nginxを再起動し、http://yourdomainname/soft/にアクセスすると、ユーザー名とパスワードの入力が求められます。

** 注意:** 認証を追加すると、このディレクトリ内のPHPは解析されず、ダウンロードのプロンプトが表示されます。PHPを解析したい場合は、上記の設定を次のように変更できます:

このチュートリアルは、ワンクリックインストールパッケージまたは独自にインストールしたLNMPに適していますが、ディレクトリと設定ファイルの場所は異なる場合があります。

設定が完了したら、/usr/local/nginx/sbin/nginx -tを実行して構成にエラーがないかをテストします。
次に、/usr/local/nginx/sbin/nginx -s reloadを実行して構成ファイルをロードします。

読み込み中...
文章は、創作者によって署名され、ブロックチェーンに安全に保存されています。