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

相关推荐
若云止水6 小时前
Ubuntu 下 nginx-1.24.0 源码分析 - conf_ctx
数据库·nginx·ubuntu
码上飞扬13 小时前
Nginx负载均衡配置详解:轻松实现高可用与高性能
运维·nginx·负载均衡
nvvas14 小时前
介绍高性能的HTTP和反向代理服务器Nginx
网络协议·nginx
P7进阶路15 小时前
nginx 代理 redis
运维·redis·nginx
handsomestWei17 小时前
docker配置固定ip解决nginx代理容器名称dns缓存不更新问题
tcp/ip·nginx·docker·dns
zhangqiang08211 天前
supervisord管理Gunicorn进程,使用Nginx作为反向代理运行flask web项目
nginx·gunicorn·supervisord
m0_748238271 天前
Nginx解决前端跨域问题
运维·前端·nginx
曦月合一1 天前
SSM架构 +Nginx+FFmpeg实现rtsp流转hls流,在前端html上实现视频播放
nginx·架构·ffmpeg·摄像头·实时预览
开源极客行1 天前
(七)企业级高性能 WEB 服务 - HTTPS 加密
nginx
花晓木1 天前
Filebeat收集nginx日志到elasticsearch,最终在kibana做展示。
运维·nginx·elasticsearch