Проблема настройки аннотации Spring MVC - PullRequest
2 голосов
/ 12 мая 2010

Я пытаюсь улучшить свою конфигурацию Spring mvc, чтобы не требовать новый файл конфигурации для каждого добавляемого сервлета, но у меня возникают проблемы. Я пытался использовать этот учебник в качестве отправной точки, но столкнулся с проблемой, которую не могу понять.

Проблема в том, что когда я выполняю GET для моего сервлета, я получаю ошибку 404. Вот мой конфиг и типичный фрагмент кода Java из контроллера:

web.xml:

<?xml version="1.0" encoding="UTF-8"?>
<web-app version="2.5" xmlns="http://java.sun.com/xml/ns/javaee"
        xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
        xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd">
    <display-name>SightLogix Coordination System</display-name>

    <description>SightLogix Coordination System</description>

    <servlet>
        <servlet-name>Spring MVC Dispatcher Servlet</servlet-name>
        <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>     
            <init-param>
                <param-name>contextConfigLocation</param-name>
                <param-value>
                    /WEB-INF/application-context.xml
                    /WEB-INF/application-security.xml
                </param-value>
            </init-param>
        <load-on-startup>1</load-on-startup>
    </servlet>

    <servlet-mapping>
        <servlet-name>Spring MVC Dispatcher Servlet</servlet-name>
        <url-pattern>/slcs/*</url-pattern>
    </servlet-mapping>

    <context-param>
        <param-name>contextConfigLocation</param-name>
        <param-value>
            /WEB-INF/application-context.xml
            /WEB-INF/application-security.xml
        </param-value>
    </context-param>

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

    <filter>
        <filter-name>springSecurityFilterChain</filter-name>
        <filter-class>org.springframework.web.filter.DelegatingFilterProxy</filter-class>
    </filter>

    <filter-mapping>
        <filter-name>springSecurityFilterChain</filter-name>
        <url-pattern>/*</url-pattern>
    </filter-mapping>
</web-app>

Приложение-context.xml:

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xmlns:mvc="http://www.springframework.org/schema/mvc"
    xmlns:context="http://www.springframework.org/schema/context"
    xsi:schemaLocation="
        http://www.springframework.org/schema/beans
        http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
        http://www.springframework.org/schema/mvc
        http://www.springframework.org/schema/mvc/spring-mvc-3.0.xsd
        http://www.springframework.org/schema/context
        http://www.springframework.org/schema/context/spring-context-3.0.xsd"

    default-init-method="init" default-destroy-method="destroy">

    <mvc:annotation-driven />

    <context:component-scan base-package="top.level" />
</beans>

Приложение-security.xml:

<beans:beans xmlns="http://www.springframework.org/schema/security"
    xmlns:beans="http://www.springframework.org/schema/beans"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
                    http://www.springframework.org/schema/security http://www.springframework.org/schema/security/spring-security-3.0.xsd">

    <http>
        <intercept-url pattern="/**" access="ROLE_MANAGER" requires-channel="https" />
        <http-basic />
    </http>

    <authentication-manager>
        <authentication-provider user-service-ref="myUserDetailsService">
            <password-encoder hash="sha"/>
        </authentication-provider>
    </authentication-manager>

    <beans:bean id="myUserDetailsService"
        class="path.to.my.UserDetailsServiceImpl">
    </beans:bean>

</beans:beans>

Фрагмент класса Controller (один из многих, но все они выглядят по существу так):

@Controller
@RequestMapping("/foo.xml")
public class FooController
{       
    @RequestMapping(method=RequestMethod.GET)
    public void handleGET(HttpServletRequest request, HttpServletResponse response) throws IOException
    {
        ...

Может кто-нибудь сказать мне, что я делаю неправильно? Спасибо!

Ответы [ 3 ]

3 голосов
/ 12 мая 2010

Единственное, что здесь неуместно, это то, что вы использовали одинаковые файлы конфигурации контекста для корневого контекста веб-приложения и вашего контекста сервлета. Это почти наверняка будет плохой идеей и приведет к очень странному поведению. Это может быть причиной вашей проблемы.

ContextLoaderListener настроен с contextConfigLocation <context-param> и создает и управляет корнем WebApplicationContext.

ServletDispatcherServlet настраивается с помощью contextConfigLocation <init-param> и создает сервлет WebApplicationContext.

и управляет им.

Корень WebApplicationContext является родительским для контекста приложения сервлета, то есть любые bean-компоненты в корне WebApplicationContext видны этим bean-компонентам в сервлете WebApplicationContext.

Ваш первый шаг должен состоять в том, чтобы отделить эти конфигурации. С правильными bean-компонентами в правильных местах (например, весь материал MVC должен идти в контексте сервлета). не делитесь определениями бина между двумя, это только запутает и / или сломает.

0 голосов
/ 28 мая 2010

Есть ли у вас более одного GET RequestMapping в контроллере случайно? Если их несколько, и существует неоднозначность при их разрешении для конкретного запроса, Spring не сопоставляется ни с одним из неоднозначных отображений GET.

0 голосов
/ 12 мая 2010

Это не отвечает на ваш вопрос напрямую, но я всегда считал полезным включить ведение журнала отладки в Spring, когда я не могу понять, что происходит не так.

Ниже приведены два, которые я обычно использую в своем файле logging.properties:

org.springframework.beans.factory.support.level=FINEST
org.springframework.security.level=FINEST
...