SpringBoot——拦截器

更多内容,前往 IT-BLOG

一、登录时可能会出现重复提交问题。我们可以通过重定向解决此问题。例如:用户提交的请求为:/user/login,通过 redirect:重定向至 main.html请求。

 1 @PostMapping("/user/login")
 2 public String login(@RequestParam("username") String name,
 3                     @RequestParam("password") String password,
 4                     Map<String,String> map,
 5                     HttpSession session){
 6     if(!StringUtils.isEmpty(name) && password.equals("123456")){
 7         //将用户名设置到session中
 8         session.setAttribute("loginUser",name);
 9         return "redirect:/main.html";
10     }else{
11         map.put("msg","密码或用户名错误");
12         return "index";
13     }
14 }

二、配置视图映射,新建配置类通过继承 WebMvcConfigurerAdapter类,实现 addViewControllers方法,添加视图映射。WebMvcConfigurerAdapter该抽象类其实里面没有任何的方法实现,只是空实现了接口WebMvcConfigurer内的全部方法,并没有给出任何的业务逻辑处理,这一点设计恰到好处的让我们不必去实现那些我们不用的方法,都交由WebMvcConfigurerAdapter抽象类空实现,如果我们需要针对具体的某一个方法做出逻辑处理,仅仅需要在WebMvcConfigurerAdapter子类中@Override对应方法就可以了。

1 @Configuration
2 public class MyMvcConfig extends WebMvcConfigurerAdapter {
3     @Override
4     public void addViewControllers(ViewControllerRegistry registry) {
5         registry.addViewController("/").setViewName("index");
6         registry.addViewController("/index.html").setViewName("index");
7         registry.addViewController("/main.html").setViewName("dashboard");
8     }
9 }

三、添加自己配置的拦截器:因为当我们访问:/main.html请求的时候,也可以跳转至dashboard.html页面,需要实现HandlerInterceptor接口。通过preHandle判断是否登录成功。preHandle:在业务处理器处理请求之前被调用。预处理,可以进行编码、安全控制、权限校验等处理;

 1 public class LoginHandlerInterceptor implements HandlerInterceptor{
 2     @Override
 3     public boolean preHandle(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse, Object o) throws Exception {
 4         Object user = httpServletRequest.getSession().getAttribute("loginUser");
 5         if(user == null){
 6             httpServletRequest.setAttribute("msg","没有权限请先登录");
 7             httpServletRequest.getRequestDispatcher("/index.html").forward(httpServletRequest,httpServletResponse);
 8             return false;
 9         }else{
10             //已登录,放行。
11             return true;
12         }
13     }
14 
15     ////postHandle:在业务处理器处理请求执行完成后,生成视图之前执行。后处理(调用了Service并返 回ModelAndView,但未进行页面渲染),有机会修改ModelAndView (这个博主就基本不怎么用了);
16     @Override
17     public void postHandle(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse, Object o, ModelAndView modelAndView) throws Exception {
18 
19     }
20 
21     //afterCompletion:在DispatcherServlet完全处理完请求后被调用,可用于清理资源等。返回处理(已经渲染了页面);    
22     @Override
23     public void afterCompletion(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse, Object o, Exception e) throws Exception {
24 
25     }
26 }

四、需要将自己定义的拦截器注册到IOC容器中,进入我们自定义的配置类MyMvcConfig。需要注意的是登录请求/user/login不要忘记排除掉。

 1 @Configuration
 2 public class MyMvcConfig extends WebMvcConfigurerAdapter {
 3 
 4     @Override
 5     public void addInterceptors(InterceptorRegistry registry) {
 6         //super.addInterceptors(registry);
 7         //SpringBoot已经做好了静态资源映射
 8         registry.addInterceptor(new LoginHandlerInterceptor()).
 9                 addPathPatterns("/**").excludePathPatterns("/index.html","/","/user/login");
10     }
11 }


 ----关注公众号,获取更多内容----

posted @ 2020-11-22 10:03  Java程序员进阶  阅读(11)  评论(0编辑  收藏  举报