그동안 바쁘다는 핑계로 눈팅만 하다, 막상 자기가 급해지니까 글을 올리고 있는 이기적인 개발자중 한명입니다 ㅠㅠ
제가 여기에 글을 쓴 이유는 프로젝트에서 특정URL 패턴에는 로그인 인터셉터를 해야 하는데 전혀 동작이 되지않아 여러 고수님들
의 가르침을 받고 싶어 올리게 되었습니다.
우선 환경은 spring3.05에 restful 형식으로 컨트롤러에 접근하고 있습니다.
===============applicationContext.xml====================
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="
http://www.springframework.org/schema/beans"
xmlns:p="
http://www.springframework.org/schema/p"
xmlns:xsi="
http://www.w3.org/2001/XMLSchema-instance"
xmlns:aop="
http://www.springframework.org/schema/aop"
xmlns:jdbc="
http://www.springframework.org/schema/jdbc"
xmlns:jee="
http://www.springframework.org/schema/jee"
xmlns:util="
http://www.springframework.org/schema/util"
xmlns:tx="
http://www.springframework.org/schema/tx"
xsi:schemaLocation="
http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/aop
http://www.springframework.org/schema/aop/spring-aop-3.0.xsd
http://www.springframework.org/schema/jdbc
http://www.springframework.org/schema/jdbc/spring-jdbc-3.0.xsd
http://www.springframework.org/schema/jee
http://www.springframework.org/schema/jee/spring-jee-3.0.xsd
http://www.springframework.org/schema/tx
http://www.springframework.org/schema/tx/spring-tx-3.0.xsd
http://www.springframework.org/schema/util
http://www.springframework.org/schema/util/spring-util-3.0.xsd">
<!-- ▼▼▼▼▼▼▼▼▼▼▼ Exception Resolver ▼▼▼▼▼▼▼▼▼ -->
<bean id="exceptionResolver"
class="com.real.common.resolver.CustomMappingExceptionResolver"
p:exceptionMappings-ref="exceptionMappings"
p:exceptionAttribute="exceptionMessage"
p:statusCodes-ref="statusCodes" />
<util:properties id="exceptionMappings">
<prop key="java.lang.Exception">common/error</prop>
</util:properties>
<util:properties id="statusCodes">
<prop key="common/error">500</prop>
</util:properties>
<!-- ▲▲▲▲▲▲▲▲▲ Exception Resolver ▲▲▲▲▲▲▲▲▲▲▲▲▲▲ -->
</beans>
======================================
========================web.xml===============
<?xml version="1.0" encoding="UTF-8"?>
<web-app id="WebApp_ID" 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>real</display-name>
<servlet>
<servlet-name>real-restful</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</
servlet-class>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>mercury-restful</servlet-name>
<url-pattern>/restful/*</url-pattern>
</servlet-mapping>
<context-param>
<param-name>log4jConfigLocation</param-name>
<param-value>/WEB-INF/log/log4j.properties</param-value>
</context-param>
<listener>
<listener-class>org.springframework.web.util.Log4jConfigListener</
listener-class>
</listener>
<context-param>
<param-name>contextConfigLocation</param-name>
<param-value>
/WEB-INF/real-restful-servlet.xml
/WEB-INF/applicationContext.xml
/WEB-INF/context-security.xml
</param-value>
</context-param>
<filter>
<filter-name>httpMethodFilter</filter-name>
<filter-class>org.springframework.web.filter.HiddenHttpMethodFilter</
filter-class>
</filter>
<filter-mapping>
<filter-name>httpMethodFilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
<!-- <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>
<listener>
<listener-class>
org.springframework.security.web.session.HttpSessionEventPublisher
</listener-class>
</listener>
-->
<listener>
<listener-
class>org.springframework.web.context.ContextLoaderListener</listener-
class>
</listener>
</web-app>
==============================================
===========real-restful-servlet.xml=========================
<beans xmlns="
http://www.springframework.org/schema/beans"
xmlns:xsi="
http://www.w3.org/2001/XMLSchema-instance"
xmlns:p="
http://www.springframework.org/schema/p"
xmlns:context="
http://www.springframework.org/schema/context"
xmlns:mvc="
http://www.springframework.org/schema/mvc"
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">
<mvc:annotation-driven/>
<context:component-scan base-package="com.real"/>
<bean
class="org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter"
p:alwaysUseFullPath="true">
<property name="messageConverters">
<list>
<bean
class="org.springframework.http.converter.json.MappingJacksonHttpMessageConverter"></
bean>
</list>
</property>
</bean>
<bean id="viewResolver"
class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name="viewClass"
value="org.springframework.web.servlet.view.JstlView" />
<property name="prefix" value="/WEB-INF/jsp/"></property>
<property name="suffix" value=".jsp" />
<property name="order" value="1"/>
</bean>
<!-- Spring interceptors -->
<mvc:interceptors>
<mvc:interceptor>
<mvc:mapping path="/restful/*" />
<bean class="com.real.common.interceptor.LoginCheckInterceptor"/>
</mvc:interceptor>
</mvc:interceptors>
</beans>
===========real-restful-servlet.xml=========================
===========LoginCheckInterceptor.java=========================
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.springframework.web.servlet.ModelAndView;
import
org.springframework.web.servlet.handler.HandlerInterceptorAdapter;
public class LoginCheckInterceptor extends HandlerInterceptorAdapter
{
public boolean preHandle(HttpServletRequest request,
HttpServletResponse response, Object handler) throws Exception {
System.out.println("===== preHandler
>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>");
return true;
}
public void postHandle(HttpServletRequest request,
HttpServletResponse response, Object handler,
ModelAndView modelAndView) throws Exception {
System.out.println("===== postHandle
>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>");
}
public void afterCompletion(HttpServletRequest request,
HttpServletResponse response, Object handler, Exception ex)
throws Exception {
System.out.println("===== afterCompletion
>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>");
}
}
=========================================
설정은 이와같이 해서
http://localhost:9080/real/restful/userinfo/test
이런형태로 컨트롤러를 호출하면 동작은 잘되는데
<mvc:interceptors>가 동작하지 않습니다.
<!-- Spring interceptors -->
<mvc:interceptors>
<mvc:interceptor>
<mvc:mapping path="/restful/*" />
<bean class="com.real.common.interceptor.LoginCheckInterceptor"/>
</mvc:interceptor>
</mvc:interceptors>
부분에서
<mvc:mapping path="/restful/*" /> 이렇게 설절하면 /restful/가 들어가는 모든 url은 설정
한
인터셉터를 동작시키는 걸로 알고 있는데 , 아무리 해봐도 동작을 안하네요.. ㅠㅠ
다른 웹사이트에 나와있는 소스를 보면 특별하게 별다른 설정하지 않고 사용하던데 ㅠㅠ
지금 걸리는 것은
<bean
class="org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter"
p:alwaysUseFullPath="true">
<property name="messageConverters">
<list>
<bean
class="org.springframework.http.converter.json.MappingJacksonHttpMessageConverter"></
bean>
</list>
</property>
</bean>
때문에
<mvc:interceptors>
<mvc:interceptor>
<mvc:mapping path="/restful/*" />
<bean class="com.real.common.interceptor.LoginCheckInterceptor"/>
</mvc:interceptor>
</mvc:interceptors>
가 동작 하지 않는건가 하는 추측으로 바꿔봐도 인터셉터를 안타네요