我创建了一个简单的WebMVC应用程序 - 配置了处理程序拦截器。拦截器的责任很简单 - 它应该检查HttpRequest中是否存在有效的会话 - 如果是,则重定向到注册页面。
我遇到的问题是在重定向时 - 浏览器正在抛出消息:
该页面未正确重定向
Firefox检测到服务器正在重定向请求 这个地址永远不会完成。
拦截器代码如下:
public class LoginInterceptor extends HandlerInterceptorAdapter{
// to be used checking session management for user.
@Override
public boolean preHandle(HttpServletRequest request,
HttpServletResponse response,
Object handler) throws Exception {
System.out.println(" <interceptor> - this is pre handle");
return true;
}
@Override
public void postHandle(HttpServletRequest request,
HttpServletResponse response, Object handler,
ModelAndView modelAndView) throws Exception {
System.out.println(" <interceptor> - this is post handle");
HttpSession session = request.getSession();
User user = (User) session.getAttribute("user");
System.out.println(" <interceptor> - session id is --> " + session.getId());
System.out.println(" <interceptor> - session create time is --> " + session.getCreationTime());
System.out.println(" <interceptor> - session last accessed time is --> " + session.getLastAccessedTime());
try {
System.out.println(" <interceptor> - user info is --> " + user.toString());
}catch(Exception e){
e.toString();
}
try{
if(session != null){
response.sendRedirect("register");
return;
}
}catch(Exception e){
e.toString();
}
}
public void afterCompletetion(){
System.out.println(" <interceptor> - this is after completion");
}
}
我试图将完整的请求上下文路径附加到重定向 - 以及根上下文 - 两者都失败了。我无法看到我在这方面的失败 - 所以任何帮助都是最受欢迎的。
答案 0 :(得分:3)
无论您编写的拦截器是什么,都会为所有请求提供图片。
所以,当它将重定向到/register
时,它也会到达拦截器,它会发现session
不是null并且再次重定向......同样的事情继续...... 无限重定向同样的要求。
@Override
public void postHandle(HttpServletRequest request,
HttpServletResponse response, Object handler,
ModelAndView modelAndView) throws Exception {
HttpSession session = request.getSession();
try{
if(session != null){ //Infinite
response.sendRedirect("register");
return;
}
}catch(Exception e){
e.toString();
}
}
因此,请确保configuration
或code
if((request.getRequestURI().equals(contextPath+"/someURI") && session != null){
response.sendRedirect("register");
}
然后它只检查特定请求并重定向到register.It不会陷入无限循环。
答案 1 :(得分:0)
检查您的拦截器配置,看它是否只接受某个网址模式。
请参阅下面的示例。
<!-- Configures Interceptors -->
<mvc:interceptors>
<!-- This XML will intercept all URIs -->
<bean class="com.howtodoinjava.interceptor.DemoInterceptor"></bean>
<!-- This XML will apply interceptor to only certain URIs -->
<!--
<mvc:interceptor>
<mvc:mapping path="/users"></mvc:mapping>
<bean class="com.howtodoinjava.interceptor.DemoInterceptor"></bean>
<mvc:interceptor>
-->
</mvc:interceptors>