深入Jetty源码之Servlet框架及实现(ServletRequest、ServletResponse)
Tomcat中添加IP限制
|
<Valve className="org.apache.catalina.valves.RemoteAddrValve" deny="" allow="1.2.3.4"/> |
如此,则只允许1.2.3.4访问,其他不允许访问
如果要限制的IP其实是在x-forwarded-for 中,则需要在该Valve前面(后面还真不行)添加:
|
<Valve className="org.apache.catalina.valves.RemoteIpValve" /> |
但是,这样做会有一个副作用,就是
|
<Valve className="org.apache.catalina.valves.AccessLogValve" directory="logs" prefix="localhost_access_log" suffix=".log" pattern="%h %{X-Forwarded-For}i %l %u %t &quot;%r&quot; %s %b" /> |
中的
将不能再获取到了,而且%h 显示的也不是x-forwarded-for的IP;不过,access的valve中添加:
|
requestAttributesEnabled="true" |
如下:
|
<Valve className="org.apache.catalina.valves.AccessLogValve" directory="logs" prefix="localhost_access_log" suffix=".log" pattern="%h %l %u %t &quot;%r&quot; %s %b" requestAttributesEnabled="true" /> |
则, %h 就是 x-forwarded-for的IP了
分析:
|
org.apache.catalina.valves.RemoteAddrValve |
中限制的是remoteAddr,乍一看,对x-forwarded-for 是不生效的,但是:
|
org.apache.catalina.valves.RemoteIpValve |
可以根据 x-forwarded-for 修改request中的remoteAddr的值。
如何将remoteIpValve.java 中的如下的log信息显示出来?

办法:
在 conf/logging.properties 中添加:
|
org.apache.catalina.level = FINE |
然后,在 catalina.out 中就可以看到了
配置文件
1. 如果配置文件中配置的docBase不存在,则tomcat无法启动,但是对于这种情况,configtest是检查不出来的