我已经实现了一个过滤器对象并将其注册到 web.xml 文件中。启动tomcat服务器时出现以下错误:
Apr 7, 2012 12:24:18 AM org.apache.catalina.core.StandardContext filterStart
SEVERE: Exception starting filter Google Bot Filter
java.lang.InstantiationException: eu.homeinspiration.server.SEOFilter
at java.lang.Class.newInstance0(Class.java:340)
at java.lang.Class.newInstance(Class.java:308)
at org.apache.catalina.core.DefaultInstanceManager.newInstance(DefaultInstanceManager.java:125)
at org.apache.catalina.core.ApplicationFilterConfig.getFilter(ApplicationFilterConfig.java:256)
at org.apache.catalina.core.ApplicationFilterConfig.setFilterDef(ApplicationFilterConfig.java:382)
at org.apache.catalina.core.ApplicationFilterConfig.<init>(ApplicationFilterConfig.java:103)
at org.apache.catalina.core.StandardContext.filterStart(StandardContext.java:4638)
at org.apache.catalina.core.StandardContext.startInternal(StandardContext.java:5294)
at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:150)
at org.apache.catalina.core.ContainerBase.addChildInternal(ContainerBase.java:895)
at org.apache.catalina.core.ContainerBase.addChild(ContainerBase.java:871)
at org.apache.catalina.core.StandardHost.addChild(StandardHost.java:615)
at org.apache.catalina.startup.HostConfig.deployWAR(HostConfig.java:958)
at org.apache.catalina.startup.HostConfig$DeployWar.run(HostConfig.java:1599)
at java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:441)
at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:303)
at java.util.concurrent.FutureTask.run(FutureTask.java:138)
at java.util.concurrent.ThreadPoolExecutor$Worker.runTask(ThreadPoolExecutor.java:886)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:908)
at java.lang.Thread.run(Thread.java:680)
我不明白这里出了什么问题。过滤器对象与此链接http://code.google.com/p/gwt-platform/source/browse/src/com/philbeaudoin/gwtp/提供的过滤器类代码几乎相似(除了一些小的更改)爬虫/服务器/CrawlFilter.java?r=6e633296934feb9d8150f53b07b8b9515ea6dc4b
编辑:问题是由构造函数引起的:
public SEOFilter( Logger log )
我添加了一个通用构造函数
public SEOFilter() {
this.log = Logger.getAnonymousLogger();
}
现在它起作用了。谢谢阅读。