springboot之网站超级简单拦截器

简单拦截器的实现

  • 需要有一个继承HandlerInterceptor的类

    这个类中只需要重写preHandle()方法即可。
    Talking is cheap~~ ,先上代码,后面解释。

public class LoginHandlerInterceptor implements HandlerInterceptor {
    @Override
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
        Object loginUser = request.getSession().getAttribute("loginUser");
        if (loginUser == null){
            request.setAttribute("msg", "没有权限,请先登录!");
            request.getRequestDispatcher("/index.html").forward(request, response);
            return false;
        }else {
            return true;
        }
    }
}

第一行是查看我在登陆成功的时候放入的session,如果有就放行,返回true。没有则提示:没有权限,请先登录。然后跳转到首页登陆。

 @RequestMapping("/user/login")
    public String login(@RequestParam("username")String username,
                        @RequestParam("password")String password,
                        Model model, HttpSession session){
        if (!StringUtils.isEmpty(username) && "123".equals(password)){
            session.setAttribute("loginUser", username);
            return  "redirect:/main.html";
        }else {
            model.addAttribute("msg", "用户名或密码错误");
            return "index";
        }
    }

这里正常是需要去数据库查询账号密码判断是否正确的。
但是我就是不,就是偷懒,你咬我啊~ 略略略*
一切从简。用户名不为空,密码是123就可以了。好了就看下一步

  • 将类托管给spring
 @Override
    public void addInterceptors(InterceptorRegistry registry) {
        registry.addInterceptor(new LoginHandlerInterceptor())
                .addPathPatterns("/**")
                .excludePathPatterns("/index.html","/","/user/login","/asserts/**");
    }

一样在实现WebMvcConfigurer接口的类中重写addInterceptors()即可。格式如上,addPathPatterns拦截所有页面,excludePathPatterns排除不拦截的页面。

测试一下。成功!搞定收工。
如果你都觉得这个文章帮助到你了,请点个赞,谢谢!

猜你喜欢

转载自blog.csdn.net/Bernie_7/article/details/107501394
今日推荐