登录、项目-Spring mvc Session拦截器-by小雨
最近用使开发的过程中出现了一个小问题,顺便记录一下原因和方法--登录、项目-
未登录,不允许拜访项目文件夹内的面页,那如何断判否是登录呢?
下面向大家细详分析spring mvc Session拦截器的用使,本文以登录为例,未登录无限权拜访项目内面页,session为空时返回项目首页。
代码如下:
package com.sundear.sundearemm.interceptor;
import com.sundear.sundearemm.model.User;
import java.util.logging.Level;
import java.util.logging.Logger;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.springframework.web.servlet.HandlerInterceptor;
import org.springframework.web.servlet.ModelAndView;
/**
*
* @author yh
*/
public class SessionInterceptor implements HandlerInterceptor {
private Logger logger = Logger.getLogger(SessionInterceptor.class.getName());
@Override
public boolean preHandle(HttpServletRequest hsr, HttpServletResponse hsr1, Object o) throws Exception {
User user=(User) hsr.getSession().getAttribute("LoginUser");
if(user==null){
logger.log(Level.INFO, "user not login");
hsr1.sendRedirect("/SundearEmm");
return false;
}
return true;
}
@Override
public void postHandle(HttpServletRequest hsr, HttpServletResponse hsr1, Object o, ModelAndView mav) throws Exception {
}
@Override
public void afterCompletion(HttpServletRequest hsr, HttpServletResponse hsr1, Object o, Exception excptn) throws Exception {
}
}
仅这些还不敷,我们还需要修改spring mvc的配置文件dispatcher-servlet.xml,入加拦截器代码如下:
<!-- interceptors -->
<mvc:interceptors >
<mvc:interceptor>
<mvc:mapping path="/group/*" />
<mvc:mapping path="/user/*"/>
<mvc:mapping path="/subscribe/*"/>
<mvc:mapping path="/recipient/*"/>
<mvc:mapping path="/mail/*"/>
<bean class="com.sundear.sundearemm.interceptor.SessionInterceptor"></bean>
</mvc:interceptor>
</mvc:interceptors>
若有访客不明白的可以给我留言,我会给大家满足的解决方法……
文章结束给大家分享下程序员的一些笑话语录: 小沈阳版程序员~~~ \n程序员其实可痛苦的了......需求一做一改,一个月就过去了;嚎~ \n需求再一改一调,一季度就过去了;嚎~ \n程序员最痛苦的事儿是啥,知道不?就是,程序没做完,需求又改了; \n程序员最最痛苦的事儿是啥,知道不? 就是,系统好不容易做完了,方案全改了; \n程序员最最最痛苦的事儿是啥,知道不? 就是,系统做完了,狗日的客户跑了; \n程序员最最最最最痛苦的事儿是啥,知道不? 就是,狗日的客户又回来了,程序给删没了!

浙公网安备 33010602011771号