


mod_auth_basicおよびmod_auth_digestを使用してApacheにHTTP認証(Basic Auth、Digest Auth)を実装するにはどうすればよいですか?
mod_auth_basicおよびmod_auth_digestを使用してApacheでHTTP認証を実装します
mod_auth_basic
およびmod_auth_digest
を使用してApacheに基本的およびダイジェスト認証を実装するには、Apacheの仮想ホストまたはディレクトリ構成ファイルの構成が含まれます。基本認証から始めましょう。
基本認証:
-
モジュールを有効にする:
mod_auth_basic
が有効になっていることを確認してください。これは通常、LoadModule auth_basic_module modules/mod_auth_basic.so
のapache構成ファイル(httpd.conf
または関連する仮想ホスト構成ファイル)の行を開始することで行われます。 -
パスワードファイルの作成:ユーザー名とその暗号化されたパスワードを含むパスワードファイルが必要です。 Apacheは、これに
htpasswd
ユーティリティを提供します。それを使用して、新しいファイル(.htpasswd
など)を作成し、ユーザーを追加します。<code class="bash">sudo htpasswd -c /path/to/.htpasswd username</code>
ログイン後にコピー(
-c
フラグは新しいファイルを作成します。既存のファイルにユーザーを追加するためにそれを省略します。)コマンドはパスワードを求めます。ユーザーごとにこれを繰り返します。重要なことに、このファイルを安全に保存します。その妥協点は認証を妥協します。 -
Apacheの構成: apache構成ファイルで、
<directory></directory>
または<location></location>
内部で、保護エリアを定義するブロックをブロックするには、次のディレクティブを追加します。<code class="apache"><directory> AuthType Basic AuthName "Restricted Area" AuthUserFile /path/to/.htpasswd Require valid-user </directory></code>
ログイン後にコピー/path/to/protected/directory
および/path/to/.htpasswd
を実際のパスに置き換えます。AuthName
、ユーザーに表示されるレルム名を設定します。
認証を消化する:
ダイジェスト認証は、平易なテキストでパスワードの送信を避けるため、基本認証よりも安全です。プロセスは似ています:
-
モジュールを有効にする:
mod_auth_digest
が有効になっていることを確認します(mod_auth_basic
と同様)。 -
パスワードファイルの作成:以前と同じ
htpasswd
ユーティリティを使用しますが、Digest認証用の個別のパスワードファイルが必要になる場合があります。 -
Apacheの構成:構成は基本認証に似ていますが、
AuthType
が変更されています。<code class="apache"><directory> AuthType Digest AuthName "Restricted Area" AuthUserFile /path/to/.htdigest Require valid-user </directory></code>
ログイン後にコピーDigest Passwordファイルへのパスを使用して、
/path/to/.htdigest
を置き換えます。
基本と消化認証のセキュリティへの影響
基本認証:ユーザー名とパスワードをプレーンテキストで送信します(base64エンコードされていますが、簡単に解読されます)。これにより、接続がHTTPSで固定されていない場合、盗聴に対して脆弱になります。 HTTPSなしでは基本認証を使用しないでください。
消化認証:より安全。パスワードのハッシュを送信して、実際のパスワードが明らかになるのを防ぎます。基本認証よりもはるかに安全ですが、安全なコンテキスト(HTTPS)内で適切に実装されていない場合、リプレイ攻撃や中間攻撃などの特定の攻撃に対して依然として脆弱です。
特定のディレクトリまたはファイルの認証を要求するようにApacheを構成する
Apacheは、 <directory></directory>
および<location></location>
ディレクティブを使用して、認証を細かく制御できます。
-
<directory></directory>
:ディレクトリ全体とそのサブディレクトリに認証を適用します。指定されたパスは絶対にする必要があります。 -
<location></location>
:ファイルシステム上の場所に関係なく、特定のURLに認証を適用します。これは、特定のスクリプトまたはページを保護するのに役立ちます。
例: /private
ディレクトリとそのサブ/public
のみを保護する。
<code class="apache"><directory> AuthType Basic AuthName "Private Area" AuthUserFile /path/to/.htpasswd Require valid-user </directory> <directory> # No authentication required here </directory></code>
構成変更を加えた後にApacheを再起動することを忘れないでください(debian/ubuntuでsudo systemctl restart apache2
)。
HTTP認証のユーザー資格情報の管理と更新
ユーザーの資格情報は、 htpasswd
ユーティリティを通じて管理されます。
-
ユーザーの追加:
htpasswd -m /path/to/.htpasswd newuser
を使用します(-m
オプションは、より安全なMD5ハッシュアルゴリズムを使用します)。 -
パスワードの変更:
htpasswd /path/to/.htpasswd existinguser
を使用します。これにより、新しいパスワードが求められます。 -
ユーザーの削除:
htpasswd
ファイルからユーザーを削除するための直接コマンドはありません。最も安全なアプローチは、目的のユーザーを使用して新しいパスワードファイルを作成し、古いユーザーを交換することです。これを行う前に、すべてのApacheプロセスが停止されるようにする必要があります。
HTTP認証を実装するときは、盗聴から保護するためにHTTPSを常に使用することを忘れないでください。 OAUTH 2.0やOpenID Connectなどのより堅牢な認証方法を検討して、生産環境でセキュリティを高めるために検討してください。
以上がmod_auth_basicおよびmod_auth_digestを使用してApacheにHTTP認証(Basic Auth、Digest Auth)を実装するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

Video Face Swap
完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

人気の記事

ホットツール

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

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

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

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

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

ホットトピック











ApacheでCGIディレクトリを設定するには、次の手順を実行する必要があります。「CGI-Bin」などのCGIディレクトリを作成し、Apacheの書き込み許可を付与します。 Apache構成ファイルに「Scriptalias」ディレクティブブロックを追加して、CGIディレクトリを「/cgi-bin」URLにマッピングします。 Apacheを再起動します。

Apacheはデータベースに接続するには、次の手順が必要です。データベースドライバーをインストールします。 web.xmlファイルを構成して、接続プールを作成します。 JDBCデータソースを作成し、接続設定を指定します。 JDBC APIを使用して、接続の取得、ステートメントの作成、バインディングパラメーター、クエリまたは更新の実行、結果の処理など、Javaコードのデータベースにアクセスします。

Apacheサーバーでバージョンを表示するには3つの方法があります。コマンドライン(Apachectl -vまたはapache2ctl -v)を介して、サーバーステータスページ(http://&lt; server ipまたはdomain name&gt;/server -status)を確認します。

Apache 80ポートが占有されている場合、ソリューションは次のとおりです。ポートを占有するプロセスを見つけて閉じます。ファイアウォールの設定を確認して、Apacheがブロックされていないことを確認してください。上記の方法が機能しない場合は、Apacheを再構成して別のポートを使用してください。 Apacheサービスを再起動します。

Apacheバージョンを表示する方法は? Apache Serverを起動する:sudo service apache2を使用してサーバーを起動します。バージョン番号の表示:次のメソッドのいずれかを使用してバージョンを表示します。コマンドライン:apache2 -vコマンドを実行します。サーバーステータスページ:WebブラウザーでApacheサーバーのデフォルトポート(通常80)にアクセスすると、バージョン情報がページの下部に表示されます。

Apacheは、次の理由で起動できません。構成ファイル構文エラー。他のアプリケーションポートとの競合。権限の問題。メモリから。デッドロックを処理します。デーモン障害。 Selinux許可の問題。ファイアウォールの問題。ソフトウェアの競合。

ApacheでZendを構成する方法は? Apache WebサーバーでZend Frameworkを構成する手順は次のとおりです。ZendFrameworkをインストールし、Webサーバーディレクトリに抽出します。 .htaccessファイルを作成します。 Zend Application Directoryを作成し、index.phpファイルを追加します。 Zend Application(Application.ini)を構成します。 Apache Webサーバーを再起動します。

Apacheから追加のservernameディレクティブを削除するには、次の手順を実行できます。追加のservernameディレクティブを識別して削除します。 Apacheを再起動して変更を有効にします。構成ファイルを確認して、変更を確認します。サーバーをテストして、問題が解決されていることを確認します。
