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 功能,仅屏蔽对外暴露的服务信息。
相关推荐
kjl53656611 分钟前
docker命令
运维·docker·容器
野熊佩骑12 分钟前
CentOS7二进制安装包方式部署K8S集群之ETCD集群部署
运维·数据库·云原生·容器·kubernetes·centos·etcd
半夏知半秋4 小时前
skynet-socket.lua源码分析
服务器·开发语言·学习·架构·lua
小白银子4 小时前
零基础从头教学Linux(Day 45)
linux·运维·junit·openresty
半梦半醒*5 小时前
nginx反向代理和负载均衡
linux·运维·nginx·centos·tomcat·负载均衡
喜欢你,还有大家5 小时前
集群的概述和分类和负载均衡集群
运维·负载均衡
liu****5 小时前
负载均衡式的在线OJ项目编写(六)
运维·c++·负载均衡·个人开发
swaveye90606 小时前
轻量服务器创建mysql,并配置远程连接
服务器·mysql·adb
Elastic 中国社区官方博客7 小时前
CI/CD 流水线与 agentic AI:如何创建自我纠正的 monorepos
大数据·运维·数据库·人工智能·搜索引擎·ci/cd·全文检索
A-刘晨阳7 小时前
Linux安装centos8及基础配置
linux·运维·服务器·操作系统·centos8