前言
應用程式場景:大概是在內部網站需要外部使用者存取到,同時不能給訪客網站帳號權限,所以在 nginx 層級進行限制。例如外包項目,內部員工有帳號進行文檔的操作,外包員工沒有內部帳號,但需要讓他們能夠看到文檔,所以在nginx 層級設定使用者驗證是最佳最簡單的選擇,多數情況下雇主方不會給外包員工開一個基礎存取權限的帳號。
在nginx 層級進行進行使用者認證的前置條件:需要有對應的密碼建立程序,如apache2-utils(debian,ubuntu)或httpd-tools(rhel / centos / oracle linux),不同操作系統是不同的軟體。
建立帳號密碼檔
#使用指令
sudo htpasswd -c /etc/apache2/.htpasswd user1
建立第一個帳戶,然後按下enter 鍵輸入密碼,同樣的命令,沒有-c 參數創建第二個用戶及密碼, -c 參數為創建文件,在第二次及以後的命令中不需要再次建立文件。確認一下檔案及帳號資訊產生成功,使用指令cat /etc/apache2/.htpasswd 檢視檔案內容,應為帳號及加密後的密碼,如:
user1 :$apr1$/woc1jnp$kah0ssvn5qesmjttn0e9q0
等。
設定nginx 進行http 基礎使用者驗證
使用auth_basic 指令指定設定受保護區域的名稱,此名稱會顯示在在帳號密碼彈出式上,使用auth_basic_user_file 指令設定帶有帳號密碼資訊的.htpasswd 路徑。例如配置:
location /api { auth_basic "administrator's area"; auth_basic_user_file /etc/apache2/.htpasswd; }
此外,如果某個區塊不想繼承整個認證體系,可以在區塊內設定 auth_basic off,即用戶認證關閉狀態。例如設定:
server { ... auth_basic "administrator's area"; auth_basic_user_file conf/htpasswd; location /public/ { auth_basic off; } }
透過 ip 位址將認證與存取限制結合
http基本認證可以透過ip位址有效地與存取限制結合。您可以實現至少兩種方案:
使用者需要通過身份驗證並且具有ip 存取權
使用者需要通過身份驗證或具有ip存取權限
1、使用allow 和deny 指令來允許或限制指定ip 的訪問,例如配置:
location /api { #... deny 192.168.1.2; allow 192.168.1.1/24; allow 127.0.0.1; deny all; }
2、在192.168.1.2 位址以外的網絡,僅授予192.168.1.1/24 的存取權限。注意:allow 和 deny 指令將依照定義的順序套用。
透過ip 和 http 驗證將限制與 satisfy 指令結合。如果將指令設為all,則在用戶端滿足這兩個條件時授予存取權限。如果將指令設為any,則如果客戶端滿足至少一個條件,則授予存取權限,例如配置:
location /api { #... satisfy all; deny 192.168.1.2; allow 192.168.1.1/24; allow 127.0.0.1; deny all; auth_basic "administrator's area"; auth_basic_user_file conf/htpasswd; }
綜上可以組織成一個完整的範例:
http { server { listen 192.168.1.23:8080; root /usr/share/nginx/html; location /api { api; satisfy all; deny 192.168.1.2; allow 192.168.1.1/24; allow 127.0.0.1; deny all; auth_basic "administrator's area"; auth_basic_user_file /etc/apache2/.htpasswd; } } }
最終效果如圖:
以上是Nginx如何設定使用者驗證頁面的詳細內容。更多資訊請關注PHP中文網其他相關文章!

NGINX適合處理高並發和靜態內容,Apache則適用於復雜配置和動態內容。 1.NGINX高效處理並發連接,適合高流量場景,但處理動態內容需額外配置。 2.Apache提供豐富模塊和靈活配置,適合複雜需求,但高並發性能較差。

NGINX和Apache各有優劣,選擇應基於具體需求。 1.NGINX適合高並發場景,因其異步非阻塞架構。 2.Apache適用於需要復雜配置的低並發場景,因其模塊化設計。

NGINXUnit是一個開源應用服務器,支持多種編程語言,提供動態配置、零停機更新和內置負載均衡等功能。 1.動態配置:無需重啟即可修改配置。 2.多語言支持:兼容Python、Go、Java、PHP等。 3.零停機更新:支持不中斷服務的應用更新。 4.內置負載均衡:可將請求分發到多個應用實例。

NGINXUnit優於ApacheTomcat、Gunicorn和Node.js內置HTTP服務器,適用於多語言項目和動態配置需求。 1)支持多種編程語言,2)提供動態配置重載,3)內置負載均衡功能,適合需要高擴展性和可靠性的項目。

NGINXUnit通過其模塊化架構和動態重配置功能提高了應用的性能和可管理性。 1)模塊化設計包括主控進程、路由器和應用進程,支持高效管理和擴展。 2)動態重配置允許在運行時無縫更新配置,適用於CI/CD環境。 3)多語言支持通過動態加載語言運行時實現,提升了開發靈活性。 4)高性能通過事件驅動模型和異步I/O實現,即使在高並發下也保持高效。 5)安全性通過隔離應用進程提高,減少應用間相互影響。

NGINXUnit可用於部署和管理多種語言的應用。 1)安裝NGINXUnit。 2)配置它以運行不同類型的應用,如Python和PHP。 3)利用其動態配置功能進行應用管理。通過這些步驟,你可以高效地部署和管理應用,提升項目效率。

NGINX更适合处理高并发连接,而Apache更适合需要复杂配置和模块扩展的场景。1.NGINX以高性能和低资源消耗著称,适合高并发。2.Apache以稳定性和丰富的模块扩展闻名,适合复杂配置需求。

NGINXUnit通過其動態配置和高性能架構提升應用的靈活性和性能。 1.動態配置允許在不重啟服務器的情況下調整應用配置。 2.高性能體現在事件驅動和非阻塞架構以及多進程模型上,能夠高效處理並發連接和利用多核CPU。


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

Safe Exam Browser
Safe Exam Browser是一個安全的瀏覽器環境,安全地進行線上考試。該軟體將任何電腦變成一個安全的工作站。它控制對任何實用工具的訪問,並防止學生使用未經授權的資源。

記事本++7.3.1
好用且免費的程式碼編輯器

SAP NetWeaver Server Adapter for Eclipse
將Eclipse與SAP NetWeaver應用伺服器整合。

SublimeText3漢化版
中文版,非常好用

EditPlus 中文破解版
體積小,語法高亮,不支援程式碼提示功能