在Nginx用htpasswd對(duì)網(wǎng)站進(jìn)行密碼保護(hù)的設(shè)置方法
更新時(shí)間:2013年06月10日 20:00:27 作者:
很多時(shí)候我們需要對(duì)一些網(wǎng)站進(jìn)行密碼保護(hù),比如團(tuán)隊(duì)內(nèi)部的站點(diǎn)、demo站點(diǎn)等等。這里所說的密碼保護(hù)是服務(wù)器級(jí)的,并非網(wǎng)站應(yīng)用層的注冊(cè)登錄那一套,而是利用服務(wù)器配置和htpasswd文件來實(shí)現(xiàn)訪問的密碼驗(yàn)證
最后的效果就類似(不同瀏覽器的界面有所不同):

要實(shí)現(xiàn)這樣的功能,就需要更改服務(wù)器的配置,并設(shè)定好用于登錄的用戶名和密碼。
首先我們需要更改網(wǎng)站的Nginx的server配置,Ubuntu服務(wù)器的話這個(gè)配置文件通常位于/etc/nginx/sites-enabled/,比如我這里就使用默認(rèn)的配置文件/etc/nginx/sites-enabled/default來做一個(gè)例子:
復(fù)制代碼 代碼如下:
server {
server_name www.fancycedar.info
root /www/fancycedar
# ...
location / {
# 添加下面兩行
auth_basic "Restricted";
auth_basic_user_file htpasswd;
# ...
}
# ...
}
接下來需要?jiǎng)?chuàng)建htpasswd文件,這里有一些細(xì)節(jié)需要注意:
htpasswd的路徑
和nginx.conf在同一級(jí)目錄即可。Ubuntu服務(wù)器的話一般就在/etc/nginx/下面。
htpasswd的內(nèi)容
每一行為一個(gè)用戶,格式為username:password。但是要注意,這里的password不是明文,而是將password進(jìn)行crypt(3)加密后的字符串。
你可以使用一段PHP代碼來生成htpasswd中的password:
復(fù)制代碼 代碼如下:
// 密碼明文
$password = 'some password';
// 對(duì)密碼進(jìn)行加密
$password = crypt($password, base64_encode($password));
// 獲得加密后的密碼
echo $password;
然后將字符串寫入htpasswd文件中:
復(fù)制代碼 代碼如下:
username1:xucqMk13TfooE
username2:YXTfb3xWKOMBM
...
htpasswd的權(quán)限
需要更改htpasswd文件的權(quán)限,執(zhí)行如下命令:
復(fù)制代碼 代碼如下:
sudo chown root:www-data htpasswd
sudo chmod 640 htpasswd
Are You Ready?
當(dāng)上面的準(zhǔn)備工作都做好之后,我們就可以重新載入或者重啟Nginx服務(wù)器了:
復(fù)制代碼 代碼如下:
sudo /etc/init.d/nginx reload
# or
sudo /etc/init.d/nginx restart
完工。

原文鏈接:http://www.fancycedar.info/2013/06/apache-nginx-htpasswd/
您可能感興趣的文章:
- Android 開發(fā)仿簡(jiǎn)書登錄框可刪除內(nèi)容或顯示密碼框的內(nèi)容
- Android設(shè)計(jì)登錄界面、找回密碼、注冊(cè)功能
- 頁面使用密碼保護(hù)代碼
- 設(shè)置密碼保護(hù)的SqlServer數(shù)據(jù)庫(kù)備份文件與恢復(fù)文件的方法
- Android開發(fā)之登錄驗(yàn)證實(shí)例教程
- Android集成新浪微博第三方登錄的方法
- Android開發(fā)之注冊(cè)登錄方法示例
- Android實(shí)現(xiàn)登錄功能demo示例
- Android調(diào)用第三方QQ登錄代碼分享
- Android登錄時(shí)密碼保護(hù)功能
相關(guān)文章
nginx反向代理proxy_pass遇到的死循環(huán)問題
這篇文章主要介紹了nginx反向代理proxy_pass遇到的死循環(huán)問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-01-01
Nginx配置文件(nginx.conf)配置詳解(總結(jié))
本篇文章主要介紹了Nginx配置文件(nginx.conf)配置詳解,這對(duì)初學(xué)者有一定的參考價(jià)值,有興趣的可以了解一下。2016-12-12
keepalived?+?nginx?實(shí)現(xiàn)高可用方案
這篇文章主要介紹了keepalived?+?nginx?實(shí)現(xiàn)高可用方案的相關(guān)資料,需要的朋友可以參考下2022-12-12
Nginx服務(wù)器配置https安全協(xié)議的實(shí)現(xiàn)
HTTP是互聯(lián)網(wǎng)中最常用的協(xié)議,用于從服務(wù)器傳輸超文本到瀏覽器,HTTPS是HTTP的安全版本,本文就來介紹一下Nginx服務(wù)器配置https安全協(xié)議的實(shí)現(xiàn),感興趣的可以了解一下2024-09-09
關(guān)于nginx沒有跳轉(zhuǎn)到upstream地址的解決
這篇文章主要介紹了關(guān)于nginx沒有跳轉(zhuǎn)到upstream地址的解決,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-09-09
使用AWS的ELB服務(wù)時(shí)為Nginx啟用代理協(xié)議的步驟講解
這篇文章主要介紹了使用AWS的ELB服務(wù)時(shí)為Nginx啟用代理協(xié)議的步驟講解,ELB服務(wù)是亞馬遜服務(wù)器提供的常用的負(fù)載均衡方案,需要的朋友可以參考下2015-12-12

