背景:寫一個用戶登錄攔截,在網上找了一圈沒找到好用的,于是自己試驗了一下,總結出來,分享給大家。
1.自定義登錄攔截器LoginInterceptor
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
|
public class LoginInterceptor implements HandlerInterceptor { @Override public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception { // 這里是關鍵 User loginUser = (User) request.getSession().getAttribute( "user" ); if (loginUser == null ) { // 未登錄拋出異常,交給統一異常處理器處理 throw new CustomException(ResultCode.USER_NOT_LOGIN); } return true ; } @Override public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception { } @Override public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception { } } |
2.在WebConfigurer中添加攔截器
1
2
3
4
5
6
7
8
9
10
11
12
|
@Configuration public class WebMvcConfig implements WebMvcConfigurer { @Override public void addInterceptors(InterceptorRegistry registry) { //注冊TestInterceptor攔截器 registry.addInterceptor( new LoginInterceptor()) .addPathPatterns( "/**" ) // 排除登錄注冊等接口,注意這里的格式是 /**/xxx .excludePathPatterns( "/**/login" , "/**/register" ); } } |
3.登錄接口
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
|
/** * 登錄 * @return 用戶信息 */ public User login(UserVO userVO. HttpServlet) { String username = userVO.getUsername(); String password = userVO.getPassword(); User user = userMapper.findByUsernameAndPassword(username, password); // 未找到用戶 if (user == null ) { throw new CustomException(ResultCode.USER_ACCOUNT_ERROR); } // 設置session中的用戶信息 SessionUtils.setSessionAttribute( "user" , user); return user; } |
文中的代碼細節不一一列舉了,這里重點討論的攔截器,感興趣的朋友可以私聊我獲取其他代碼。
結果
未登錄的情況下,請求普通接口提示未登錄。
請求登錄接口。
登錄后再去請求普通接口,返回正常。
到此這篇關于SpringBoot登錄攔截配置詳解(實測可用)的文章就介紹到這了,更多相關SpringBoot登錄攔截內容請搜索服務器之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持服務器之家!
原文鏈接:https://blog.csdn.net/xqnode/article/details/107468535