您好,登錄后才能下訂單哦!
這篇文章主要介紹“在springboot中怎么使用攔截器”,在日常操作中,相信很多人在在springboot中怎么使用攔截器問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”在springboot中怎么使用攔截器”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!
攔截器Interceptor,是SpringMVC中的核心內容,利用spring的AOP(Aspect Oriented Programming, 面向切面編程)特性,可以很方便的對用戶的業務代碼進行橫向抽取,根據具體業務需求對應用功能進行增強。
在SpringBoot中使用Interceptor,同時采用全注解開發,涉及到以下接口和類:
HandlerInterceptor:處理器攔截器,handler就是處理器,在springboot web開發中,由控制器來處理web請求,因此handler具體指控制器
使用全注解開發,通過@Configuration注解,讓一個java對象主任到IOC容器,并作為配置對象,這里的JavaConfig類相當于一個xml配置文件;
在以前的xml配置中
(1)通過引入一些標簽進行配置,在JavaConfig中,通過繼承一個類或者實現一個接口來實現配置,這里所繼承的類、所實現的接口就相當于引入的標簽;
(3)通過設置所引入標簽的屬性和值,可以實現個性化配置,在JavaConfig中通過覆蓋類或者接口的方法來實現個性化配置。
下面通過一個案例來實現自定義攔截器
攔截/user/開頭的請求,不攔截/usr/login請求
package cn.eis220.web; import org.springframework.web.servlet.HandlerInterceptor; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; public class LoginInterceptor implements HandlerInterceptor { @Override public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception { System.out.println("執行了logininterceptor的preHandle方法"); return true; } }
java配置類相當于xml配置文件
xml中通過引入interceptor標簽來進行配置,java配置類通過實現WebMvcController進行配置;
xml中通過修改標簽的屬性和值來個性化配置,java配置類通過實現WebMvcController的方法進行個性化配置
package cn.eis220.config; import cn.eis220.web.LoginInterceptor; import org.springframework.context.annotation.Configuration; import org.springframework.web.servlet.config.annotation.InterceptorRegistry; import org.springframework.web.servlet.config.annotation.WebMvcConfigurer; @Configuration public class MyAppCofnig implements WebMvcConfigurer { @Override public void addInterceptors(InterceptorRegistry registry) { LoginInterceptor loginInterceptor = new LoginInterceptor(); String[] path = {"/user/**"}; String[] excludePath = {"/user/login"}; registry.addInterceptor(loginInterceptor).addPathPatterns(path).excludePathPatterns(excludePath); } }
package cn.eis220.controller; import org.springframework.stereotype.Controller; import org.springframework.web.bind.annotation.RequestBody; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.ResponseBody; @Controller public class BootController { @RequestMapping("/user/account") @ResponseBody public String userAccount(){ return "/user/account"; } @RequestMapping("/user/login") @ResponseBody public String userLogin(){ return "/user/login"; } }
到此,關于“在springboot中怎么使用攔截器”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續學習更多相關知識,請繼續關注億速云網站,小編會繼續努力為大家帶來更多實用的文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。