Nginx 屏蔽服务器名称与版本信息(源码级修改)

Nginx 屏蔽服务器名称与版本信息(源码级修改)

一、背景与目的

在生产环境部署 Nginx 时,默认配置会在 Server 响应头中暴露服务类型(如 nginx)和版本号(如 nginx/1.25.4)。这些信息可能被攻击者利用来针对性发起攻击,因此需通过源码修改彻底屏蔽,确保 Server 头不包含任何服务标识。

二、适用版本

本文以 Nginx 1.25.4 为例,其他版本(如 1.23.x、1.24.x)操作流程类似。

三、操作步骤

修改源码文件

  1. 进入 Nginx 源码目录(假设已下载并解压 nginx-1.25.4.tar.gz):

    bash 复制代码
    cd nginx-1.25.4
  2. 打开定义服务器标识的核心文件:

    bash 复制代码
    vi src/http/ngx_http_header_filter_module.c
  3. 找到以下原代码行(定义 Server 头信息):

    c 复制代码
    static u_char ngx_http_server_string[] = "Server: nginx" CRLF;
    static u_char ngx_http_server_full_string[] = "Server: " NGINX_VER CRLF;
    static u_char ngx_http_server_build_string[] = "Server: " NGINX_VER_BUILD CRLF;
  4. 修改为以下内容(移除所有服务类型和版本信息):

    c 复制代码
    static u_char ngx_http_server_string[] = "Server:" CRLF;
    static u_char ngx_http_server_full_string[] = "Server: " CRLF;
    static u_char ngx_http_server_build_string[] = "Server: " CRLF;
  5. 保存文件并退出编辑器(vi 中按 ESC 后输入 :wq 回车)。

四、后续操作提示

修改源码后,需继续执行配置、编译、安装等步骤使修改生效,具体可参考:

  1. 配置编译选项(如启用 SSL 模块等)
  2. 执行 make 编译
  3. 执行 make install 安装
  4. 启动 Nginx 并验证 Server 头是否已屏蔽

五、注意事项

  • 升级 Nginx 时需重新修改源码,否则会恢复默认标识。
  • 该修改不影响 Nginx 功能,仅屏蔽对外暴露的服务信息。
相关推荐
范纹杉想快点毕业33 分钟前
《嵌入式 C 语言编码规范与工程实践个人笔记》参考华为C语言规范标准
服务器·c语言·stm32·单片机·华为·fpga开发·51单片机
Skylar_.1 小时前
嵌入式 - Linux软件编程:进程
java·linux·服务器
ApeAssistant1 小时前
windows 端口占用解决方案
服务器·后端
野生柚子2 小时前
记录学习K8s 集群中OOM Killer的决策基准及执行流程
linux·运维
TLucas3 小时前
在CentOS 7上将PostgreSQL数据库从默认路径迁移到自定义目录
linux·运维·postgresql·centos
ZoeLandia4 小时前
nginx实战分析
运维·前端·nginx
菜菜子爱学习5 小时前
Nginx学习笔记(九)—— Nginx Rewrite深度解析
linux·运维·笔记·学习·nginx
迷之程序员5 小时前
服务器装两个cpu
运维·服务器
Mr_Xuhhh7 小时前
传输层协议 TCP(1)
运维·服务器·网络·c++·网络协议·tcp/ip·https