登陆拦截器Interceptor

拦截器的目的是什么?

当然是,拦截非法操作,我们需要登陆的,和不需要登陆的需求。

开始进行操作:

第一步:

建立需要拦截的对象,如我自己建立的Iterceptor

public class LoginInterceptor implements HandlerInterceptor{

    @Override
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler)
            throws Exception {
        // TODO Auto-generated method stub
        HttpSession session=request.getSession();
        String contextPath=session.getServletContext().getContextPath();
        String[] requirePath=new String[] {
                "admin_userlist",
                "admin_reservelist",
                "admin_about",
                "admin_post_list",
                "admin_config_list"
        };
        String uri=request.getRequestURI();
        uri=org.apache.commons.lang3.StringUtils.remove(uri, contextPath+"/");
        String page=uri;
        if(Beginwith(page,requirePath)) {
            User user=(User) session.getAttribute("user");
            if(user== null) {
                response.sendRedirect("hello");
                return false;
            }
        }
        return true;
    }
    private boolean Beginwith(String page,String[] requirePath) {
        boolean result=false;
        for(String requirePa :requirePath) {
            if(StringUtils.startsWith(page, requirePa)) {
                result=true;
                return result;
            }
        }
        return result;
        
    }

    @Override
    public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler,
            ModelAndView modelAndView) throws Exception {
        // TODO Auto-generated method stub
        
    }

    @Override
    public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex)
            throws Exception {
        // TODO Auto-generated method stub
        
    }

}

代码不讲解,low

第二步,配置拦截器configure

@Configuration
public class WebMvcConfigurer extends WebMvcConfigurerAdapter {

    @Bean
    public LoginInterceptor loginInterceptor() {
        return new LoginInterceptor();
    }
    
    public void addInterceptors(InterceptorRegistry registry) {
        registry.addInterceptor(loginInterceptor())
        .addPathPatterns("/**");
    }
}
该拦截器在springboot框架基础上进行配置

转载于:https://www.cnblogs.com/DIVEY/p/10876756.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值