安全审计中有时会有
漏洞名称 HTTP服务器版本信息泄漏
漏洞描述 目标服务器返回的信息头中包含了Web Server的软件或者版本信息。
可以安装 nginx的headers-more-nginx-module模块修改或隐藏响应头信息
一、安装
1.下载 headers-more-nginx-module
下载地址
https://github.com/openresty/headers-more-nginx-module/tags
[root@localhost /]# cd /www/tools[root@localhost tools]# wget https://github.com/openresty/headers-more-nginx-module/archive/refs/tags/v0.37.tar.gz
2.解压
解压后会多出一个headers-more-nginx-module-0.37文件夹
[root@localhost tools]# tar -zxvf v0.37.tar.gz# 进入[root@localhost tools]# cd headers-more-nginx-module-0.37/# 查看当前完整路径[root@localhost headers-more-nginx-module-0.37]# pwd# 复制装盘备用
/www/tools/headers-more-nginx-module-0.37
[root@localhost headers-more-nginx-module-0.37]# cd ..
3.查看当前系统nginx信息
// 查看当前nginx加载的模块
[root@localhost tools]# /www/server/nginx/sbin/nginx -V
nginx version: nginx/1.22.1
built by gcc 4.8.5 20150623(Red Hat 4.8.5-44)(GCC)
built with OpenSSL 1.1.1q 5 Jul 2022
TLS SNI support enabled
# 复制装盘备用
configure arguments: --user=www --group=www --prefix=/www/server/nginx --add-module=/www/server/nginx/src/ngx_devel_kit --add-module=/www/server/nginx/src/lua_nginx_module --add-module=/www/server/nginx/src/ngx_cache_purge --add-module=/www/server/nginx/src/nginx-sticky-module --with-openssl=/www/server/nginx/src/openssl --with-pcre=/www/server/nginx/src/pcre-8.43 --with-http_v2_module --with-stream --with-stream_ssl_module --with-stream_ssl_preread_module --with-http_stub_status_module --with-http_ssl_module --with-http_image_filter_module --with-http_gzip_static_module --with-http_gunzip_module --with-ipv6 --with-http_sub_module --with-http_flv_module --with-http_addition_module --with-http_realip_module --with-http_mp4_module --add-module=/www/server/nginx/src/ngx_http_substitutions_filter_module-master --with-ld-opt=-Wl,-E --with-cc-opt=-Wno-error --with-ld-opt=-ljemalloc --with-http_dav_module --add-module=/www/server/nginx/src/nginx-dav-ext-module
4.下载对应版本的nginx
下载对应版本的nginx
# 下载[root@localhost tools]# wget http://nginx.org/download/nginx-1.22.1.tar.gz # 解压[root@localhost tools]# tar -zxvf nginx-1.22.1.tar.gz
5.编译
在末尾添加 --add-module=/www/tools/headers-more-nginx-module-0.37
注意路径【/www/tools/headers-more-nginx-module-0.37】要换成你自己的
# 进入 nginx-1.22.1目录[root@localhost tools]# cd nginx-1.22.1# 先备份[root@localhost nginx-1.12.1]# cp /www/server/nginx/sbin/nginx /www/server/nginx/sbin/nginx_old# 编译[root@localhost nginx-1.12.1]# ./configure --user=www --group=www --prefix=/www/server/nginx --add-module=/www/server/nginx/src/ngx_devel_kit --add-module=/www/server/nginx/src/lua_nginx_module --add-module=/www/server/nginx/src/ngx_cache_purge --add-module=/www/server/nginx/src/nginx-sticky-module --with-openssl=/www/server/nginx/src/openssl --with-pcre=/www/server/nginx/src/pcre-8.43 --with-http_v2_module --with-stream --with-stream_ssl_module --with-stream_ssl_preread_module --with-http_stub_status_module --with-http_ssl_module --with-http_image_filter_module --with-http_gzip_static_module --with-http_gunzip_module --with-ipv6 --with-http_sub_module --with-http_flv_module --with-http_addition_module --with-http_realip_module --with-http_mp4_module --add-module=/www/server/nginx/src/ngx_http_substitutions_filter_module-master --with-ld-opt=-Wl,-E --with-cc-opt=-Wno-error --with-ld-opt=-ljemalloc --with-http_dav_module --add-module=/www/server/nginx/src/nginx-dav-ext-module --add-module=/www/tools/headers-more-nginx-module-0.37# configure完成后进行make(如原本无nginx,make后还需make install)[root@localhost nginx-1.12.1]# make
6.复制新的nginx到目录
[root@localhost nginx-1.12.1]# mv /www/server/nginx/sbin/nginx /www/server/nginx/sbin/nginx_bak[root@localhost nginx-1.12.1]# cp objs/nginx /www/server/nginx/sbin/nginx
7.重新nginx生效
二、食用
修改nginx配置文件,增加代码块
# set the Server output header# 隐藏Server
more_clear_headers 'Server';# 伪装Server
more_set_headers 'Server: my-server';# set and clear output headers
location /bar {
more_set_headers 'X-MyHeader: blah''X-MyHeader2: foo';
more_set_headers -t'text/plain text/css''Content-Type: text/foo';
more_set_headers -s'400 404 500 503'-s413'Foo: Bar';
more_clear_headers 'Content-Type';# your proxy_pass/memcached_pass/or any other config goes here...}# set output headers
location /type {
more_set_headers 'Content-Type: text/plain';# ...}# set input headers
location /foo {set$my_host'my dog';
more_set_input_headers 'Host: $my_host';
more_set_input_headers -t'text/plain''X-Foo: bah';# now $host and $http_host have their new values...# ...}# replace input header X-Foo *only* if it already exists
more_set_input_headers -r'X-Foo: howdy';
版权归原作者 jugt 所有, 如有侵权,请联系我们删除。