技术解析

如何隐藏服务器信息
0
2021-05-26 17:23:01
idczone

比如说我不想让别人知道我的站点是用了 nginx 的。Google 了一下发现大多数都只说了怎么隐藏 nginx 的版本号,而不是彻底隐藏整个 美国服务器nginx 的(我的意思是不让人知道用的是 nginx)。


不要用nginx

编译的时候修改点东西,参考: http://www.zntec.cn/archives/nginx-change-tengine-151.html
然后把错误页改改 。。。估计差不多可以隐藏了

nginx 源码修改
NGINX_VAR
然后编译安装之

自己做一个"like nginx"

https://github.com/sanddudu/fake-iis
只是用来参考,然后改源代码,不要直接用

需要改源码然后重新编译nginx吧

tengine
服务器配置:
server_token off;
server_tag 自己随便写;

nginx前面放一个varnish
sub vcl_fetch {
set beresp.http.Server = "爱写什么写什么";
}

记得把默认的错误页面都换掉,不然随便一个404就知道你是什么了

除了用 Headers More 来修改 http header 之外,再用 Echo 来改写错误页的内容就 OK 了

高中狗就好好读书,没事别想这想那的=。=

故意搞一个IIS的出错页面,改源码再编译之类的。不过还是可能被nmap等指纹检测出来的。
不明白为何用Nginx要藏着...安全问题其实大部分是出在自己的应用代码上

不觉得很好玩嘛?安全什么的才不去管呢

抱歉……我不是高中生……

_(:з」∠)_想伪装 IIS 的可以注意一下这个差异,IIS 在遇到无效 HTP 请求的时候返回的 Server 头不是 IIS 而是 Microsoft-HTTPAPI/2.0,而且 400 里会有为什么是无效的请求……
漏了 Host 的请求:
-- snip --
"GET / HTTP/1.1\n\n" | nc 192.168.43.177 80   0  1
HTTP/1.1 400 Bad Request
Content-Type: text/html; charset=us-ascii
Server: Microsoft-HTTPAPI/2.0
Date: Sun, 24 May 2015 21:02:37 GMT
Connection: close
Content-Length: 334

Bad Request

Bad Request - Invalid Hostname



HTTP Error 400. The request hostname is invalid.



-- snip --
根本就不是 HTTP 的请求:
-- snip --
"WHAT THE FUCK\n\n" | nc 192.168.43.177 80
HTTP/1.1 400 Bad Request
Content-Type: text/html; charset=us-ascii
Server: Microsoft-HTTPAPI/2.0
Date: Sun, 24 May 2015 21:04:14 GMT
Connection: close
Content-Length: 311

Bad Request

Bad Request



HTTP Error 400. The request is badly formed.



-- snip --
好像是个正常的 HTTP 请求(相应内容被省去了):
-- snip --
"GET / HTTP/1.1\nHost: 192.168.43.177\n" | nc 192.168.43.177 80
HTTP/1.1 200 OK
Content-Type: text/html
Last-Modified: Tue, 04 Nov 2014 07:02:27 GMT
Accept-Ranges: bytes
ETag: "7b6a334bfdf7cf1:0"
Server: Microsoft-IIS/8.5
X-Powered-By: ASP.NET
Date: Sun, 24 May 2015 21:02:54 GMT
Content-Length: 701
-- snip --

数据地带为您的网站提供全球顶级IDC资源
在线咨询
专属客服