Nginx路由转发案例实战

文章目录

问题背景

本地系统同步了第三方的图片资源,例如 https://4.x.x.9:8001/hsdrone1/file/e8c785fc-5703-4f70-a43c-268f48f3efa0/a.jpeg,由于这些链接使用第三方的IP和端口,并且采用HTTPS协议,浏览器经常弹出SSL证书认证警告,严重影响用户体验。

解决方案

步骤一:修改图片地址策略

将数据库中存储的第三方图片绝对地址改为相对地址:

  1. 在数据表中添加一个字段用于存储相对地址
  2. 或者在查询时动态返回相对地址
  3. 前端获取相对地址后,拼接成本地系统的完整访问地址,如 https://10.x.x.12:3100/hsdrone1/file/a.jpeg

注意:此时直接访问仍会返回404错误,因为缺少转发配置。

步骤二:配置Nginx反向代理

针对具有规律性路径的第三方资源(如以 /hsdrone1 开头的地址),通过Nginx配置实现请求转发。

从而实现将https://4.x.x.9:8001/hsdrone1/file/e8c785fc-5703-4f70-a43c-268f48f3efa0/a.jpeg转发到https://10.x.x.12:3100/hsdrone1/file/a.jpeg

以下是完整的Nginx配置示例:

nginx 复制代码
server {
    listen       8001 ssl;
    server_name  localhost;

    # SSL证书配置(因服务启用HTTPS,需配置证书)
    ssl_certificate /home/xx/nginxssl/server.crt;  # 证书文件路径
    ssl_certificate_key  /home/xx/nginxssl/server.key;  # 私钥文件路径

    # SSL协议和加密算法配置
    ssl_protocols TLSv1.2 TLSv1.3;                    # 支持的协议版本
    ssl_ciphers HIGH:!aNULL:!MD5;                     # 加密套件
    ssl_prefer_server_ciphers on;                     # 优先使用服务器端的加密套件

    # 日志和上传限制配置
    #access_log  /var/log/nginx/host.access.log  main;
    client_max_body_size 100M;

    # 主应用代理
    location / {
        proxy_pass http://127.0.0.1:31001;
        proxy_hide_header X-Frame-Options;
        add_header X-Frame-Options ALLOWALL; 
    }
    
    # 启用GZIP压缩提升性能
    gzip on;
    gzip_buffers 32 4K;
    gzip_comp_level 6;
    gzip_min_length 100;
    gzip_types application/javascript text/css text/xml application/json image/svg+xml;
    gzip_disable "MSIE [1-6]\.";
    gzip_vary on;
    
  

    # 第三方文件路由转发(核心配置)
    location ~ ^/hsdrone1 {
        proxy_pass https://10.x.x.12:3100;
        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;
    }


}

此配置可实现将 https://10.x.x.12:3100/hsdrone1/file/a.jpeg 的请求转发至原始第三方地址,同时避免浏览器SSL证书警告。

证书生成方法

如需创建自签名证书,可使用以下命令:

bash 复制代码
# 生成私钥
openssl genrsa -out server.key 2048

# 生成证书签名请求
openssl req -new -key server.key -out server.csr

# 生成自签名证书
openssl x509 -req -days 365 -in server.csr -signkey server.key -out server.crt

证书配置要点

  • 将证书文件放置于指定目录(如 /home/zhfyc/nginxssl/
  • 确保Nginx进程对证书文件有读取权限
  • 定期更新证书以确保安全性

Nginx常用管理命令

配置文件位置

plain 复制代码
/etc/nginx/nginx.conf                # 默认主配置文件
include /etc/nginx/conf.d/*.conf;    # 子配置文件目录

常用操作命令

bash 复制代码
# 检查配置文件有效性
nginx -t

# 重新加载配置(无需重启服务)
nginx -s reload
systemctl reload nginx

# 查看服务状态
systemctl status nginx

# 启动/停止/重启服务
systemctl start nginx
systemctl stop nginx
systemctl restart nginx

# 查找配置文件实际位置
sudo nginx -t 2>&1 | grep -E "file|directory"

故障排查

常见问题及解决方案:

  • 404错误:检查location匹配规则和proxy_pass目标地址
  • SSL错误:确认证书路径正确且证书未过期
  • 跨域问题:适当配置CORS相关header
  • 性能问题:检查gzip配置和连接超时设置

通过以上配置,可以有效解决第三方HTTPS资源导致的浏览器安全警告问题,提升用户体验。

相关推荐
躺平大鹅4 分钟前
Java面向对象入门(类与对象,新手秒懂)
java
初次攀爬者1 小时前
RocketMQ在Spring Boot上的基础使用
java·spring boot·rocketmq
花花无缺1 小时前
搞懂@Autowired 与@Resuorce
java·spring boot·后端
Derek_Smart2 小时前
从一次 OOM 事故说起:打造生产级的 JVM 健康检查组件
java·jvm·spring boot
闲云一鹤3 小时前
nginx 快速入门教程 - 写给前端的你
前端·nginx·前端工程化
NE_STOP3 小时前
MyBatis-mybatis入门与增删改查
java
孟陬7 小时前
国外技术周刊 #1:Paul Graham 重新分享最受欢迎的文章《创作者的品味》、本周被划线最多 YouTube《如何在 19 分钟内学会 AI》、为何我不
java·前端·后端
想用offer打牌7 小时前
一站式了解四种限流算法
java·后端·go
华仔啊7 小时前
Java 开发千万别给布尔变量加 is 前缀!很容易背锅
java