您好,登錄后才能下訂單哦!
這篇文章主要介紹了springboot攔截器如何解決無法注入redisTemplate,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。
先看下問題,新建一個攔截器,然后注入redisTemplate
/** * @author: lockie * @Date: 2019/8/13 16:16 * @Description: 接口限流攔截器 */ @Component public class AccessLimitIntercept implements HandlerInterceptor { private static final Logger logger = LoggerFactory.getLogger(AccessLimitIntercept.class); @Autowired private StringRedisTemplate redisTemplate; /** * 接口調用前檢查對方ip是否頻繁調用接口 * @param request * @param response * @param handler * @return * @throws Exception */ @Override public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception { try { String test = redisTemplate.opsForValue().get("test"); logger.info(test); } catch (Exception e) { logger.error("API請求限流攔截異常,異常原因:", e); throw new ParameterException(e); } 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 { } private boolean setResponse(Results results, HttpServletResponse response) throws IOException { ServletOutputStream outputStream = null; try { response.setHeader("Content-type", "application/json; charset=utf-8"); outputStream = response.getOutputStream(); outputStream.write(JsonUtil.toJson(results).getBytes("UTF-8")); } catch (Exception e) { logger.error("setResponse方法報錯", e); return false; } finally { if (outputStream != null) { outputStream.flush(); outputStream.close(); } } return true; } }
然后配置攔截器,新建一個攔截器config類,我們這里讓所有的url都攔截
@Configuration public class WebFilterConfig implements WebMvcConfigurer { /** * 多個攔截器組成一個攔截器鏈 * @param registry */ @Override public void addInterceptors(InterceptorRegistry registry) { registry.addInterceptor(new AccessLimitIntercept()).addPathPatterns("/**"); } }
新建一個controller里面增加一個接口,使用postman調用接口
@RestController @RequestMapping("/") public class PingController extends BaseController { @GetMapping(value = "/ping") public Results ping() { return succeed("pong", ""); } }
使用postman調用/ping接口,發現返回系統錯誤
控制臺發現是空指針的錯誤,定位錯誤發現當我們想獲取redis里面key是test的值時,發現redisTemplate沒有是空的沒有注入進來
知道攔截器執行在bean實例化前執行的,那么我們就讓攔截器執行的時候實例化攔截器Bean,在攔截器配置類里面先實例化攔截器,然后再獲取
@Configuration public class WebFilterConfig implements WebMvcConfigurer { /** * 這里需要先將限流攔截器入住,不然無法獲取到攔截器中的redistemplate * @return */ @Bean public AccessLimitIntercept getAccessLimitIntercept() { return new AccessLimitIntercept(); } /** * 多個攔截器組成一個攔截器鏈 * @param registry */ @Override public void addInterceptors(InterceptorRegistry registry) { registry.addInterceptor(getAccessLimitIntercept()).addPathPatterns("/**"); } }
使用postman再次請求就可以訪問到
感謝你能夠認真閱讀完這篇文章,希望小編分享的“springboot攔截器如何解決無法注入redisTemplate”這篇文章對大家有幫助,同時也希望大家多多支持億速云,關注億速云行業資訊頻道,更多相關知識等著你來學習!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。