国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術文章
文章詳情頁

詳解Spring 攔截器流程及多個攔截器的執行順序

瀏覽:34日期:2023-07-15 18:06:49

攔截器是 Spring MVC 中的組件,它可以在進入請求方法前做一些操作,也可以在請求方法后和渲染視圖后做一些事情。

攔截器的定義

SpringMVC 的攔截器只需要實現 HandlerInterceptor 接口,并進行配置即可。HandlerInterceptor 接口的定義如下:

public interface HandlerInterceptor { default boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {return true; } default void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, @Nullable ModelAndView modelAndView) throws Exception { } default void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, @Nullable Exception ex) throws Exception { }}

在 HandlerInterceptor 中共有三個方法,每個方法的含義如下:

preHandler:進入請求方法之前執行;

postHandler:請求方法執行完成之后執行;

afterCompletion:視圖渲染后執行。

攔截器的執行流程

在 preHandle 方法中,它的返回值是 boolean 類型的,它的返回值影響著請求方法,以及 postHandle 和 afterCompletion 的執行。具體如下。

詳解Spring 攔截器流程及多個攔截器的執行順序

也就是說,在 preHandle 中如果返回 false,那么后續的流程將不被執行,這可能也是攔截器命名的由來。

測試攔截器

寫一個簡單攔截器,代碼如下:

@Slf4jpublic class TestInterceptor implements HandlerInterceptor { @Override public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {log.info('preHandler');return true; } @Override public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {log.info('postHandler'); } @Override public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception {log.info('afterCompletion'); }}

創建了一個 TestInterceptor 的監聽器類,它實現了 HandlerInterceptor 的所有接口。寫完 TestInterceptor 還需要進行注冊。代碼如下:

@Configurationpublic class InterceptorConfig implements WebMvcConfigurer { @Override public void addInterceptors(InterceptorRegistry registry) {registry.addInterceptor(testInterceptor()); }

再來寫一個簡單的請求方法,代碼如下:

@GetMapping('test')public String test(){ return 'test';}

來啟動我們的項目,并進行訪問,控制臺的輸出如下:

2021-05-05 16:02:08.110 INFO 88509 --- [nio-8081-exec-6] com.example.demo.TestInterceptor : preHandler2021-05-05 16:02:08.111 INFO 88509 --- [nio-8081-exec-6] com.example.demo.TestInterceptor : postHandler2021-05-05 16:02:08.111 INFO 88509 --- [nio-8081-exec-6] com.example.demo.TestInterceptor : afterCompletion多個攔截器的執行順序

我們來寫多個相同的監聽器,分別是 TestInterceptor、TestInterceptor2 和 TestInterceptor3。然后我們進行注冊,注冊代碼如下:

@Overridepublic void addInterceptors(InterceptorRegistry registry) { registry.addInterceptor(testInterceptor()); registry.addInterceptor(testInterceptor2()); registry.addInterceptor(testInterceptor3());}

請求我們的方法,輸出如下:

2021-05-05 16:09:57.735 INFO 88572 --- [nio-8081-exec-1] com.example.demo.TestInterceptor : preHandler2021-05-05 16:09:57.736 INFO 88572 --- [nio-8081-exec-1] com.example.demo.TestInterceptor2: preHandler22021-05-05 16:09:57.736 INFO 88572 --- [nio-8081-exec-1] com.example.demo.TestInterceptor3: preHandler32021-05-05 16:09:57.755 INFO 88572 --- [nio-8081-exec-1] com.example.demo.TestInterceptor3: postHandler32021-05-05 16:09:57.755 INFO 88572 --- [nio-8081-exec-1] com.example.demo.TestInterceptor2: postHandler22021-05-05 16:09:57.755 INFO 88572 --- [nio-8081-exec-1] com.example.demo.TestInterceptor : postHandler2021-05-05 16:09:57.755 INFO 88572 --- [nio-8081-exec-1] com.example.demo.TestInterceptor3: afterCompletion32021-05-05 16:09:57.755 INFO 88572 --- [nio-8081-exec-1] com.example.demo.TestInterceptor2: afterCompletion22021-05-05 16:09:57.755 INFO 88572 --- [nio-8081-exec-1] com.example.demo.TestInterceptor : afterCompletion

注意觀察輸出的順序,preHandle 方法是按注冊順序進行執行的,而 postHandle 和 afterCompletion 跟注冊順序是相反的。

讓 preHandle 進行攔截

我們讓 TestInterceptor2 的 preHandle 返回值為 false,然后查看一下輸出內容。

2021-05-05 16:14:00.997 INFO 88582 --- [nio-8081-exec-1] com.example.demo.TestInterceptor : preHandler2021-05-05 16:14:00.998 INFO 88582 --- [nio-8081-exec-1] com.example.demo.TestInterceptor2: preHandler22021-05-05 16:14:00.998 INFO 88582 --- [nio-8081-exec-1] com.example.demo.TestInterceptor : afterCompletion

可以看到,TestInterceptor2 的 preHandle 的返回值為 false 以后,相當于在 TestInterceptor2 的 preHandle 后續流程則不再繼續執行了。

我們調整一下注冊的順序,代碼如下:

@Overridepublic void addInterceptors(InterceptorRegistry registry) { registry.addInterceptor(testInterceptor2()); registry.addInterceptor(testInterceptor()); registry.addInterceptor(testInterceptor3());}

修改順序后的輸出如下:

2021-05-05 16:17:23.956 INFO 88589 --- [nio-8081-exec-1] com.example.demo.TestInterceptor2: preHandler2

可以看到它后面的流程都被攔截了,沒有機會執行了。

總結

攔截器是使用一個 List 進行保存,我們可以在項目中添加多個攔截器來完成不同的功能,比如可以進行 Token 的驗證,權限的獲取等。我們可以放到不同的攔截器中來進行相關的操作。

以上就是詳解Spring 攔截器流程及多個攔截器的執行順序的詳細內容,更多關于Spring 攔截器的資料請關注好吧啦網其它相關文章!

標簽: Spring
相關文章:
主站蜘蛛池模板: 国产一级特黄全黄毛片 | 欧美videos性视频 | 日韩精品首页 | 一级黄片毛片 | 国产成人精品三区 | 欧美日韩视频一区二区在线观看 | 国产日韩一区二区三区在线观看 | 欧美高清一区二区三区欧美 | 亚洲欧美一区二区三区在线观看 | 一区二区三区在线免费视频 | 国内黄色一级精品 | 欧美一级做一a做片性视频 欧美一级做一级爱a做片性 | 免费观看毛片视频 | 三级a黄| 国产精品色午夜视频免费看 | 免费观看性欧美一级 | 中文字幕在线视频观看 | 性做久久久久免费看 | 日本天堂免费 | 国产一区二区三区在线免费观看 | 二级黄的全免费视频 | 欧美激情中文字幕 | 亚洲成人高清在线 | 免费欧美一级 | 成人欧美视频在线观看播放 | 欧美日韩一区二区三区视频播 | 亚洲欧美另类日本久久影院 | 日韩久草 | 中文字幕精品一区二区精品 | 亚洲精品中文字幕字幕 | 手机看片日韩日韩 | 国产大乳喷奶水在线看 | 日韩三级小视频 | 中文字幕福利片 | 日本一道免费一区二区三区 | 成人毛片免费观看视频 | 成人午夜免费观看 | 大焦伊人 | 欧美精品在线免费观看 | 69性欧美高清影院 | 国产精品99久久久久久www |