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 文件中配置的用户名和密码即可访问。

相关推荐
π大星星️5 小时前
HAProxy + Keepalived + Nginx 高可用负载均衡系统
运维·nginx·负载均衡
Johny_Zhao7 小时前
K8S+nginx+MYSQL+TOMCAT高可用架构企业自建网站
linux·网络·mysql·nginx·网络安全·信息安全·tomcat·云计算·shell·yum源·系统运维·itsm
专注代码七年7 小时前
在Windows 境下,将Redis和Nginx注册为服务。
windows·redis·nginx
xixingzhe29 小时前
Nginx 配置多个监听端口
服务器·前端·nginx
Hello.Reader1 天前
ngx_http_keyval_module动态键值管理
网络协议·nginx·http
又逢乱世1 天前
Ubuntu 安装 Nginx
运维·nginx
matrixlzp2 天前
Nginx yum 安装
nginx
matrixlzp2 天前
Nginx 使用 Keepalived 搭建 nginx 高可用
运维·nginx
Yang三少喜欢撸铁2 天前
【阿里云免费领取域名以及ssl证书,通过Nginx反向代理web服务】
nginx·阿里云·代理模式·ssl
Lw老王要学习2 天前
Linux架构篇、第三章_2_Linux服务器监控与NGINX优化
linux·运维·服务器·nginx·架构·云计算