javax.- servlet.ServletException: Servlet.init() for servlet-Relais warf Ausnahme
Ich gebaut-Anwendung mit Netbeans und seine Arbeitsmethoden in Ordnung. Aber Wenn ich das Deployment auf TOMCAT ich bin immer diese Fehlermeldung
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)
Jede Idee.
Du musst angemeldet sein, um einen Kommentar abzugeben.
Sieht aus wie der SecurityManager ist so konfiguriert, blockieren Sie änderungen an den class-path. Auf welcher Plattform laufen Sie auf? Und haben Sie einen Blick auf die tomcat-conf-Verzeichnis für die security-manager-Konfiguration.
Check-out diese docs für tomcat 5.5.
Ich denke, Sie sollten überprüfen, ob Sie eine Datei
$CATALINA_BASE/conf/catalina.policy
, und wenn so etwas hinzufügen wie:Wenn Sie schreiben, dass die Klasse Pfad in das Relay servlet, sollten Sie nicht verwenden, jasper.Berichte aber Ihr eigenes Paket.