javax.servlet.ServletException: Servlet.init () для сервлета Relay выбросил исключение - PullRequest
0 голосов
/ 24 марта 2010

Я создал приложение, используя 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 Ответ

2 голосов
/ 24 марта 2010

Похоже, что SecurityManager настроен для блокировки изменений пути к классам. На какой платформе вы работаете? И посмотрите каталог conf tomcat для настройки менеджера безопасности.

Проверьте эти документы для Tomcat 5.5.

Я думаю, вам следует проверить, есть ли у вас файл $CATALINA_BASE/conf/catalina.policy, и если это так, добавить что-то вроде:

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

Если вы пишете в этот путь к классу в своем сервлете Relay, вы не должны использовать jasper.reports, а свой собственный пакет.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...