Нулевое поле Spring Autowired при наличии метода с аннотацией аспекта - PullRequest
0 голосов
/ 30 марта 2020

Я разрабатываю весеннее веб-приложение. У меня нет конфигурации 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-компонентов работает. Почему это происходит?

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...