Java Tomcat在自定义CORS筛选器上抛出奇怪错误

Java Tomcat在自定义CORS筛选器上抛出奇怪错误,java,tomcat,websocket,cors,Java,Tomcat,Websocket,Cors,我正在运行Tomcat 7.0.56,并且正在使用WebSocket。我需要一些定制的CORS参数,所以我使用了Transaction公司的CORSFilter SEVERE: Exception starting filter CORS java.lang.IllegalAccessException: Class org.apache.catalina.core.DefaultInstanceManager can not access a member of class com.thetr

我正在运行Tomcat 7.0.56,并且正在使用WebSocket。我需要一些定制的CORS参数,所以我使用了Transaction公司的CORSFilter

SEVERE: Exception starting filter CORS
java.lang.IllegalAccessException: Class org.apache.catalina.core.DefaultInstanceManager can not access a member of class com.thetransactioncompany.cors.CORSFilter with modifiers ""
    at sun.reflect.Reflection.ensureMemberAccess(Reflection.java:109)
    at java.lang.Class.newInstance(Class.java:368)
    at org.apache.catalina.core.DefaultInstanceManager.newInstance(DefaultInstanceManager.java:140)
    at org.apache.catalina.core.ApplicationFilterConfig.getFilter(ApplicationFilterConfig.java:258)
    at org.apache.catalina.core.ApplicationFilterConfig.<init>(ApplicationFilterConfig.java:105)
    at org.apache.catalina.core.StandardContext.filterStart(StandardContext.java:4809)
    at org.apache.catalina.core.StandardContext.startInternal(StandardContext.java:5485)
    at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:150)
    at org.apache.catalina.core.ContainerBase.addChildInternal(ContainerBase.java:901)
    at org.apache.catalina.core.ContainerBase.addChild(ContainerBase.java:877)
    at org.apache.catalina.core.StandardHost.addChild(StandardHost.java:632)
    at org.apache.catalina.startup.HostConfig.deployWAR(HostConfig.java:1073)
    at org.apache.catalina.startup.HostConfig$DeployWar.run(HostConfig.java:1857)
    at java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:471)
    at java.util.concurrent.FutureTask.run(FutureTask.java:262)
    at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1145)
    at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:615)
    at java.lang.Thread.run(Thread.java:745)
严重:启动过滤器CORS时出现异常
java.lang.IllegalAccessException:Class org.apache.catalina.core.DefaultInstanceManager无法使用修饰符“”访问类com.thetransactioncompany.cors.CORSFilter的成员
at sun.reflect.Reflection.ensureMemberAccess(Reflection.java:109)
位于java.lang.Class.newInstance(Class.java:368)
位于org.apache.catalina.core.DefaultInstanceManager.newInstance(DefaultInstanceManager.java:140)
位于org.apache.catalina.core.ApplicationFilterConfig.getFilter(ApplicationFilterConfig.java:258)
位于org.apache.catalina.core.ApplicationFilterConfig.(ApplicationFilterConfig.java:105)
位于org.apache.catalina.core.StandardContext.filterStart(StandardContext.java:4809)
位于org.apache.catalina.core.StandardContext.startInternal(StandardContext.java:5485)
位于org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:150)
位于org.apache.catalina.core.ContainerBase.addChildInternal(ContainerBase.java:901)
位于org.apache.catalina.core.ContainerBase.addChild(ContainerBase.java:877)
位于org.apache.catalina.core.StandardHost.addChild(StandardHost.java:632)
位于org.apache.catalina.startup.HostConfig.deployWAR(HostConfig.java:1073)
位于org.apache.catalina.startup.HostConfig$DeployWar.run(HostConfig.java:1857)
位于java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:471)
在java.util.concurrent.FutureTask.run(FutureTask.java:262)处
位于java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1145)
位于java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:615)
运行(Thread.java:745)

我确实在Tomcat服务器上全局包含了所有正确的jar文件。有趣的是,这种方法过去很管用;我重新部署了这个项目,并开始在日志中发现这个错误。我无法识别堆栈跟踪中的任何包名,也没有更改类。

升级到CORS筛选器的2.2.1版(或更高版本)。它修复了一个使默认构造函数非公共的回归错误,这可能是导致此错误消息的原因。

您是否发现了这一点?是的,我使用了此第三方插件:酷,非常感谢!欢迎让我知道进展如何!