关于tomcat服务器绑定域名防止恶意域名绑定

今天下午突然发现客户的域名被恶意域名“www.walking.cn”绑定了,由于之前没有遇到过这种情况,刚开始不知道是什么情况,还以为是客户那边改了,一问都没有,在网上找了很多解决方法什么ngnxi啊都不管用,都是说绑定自己的域名,没说如何不让其他域名绑定。

于是开始研究server.xml文件,修改tomcat/conf/server.xml,找到engine元素,仿照已有的localhost,添加host元素,比如你想禁止www.dddd.com,可以这样写: 

Xml代码   收藏代码
  1. <Host name="www.dddd.com"  appBase="notexists"  
  2.     unpackWARs="true" autoDeploy="true"  
  3.     xmlValidation="false" xmlNamespaceAware="false">Host>  

其中的appBase是一个不存在的目录,所以www.dddd.com请求时,不会访问你真实的应用。但是这样只是屏蔽了一个已知的,还有很多恶意域名是不可预知的,你并不知道会有多少域名绑定到你的IP,所以这种方式行不通。 

上面的方式是默认允许,把禁止的列出来,变换下思路,默认禁止,将允许的列出来,这样不就OK了?所以有第二种方式: 
Xml代码   收藏代码
  1.   
  2. <Engine name="Catalina" defaultHost="forbiden">  
  3.     <Realm className="org.apache.catalina.realm.UserDatabaseRealm"  
  4.         resourceName="UserDatabase"/>  
  5.             
  6.       
  7.     <Host name="localhost"  appBase="webapps"  
  8.             unpackWARs="true" autoDeploy="true"  
  9.             xmlValidation="false" xmlNamespaceAware="false">Host>  
  10.     <Host name="www.yourweb.com"  appBase="webapps"  
  11.             unpackWARs="true" autoDeploy="true"  
  12.             xmlValidation="false" xmlNamespaceAware="false">Host>          
  13.     <Host name="192.168.0.34"  appBase="webapps"  
  14.             unpackWARs="true" autoDeploy="true"  
  15.             xmlValidation="false" xmlNamespaceAware="false">Host>       
  16.               
  17.     

你可能感兴趣的:(tomcat域名,恶意域名)