SpringBoot實(shí)現(xiàn)登錄攔截器(實(shí)戰(zhàn)版)
文章目錄
3.1、訪問(wèn) localhost:8081/index 頁(yè)面:
3.2、正確輸入用戶(hù)名和密碼登錄
3.3、再次訪問(wèn) localhost:8081/index
1.1、實(shí)現(xiàn)?
HandlerInterceptor?接口1.2、實(shí)現(xiàn)?
WebMvcConfigurer?接口,注冊(cè)攔截器1.3、保持登錄狀態(tài)
1、SpringBoot 實(shí)現(xiàn)登錄攔截的原理
2、代碼實(shí)現(xiàn)及示例
3、效果驗(yàn)證
對(duì)于管理系統(tǒng)或其他需要用戶(hù)登錄的系統(tǒng),登錄驗(yàn)證都是必不可少的環(huán)節(jié),在 SpringBoot 開(kāi)發(fā)的項(xiàng)目中,通過(guò)實(shí)現(xiàn)攔截器來(lái)實(shí)現(xiàn)用戶(hù)登錄攔截并驗(yàn)證。
1、SpringBoot 實(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、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)一攔截(查詢(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、正確輸入用戶(hù)名和密碼登錄

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

沒(méi)有再次被登錄攔截器攔截,證明可以保持登錄.
作者:Kant101
https://blog.csdn.net/qq_27198345/article/details/111401610
(完)
?關(guān)注公眾號(hào):Java后端編程,回復(fù)下面關(guān)鍵字?
要Java學(xué)習(xí)完整路線,回復(fù)??路線?
缺Java入門(mén)視頻,回復(fù):?視頻?
要Java面試經(jīng)驗(yàn),回復(fù)??面試?
缺Java項(xiàng)目,回復(fù):?項(xiàng)目?
進(jìn)Java粉絲群:?加群?
PS:如果覺(jué)得我的分享不錯(cuò),歡迎大家隨手點(diǎn)贊、在看。
(完) 加我"微信"?獲取一份 最新Java面試題資料 請(qǐng)備注:666,不然不通過(guò)~
最近好文
1、Mybatis 開(kāi)發(fā)神器:Fast MyBatis 超好用
3、突發(fā)!Spring Cloud 爆高危漏洞。。趕緊修復(fù)!!
最近面試BAT,整理一份面試資料《Java面試BAT通關(guān)手冊(cè)》,覆蓋了Java核心技術(shù)、JVM、Java并發(fā)、SSM、微服務(wù)、數(shù)據(jù)庫(kù)、數(shù)據(jù)結(jié)構(gòu)等等。 獲取方式:關(guān)注公眾號(hào)并回復(fù)?java?領(lǐng)取,更多內(nèi)容陸續(xù)奉上。 明天見(jiàn)(??ω??)??
