Java Restful API的攔截詳解
一、Restful API的攔截三種方式
- 過濾器(Filter)
- 攔截器(Interceptor)
- 切片(Aspect)
二、過濾器(Filter)的演示示例(springboot項(xiàng)目)
1、自定義一個(gè)名稱為TimeFilter的過濾器,代碼如下:
package com.xz.springsecuritydemo.filter; import org.springframework.stereotype.Component; import javax.servlet.*; import java.io.IOException; import java.util.Date; @Component//添加該注解使過濾器啟作用,如果不使用@Component注解需要寫配置類,例lz寫的WebConfig進(jìn)行注冊 public class TimeFilter implements Filter { //在控制器方法(即controller類中的方法)調(diào)用之前調(diào)用 @Override public void init(FilterConfig filterConfig) throws ServletException { System.out.println("Time Filter init"); } //在控制器方法(即controller類中的方法)調(diào)用之后調(diào)用 @Override public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException { System.out.println("Time Filter start"); long startTime = new Date().getTime(); chain.doFilter(request,response); long endTime = new Date().getTime(); System.out.println("Filter耗時(shí):"+(endTime-startTime)); System.out.println("Time Filter end"); } //在控制器方法(即controller類中的方法)調(diào)用之后調(diào)用 @Override public void destroy() { System.out.println("Time Filter destroy"); } }
2、自定義一個(gè)WebFilterConfig配置類,步驟1中如果不使用@Component注解,需要使用基于java的配置方式實(shí)現(xiàn),代碼如下:
package com.xz.springsecuritydemo.filter; import org.springframework.boot.web.servlet.FilterRegistrationBean; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; import java.util.ArrayList; @Configuration public class WebFilterConfig { @Bean public FilterRegistrationBean timeFilter(){ FilterRegistrationBean filterRegistrationBean=new FilterRegistrationBean(); filterRegistrationBean.setFilter(new TimeFilter()); ArrayList<String> list = new ArrayList<>(); list.add("/*");//過濾所有路徑 filterRegistrationBean.setUrlPatterns(list); return filterRegistrationBean; } }
3、自定義一個(gè)控制類,代碼如下
@RestController//表示此Controller提供RestAPI public class SysQueryController { /** * @RequestMapping 映射http請求url到j(luò)ava方法 * @RequestParam 映射請求參數(shù)到j(luò)ava方法的參數(shù) */ @RequestMapping(value = "/user1",method = RequestMethod.GET) public void query1(@RequestParam String username){ System.out.println("query1====="+username); } }
4、測試步驟
- 啟動(dòng)項(xiàng)目時(shí)會(huì)先輸出自定義過濾器類TimeFilter的init方式的信息,如下圖:
- 再用postman測試工具發(fā)送請求,如下圖:
- 最后查看控制態(tài)輸出信息,如下圖:
//輸出內(nèi)容 Time Filter start query1=====xz Filter耗時(shí):128 Time Filter end
5、輸出第4步的內(nèi)容表示自定義的Filter過濾器成功。
三、Filter過濾器特點(diǎn)
由上面的示例可知:Filter過濾器可以獲取到原始的http請求和響應(yīng)的信息,但是獲取不到真正處理請求的方法信息。
四、Filter過濾器、Interceptor攔截器 、Aspect切面起作用的順序
- 先是Filter過濾器起作用
- 然后Interceptor攔截器起作用
- 然后Aspect切面起作用
- 最后進(jìn)入Controller方法中
五、當(dāng)控制層(即Controller層)的方法拋異常時(shí),F(xiàn)ilter過濾器、Interceptor攔截器 、Aspect切面 拋異常的順序
- 先是Aspect切面
- 如果使用@ControllerAdvice自定義異常,再進(jìn)入這個(gè)處理異常類
- 然后Interceptor攔截器
- 然后Filter過濾器
- 如果都沒處理,最后到tomcat
總結(jié)
本篇文章就到這里了,希望能夠給你帶來幫助,也希望您能夠多多關(guān)注腳本之家的更多內(nèi)容!
相關(guān)文章
Java泛型模擬scala實(shí)現(xiàn)自定義ArrayList方式
這篇文章主要介紹了Java泛型模擬scala實(shí)現(xiàn)自定義ArrayList方式,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-10-10Java滾動(dòng)數(shù)組計(jì)算編輯距離操作示例
這篇文章主要介紹了Java滾動(dòng)數(shù)組計(jì)算編輯距離操作,涉及java字符串與數(shù)組的遍歷、計(jì)算、轉(zhuǎn)換等相關(guān)操作技巧,需要的朋友可以參考下2019-12-12Spring Boot Actuator監(jiān)控端點(diǎn)小結(jié)
這篇文章主要介紹了Spring Boot Actuator監(jiān)控端點(diǎn)小結(jié),需要的朋友可以參考下2017-06-06SpringBoot實(shí)現(xiàn)redis緩存菜單列表
本文主要介紹了SpringBoot實(shí)現(xiàn)redis緩存菜單列表,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-01-01java實(shí)現(xiàn)把對象數(shù)組通過excel方式導(dǎo)出的功能
本文主要介紹了java實(shí)現(xiàn)把對象數(shù)組通過excel方式導(dǎo)出的功能的相關(guān)知識(shí)。具有很好的參考價(jià)值,下面跟著小編一起來看下吧2017-03-03Java自學(xué)書籍推薦 程序員到架構(gòu)師必看的書
這篇文章主要為大家推薦了Java程序員到架構(gòu)師自學(xué)書籍,幫助大家不斷提高自己的專業(yè)水平,感興趣的小伙伴們可以參考一下2016-09-09在IDEA中安裝MyBatis Log Plugin插件,執(zhí)行mybatis的sql語句(推薦)
這篇文章主要介紹了在IDEA中安裝MyBatis Log Plugin插件,執(zhí)行mybatis的sql語句,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-07-07