广告位联系
返回顶部
分享到

Nginx隐藏server头信息的实现介绍

nginx 来源:互联网 作者:佚名 发布时间:2023-01-19 21:30:20 人浏览
摘要

分析 上一篇文章我们搭建了Nginx,请求响应头如下 1 2 3 4 5 6 7 8 9 10 [nginx@node01 sbin]$ curl -I 127.0.0.1:8090 HTTP/1.1 200 OK Server: nginx/1.9.9 Date: Fri, 11 Nov 2022 14:56:38 GMT Content-Type: text/html Content-Leng

分析

上一篇文章我们搭建了Nginx,请求响应头如下

1

2

3

4

5

6

7

8

9

10

[nginx@node01 sbin]$ curl -I 127.0.0.1:8090

HTTP/1.1 200 OK

Server: nginx/1.9.9

Date: Fri, 11 Nov 2022 14:56:38 GMT

Content-Type: text/html

Content-Length: 612

Last-Modified: Fri, 11 Nov 2022 12:47:59 GMT

Connection: keep-alive

ETag: "636e447f-264"

Accept-Ranges: bytes

可看到这么一行 Server: nginx/1.9.9,暴露了服务为Nginx并且还知道了具体版本号,如果有人想要攻击我们网站,那么他们就会通过这种方式来获取我们网站的一些信息。比如 知道了是Nginx,并且如果恰好发现该版本是有一些漏洞的,那么攻击者就能够很轻松的找到攻击我们的方案,所以隐藏一些信息是很有必要的。

Nginx它考虑到了这方面的问题。给我们提供了一个配置 server_tokens。将该配置放到http快中就可以隐藏版本号了。

隐藏版本号

修改 nginx.conf,添加server_tokens,配置如下

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

worker_processes  1;

 

events {

    worker_connections  1024;

}

 

http {

    include       mime.types;

    default_type  application/octet-stream;

    server_tokens off;

    sendfile        on;

 

    keepalive_timeout  65;

 

    server {

        listen       8090;

        server_name  localhost;

             

        location / {

            root   html;

            index  index.html index.htm;

        }

    }

 

}

重启nginx

版本号已隐藏

1

2

3

4

5

6

7

8

9

10

11

12

[nginx@node01 sbin]$ ./nginx -s reload

 

[nginx@node01 sbin]$ curl -I 127.0.0.1:8090

HTTP/1.1 200 OK

Server: nginx

Date: Fri, 11 Nov 2022 15:08:55 GMT

Content-Type: text/html

Content-Length: 612

Last-Modified: Fri, 11 Nov 2022 12:47:59 GMT

Connection: keep-alive

ETag: "636e447f-264"

Accept-Ranges: bytes

php-fpm服务器隐藏版本号

如果搭建的是 php-fpm 服务器的话,还得修改 fastcgi.conf

在该配置中有这么一行

1

2

3

fastcgi_param  SERVER_SOFTWARE    nginx/$nginx_version;

修改后

fastcgi_param  SERVER_SOFTWARE    nginx;

隐藏Server

经过上面的修改,版本号就已经隐藏了,如果连Server信息都不想让别人知道,那就只能修改源码了

修改C文件 src/http/ngx_http_header_filter_module.c

大概在50行左右,将nginx修改为 其它名字

1

2

3

4

//static char ngx_http_server_string[] = "Server: nginx" CRLF;

//static char ngx_http_server_full_string[] = "Server: " NGINX_VER CRLF;

static char ngx_http_server_string[] = "Server: juan" CRLF;

static char ngx_http_server_full_string[] = "Server: " NGINX_VER CRLF;

重新编译前记得停掉Nginx 备份自己的nginx.conf

编译完后替换之前备份的文件,启动Nginx

1

2

3

4

5

6

7

8

9

10

[nginx@node01 sbin]$ curl -I 127.0.0.1:8090

HTTP/1.1 200 OK

Server: juan

Date: Fri, 11 Nov 2022 15:34:27 GMT

Content-Type: text/html

Content-Length: 612

Last-Modified: Fri, 11 Nov 2022 15:30:46 GMT

Connection: keep-alive

ETag: "636e6aa6-264"

Accept-Ranges: bytes

这时Server已经变成自己定义的名字了,nginx的加固就介绍到这。


版权声明 : 本文内容来源于互联网或用户自行发布贡献,该文观点仅代表原作者本人。本站仅提供信息存储空间服务和不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权, 违法违规的内容, 请发送邮件至2530232025#qq.cn(#换@)举报,一经查实,本站将立刻删除。
原文链接 : https://blog.csdn.net/weixin_44412085/article/details/127819247
相关文章
  • nginx降权与匹配php详细结束

    nginx降权与匹配php详细结束
    nginx降权启动 确认普通用户无法开启nginx 创建普通用户: 1 2 3 4 5 6 root@ubuntu:~# useradd -d /home/test -m test root@ubuntu:~# passwd test New password: Retype
  • Nginx隐藏server头信息的实现介绍
    分析 上一篇文章我们搭建了Nginx,请求响应头如下 1 2 3 4 5 6 7 8 9 10 [nginx@node01 sbin]$ curl -I 127.0.0.1:8090 HTTP/1.1 200 OK Server: nginx/1.9.9 Date: Fri, 11
  • nginx配置x-forwarded-for头部的方法介绍

    nginx配置x-forwarded-for头部的方法介绍
    nginx配置x-forwarded-for头部 本地用tomcat起了一个j2ee的应用,然后又起了一个nginx做反向代理。 nginx.conf: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 1
  • shell脚本实战之部署nginx脚本实例介绍
    我们写脚本一定要从最简单的脚本开始,循序渐进,不要一上来就想着用for循环,用函数,而应该在写的过程中,突然发现这里可以改为函
  • nginx rewrite参数介绍
    在nginx的配置中,是否对rewrite的配置模糊不清,还有令人迷惑的$1、$2...参数,(其实$1、$2参数在shell脚本中经常用到,用来承接传递的参数
  • Nginx配置之main events块使用介绍
    作用 反向代理 负载均衡 web缓存 配置 nginx的配置主要可以划分为main、events、http、server、location块。 main:置影响nginx全局的指令。一般有运
  • Windows设置nginx开机自启动的方法

    Windows设置nginx开机自启动的方法
    使用环境:Windows 10 专业版,nginx 1.20.1 通过两种方式实现nginx的开机自启动:winws和window计划程序。 一、winws实现nginx开机自启动 1、首先下载
  • Clash Linux服务器安装教程

    Clash Linux服务器安装教程
    Clash软件安装 软件下载地址 github公开地址:https://github.com/Dreamacro/clash 1.使用wget下载linux安装包,保存并解压至/opt/clash文件夹中。 1 2 3 4 m
  • Nginx配置ssl证书(https)的全过程
    如果有防火墙的话,记得开通443端口 准备材料: 1.申请ssl证书,这个如何申请可以到百度搜一下,因为域名服务商不同,这里不做过多赘述; 2.服
  • 在Debian11上安装Openresty服务(Nginx+Lua)的教程
    OpenResty 是一个基于 Nginx 与 Lua 的高性能 Web 平台,其内部集成了大量精良的 Lua 库、第三方模块以及大多数的依赖项。用于方便地搭建能够处
  • 本站所有内容来源于互联网或用户自行发布,本站仅提供信息存储空间服务,不拥有版权,不承担法律责任。如有侵犯您的权益,请您联系站长处理!
  • Copyright © 2017-2022 F11.CN All Rights Reserved. F11站长开发者网 版权所有 | 苏ICP备2022031554号-1 | 51LA统计