其实隐藏 Nginx 版本号无非就是为了防止“各版本公开的漏洞”被人利用而已,这点 Nginx 其实很早就考虑到了,在Nginx 的配置文件里只要加上server_tokens off就可以在网页head里隐藏掉 Nginx 的版本号了。
隐藏 Nginx 版本号
具体操作如下:
第一步:
vim /usr/local/nginx/conf/nginx.conf
在 http{}
中加入
server_tokens off;
第二歩:
vi /usr/local/nginx/conf/fastcgi_params
将里面的
fastcgi_param SERVER_SOFTWARE nginx/$nginx_version;
修改为:
fastcgi_param SERVER_SOFTWARE nginx;
隐藏 Web 服务器名称
关于如何隐藏Web 服务器名称,目前看除了在编译 Web 服务器名称的时候进行伪装以外没有很好的办法了。下面以 Nginx 为例,伪装Nginx的具体办法,
首先需要在官网上下载 Nginx 源码解压,解压后编辑源码中的 src/core/nginx.h
文件
vi /src/core/nginx.h
修改为:
注意:#
不可以删除否则会报错,注释的部分可修改为任何字符。
#define NGINX_VERSION "1.0" //修改版本号
#define NGINX_VER "GWS/" NGINX_VERSION //修改服务名称
修改 HTTP 响应头:
vi src/http/ngx_http_header_filter_module.c
修改为:
static u_char ngx_http_server_string[] = "Server: GWS" CRLF;
修改错误页的底部 Footer:
vi src/http/ngx_http_special_response.c
修改为:
static u_char ngx_http_error_tail[] =
"<hr><center>GWS</center>" CRLF
"</body>" CRLF
"</html>" CRLF
;
之后重新编译 nginx 即可。
注意事项:程序重新编译完后,要 reload 不会生效,需要用 kill 命令杀死原来的进程,再重新启动 Nginx 。
其实还有一个最简单的隐藏 Web 服务器名称的方法,那就启用 CDN 服务,当客户端访问的是 CDN 节点的时候,看到的当然也就是 CDN 节点的 Web 服务器名称了,至于自己网站的 Web 服务器名称只要没有“真实IP”几乎是不可能获得了,国内很多的免费 CDN 都可以的。
隐藏 PHP 版本号
找到 PHP 配置文件 php.ini
定位到关键词 expose_php
,并将值设置成 Off
:
expose_php = Off
保存并退出文件。重启 web 服务器即可。