nginx server_tokens 和proxy_hide_header的差别

nginx server_tokens offproxy_hide_header 都是用于隐藏服务器信息的配置,但作用对象、范围和效果有本质区别,具体如下:

一、server_tokens off 的功能

server_tokens 是 Nginx 自身的核心配置,用于控制 Nginx 服务器在响应头和错误页面中是否显示版本信息

  • 默认行为server_tokens on(默认值)时,Nginx 会在 Server 响应头和错误页面(如 404 页面)中显示具体版本,例如:
    • 响应头:Server: nginx/1.24.0
    • 错误页面底部:nginx/1.24.0
  • server_tokens off 的效果
    • 隐藏版本号,Server 头仅显示 Server: nginx(不显示具体版本如 1.24.0)。
    • 错误页面不再显示版本号。

二、proxy_hide_header 的功能

proxy_hide_header 是 Nginx 作为反向代理时的配置,用于 隐藏后端上游服务(如 Tomcat、Jenkins、PHP-FPM 等)返回的响应头

  • 作用对象:仅针对通过 proxy_pass 代理的后端服务返回的响应头(不影响 Nginx 自身生成的头)。
  • 示例:若后端 Tomcat 返回 X-Powered-By: Servlet/3.1,配置 proxy_hide_header X-Powered-By; 后,客户端将看不到该头。

三、核心区别

维度 server_tokens off proxy_hide_header
作用对象 Nginx 服务器自身生成的信息(Server 头、错误页面版本) 后端上游服务(如 Tomcat、Jenkins)返回的响应头
控制范围 仅 Nginx 自身的标识信息 仅代理场景下后端服务的响应头
典型用途 隐藏 Nginx 版本号(减少针对特定版本漏洞的攻击) 隐藏后端技术栈(如 X-Powered-By: PHP/7.4
是否依赖代理 不依赖(无论是否作为代理,都生效) 依赖(仅在 proxy_pass 代理场景下生效)
能否完全删除头 不能(Server: nginx 仍会存在,仅隐藏版本) 能(可完全删除后端返回的指定头)

四、总结

  • 若想隐藏 Nginx 自身的版本信息(如避免暴露 nginx/1.24.0),用 server_tokens off
  • 若想隐藏后端服务的技术栈信息(如避免暴露 X-Powered-By: Java/11),用 proxy_hide_header

两者常配合使用,共同减少服务器信息泄露,提升安全性(例如:server_tokens off 隐藏 Nginx 版本 + proxy_hide_header Server; 隐藏后端服务器的 Server 头)。

相关推荐
SPC的存折7 小时前
1、Redis数据库基础
linux·运维·服务器·数据库·redis·缓存
爱学习的小囧7 小时前
VMware ESXi 6.7U3v 新版特性、驱动集成教程和资源包、部署教程及高频问答详情
运维·服务器·虚拟化·esxi6.7·esxi蟹卡驱动
小疙瘩8 小时前
只是记录自己发布若依分离系统到linux过程中遇到的问题
linux·运维·服务器
dldw7778 小时前
IE无法正常登录windows2000server的FTP服务器
运维·服务器·网络
运维有小邓@9 小时前
什么是重放攻击?如何避免成为受害者?
运维·网络·安全
汤愈韬9 小时前
下一代防火墙通用原理
运维·服务器·网络·security
IMPYLH10 小时前
Linux 的 od 命令
linux·运维·服务器·bash
Kk.080211 小时前
Linux(十一)fork实例练习、文件操作示例及相关面试题目分享
linux·运维·算法
数据雕塑家11 小时前
Linux下大文件切割与合并实战:解决FAT32文件系统传输限制
linux·运维·服务器
IMPYLH12 小时前
Linux 的 nice 命令
linux·运维·服务器·bash