Java Restful API的攔截詳解
一、Restful API的攔截三種方式
- 過濾器(Filter)
- 攔截器(Interceptor)
- 切片(Aspect)
二、過濾器(Filter)的演示示例(springboot項目)
1、自定義一個名稱為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耗時:"+(endTime-startTime));
System.out.println("Time Filter end");
}
//在控制器方法(即controller類中的方法)調(diào)用之后調(diào)用
@Override
public void destroy() {
System.out.println("Time Filter destroy");
}
}
2、自定義一個WebFilterConfig配置類,步驟1中如果不使用@Component注解,需要使用基于java的配置方式實現(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、自定義一個控制類,代碼如下
@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、測試步驟
- 啟動項目時會先輸出自定義過濾器類TimeFilter的init方式的信息,如下圖:

- 再用postman測試工具發(fā)送請求,如下圖:

- 最后查看控制態(tài)輸出信息,如下圖:
//輸出內(nèi)容 Time Filter start query1=====xz Filter耗時:128 Time Filter end

5、輸出第4步的內(nèi)容表示自定義的Filter過濾器成功。
三、Filter過濾器特點
由上面的示例可知:Filter過濾器可以獲取到原始的http請求和響應(yīng)的信息,但是獲取不到真正處理請求的方法信息。
四、Filter過濾器、Interceptor攔截器 、Aspect切面起作用的順序
- 先是Filter過濾器起作用
- 然后Interceptor攔截器起作用
- 然后Aspect切面起作用
- 最后進(jìn)入Controller方法中
五、當(dāng)控制層(即Controller層)的方法拋異常時,F(xiàn)ilter過濾器、Interceptor攔截器 、Aspect切面 拋異常的順序
- 先是Aspect切面
- 如果使用@ControllerAdvice自定義異常,再進(jìn)入這個處理異常類
- 然后Interceptor攔截器
- 然后Filter過濾器
- 如果都沒處理,最后到tomcat
總結(jié)
本篇文章就到這里了,希望能夠給你帶來幫助,也希望您能夠多多關(guān)注腳本之家的更多內(nèi)容!
相關(guān)文章
Java泛型模擬scala實現(xiàn)自定義ArrayList方式
這篇文章主要介紹了Java泛型模擬scala實現(xiàn)自定義ArrayList方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-10-10
Spring Boot Actuator監(jiān)控端點小結(jié)
這篇文章主要介紹了Spring Boot Actuator監(jiān)控端點小結(jié),需要的朋友可以參考下2017-06-06
java實現(xiàn)把對象數(shù)組通過excel方式導(dǎo)出的功能
本文主要介紹了java實現(xiàn)把對象數(shù)組通過excel方式導(dǎo)出的功能的相關(guān)知識。具有很好的參考價值,下面跟著小編一起來看下吧2017-03-03
Java自學(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í)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-07-07

