nginx 设置 帐户密码 授权访问

同步发布于我的网站 🚀

配置 Nginx 的基本认证(HTTP Basic Authentication)可以通过 auth_basic 指令和 auth_basic_user_file 指令来实现。下面是一个简单的步骤指南,用于设置一个受保护的目录或页面。

步骤 1: 安装 htpasswd 工具

首先,你需要安装 htpasswd 工具,它通常包含在 Apache HTTP Server 包中,即使你使用的是 Nginx。htpasswd 用来创建和更新存储用户名和密码的文件。

  • 在 Debian/Ubuntu 系统上:
    sudo apt-get install apache2-utils
    
  • 在 CentOS/RHEL 系统上:
    sudo yum install httpd-tools
    

步骤 2: 创建密码文件

接下来,使用 htpasswd 创建一个新的用户,并将其添加到密码文件中。这个文件可以放在任何安全的位置,但不要将其放在 Web 可访问的目录下。按下回车,会提示设置密码。

sudo htpasswd -c /etc/nginx/.htpasswd username

-c 参数表示创建新文件,如果你要添加更多用户,后续添加时请去掉 -c 参数。

步骤 3: 编辑 Nginx 配置文件

编辑你的 Nginx 服务器配置文件,通常位于 /etc/nginx/sites-available/default/etc/nginx/conf.d/ 目录下的某个文件中,具体取决于你的操作系统和 Nginx 设置。

为需要保护的 location 块添加以下指令:

location /protected/ {
    auth_basic "Restricted Access";
    auth_basic_user_file /etc/nginx/.htpasswd;
}

这里的 auth_basic 是提示信息,当浏览器请求该路径时会显示给用户;auth_basic_user_file 指向你之前创建的 .htpasswd 文件位置。

步骤 4: 测试配置并重启 Nginx

保存更改后,检查 Nginx 配置是否正确:

sudo nginx -t

如果一切正常,重启 Nginx 使更改生效:

sudo systemctl restart nginx

或者,如果你使用的是不同的初始化系统:

sudo service nginx restart

现在,当你尝试访问 http://yourdomain.com/protected/ 这个 URL 时,应该会被提示输入用户名和密码。只有提供正确的凭证,才能查看受保护的内容。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

溜达哥

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值