Я разрабатываю весеннее веб-приложение. У меня нет конфигурации XML. Основной класс приложения весенней загрузки - annotatd с проверкой компонентов, которая включает все перечисленные здесь компоненты.
Имея этот класс контроллера:
@CrossOrigin
@RestController
@RequestMapping(value = "/documento/detail/tabs")
public class InfoController {
@Autowired
private DocDetailService detailService;
/**
* SEC 26-28: Pricing e posizioni
*/
@LogMethod
@GetMapping(value = "/pricing/{numOperazione}", produces = MediaType.APPLICATION_JSON_VALUE)
private ResponseEntity<DetailPricingDTO> getDettagliPricingEPosizioni(
@PathVariable(value = "numOperazione") final String numOperazione) throws DocumentNotFoundException {
return ResponseEntity.ok(detailService.getDettagliPricing(numOperazione));
}
И @LogMethod определяется следующим образом:
@Documented
@Retention(RUNTIME)
@Target({ METHOD })
public @interface LogMethod {
}
С аспектом, определенным следующим образом, для регистрации всех методов, помеченных этим request
@Aspect
@Component
@Scope("singleton")
public class LogEventAspect {
private final Logger log = LoggerFactory.getLogger(this.getClass());
@PostConstruct
public void postConstruct() {
log.info("# LogMethod annotation ASPECT is enabled #");
}
@Pointcut("@annotation(LogMethod)")
public void logEventAnnotationPointCut() {
// Method is empty as this is just a point-cut, the implementations are in the
// advises.
}
@AfterThrowing(pointcut = "logEventAnnotationPointCut()", throwing = "e")
public void logAfterThrowing(JoinPoint joinPoint, Throwable e) {
log.error("Exception in {}.{}() with cause = \'{}\' and exception = \'{}\'",
joinPoint.getSignature().getDeclaringTypeName(), joinPoint.getSignature().getName(),
e.getCause() != null ? e.getCause() : "NULL", e.getMessage(), e);
}
@Around("logEventAnnotationPointCut()")
public Object logAround(ProceedingJoinPoint joinPoint) throws Throwable {
// Log before execution
if (log.isDebugEnabled()) {
log.debug("Enter>>>: {}.{}() with argument[s] = {}", joinPoint.getSignature().getDeclaringTypeName(),
joinPoint.getSignature().getName(), Arrays.toString(joinPoint.getArgs()));
}
Object result = joinPoint.proceed();
// log after execution
if (log.isDebugEnabled()) {
log.debug("Exit<<<: {}.{}() with result = {}", joinPoint.getSignature().getDeclaringTypeName(),
joinPoint.getSignature().getName(), result);
}
return result;
}
}
DetailService в контроллере имеет значение NULL. Если я удалю @LogMethod, служба будет правильно инициализирована.
Кроме того, если я использую @LogMethod в классе @Service вместо @RestController, автопроводка других bean-компонентов работает. Почему это происходит?