import com.rabbitmq.client.*; import java.io.IOException; /** * 利用信道 Channel 的 basicPublish() 简单发送消息 * @author Administrator * @date 2022年2月17日13:59:29 */ public class PushMessage1 { private static final String EXCHANGE_NAME = "exchange_" + PushMessage1.class.getSimpleName(); /** * 发送消息 */ private void sender() { Connection connection = null; try { // 创建连接 ConnectionFactory factory = new ConnectionFactory(); factory.setHost("127.0.0.1"); factory.setPort(5672); connection = factory.newConnection(); // 创建通道 Channel channel = connection.createChannel(); channel.exchangeDeclare(EXCHANGE_NAME, "topic"); // 发送消息 System.out.println("[Send] Sending Message..."); byte[] msg = "hello wrold".getBytes(); channel.basicPublish(EXCHANGE_NAME, "www.hxstrive.com", null, msg); } catch(Exception e) { e.printStackTrace(); } finally { if ( connection != null ) { try { connection.close(); } catch (IOException e) { e.printStackTrace(); } } } } /** * 消费消息 */ private void consumer() { try { // 创建连接 ConnectionFactory factory = new ConnectionFactory(); factory.setHost("127.0.0.1"); factory.setPort(5672); Connection connection = factory.newConnection(); // 创建通道 Channel channel = connection.createChannel(); channel.exchangeDeclare(EXCHANGE_NAME, "topic"); // 绑定exchange与queue String queueName = channel.queueDeclare().getQueue(); channel.queueBind(queueName, EXCHANGE_NAME, "*.hxstrive.com"); System.out.println("[Receive] Waiting Message..."); // 消费消息 channel.basicConsume(queueName, true, new DefaultConsumer(channel){ @Override public void handleDelivery(String consumerTag, Envelope envelope, AMQP.BasicProperties properties, byte[] body) throws IOException { System.out.println("[Receive] Receive Message :: " + new String(body)); } }); } catch(Exception e) { e.printStackTrace(); } } public static void main(String[] args) { PushMessage1 demo = new PushMessage1(); demo.consumer(); demo.sender(); } }