Как создать ActiveMQ HTTP слушатель, используя Java

Я использовал следующий код, чтобы прочитать сообщение activemq. Мне нужно реализовать activemq слушатель, используя REST.

Это сообщение читать демо-класс

public class ActiveMQConsumer {

    public static void main(String args[]) {
         String url = "http://localhost:8161/api/message?destination=queue://test.queue&readTimeout=10000&type=queue&clientId=test";

         RestClient client = new RestClient(userName, password);
         String activeMQResponse = client.get(url);
         System.out.println(activeMQResponse);
     }
}

Это пружинный класс подключения HTTP.

public class RestClient {

    private String server = "";
    private RestTemplate rest;
    private HttpHeaders headers;
    private HttpStatus status;

    public RestClient(String userName, String password) {
        this.rest = new RestTemplate();
        this.headers = createHeaders(userName, password);
    }

    public HttpHeaders createHeaders(String username, String password) {
        return new HttpHeaders() {
            {
                String auth = username + ":" + password;
                byte[] encodedAuth = Base64.encodeBase64(auth.getBytes(Charset.forName("US-ASCII")));
                String authHeader = "Basic " + new String(encodedAuth);
                set("Authorization", authHeader);
                set("Content-Type", "application/x-www-form-urlencoded; charset=UTF-8");
                set("Accept", "*/*");
            }
        };
    }

    public String get(String uri) {
        HttpEntity<String> requestEntity = new HttpEntity<String>("", headers);
        ResponseEntity<String> responseEntity = rest.exchange(server + uri, HttpMethod.GET, requestEntity, String.class);
        this.setStatus(responseEntity.getStatusCode());
        return responseEntity.getBody();
    }   

    public HttpStatus getStatus() {
        return status;
    }

    public void setStatus(HttpStatus status) {
        this.status = status;
    }
}

1 ответ

Прежде всего, я бы не использовал RestClient для связи с каким-либо брокером, поскольку это не просто http-связь. Это mqtt или же amqt протокол не http, Хорошо, я вижу, что активный mq предоставляет http api, но все же я предлагаю использовать другой подход.

Используйте компонент apache-camel activemq. Тогда вы просто создадите маршрут как:

from("activemq:queue:your_queue")
  .process(e -> {...}) // your processing of message goes here.

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

Если это требование, что вы должны потреблять сообщения от отдыха, то я бы, вероятно, использовал unirest.

Другие вопросы по тегам