简单拦截器的实现
-
需要有一个继承
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
排除不拦截的页面。
测试一下。成功!搞定收工。
如果你都觉得这个文章帮助到你了,请点个赞,谢谢!