nginx中的proxy_set_header参数详解

在使用 Nginx 作为反向代理服务器时,proxy_set_header 指令扮演着至关重要的角色。它允许我们自定义请求头信息,将客户端请求传递给上游服务器时,添加或修改特定的信息,从而实现更灵活的代理功能。本文将深入探讨 proxy_set_header 指令的用法,并结合实际场景,分析其在不同应用场景下的作用。

1、proxy_set_header 的指令概述

proxy_set_header 是 Nginx 配置中用于设置代理请求 HTTP 头部的指令。当 Nginx 作为反向代理时,它允许自定义从客户端接收到的请求或添加新的请求头,然后将其转发到后端服务器。这对于维护 HTTP 协议的连贯性、安全性和功能性至关重要。

2、proxy_set_header指令的语法

proxy_set_header 指令的语法如下:

proxy_set_header <header-name> <value>;
  • :要设置或修改的 HTTP 请求头的名称。

  • :请求头的新值,可以是静态字符串、变量或表达式。

  • value 可以是字符串、变量或它们的组合。Nginx 提供了丰富的内置变量,可以方便地获取请求信息,例如:

    host: Host头部是 HTTP 请求中用于指定请求资源的服务器地址。在代理设置中,proxy_set_header Host $host; 确保了请求头中的 Host 字段被正确传递,避免了请求中的 Host 头被 Nginx 默认值覆盖。
    X-Forwarded-For:用于记录经过的代理服务器的 IP 地址链。
    X-Forwarded-Proto:指示原始请求使用的协议(HTTP 或 HTTPS)。
    $http_user_agent: 客户端的 User-Agent 信息。
    $request_uri: 客户端请求的 URI。
    X-Real-IP: X-Real-IP头部用于记录客户端的真实 IP 地址。在代理设置中,proxy_set_header X-Real-IP $remote_addr; 可以防止 Nginx 重写原始请求中的 IP 地址,使得后端服务能够识别客户端的真实来源。
    Origin:用于 CORS(跨域资源共享)请求,指示请求的来源。

3、proxy_set_header 指令的应用场景

假设您有一个运行在内网的 Web 应用服务器,您希望通过 Nginx 反向代理将该应用暴露给外网用户。以下是一些可能的配置场景:

1. 传递客户端 IP 地址:

在代理环境中,上游服务器无法直接获取客户端的真实 IP 地址。为了让上游服务器能够识别客户端的真实 IP 地址,可以使用 proxy_set_header 指令传递客户端 IP 地址。

proxy_set_header X-Real-IP $remote_addr;
  • X-Real-IP 是一个自定义的请求头字段,用于存储客户端的真实 IP 地址。
  • 上游服务器可以通过读取 X-Real-IP 字段获取客户端的 IP 地址。
2. 传递代理信息:

在多级代理环境中,上游服务器可能需要了解请求经过了哪些代理服务器。可以使用 proxy_set_header 指令传递代理信息。

proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
  • X-Forwarded-For 是一个标准的请求头字段,用于存储客户端 IP 地址和所有代理服务器的 IP 地址,以逗号分隔。
  • 上游服务器可以通过读取 X-Forwarded-For 字段获取所有代理服务器的 IP 地址。
3. 支持 WebSocket 协议:

WebSocket 协议是一种双向通信协议,需要在请求头中设置 Upgrade 和 Connection 字段。可以使用 proxy_set_header 指令传递 WebSocket 协议信息。

proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection "upgrade";
  • $http_upgrade 变量获取客户端请求的 Upgrade 字段的值。
  • 将 Connection 字段设置为 upgrade,表示请求升级为 WebSocket 协议。
4. 自定义请求头信息:

除了传递客户端 IP 地址和代理信息,还可以使用 proxy_set_header 指令添加其他自定义的请求头信息,例如:

proxy_set_header X-My-Header "My Value";
  • X-My-Header 是一个自定义的请求头字段,用于存储自定义信息。
  • 上游服务器可以通过读取 X-My-Header 字段获取自定义信息。
5. 移除请求头信息:

可以使用 proxy_set_header 指令将请求头字段的值设置为 “”,从而移除该请求头字段。

proxy_set_header User-Agent "";
  • 这将移除请求头中的 User-Agent 字段。
6、跨域资源共享 (CORS)

在处理跨域请求时,后端服务器需要知道请求的来源。通过设置 Origin 请求头,后端可以根据需要决定是否允许该请求。例如:

proxy_set_header Origin $http_origin;

这将确保后端服务器能够接收到正确的来源信息,从而做出相应的 CORS 响应。

配置示例

server {listen 8080;server_name your_domain.com;location / {proxy_pass http://backend_server:80;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 Upgrade $http_upgrade;proxy_set_header Connection "upgrade";proxy_set_header Origin $http_origin;proxy_read_timeout 6000s;proxy_set_header X-NginX-Proxy true;proxy_http_version 1.1;chunked_transfer_encoding off;}
}

在这个配置中,Nginx将请求转发到backend_server,并通过各种proxy_set_header指令传递客户端的相关信息。

proxy_set_header 指令的注意事项

  • 确保设置的请求头字段名称和值符合规范,避免与其他请求头字段冲突。
  • 确保 proxy_set_header 指令在正确的 location 块内,以便它们只应用于特定的请求。
  • 谨慎使用 proxy_set_header 指令,避免传递敏感信息,例如用户密码等。
  • 在使用 proxy_set_header 指令时,需要根据实际情况选择合适的变量和值,以确保上游服务器能够正确识别和处理请求信息。

总结

proxy_set_header 指令是 Nginx 反向代理服务器中一个非常重要的指令,为反向代理配置提供了强大的灵活性。它允许我们自定义请求头信息,传递客户端 IP 地址、代理信息、WebSocket 协议信息等,从而实现更灵活的代理功能。在使用 proxy_set_header 指令时,需要根据实际情况选择合适的变量和值,以确保上游服务器能够正确识别和处理请求信息。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/498106.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

FFmpeg 编码和解码

文章目录 音频格式AACADIF音频数据交换格式ADTS音频数据传输流 音频解码音频编码 视频格式H264GOP图像组I帧&#xff0c;P帧&#xff0c;B帧H264压缩技术H264压缩级别H264视频级别H264码流结构SPSPPS 解码视频编码视频 音频格式 AAC AAC全称 Advanced Audio Coding&#xff0…

计算机的错误计算(一百九十六)

摘要 用两个大模型计算 arccos(0.444). 结果保留 4位有效数字。两个大模型的计算结果相同&#xff0c;并均有误差。 例1. 计算 arccos(0.444). 结果保留 4位有效数字。 下面是与一个大模型的对话。 以上为与一大模型的对话。 下面是与另一大模型的对话。 点评&#xff1a; &…

【pytorch】循环神经网络

如果说卷积神经网络可以有效地处理空间信息&#xff0c;那么循环神经网络则可以更好地处理序列信息。循环神经网络通过引入状态变量存储过去的信息和当前的输入&#xff0c;从而可以确定当前的输出。 1 循环神经网络 隐藏层和隐状态指的是两个截然不同的概念。隐藏层是在从输…

MySQL root用户密码忘记怎么办(Reset root account password)

在使用MySQL数据库的的过程中&#xff0c;不可避免的会出现忘记密码的现象。普通用户的密码如果忘记&#xff0c;可以用更高权限的用户&#xff08;例如root&#xff09;进行重置。但是如果root用户的密码忘记了&#xff0c;由于root用户本身就是最高权限&#xff0c;那这个方法…

GPU 进阶笔记(二):华为昇腾 910B GPU

大家读完觉得有意义记得关注和点赞&#xff01;&#xff01;&#xff01; 1 术语 1.1 与 NVIDIA 术语对应关系1.2 缩写2 产品与机器 2.1 GPU 产品2.2 训练机器 底座 CPU功耗操作系统2.3 性能3 实探&#xff1a;鲲鹏底座 8*910B GPU 主机 3.1 CPU3.2 网卡和网络3.3 GPU 信息 3.3…

word中插入zotero引用

1、参考文献末尾没有文献&#xff1f; 在文献条目要显示的地方点击“refresh” 2、参考文献条目没有悬挂缩进&#xff1f; 把“书目”添加到样式库中&#xff0c;修改样式为悬挂缩进1.5字符 3、交叉引用&#xff1f; 宏 新建一个宏 粘贴下面代码 Public Sub ZoteroLinkCita…

【服务器项目部署】⭐️将本地项目部署到服务器!

目录 &#x1f378;前言 &#x1f37b;一、服务器选择 &#x1f379; 二、服务器环境部署 2.1 java 环境部署 2.2 mysql 环境部署 &#x1f378;三、项目部署 3.1 静态页面调整 3.2 服务器端口开放 3.3 项目部署 ​ &#x1f379;四、测试 &#x1f378;前言 小伙伴们大家好…

【mysql】MVCC及实现原理

【mysql】MVCC及实现原理 【一】介绍【1】什么是MVCC【2】什么是当前读和快照读【3】当前读&#xff0c;快照读和MVCC的关系【4】MVCC 能解决什么问题&#xff0c;好处&#xff08;1&#xff09;数据库并发场景有三种&#xff0c;分别为&#xff1a;&#xff08;2&#xff09;M…

AI对话机器人简单实现--智谱BigModel+SpringBoot+Vue2+ElementUI

成品展示 一、首先去注册个账号然后申请个API keys 二、引入依赖 <dependency><groupId>cn.bigmodel.openapi</groupId><artifactId>oapi-java-sdk</artifactId><version>release-V4-2.3.0</version></dependency><depend…

FPGA多路红外相机视频拼接输出,提供2套工程源码和技术支持

目录 1、前言工程概述免责声明 2、相关方案推荐我已有的所有工程源码总目录----方便你快速找到自己喜欢的项目我这里已有的红外相机图像处理解决方案本博已有的已有的FPGA视频拼接叠加融合方案 3、工程详细设计方案工程设计原理框图红外相机FDMA多路视频拼接算法FDMA图像缓存视…

Navicat 连接 SQL Server 详尽指南

Navicat 是一款功能强大的数据库管理工具&#xff0c;它提供了直观的图形界面&#xff0c;使用户能够轻松地管理和操作各种类型的数据库&#xff0c;包括 SQL Server。本文将详尽介绍如何使用 Navicat 连接到 SQL Server 数据库&#xff0c;包括安装设置、连接配置、常见问题排…

【JAVA】Java常用注解汇总

一、注解的定义 Java注解是Java编程语言中的一种特殊形式的元数据&#xff0c;它们可以用于为程序的各个元素&#xff08;例如类、方法、字段等&#xff09;添加额外的信息和属性。注解是在Java 5中引入的&#xff0c;通过在代码中使用注解&#xff0c;开发人员可以提供关于程…

debian安装Nginx

编译安装Nginx sudo apt-get update 环境准备 编译Nginx需要gcc的环境支持&#xff0c;build-essential内包含gcc套件&#xff0c;所以我们安装build-essential即可&#xff1a; sudo apt-get install build-essential 因为nginx.conf中使用了正则表达式&#xff0c;所以编…

基于PLC的电梯控制系统(论文+源码)

1.系统设计 电梯采用了PLC控制方式&#xff0c;通过对PLC进行逻辑程序设计&#xff0c;电梯不仅在控制水平上得到了质的提升&#xff0c;同时在安全性上也得到了大大提高。控制系统在构造上实现了简洁化&#xff0c;不仅优化了硬件接线方便了线路施工&#xff0c;同时对控制要…

MySQL从入门到入土---MySQL表的约束 (内含实践)---详细版

目录 引入&#xff1a; null 与not null default&#xff1a; comment列描述 &#xff1a; not null 和 default&#xff1a; zerofill &#xff1a; 主键&#xff1a;primary key 复合主键&#xff1a; 自增长:auto_increment 唯一键&#xff1a;unique key 外键&a…

linux安装nginxs报错:openssl not found

系统&#xff1a; linux 版本&#xff1a;centOS7 nginx版本&#xff1a;nginx-1.20.2 linux安装nginx时 执行下面命令时报错&#xff1a; ./configure --with-http_stub_status_module --with-http_ssl_module --prefix/usr/local/nginxchecking for OpenSSL library ... not …

Flutter:打包apk,详细图文介绍

困扰了一天&#xff0c;终于能正常打包apk安装了&#xff0c;记录下打包的流程。建议参考我这篇文章时&#xff0c;同时看下官网的构建说明。 官网构建并发布 Android 应用详情 1、AS创建Flutter项目 2、cmd执行命令 生成一个sunluyi.jks的文件&#xff0c;可以自行把sunluyi替…

shell命令以及运行原理

目录 一、命令解释器 1、什么是命令行解释器 shell和bash联系 2、为什么用命令行解释器 作用 存在意义 二、Linux权限 1、用户分类 2、Linux权限管理 1&#xff09;权限身份 2&#xff09;文件类型和访问权限 3&#xff09;文件访问权限的相关设置方法 a. chmod …

精准识别花生豆:基于EfficientNetB0的深度学习检测与分类项目

精准检测花生豆&#xff1a;基于EfficientNet的深度学习分类项目 在现代农业生产中&#xff0c;作物的质量检测和分类是确保产品质量的重要环节。针对花生豆的检测与分类需求&#xff0c;我们开发了一套基于深度学习的解决方案&#xff0c;利用EfficientNetB0模型实现高效、准…

CSS利用浮动实现文字环绕右下角,展开/收起效果

期望实现 文字最多展示 N 行&#xff0c;超出部分截断&#xff0c;并在右下角显示 “…” “更多”&#xff1b; 点击更多&#xff0c;文字展开全部内容&#xff0c;右下角显示“收起”。效果如下&#xff1a; 思路 尽量使用CSS控制样式&#xff0c;减少JS代码复杂度。 利…