nginx代理服务地址时添加帐号密码认证

在 Nginx 中,可以通过设置基本认证(Basic Authentication)来保护代理访问。以下是具体步骤:

1. 安装 htpasswd 工具

在大多数 Linux 发行版中,htpasswd 工具是 apache2-utils 或 httpd-tools 包的一部分。可以通过以下命令安装:

Debian/Ubuntu

sudo apt-get install apache2-utils

CentOS/RHEL

sudo yum install httpd-tools

2. 创建 .htpasswd 文件

使用 htpasswd 工具创建一个包含用户名和密码的文件。例如,创建一个名为 auth 的文件,并添加一个用户 user1:

htpasswd -c /etc/nginx/.htpasswd user1

系统会提示输入并确认密码。如果需要添加更多用户,可以使用以下命令(不加 -c 选项):

htpasswd /etc/nginx/.htpasswd user2

3. 配置 Nginx

在 Nginx 配置文件中,使用 auth_basic 和 auth_basic_user_file 指令来启用基本认证。以下是一个示例配置:

bash 复制代码
server {
    listen 80;
    server_name example.com;

    location / {
        # 启用基本认证
        auth_basic "Restricted Content";
        auth_basic_user_file /etc/nginx/.htpasswd;

        # 代理到后端服务器
        proxy_pass http://backend_server;
        proxy_set_header Host $host;
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        proxy_set_header X-Forwarded-Proto $scheme;
    }
}

4. 测试配置并重启 Nginx

在修改 Nginx 配置文件后,先测试配置文件是否正确:

sudo nginx -t

如果没有错误,重启 Nginx 以应用更改:

sudo systemctl restart nginx

  1. 访问验证

现在,当你访问配置的路径时,浏览器会弹出一个对话框,要求输入用户名和密码。输入在 .htpasswd 文件中配置的用户名和密码即可访问。

相关推荐
xian_wwq8 小时前
【学习笔记】Nginx常用安全配置
笔记·学习·nginx
不知疲倦的仄仄11 小时前
2025Nginx最新版讲解/面试
nginx·代理模式·proxy模式
不要图透17 小时前
初用nginx
nginx
启明真纳19 小时前
[特殊字符]使用 Nginx 将 HTTP 重定向到 HTTPS
nginx·http·https
潘晓可2 天前
Docker部署Nginx代理多个服务:公网域名与内网IP场景全解
nginx·docker·nginx proxy
✧北辰٩(ˊωˋ*)و南冥✧2 天前
nginx 负载均衡配置(加解决重复登录问题)
运维·nginx·负载均衡
hnlucky2 天前
《Nginx + 双Tomcat实战:域名解析、静态服务与反向代理、负载均衡全指南》
java·linux·服务器·前端·nginx·tomcat·web
步、步、为营2 天前
.net服务器Kestrel配置Nginx作为反向代理
服务器·nginx·.net
晨岳3 天前
CentOS 安装 JDK+ NGINX+ Tomcat + Redis + MySQL搭建项目环境
java·redis·mysql·nginx·centos·tomcat
执笔诉情殇〆3 天前
前后端分离(java) 和 Nginx在服务器上的完整部署方案(redis、minio)
java·服务器·redis·nginx·minio