Может быть не публично или недействительно? Использование Springsocket и Kafka Spring - PullRequest
0 голосов
/ 10 сентября 2018

Поскольку я пытаюсь использовать данные из темы (имя темы основано на пользователе), а во время выполнения я пытаюсь получить сообщение из темы, но получаю следующую ошибку.

вызвано: org.springframework.expression.spel.SpelEvaluationException: EL1008E: Свойство или поле customerProperties не может быть найдено для объекта тип 'org.springframework.beans.factory.config.BeanExpressionContext' - может быть не публично или недействительно?

Вот мой код

@Service
public class kafkaConsumerService {


    private SimpMessagingTemplate template;

     KafkaConsumerProperties consumerProperties;

     @Autowired
    public kafkaConsumerService(KafkaConsumerProperties consumerProperties, SimpMessagingTemplate template) {
         this.consumerProperties=consumerProperties;
         this.template=template;
    }

    @KafkaListener(topics = {"#{consumerProperties.getTopic()}"})
    // @KafkaListener(topics="Chandan3706")
    public void consume(@Payload Message message) {
        System.out.println("from kafka topic::" + message);
        template.convertAndSend("/chat/getMessage", message);
    }

}

Мой KafkaConsumerProperties.class

@Component
@ConfigurationProperties(prefix="kafka.consumer")
public class KafkaConsumerProperties {

    private String bootStrap;
    private String group;
    private String topic;

    public String getBootStrap() {
        return bootStrap;
    }

    public void setBootStrap(String bootStrap) {
        this.bootStrap = bootStrap;
    }

    public String getGroup() {
        return group;
    }

    public void setGroup(String group) {
        this.group = group;
    }

    public String getTopic() {
        return topic;
    }

    public void setTopic(String topic) {
        this.topic = topic;

    }

    @Override
    public String toString() {
        return "KafkaConsumerProperties [bootStrap=" + bootStrap + ", group=" + group + ", topic=" + topic + "]";
    }
}

Заранее спасибо

1 Ответ

0 голосов
/ 10 сентября 2018

Поскольку вы не предоставляете имя компонента для компонента KafkaConsumerProperties, по умолчанию используется имя с заглавной буквы . Это один.

Выражение, которое вы используете в @KafkaListener, является регулярным выражением фазы определения компонента , поэтому корневым объектом является какой-то BeanExpressionContext, но не ваш компонент-слушатель, когда вы пытаетесь получить доступ через свойство.

Не уверен, если вам нужно это свойство KafkaConsumerProperties в этом слушателе, но выражение должно запрашивать bean-компонент kafkaConsumerProperties:

@Service
public class kafkaConsumerService {


    private SimpMessagingTemplate template;

     @Autowired
    public kafkaConsumerService(SimpMessagingTemplate template) {
         this.template=template;
    }

    @KafkaListener(topics = {"#{kafkaConsumerProperties.topic}"})
    // @KafkaListener(topics="Chandan3706")
    public void consume(@Payload Message message) {
        System.out.println("from kafka topic::" + message);
        template.convertAndSend("/chat/getMessage", message);
    }

}
...