Как заставить Spring хорошо играть с Wicket?(Проблема ContextLoaderListener) - PullRequest
4 голосов
/ 28 июня 2011

Насколько мне известно, и согласно инструкциям, которые я нашел (например, это и это тоже ), мне нужно это в web.xml для работы Spring:

<listener>
    <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>

В моем классе приложения Wicket у меня было бы:

public class MyApplication extends WebApplication {

    @Override
    protected void init() {
        super.init();    
        addComponentInstantiationListener(new SpringComponentInjector(this));
    }

    @Override
    public Class<? extends Page> getHomePage() {
        return HelloWorldPage.class;
    }
}

Проблема в том, что когда у меня есть ContextLoaderListener в web.xml, Wicket не запускается. Я просто получаю 404 ошибки (или пустую страницу) и вывод на консоль, например:

SEVERE: Error listenerStart
Jun 28, 2011 12:49:04 PM org.apache.catalina.util.SessionIdGenerator createSecureRandom
INFO: Creation of SecureRandom instance for session ID generation using [SHA1PRNG] took [1,973] milliseconds.
Jun 28, 2011 12:49:04 PM org.apache.catalina.core.StandardContext startInternal
SEVERE: Context [] startup failed due to previous errors
Jun 28, 2011 12:49:04 PM org.apache.catalina.loader.WebappClassLoader clearReferencesJdbc
SEVERE: The web application [] registered the JDBC driver [org.hsqldb.jdbc.JDBCDriver] but failed to unregister it when the web application was stopped. To prevent a memory leak, the JDBC Driver has been forcibly unregistered.
Jun 28, 2011 12:49:04 PM org.apache.catalina.loader.WebappClassLoader clearReferencesJdbc
SEVERE: The web application [] registered the JDBC driver [com.mysql.jdbc.Driver] but failed to unregister it when the web application was stopped. To prevent a memory leak, the JDBC Driver has been forcibly unregistered.
Jun 28, 2011 12:49:04 PM org.apache.catalina.startup.HostConfig deployDirectory

Я использую последние версии обеих платформ (Wicket 1.4.17 и Spring 3.0.5) и Tomcat 7 длязапустите их (то же самое происходит с Tomcat 6).Также у меня есть следующие jar-файлы в WEB-INF / lib.Чего-то не хватает или слишком много?

antlr-2.7.6.jar                        log4j-1.2.16.jar              spring-web-3.0.5.jar
commons-collections-3.1.jar            mysql-connector-5.1.10.jar    slf4j-api-1.6.1.jar
dom4j-1.6.1.jar                        spring-beans-3.0.5.jar        slf4j-log4j12-1.6.1.jar
guava-r09.jar                          spring-context-3.0.5.jar      wicket-1.4.17.jar
hibernate-3.6.5.jar                    spring-core-3.0.5.jar         wicket-auth-roles-1.4.17.jar
hibernate-jpa-2.0-api-1.0.0.Final.jar  spring-jdbc-3.0.5.jar         wicket-datetime-1.4.17.jar
hsqldb.jar                             spring-orm-3.0.5.jar          wicket-ioc-1.4.17.jar
javassist-3.12.0.GA.jar                spring-test-3.0.5.jar         wicket-spring-1.4.17.jar
jta-1.1.jar                            spring-transaction-3.0.5.jar  wicketstuff-annotation-1.4.17.2.jar

Остальная часть файла web.xml (я пытался настроить Wicket и с сервлетом, и с фильтром; без разницы):

<?xml version="1.0" encoding="UTF-8"?>
<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">

    <display-name>My App</display-name>

    <context-param>
        <param-name>contextConfigLocation</param-name>
        <param-value>classpath:applicationContext.xml</param-value>
    </context-param>

    <context-param>
        <param-name>configuration</param-name>
        <param-value>development</param-value>
    </context-param>

    <filter>
        <filter-name>MyApp</filter-name>
        <filter-class>org.apache.wicket.protocol.http.WicketFilter</filter-class>
        <init-param>
            <param-name>applicationClassName</param-name>
            <param-value>com.acme.MyApplication</param-value>
        </init-param>
    </filter>

    <filter-mapping>
        <filter-name>MyApp</filter-name>
        <url-pattern>/*</url-pattern>
    </filter-mapping>

     <listener>
        <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
    </listener>

</web-app>

Погуглив вокруг, я нашел кого-то с той же проблемой , но без решений.

Забавно, у меня раньше Spring и Wicket прекрасно работали вместе, с почти одинаковыми настройками.Есть идеи?

Ответы [ 3 ]

0 голосов
/ 28 июня 2011

Пожалуйста, отметьте contextConfigLocation . Значение param должно быть classpath *: applicationContext.xml . Пожалуйста, проверьте конфигурацию слушателей также в моем примере. Надеюсь, я помог!

Это моя конфигурация web.xml, которая прекрасно работает:

<?xml version="1.0" encoding="ISO-8859-1"?>
<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">

    <display-name>mywebapp</display-name>

    <filter>
        <filter-name>springRequestContextFilter</filter-name>
        <filter-class>org.springframework.web.filter.RequestContextFilter</filter-class>
    </filter>

    <context-param>
        <param-name>contextConfigLocation</param-name>
        <param-value>
            classpath*:applicationContext.xml
        </param-value>
    </context-param>

    <listener>
        <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
    </listener>
    <listener>
        <listener-class>org.springframework.web.context.request.RequestContextListener</listener-class>
    </listener>

    <filter>
        <filter-name>wicket.mywebapp</filter-name>
        <filter-class>org.apache.wicket.protocol.http.WicketFilter</filter-class>
        <init-param>
            <param-name>applicationClassName</param-name>
            <param-value>com.company.example.web.MyApplication</param-value>
        </init-param>
    </filter>

        <!-- Enables Spring Security -->
    <filter>
        <filter-name>filterChainProxy</filter-name>
        <filter-class>org.springframework.web.filter.DelegatingFilterProxy</filter-class>
    </filter>

    <filter-mapping>
      <filter-name>filterChainProxy</filter-name>
      <url-pattern>/*</url-pattern>
    </filter-mapping>

 <filter-mapping>
  <filter-name>wicket.mywebapp</filter-name>
    <url-pattern>/*</url-pattern>
 </filter-mapping>

</web-app>
0 голосов
/ 28 июня 2011

Редактировать: Позже я понял, что корень проблемы здесь, скорее всего, отсутствует конфигурация журнала .В нашем случае (с использованием SLF4J с log4j) после добавления правильной конфигурации в log4j.properties стали видны все виды предупреждений и ошибок, регистрируемых библиотеками, даже с Tomcat.


Я пытался Jetty вместо Tomcat , и начали получать лучшие сообщения об ошибках.Оказалось, что было пропущено несколько библиотек - материал, необходимый для некоторых библиотек, которые я уже использовал.

2011-06-28 15:57:01.879:WARN::Unable to reach node goal: started
java.lang.NoClassDefFoundError: org/apache/commons/logging/LogFactory
    at org.springframework.web.context.ContextLoader.initWebApplicationContext(ContextLoader.java:184)
    at org.springframework.web.context.ContextLoaderListener.contextInitialized(ContextLoaderListener.java:47)
    at org.eclipse.jetty.server.handler.ContextHandler.startContext(ContextHandler.java:640)

Некоторые библиотеки, по-видимому, требуют регистрации общего доступа, которую я добавил.Далее:

java.lang.NoClassDefFoundError: org/springframework/asm/ClassVisitor
    at org.springframework.context.support.AbstractRefreshableApplicationContext.customizeBeanFactory(AbstractRefreshableApplicationContext.java:218)

Добавлен весенний асм.Далее:

org.springframework.beans.factory.BeanDefinitionStoreException: 
  Unexpected exception parsing XML document from class path resource [applicationContext.xml]; 
  nested exception is java.lang.NoClassDefFoundError: org/springframework/aop/config/AopNamespaceUtils

Добавлен spring-aop.Далее что-то чуть менее прямолинейное:

org.springframework.beans.factory.BeanDefinitionStoreException: 
  Unexpected exception parsing XML document from class path resource [applicationContext.xml]; 
  nested exception is java.lang.NoClassDefFoundError: org/aopalliance/intercept/MethodInterceptor

Обнаружена дискуссия по поводу отсутствия aopalliance в комментариях к весеннему блогу .Очевидно, он был полностью удален из spring-aop, и вам нужно получить aopalliance.jar из sourceforge .

(я думаю, что это болото - это Java EE в худшем случае:Не знаю, что делают spring-asm или spring-aop, не говоря уже о aopalliance, но, видимо, они мне нужны. :-P)

Итак, добавлен aopalliance.jar.Позже мне все еще нужно было добавить spring-expression и cglib-2.2 (который поставляется с Hibernate).

После этого остаются некоторые проблемы с моей конфигурацией персистентного слоя Spring / Hibernate, но они выходят за рамки этого вопроса,В противном случае Wicket & Spring теперь работают хорошо (например, для внедрения объектов сервисного слоя на страницы Wicket).

Я предполагаю, что одна из моральных причин этого заключается в том, что в некоторых случаях Tomcat ест полезные сообщения об ошибках, и Jetty может быть лучше для отладки.Кроме того, использование Maven, возможно, могло бы помочь с адом зависимостей (но оно также не без проблем).

0 голосов
/ 28 июня 2011

Это конфигурация моего проекта:

<?xml version="1.0" encoding="UTF-8"?>

<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">

    <!-- Spring context config location(s) -->
    <context-param>
    <param-name>contextConfigLocation</param-name>
    <param-value>
        /WEB-INF/applicationContext.xml
    </param-value>
    </context-param>  

    <display-name>afrodite</display-name>

    <!-- used by Log4jConfigListener -->
    <context-param>
    <param-name>webAppRootKey</param-name>
    <param-value>afrodite.root</param-value>
    </context-param>     

    <context-param>
    <param-name>log4jConfigLocation</param-name>
    <param-value>/WEB-INF/log4j.properties</param-value>
    </context-param>   

    <filter>
    <filter-name>openSessionInView</filter-name>
    <filter-class>org.springframework.orm.hibernate3.support.OpenSessionInViewFilter</filter-class>
    </filter>

    <filter>
    <filter-name>afrodite-app</filter-name>
    <filter-class>org.apache.wicket.protocol.http.WicketFilter</filter-class>
    <init-param>
        <param-name>applicationClassName</param-name>
        <param-value>info.afrodite.wicket.AfroditeApplication</param-value>
    </init-param>
    <init-param>
        <param-name>configuration</param-name>
        <param-value>DEPLOYMENT</param-value>
    </init-param>
    </filter>    

    <!-- open session should be above the wicket filter -->
    <filter-mapping>
    <filter-name>openSessionInView</filter-name>
    <url-pattern>/app/*</url-pattern>
    </filter-mapping>     

    <filter-mapping>
    <filter-name>afrodite-app</filter-name>
    <url-pattern>/app/*</url-pattern>
    </filter-mapping>           

    <listener>
    <listener-class>org.springframework.web.util.Log4jConfigListener</listener-class>
    </listener>

    <listener>
    <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
    </listener>

    <servlet>
    <servlet-name>afrodite-api</servlet-name>
    <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
    <load-on-startup>2</load-on-startup>
    </servlet>

    <servlet-mapping>
    <servlet-name>afrodite-api</servlet-name>
    <url-pattern>/api/*</url-pattern>
    </servlet-mapping>    

    <welcome-file-list>
    <welcome-file>index.html</welcome-file>
    </welcome-file-list>

</web-app>

Надеюсь, это поможет.

...