如何解决SpringBoot 加入AOP后无法注入的问题

网友投稿 277 2023-01-03

如何解决SpringBoot 加入AOP后无法注入的问题

SpringBoot 开启AOP后 出现无法注入的问题 真是坑的很啊~

提示错误

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代理,默认为false

spring.aop.proxy-target-class=true

引以为戒啊!!!!!!!

springboot使用aop拦截controller干一些事导致service们@Autowired全部注入失败

springboot使用aop拦截controller干一些事导致controller里的service们@Autowired全部注入失败,报空指针

先集成使用aop吧

org.springframework.boot

spring-boot-starter-aop

properties修改

#aop

spring.aop.proxy-thttp://arget-class=true

spring.aop.auto=true

proxy-target-class属性值决定是基于接口的还是基于类的代理被创建。如果proxy-target-class 属性值被设置为true,那么基于类的代理将起作用(这时需要cglib库)。

如果proxy-target-class属值被设置为false或者这个属性被省略,那么标准的JDK 基于接口的代理将起作用。

然后直接贴一个模型代码吧

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;

}

/**

* 请求参数拼装

* @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之后发现 service都注入失败

解决方案

这个aop只能适用于 protect 和public

之后把controller中的所有方法都改成public

一个小坑吧~

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:速腾快递物流查询单号(速腾快递单号查询快递查询官网)
下一篇:如何调用网站api接口(如何调用网站api接口)
相关文章

 发表评论

暂时没有评论,来抢沙发吧~