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 功能,仅屏蔽对外暴露的服务信息。
相关推荐
2301_794333911 天前
实验室服务器配置|通过Docker实现Linux系统多用户隔离与安全防控
linux·服务器·docker·实验室
打码人的日常分享1 天前
运维服务方案,运维巡检方案,运维安全保障方案文件
大数据·运维·安全·word·安全架构
荣光波比1 天前
Nginx 实战系列(一)—— Web 核心概念、HTTP/HTTPS协议 与 Nginx 安装
linux·运维·服务器·nginx·云计算
武文斌771 天前
单片机:DS18B20测温度、74HC595扩展芯片、8*8LED矩阵
运维·服务器·单片机·嵌入式硬件
fengfuyao9851 天前
诊断并修复SSH连接Github时遇到的“connection closed“错误
运维·ssh·github
scugxl1 天前
centos7 docker离线安装
运维·docker·容器
阿sir1981 天前
ZYNQ 自定义IP
服务器·网络·tcp/ip
绿箭柠檬茶1 天前
Ubuntu 使用 Samba 共享文件夹
linux·运维·ubuntu
工藤新一¹1 天前
Linux —— 虚拟进程地址空间
linux·运维·服务器·c/c++·虚拟进程地址空间
再难也得平1 天前
Linux初级篇
linux·运维·服务器