服务器banner泄漏风险


一.nginx banner泄漏风险

  响应包返回服务器标志:Server: nginx/1.8.3,需修改响应包头返回和错误页面显示,修改后记得重启服务器

1.修改响应包返回
  修改配置文件,之后记得重启服务器:
  nginx 配置文件里增加 server_tokens off;
  server_tokens作用域是http server location语句块
  server_tokens默认值是on,表示显示版本信息,设置server_tokens值是off,就可以在所有地方隐藏nginx的版本信息。

http {
  server_tokens off; # 隐藏Nginx版本号
  ....
}

2.修改 4xx、5xx错误页面

server {
    listen       80;
    server_name  www.xx.com;
    location /      {
       root   /home/wwwroot/www.xx.com/;
       index  index.html index.htm;
        # redirecet server error pages to the static page
       error_page  401         =       /error/401.html;
       error_page  403         =       /error/403.html;
       error_page  404         =       /error/404.html;
       error_page  405         =       /error/405.html;
       error_page  500         =       /error/500.html;
       error_page  502 503 504 =      /error/503.html;
    }
}

 

二.tomcat banner泄漏风险

  响应包返回服务器标志:Apache Tomcat/7.0.55,需修改响应包头返回和错误页面显示,按如下几步修改后记得重启服务器

1.修改响应包返回
  vim */apache-tomcat-*/conf/server.xml,找到服务器站点配置,增加server="Server"配置,即可隐藏服务器名字和版本号:

<Connector port="8280" protocol="HTTP/1.1" connectionTimeout="20000" redirectPort="8443" server="Server" />

2.web.xml中修改4xx、5xx错误页面

<!--配置以下代码-->
<error-page>
    <error-code>400</error-code>
    <location>/error.jsp</location>
</error-page>
<error-page>
    <error-code>403</error-code>
    <location>/error.jsp</location>
</error-page>
<error-page>
    <error-code>404</error-code>
    <location>/error.jsp</location>
</error-page>
<error-page>
    <error-code>405</error-code>
    <location>/error.jsp</location>
</error-page>
<error-page>
    <error-code>500</error-code>
    <location>/error.jsp</location>
</error-page>
<error-page>
    <error-code>502</error-code>
    <location>/error.jsp</location>
</error-page>

3.禁用堆栈等详情显示
  找到tomcat 的server.xml,关闭showReport和showServerInfo,避免堆栈和版本详情显示,找到对应域名 <Host > 节点,建议全部host节点都新增如下子节点

<Valve className="org.apache.catalina.valves.ErrorReportValve" showReport="false" showServerInfo="false"/>

  实现上,经我的实践,在Tomcat中,配置server="Server"是达不到效果的,或者说只有curl -I 服务IP:端口号能看到效果。

  可以用网上所说的修改catalina.jar文件,我实践验证是可以达到目的。具体步骤如下:

  a.进入tomcat的lib目录找到catalina.jar文件

  b.unzip catalina.jar之后会多出两个文件夹

  c.进入org/apache/catalina/util 编辑配置文件ServerInfo.properties字段来实现来更改我们tomcat的版本信息

  修改为

server.info=Apache Tomcat
server.number=0.0.0.0
server.built=Apr 2 2017 07:25:00 UTC

   将修改后的信息压缩回jar包

# cd  /tomcat/lib
# jar uvf catalina.jar org/apache/catalina/util/ServerInfo.properties

  重启tomcat,验证前后截图如下所示:

 

参考文章:https://www.cnblogs.com/meiling12/p/8435412.html

https://cloud.tencent.com/developer/article/1398912


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM