1. <strong id="7actg"></strong>
    2. <table id="7actg"></table>

    3. <address id="7actg"></address>
      <address id="7actg"></address>
      1. <object id="7actg"><tt id="7actg"></tt></object>

        SpringBoot實(shí)現(xiàn)登錄攔截器(實(shí)戰(zhàn)版)

        共 8603字,需瀏覽 18分鐘

         ·

        2021-06-01 19:42

        點(diǎn)擊上方“程序員大白”,選擇“星標(biāo)”公眾號(hào)

        重磅干貨,第一時(shí)間送達(dá)

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

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

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

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

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

        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)一攔截(查詢當(dāng)前session是否存在user)(這里user會(huì)在每次登錄成功后,寫入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ì)重定向到登錄界面。就是通過這個(gè)攔截器,使得Controller在執(zhí)行之前,都執(zhí)行一遍preHandle.

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

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

        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è)到了攔截器列表中,并且指明了攔截哪些訪問路徑,不攔截哪些訪問路徑,不攔截哪些資源文件;最后再以@Configuration注解將配置注入。

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

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

        在正確登錄之后,就將user保存到session中,再次訪問頁面的時(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、訪問localhost:8081/index頁面:

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

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

        3.3、再次訪問localhost:8081/index

        沒有再次被登錄攔截器攔截,證明可以保持登錄。最后,關(guān)注公眾號(hào)Java筆記蝦,后臺(tái)回復(fù)“后端面試”,送你一份面試題寶典!

        (感謝閱讀,希望對(duì)你所有幫助)
        來源:blog.csdn.net/qq_27198345/article/details/111401610


        國(guó)產(chǎn)小眾瀏覽器因屏蔽視頻廣告,被索賠100萬(后續(xù))

        年輕人“不講武德”:因看黃片上癮,把網(wǎng)站和786名女主播起訴了

        中國(guó)聯(lián)通官網(wǎng)被發(fā)現(xiàn)含木馬腳本,可向用戶推廣色情APP

        張一鳴:每個(gè)逆襲的年輕人,都具備的底層能力


        關(guān)


        ,學(xué),西學(xué)學(xué)運(yùn)營(yíng)護(hù)號(hào)質(zhì),結(jié)識(shí),關(guān)[]學(xué)習(xí)進(jìn)!


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

        手機(jī)掃一掃分享

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

        手機(jī)掃一掃分享

        分享
        舉報(bào)
        1. <strong id="7actg"></strong>
        2. <table id="7actg"></table>

        3. <address id="7actg"></address>
          <address id="7actg"></address>
          1. <object id="7actg"><tt id="7actg"></tt></object>
            艹艹网| 酒吧站着做爰视频 | 七三一女兵一级毛片 | 精品99国产国产精 | 久久国产亚洲精品 | 精品无码国产成人网站尤物app | 人妖精品人妖TS视频在线观看 | 开心五月天激情成人网 | 亚洲成人免费 | 黄色A片一级一级一级久别的草原 |