如何解決SpringBoot 加入AOP后無法注入的問題
SpringBoot 開啟AOP后 出現(xiàn)無法注入的問題 真是坑的很啊~
提示錯(cuò)誤
org.springframework.beans.factory.NoSuchBeanDefinitionException: No unique bean of type
或者
java.lang.ClassCastException: com.sun.proxy.$Proxy12 cannot be cast to cn.edu.nuc.SpringTest.service.impl.DemoServiceImpl
解決方案
在application.properties中添加配置
#true為使用CGLIB代理,false為JDK代理,默認(rèn)為false spring.aop.proxy-target-class=true
引以為戒啊!!!!!!!
springboot使用aop攔截controller干一些事導(dǎo)致service們@Autowired全部注入失敗
springboot使用aop攔截controller干一些事導(dǎo)致controller里的service們@Autowired全部注入失敗,報(bào)空指針
先集成使用aop吧
<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-aop</artifactId> </dependency>
properties修改
#aop spring.aop.proxy-target-class=true spring.aop.auto=true
proxy-target-class屬性值決定是基于接口的還是基于類的代理被創(chuàng)建。如果proxy-target-class 屬性值被設(shè)置為true,那么基于類的代理將起作用(這時(shí)需要cglib庫)。
如果proxy-target-class屬值被設(shè)置為false或者這個(gè)屬性被省略,那么標(biāo)準(zhǔn)的JDK 基于接口的代理將起作用。
然后直接貼一個(gè)模型代碼吧
import cc.datebook.utils.IpUtil; import com.google.gson.Gson; import org.aspectj.lang.ProceedingJoinPoint; import org.aspectj.lang.annotation.*; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.context.annotation.Configuration; import org.springframework.web.context.request.RequestAttributes; import org.springframework.web.context.request.RequestContextHolder; import org.springframework.web.context.request.ServletRequestAttributes; import org.springframework.web.servlet.HandlerMapping; import javax.servlet.http.HttpServletRequest; import java.util.Map; /** * Created by wangH on 2017/12/12. */ @Aspect @Configuration public class ControllerMonitorAop { private static final Logger logger = LoggerFactory.getLogger(ControllerMonitorAop.class); ThreadLocal<Long> startTime = new ThreadLocal<>(); @Pointcut("execution(public * cc.datebook.web.*Controller.*(..))") public void excudeService() {} @Around("excudeService()") public Object doAround(ProceedingJoinPoint pjp) throws Throwable { RequestAttributes ra = RequestContextHolder.getRequestAttributes(); ServletRequestAttributes sra = (ServletRequestAttributes) ra; HttpServletRequest request = sra.getRequest(); String ipAddr = IpUtil.getIpAddr(request); String url = request.getRequestURL().toString(); String method = request.getMethod(); String uri = request.getRequestURI(); String queryString = request.getQueryString(); String params = ""; if ("POST".equals(method)) { Object[] paramsArray = pjp.getArgs(); params = argsArrayToString(paramsArray); } else { Map<?, ?> paramsMap = (Map<?, ?>) request.getAttribute(HandlerMapping.URI_TEMPLATE_VARIABLES_ATTRIBUTE); params = paramsMap.toString(); } logger.info("request begin=>ipAddr: {}, url: {}, method: {}, uri: {}, params: {}", ipAddr, url, method, uri, params); // result的值就是被攔截方法的返回值 Object result = pjp.proceed(); Gson gson = new Gson(); String ab = gson.toJson(result).toString(); if (ab.length() > 200){ ab = ab.substring(0,200); } logger.info("request end=>" + ab); return result; } /** * 請求參數(shù)拼裝 * @param paramsArray * @return */ private String argsArrayToString(Object[] paramsArray) { String params = ""; if (paramsArray != null && paramsArray.length > 0) { for (int i = 0; i < paramsArray.length; i++) { Gson gson = new Gson(); Object jsonObj = gson.toJson(paramsArray[i]); params += jsonObj.toString() + " "; } } return params.trim(); } }
但是攔截所有controller之后發(fā)現(xiàn) service都注入失敗
解決方案
這個(gè)aop只能適用于 protect 和public
之后把controller中的所有方法都改成public
一個(gè)小坑吧~
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
Java BeanMap實(shí)現(xiàn)Bean與Map的相互轉(zhuǎn)換
這篇文章主要介紹了利用BeanMap進(jìn)行對象與Map的相互轉(zhuǎn)換,通過net.sf.cglib.beans.BeanMap類中的方法來轉(zhuǎn)換,效率極高,本文給大家分享實(shí)現(xiàn)代碼,感興趣的朋友一起看看吧2022-11-11Springboot集成knife4j實(shí)現(xiàn)風(fēng)格化API文檔
這篇文章主要介紹了Springboot如何集成knife4j實(shí)現(xiàn)風(fēng)格化API文檔,幫助大家更好的使用springboot框架,感興趣的朋友可以了解下2020-12-12Java實(shí)現(xiàn)的日期處理類完整實(shí)例
這篇文章主要介紹了Java實(shí)現(xiàn)的日期處理類,結(jié)合完整實(shí)例形式分析了Java針對日期的獲取、運(yùn)算、轉(zhuǎn)換等相關(guān)操作技巧,需要的朋友可以參考下2017-09-09Kafka多節(jié)點(diǎn)分布式集群搭建實(shí)現(xiàn)過程詳解
這篇文章主要介紹了Kafka多節(jié)點(diǎn)分布式集群搭建實(shí)現(xiàn)過程詳解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-11-11