<kbd id="afajh"><form id="afajh"></form></kbd>
<strong id="afajh"><dl id="afajh"></dl></strong>
    <del id="afajh"><form id="afajh"></form></del>
        1. <th id="afajh"><progress id="afajh"></progress></th>
          <b id="afajh"><abbr id="afajh"></abbr></b>
          <th id="afajh"><progress id="afajh"></progress></th>

          Spring Boot 實(shí)現(xiàn)登錄攔截器,這才是正確的姿勢(shì)!!

          共 8947字,需瀏覽 18分鐘

           ·

          2021-08-13 20:16

          相關(guān)閱讀

          300本計(jì)算機(jī)編程的經(jīng)典書(shū)籍下載

          AI全套:Python3+TensorFlow打造人臉識(shí)別智能小程序

          最新人工智能資料-Google工程師親授 Tensorflow-入門(mén)到進(jìn)階

          Java架構(gòu)全階段七期完整

          黑馬頭條項(xiàng)目 - Java Springboot2.0(視頻、資料、代碼和講義)14天完整版

          Spring核心編程思想

          原文:https://blog.csdn.net/qq_27198345/article/details/111401610

          對(duì)于管理系統(tǒng)或其他需要用戶登錄的系統(tǒng),登錄驗(yàn)證都是必不可少的環(huán)節(jié),在SpringBoot開(kāi)發(fā)的項(xiàng)目中,通過(guò)實(shí)現(xiàn)攔截器來(lái)實(shí)現(xiàn)用戶登錄攔截并驗(yàn)證。

          1、Spring Boot實(shí)現(xiàn)登錄攔截原理

          SpringBoot通過(guò)實(shí)現(xiàn)HandlerInterceptor接口實(shí)現(xiàn)攔截器,通過(guò)實(shí)現(xiàn)WebMvcConfigurer接口實(shí)現(xiàn)一個(gè)配置類(lèi),在配置類(lèi)中注入攔截器,最后再通過(guò)@Configuration注解注入配置。

          1.1、實(shí)現(xiàn)HandlerInterceptor接口

          實(shí)現(xiàn)HandlerInterceptor接口需要實(shí)現(xiàn)3個(gè)方法:preHandle、postHandleafterCompletion.

          3個(gè)方法各自的功能如下:

          package blog.interceptor;

          import blog.entity.User;
          import org.springframework.web.servlet.HandlerInterceptor;
          import org.springframework.web.servlet.ModelAndView;

          import javax.servlet.http.HttpServletRequest;
          import javax.servlet.http.HttpServletResponse;
          import javax.servlet.http.HttpSession;

          public class UserLoginInterceptor implements HandlerInterceptor {

              /***
               * 在請(qǐng)求處理之前進(jìn)行調(diào)用(Controller方法調(diào)用之前)
               */
              @Override
              public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
                  System.out.println("執(zhí)行了攔截器的preHandle方法");
                  try {
                      HttpSession session = request.getSession();
                      //統(tǒng)一攔截(查詢(xún)當(dāng)前session是否存在user)(這里user會(huì)在每次登錄成功后,寫(xiě)入session)
                      User user = (User) session.getAttribute("user");
                      if (user != null) {
                          return true;
                      }
                      response.sendRedirect(request.getContextPath() + "login");
                  } catch (Exception e) {
                      e.printStackTrace();
                  }
                  return false;
                  //如果設(shè)置為false時(shí),被請(qǐng)求時(shí),攔截器執(zhí)行到此處將不會(huì)繼續(xù)操作
                  //如果設(shè)置為true時(shí),請(qǐng)求將會(huì)繼續(xù)執(zhí)行后面的操作
              }

              /***
               * 請(qǐng)求處理之后進(jìn)行調(diào)用,但是在視圖被渲染之前(Controller方法調(diào)用之后)
               */
              @Override
              public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {
                  System.out.println("執(zhí)行了攔截器的postHandle方法");
              }

              /***
               * 整個(gè)請(qǐng)求結(jié)束之后被調(diào)用,也就是在DispatchServlet渲染了對(duì)應(yīng)的視圖之后執(zhí)行(主要用于進(jìn)行資源清理工作)
               */
              @Override
              public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception {
                  System.out.println("執(zhí)行了攔截器的afterCompletion方法");
              }
          }

          preHandle在Controller之前執(zhí)行,因此攔截器的功能主要就是在這個(gè)部分實(shí)現(xiàn):

          • 檢查session中是否有user對(duì)象存在;

          • 如果存在,就返回true,那么Controller就會(huì)繼續(xù)后面的操作;

          • 如果不存在,就會(huì)重定向到登錄界面。就是通過(guò)這個(gè)攔截器,使得Controller在執(zhí)行之前,都執(zhí)行一遍preHandle.

          1.2、實(shí)現(xiàn)WebMvcConfigurer接口,注冊(cè)攔截器

          實(shí)現(xiàn)WebMvcConfigurer接口來(lái)實(shí)現(xiàn)一個(gè)配置類(lèi),將上面實(shí)現(xiàn)的攔截器的一個(gè)對(duì)象注冊(cè)到這個(gè)配置類(lèi)中。

          package blog.config;

          import blog.interceptor.UserLoginInterceptor;
          import org.springframework.context.annotation.Configuration;
          import org.springframework.web.servlet.config.annotation.InterceptorRegistration;
          import org.springframework.web.servlet.config.annotation.InterceptorRegistry;
          import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;

          @Configuration
          public class LoginConfig implements WebMvcConfigurer {

              @Override
              public void addInterceptors(InterceptorRegistry registry) {
                  //注冊(cè)TestInterceptor攔截器
                  InterceptorRegistration registration = registry.addInterceptor(new UserLoginInterceptor());
                  registration.addPathPatterns("/**"); //所有路徑都被攔截
                  registration.excludePathPatterns(    //添加不攔截路徑
                          "/login",                    //登錄路徑
                          "/**/*.html",                //html靜態(tài)資源
                          "/**/*.js",                  //js靜態(tài)資源
                          "/**/*.css"                  //css靜態(tài)資源
                  );
              }
          }

          將攔截器注冊(cè)到了攔截器列表中,并且指明了攔截哪些訪問(wèn)路徑,不攔截哪些訪問(wèn)路徑,不攔截哪些資源文件;最后再以@Configuration注解將配置注入。

          1.3、保持登錄狀態(tài)

          只需一次登錄,如果登錄過(guò),下一次再訪問(wèn)的時(shí)候就無(wú)需再次進(jìn)行登錄攔截,可以直接訪問(wèn)網(wǎng)站里面的內(nèi)容了。

          在正確登錄之后,就將user保存到session中,再次訪問(wèn)頁(yè)面的時(shí)候,登錄攔截器就可以找到這個(gè)user對(duì)象,就不需要再次攔截到登錄界面了.

          @RequestMapping(value = {"""/""/index"}, method = RequestMethod.GET)
          public String index(Model model, HttpServletRequest request) {
              User user = (User) request.getSession().getAttribute("user");
              model.addAttribute("user", user);
              return "users/index";
          }

          @RequestMapping(value = {"/login"}, method = RequestMethod.GET)
          public String loginIndex() {
              return "users/login";
          }

          @RequestMapping(value = {"/login"}, method = RequestMethod.POST)
          public String login(@RequestParam(name = "username")String username, @RequestParam(name = "password")String password,
                              Model model, HttpServletRequest request) {
              User user = userService.getPwdByUsername(username);
              String pwd = user.getPassword();
              String password1 = MD5Utils.md5Code(password).toUpperCase();
              String password2 = MD5Utils.md5Code(password1).toUpperCase();
              if (pwd.equals(password2)) {
                  model.addAttribute("user", user);
                  request.getSession().setAttribute("user", user);
                  return "redirect:/index";
              } else {
                  return "users/failed";
              }
          }

          2、代碼實(shí)現(xiàn)及示例

          代碼實(shí)現(xiàn)如上所示。

          在登錄成功之后,將user信息保存到session中,下一次登錄時(shí)瀏覽器根據(jù)自己的SESSIONID就可以找到對(duì)應(yīng)的session,就不要再次登錄了,可以從Chrome瀏覽器中看到。

          3、效果驗(yàn)證

          3.1、訪問(wèn)localhost:8081/index頁(yè)面:


          被重定向到了localhost:8081/login,實(shí)現(xiàn)了登錄攔截。

          3.2、正確輸入用戶名和密碼登錄

          3.3、再次訪問(wèn)localhost:8081/index


          沒(méi)有再次被登錄攔截器攔截,證明可以保持登錄。

          看完本文有收獲?請(qǐng)轉(zhuǎn)發(fā)分享給更多人


          往期資源:


          Flutter 移動(dòng)應(yīng)用開(kāi)發(fā)實(shí)戰(zhàn) 視頻(開(kāi)發(fā)你自己的抖音APP)
          Java面試進(jìn)階訓(xùn)練營(yíng) 第2季(分布式篇)
          Java高級(jí) - 分布式系統(tǒng)開(kāi)發(fā)技術(shù)視頻


          瀏覽 70
          點(diǎn)贊
          評(píng)論
          收藏
          分享

          手機(jī)掃一掃分享

          分享
          舉報(bào)
          評(píng)論
          圖片
          表情
          推薦
          點(diǎn)贊
          評(píng)論
          收藏
          分享

          手機(jī)掃一掃分享

          分享
          舉報(bào)
          <kbd id="afajh"><form id="afajh"></form></kbd>
          <strong id="afajh"><dl id="afajh"></dl></strong>
            <del id="afajh"><form id="afajh"></form></del>
                1. <th id="afajh"><progress id="afajh"></progress></th>
                  <b id="afajh"><abbr id="afajh"></abbr></b>
                  <th id="afajh"><progress id="afajh"></progress></th>
                  无码人妻一区二区三一区免费n狂飙 | 色五月天综合 | 黄片在线播放免费观看a | 国产一级片哪里可以看 | 无需播放器的AV |