javax.servlet.ServletException:Servlet的Servlet.init()Relay抛出异常

时间:2010-03-24 12:30:19

标签: java servlets

我使用Netbeans构建了应用程序并且工作正常。但是当我部署在TOMCAT上时,我收到了这个错误

javax.servlet.ServletException: Servlet.init() for servlet Relay threw exception
       org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:102)
       org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:293)
       org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:849)
       org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:583)
       org.apache.tomcat.util.net.JIoEndpoint$Worker.run(JIoEndpoint.java:454)
       java.lang.Thread.run(Thread.java:636)

*root cause*

java.security.AccessControlException: access denied (java.util.PropertyPermission jasper.reports.compile.class.path write)
       java.security.AccessControlContext.checkPermission(AccessControlContext.java:342)
       java.security.AccessController.checkPermission(AccessController.java:553)
       java.lang.SecurityManager.checkPermission(SecurityManager.java:549)
       java.lang.System.setProperty(System.java:744)
       com.servlet.Relay.init(Relay.java:38)
       javax.servlet.GenericServlet.init(GenericServlet.java:212)
       sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
       sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)
       sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
       java.lang.reflect.Method.invoke(Method.java:616)
       org.apache.catalina.security.SecurityUtil$1.run(SecurityUtil.java:269)
       java.security.AccessController.doPrivileged(Native Method)
       javax.security.auth.Subject.doAsPrivileged(Subject.java:537)
       org.apache.catalina.security.SecurityUtil.execute(SecurityUtil.java:301)
       org.apache.catalina.security.SecurityUtil.doAsPrivilege(SecurityUtil.java:162)
       org.apache.catalina.security.SecurityUtil.doAsPrivilege(SecurityUtil.java:115)
       org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:102)
       org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:293)
       org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:849)
       org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:583)
       org.apache.tomcat.util.net.JIoEndpoint$Worker.run(JIoEndpoint.java:454) 

任何想法。

1 个答案:

答案 0 :(得分:2)

看起来SecurityManager被配置为阻止类路径的修改。你在运行什么平台?并查看tomcat conf目录以获取安全管理器配置。

查看these docs以获取tomcat 5.5。

我认为您应该查看是否有文件$CATALINA_BASE/conf/catalina.policy,如果有,请添加以下内容:

permission jasper.reports "jasper.reports.compile.class.path", "write";

如果您在Relay servlet中写入该类路径,则不应使用jasper.reports,而应使用自己的包。