Jetty maven插件无法热重新部署shiro筛选器

Jetty maven插件无法热重新部署shiro筛选器,jetty,shiro,Jetty,Shiro,我不确定这是jetty的问题还是shiro的问题,但我正在尝试使用jetty Maven插件进行开发,我想要的一个关键特性是jetty在文件更改时的热重新部署。然而,当jetty试图重新加载应用程序时,Shiro抛出了以下异常,我不确定如何纠正这一点 [Scanner-0] ERROR org.apache.shiro.web.servlet.AbstractFilter - Unable to start Filter: [No WebEnvironment found: no Environ

我不确定这是jetty的问题还是shiro的问题,但我正在尝试使用jetty Maven插件进行开发,我想要的一个关键特性是jetty在文件更改时的热重新部署。然而,当jetty试图重新加载应用程序时,Shiro抛出了以下异常,我不确定如何纠正这一点

[Scanner-0] ERROR org.apache.shiro.web.servlet.AbstractFilter - Unable to start Filter: [No WebEnvironment found: no EnvironmentLoaderListener registered?].
java.lang.IllegalStateException: No WebEnvironment found: no EnvironmentLoaderListener registered?
        at org.apache.shiro.web.util.WebUtils.getRequiredWebEnvironment(WebUtils.java:276)
        at org.apache.shiro.web.servlet.ShiroFilter.init(ShiroFilter.java:73)
        at org.apache.shiro.web.servlet.AbstractShiroFilter.onFilterConfigSet(AbstractShiroFilter.java:152)
        at org.apache.shiro.web.servlet.AbstractFilter.init(AbstractFilter.java:97)
        at org.eclipse.jetty.servlet.FilterHolder.doStart(FilterHolder.java:123)
        at org.eclipse.jetty.util.component.AbstractLifeCycle.start(AbstractLifeCycle.java:69)
        at org.eclipse.jetty.servlet.ServletHandler.initialize(ServletHandler.java:732)
        at org.eclipse.jetty.servlet.ServletContextHandler.startContext(ServletContextHandler.java:279)
        at org.eclipse.jetty.webapp.WebAppContext.startContext(WebAppContext.java:1314)
        at org.eclipse.jetty.server.handler.ContextHandler.doStart(ContextHandler.java:722)
        at org.eclipse.jetty.webapp.WebAppContext.doStart(WebAppContext.java:492)
        at org.eclipse.jetty.maven.plugin.JettyWebAppContext.doStart(JettyWebAppContext.java:275)
        at org.eclipse.jetty.util.component.AbstractLifeCycle.start(AbstractLifeCycle.java:69)
        at org.eclipse.jetty.maven.plugin.JettyRunMojo.restartWebApp(JettyRunMojo.java:527)
        at org.eclipse.jetty.maven.plugin.JettyRunMojo$1.filesChanged(JettyRunMojo.java:481)
        at org.eclipse.jetty.util.Scanner.reportBulkChanges(Scanner.java:676)
        at org.eclipse.jetty.util.Scanner.reportDifferences(Scanner.java:539)
        at org.eclipse.jetty.util.Scanner.scan(Scanner.java:391)
        at org.eclipse.jetty.util.Scanner$1.run(Scanner.java:329)
        at java.util.TimerThread.mainLoop(Timer.java:555)
        at java.util.TimerThread.run(Timer.java:505)
My web.xml如下所示:

<?xml version="1.0" ?>
<web-app xmlns="http://java.sun.com/xml/ns/j2ee"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd"
    version="2.4">  

<!-- SHIRO CONFIGURATION ============================================== -->

<listener>
  <listener-class>org.apache.shiro.web.env.EnvironmentLoaderListener</listener-class>
</listener>

<filter>
  <filter-name>ShiroFilter</filter-name>
  <filter-class>org.apache.shiro.web.servlet.ShiroFilter</filter-class>
</filter>

<filter-mapping>
  <filter-name>ShiroFilter</filter-name>
  <url-pattern>/*</url-pattern>
  <dispatcher>REQUEST</dispatcher>
  <dispatcher>FORWARD</dispatcher>
  <dispatcher>INCLUDE</dispatcher>
  <dispatcher>ERROR</dispatcher>
</filter-mapping>

<!-- DATA SOURCE ====================================================== -->

<resource-ref>
  <description>Account Data Source</description>
  <res-ref-name>jdbc/AccountDB</res-ref-name>
  <res-type>javax.sql.DataSource</res-type>
  <res-auth>Container</res-auth>
</resource-ref>

</web-app> 

org.apache.shiro.web.env.EnvironmentLoaderListener
雪洛菲特
org.apache.shiro.web.servlet.ShiroFilter
雪洛菲特
/*
要求
向前地
包括
错误
帐户数据源
jdbc/AccountDB
javax.sql.DataSource
容器
最后,这里是我的maven pom文件的相关部分:

<build>
  <plugins>
    <plugin>
      <groupId>org.eclipse.jetty</groupId>
      <artifactId>jetty-maven-plugin</artifactId>
      <version>9.0.0.RC2</version>
      <configuration>
        <jettyXml>src/jetty/jetty.xml</jettyXml>
        <scanIntervalSeconds>1</scanIntervalSeconds>
        <webApp>
          <contextPath>/</contextPath>
          <overrideDescriptor>src/jetty/override-web.xml</overrideDescriptor>
        </webApp>
      </configuration>
      <dependencies>
        <dependency>
          <groupId>mysql</groupId>
          <artifactId>mysql-connector-java</artifactId>
          <version>5.1.24</version>
        </dependency>
      </dependencies>
    </plugin>
  </plugins>

org.eclipse.jetty
jetty maven插件
9.0.0.RC2
src/jetty/jetty.xml
1.
/
src/jetty/override-web.xml
mysql
mysql连接器java
5.1.24

编辑:另一条相关信息。我正在eclipse中编辑文件,并使用M2E Maven集成eclipse插件。这可能与eclipse和/或该插件如何重新编译文件有关。

我改用jetty 8而不是jetty 9候选版本,问题就解决了。注意:我也在9.0.1.v20130408上试用过,但在该版本中也不起作用。问题似乎是ServletContextListeners在jetty 9的重新加载过程中没有重新初始化。