Aspectj 通过外部库运行
Aspectj functions through external library
我有一个外部库,它不是 spring 应用程序。它定义了几个 Aspectj functions/PointCuts 但是当我在 spring 启动应用程序中使用这个库时它没有被调用。当我在 spring 引导应用程序本身中定义切入点时,它工作正常。我想我的配置有问题,比如 @EnableAspectJAutoProxy 不工作或其他什么。
服务代码-:
@EnableAspectJAutoProxy
@Service
public class LtRequest {
RestTemplate restTemplate;
public LtRequest() {
restTemplate = new RestTemplate();
restTemplate.setErrorHandler( new LtResponseErrorHandler());
}
public Object request(String url, LtRequestType type, Class clz){
return null;
}
public RestResponseDTO getObject(String url,Class clz){
RestResponseDTO restResponseDTO =restTemplate.getForObject(url,RestResponseDTO.class);
//LtUtil.parseRequest(restResponseDTO);
return restResponseDTO;
}
private void postObject(String url,Object obj){
RestResponseDTO restResponseDTO =restTemplate.postForObject(url,obj,RestResponseDTO.class);
}
}
aspectj切入点代码
@Aspect
@Component
public class ParseRequestAspect {
static final Logger logger = LogManager.getLogger(ParseRequestAspect.class);
@Around("execution(* com.limetray.helper.utils.LtRequest.getObject(..))")
public Object parseRequestAfterReturn(ProceedingJoinPoint joinPoint) {
logger.info("calling after return aspect function..");
try{
RestResponseDTO response = (RestResponseDTO) joinPoint.proceed();
LtUtil.parseRequest(response);
return response.getResult();
}
catch (Throwable e){
throw new LtException("Exception occured while parsing request response..");
}
}
@After("execution(* com.limetray.helper.utils.LtRequest.getObject(..))")
public void parseRequestAfterReturn(JoinPoint joinPoint) {
logger.info("calling after return aspect function..new");
try{
/*RestResponseDTO response = (RestResponseDTO) joinPoint.proceed();
LtUtil.parseRequest(response);
return response.getResult();*/
}
catch (Throwable e){
throw new LtException("Exception occured while parsing request response..");
}
}
}
这两个 类 都在我的外部库中,但它没有按预期工作。请帮忙
如果您想在 Spring 应用程序中使用本机 AspectJ 方面而不是基于代理的 Spring AOP,您需要配置您的应用程序以使用 LTW(加载时织入)通过@EnableLoadTimeWeaving
或 <context:load-time-weaver/>
。有关详细信息,请参阅 Spring manual。
我有一个外部库,它不是 spring 应用程序。它定义了几个 Aspectj functions/PointCuts 但是当我在 spring 启动应用程序中使用这个库时它没有被调用。当我在 spring 引导应用程序本身中定义切入点时,它工作正常。我想我的配置有问题,比如 @EnableAspectJAutoProxy 不工作或其他什么。
服务代码-:
@EnableAspectJAutoProxy
@Service
public class LtRequest {
RestTemplate restTemplate;
public LtRequest() {
restTemplate = new RestTemplate();
restTemplate.setErrorHandler( new LtResponseErrorHandler());
}
public Object request(String url, LtRequestType type, Class clz){
return null;
}
public RestResponseDTO getObject(String url,Class clz){
RestResponseDTO restResponseDTO =restTemplate.getForObject(url,RestResponseDTO.class);
//LtUtil.parseRequest(restResponseDTO);
return restResponseDTO;
}
private void postObject(String url,Object obj){
RestResponseDTO restResponseDTO =restTemplate.postForObject(url,obj,RestResponseDTO.class);
}
}
aspectj切入点代码
@Aspect
@Component
public class ParseRequestAspect {
static final Logger logger = LogManager.getLogger(ParseRequestAspect.class);
@Around("execution(* com.limetray.helper.utils.LtRequest.getObject(..))")
public Object parseRequestAfterReturn(ProceedingJoinPoint joinPoint) {
logger.info("calling after return aspect function..");
try{
RestResponseDTO response = (RestResponseDTO) joinPoint.proceed();
LtUtil.parseRequest(response);
return response.getResult();
}
catch (Throwable e){
throw new LtException("Exception occured while parsing request response..");
}
}
@After("execution(* com.limetray.helper.utils.LtRequest.getObject(..))")
public void parseRequestAfterReturn(JoinPoint joinPoint) {
logger.info("calling after return aspect function..new");
try{
/*RestResponseDTO response = (RestResponseDTO) joinPoint.proceed();
LtUtil.parseRequest(response);
return response.getResult();*/
}
catch (Throwable e){
throw new LtException("Exception occured while parsing request response..");
}
}
}
这两个 类 都在我的外部库中,但它没有按预期工作。请帮忙
如果您想在 Spring 应用程序中使用本机 AspectJ 方面而不是基于代理的 Spring AOP,您需要配置您的应用程序以使用 LTW(加载时织入)通过@EnableLoadTimeWeaving
或 <context:load-time-weaver/>
。有关详细信息,请参阅 Spring manual。