Nginx服务器中为网站或目录添加密码访问的配置详解

代码添加位置

server {
listen 80;
server_name tool.3mu.me;
access_log /data/wwwlogs/tool.3mu.me_nginx.log combined;
index index.html index.htm index.php;
include /usr/local/nginx/conf/rewrite/none.conf;
root /data/wwwroot/tool.3mu.me;

# 设置密码访问
auth_basic "input you user name and password";
auth_basic_user_file vhost/htpasswd;

...省略

接下来需要创建htpasswd文件,这里有一些细节需要注意:

htpasswd的路径
htpasswd为密码文件。放在同nginx配置文件同一目录下,当然你也可以放在其它目录下,那在nginx的配置文件中就要写明绝对地址或相对当前目录的地址。

htpasswd的内容
每一行为一个用户,格式为username:password。但是要注意,这里的password不是明文,而是将password进行crypt(3)加密后的字符串。

你可以使用一段PHP代码来生成htpasswd中的password:

// 密码明文
$password = 'some password';
// 对密码进行加密
$password = crypt($password, base64_encode($password));
// 获得加密后的密码
echo $password;

然后将字符串写入htpasswd文件中:

username1:xucqMk13TfooE
username2:YXTfb3xWKOMBM
...
htpasswd的权限
需要更改htpasswd文件的权限,执行如下命令:

sudo chown root:www htpasswd
sudo chmod 640 htpasswd

Are You Ready?
当上面的准备工作都做好之后,我们就可以重新载入或者重启Nginx服务器了:

sudo /etc/init.d/nginx reload
# or
sudo /etc/init.d/nginx restart

完工。

参考资料:
Nginx服务器中为网站或目录添加认证密码的配置详解:http://www.jb51.net/article/77622.htm
Nginx配置实用密码访问网站的方法:http://www.weste.net/2013/6-7/92025.html

发表评论?

0 条评论。

发表评论

此站点使用Akismet来减少垃圾评论。了解我们如何处理您的评论数据