ActiveMQ 消息中间件
一.pom文件中导入依赖
<dependencies>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.12</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-core</artifactId>
<version>4.1.7.RELEASE</version>
</dependency>
<!-- spring整合jms -->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-jms</artifactId>
<version>4.1.7.RELEASE</version>
</dependency>
<!-- ActiveMQ的坐标 -->
<dependency>
<groupId>org.apache.activemq</groupId>
<artifactId>activemq-all</artifactId>
<version>5.2.0</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-test</artifactId>
<version>4.1.7.RELEASE</version>
</dependency>
<!-- 使用ActiveMQ的时候,也要导入这个坐标 -->
<dependency>
<groupId>org.apache.xbean</groupId>
<artifactId>xbean-spring</artifactId>
<version>4.2</version>
</dependency>
</dependencies>
二.配置applicationContext.xml
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:aop="http://www.springframework.org/schema/aop"
xmlns:context="http://www.springframework.org/schema/context"
xmlns:jdbc="http://www.springframework.org/schema/jdbc" xmlns:tx="http://www.springframework.org/schema/tx"
xmlns:jpa="http://www.springframework.org/schema/data/jpa" xmlns:task="http://www.springframework.org/schema/task"
xmlns:amq="http://activemq.apache.org/schema/core" xmlns:jms="http://www.springframework.org/schema/jms"
xsi:schemaLocation="
http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-4.1.xsd
http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-4.1.xsd
http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-4.1.xsd
http://www.springframework.org/schema/jdbc http://www.springframework.org/schema/jdbc/spring-jdbc-4.1.xsd
http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-4.1.xsd
http://www.springframework.org/schema/data/jpa
http://www.springframework.org/schema/data/jpa/spring-jpa.xsd
http://www.springframework.org/schema/jms
http://www.springframework.org/schema/jms/spring-jms.xsd
http://activemq.apache.org/schema/core
http://activemq.apache.org/schema/core/activemq-core-5.8.0.xsd ">
<!-- 指定Spring框架扫描的包 -->
<context:component-scan base-package="com.itheima.activemq" />
<!--
################################# 指定ActiveMQ 连接工厂 ########################################
真正可以产生Connection的ConnectionFactory,由对应的 JMS服务厂商提供
-->
<bean id="amqConnectionFactory" class="org.apache.activemq.ActiveMQConnectionFactory">
<constructor-arg index="0" value="admin"></constructor-arg>
<constructor-arg index="1" value="admin"></constructor-arg>
<constructor-arg index="2" value="tcp://localhost:61616"></constructor-arg>
</bean>
<!-- 上面和下面两种方式是同样的效果 -->
<amq:connectionFactory id="xx" userName="admin"
password="admin" brokerURL="tcp://localhost:61616"></amq:connectionFactory>
<!--
################################# 指定Spring Caching连接工厂 #################################
-->
<bean id="connectionFactory"
class="org.springframework.jms.connection.CachingConnectionFactory">
<!-- 目标ConnectionFactory对应真实的可以产生JMS Connection的ConnectionFactory -->
<property name="targetConnectionFactory" ref="xx"></property>
<!-- Session缓存数量 -->
<property name="sessionCacheSize" value="100" />
</bean>
<!--
################################# 指定消息的生产者 #################################
-->
<bean id="jmsQueueTemplate" class="org.springframework.jms.core.JmsTemplate">
<!-- 这个connectionFactory对应的是我们定义的Spring提供的那个ConnectionFactory对象 -->
<constructor-arg ref="connectionFactory" />
<!-- 定义JmsTemplate的Queue类型 -->
<!--true : 发布/订阅模式 -->
<!--false : 队列模式 -->
<property name="pubSubDomain" value="false" />
</bean>
<!--
################################# 指定消息的消费者 #################################
destination-type : 消息的类型,queue:队列模式,topic : 发布订阅模式
acknowledge: 应答机制
-->
<jms:listener-container destination-type="queue"
container-type="default" connection-factory="connectionFactory"
acknowledge="auto">
<!-- destination : 消息队列的名字 -->
<!-- ref : 消息的消费者 -->
<jms:listener destination="test.queue" ref="consumer" />
</jms:listener-container>
</beans>
三.开发生产者
3.1生产者一
@Component
public class Producer {
@Autowired
private JmsTemplate jmsTemplate;
public void sendMessage(String destinationName, final String message) {
// destinationName : 消息队列的名字,要把这个消息发送到那一个队列
jmsTemplate.send(destinationName, new MessageCreator() {
@Override
public Message createMessage(Session session) throws JMSException {
TextMessage textMessage = session.createTextMessage(message);
return textMessage;
}
});
}
}
3.2生产者二:
@Autowired
private JmsTemplate jmsTemplate;
方法体里面增加:
// 通過中間件來發送信息;
jmsTemplate.send("sms-message", new MessageCreator() {
// 参数1:消息队列的名称
// 参数2:创建消息的对象
@Override
public Message createMessage(Session session) throws JMSException {
MapMessage mapMessage = session.createMapMessage();
mapMessage.setString("telephone", model.getTelephone());
mapMessage.setString("msg", msg);
return mapMessage;
}
});
3.3生产者三
@Autowired
private JmsTemplate jmsTemplate;
方法体里面增加:
// 通過中間件來發送郵件
jmsTemplate.send("email-message", new MessageCreator() {
@Override
public Message createMessage(Session session) throws JMSException {
MapMessage mapMessage = session.createMapMessage();
mapMessage.setString("email", model.getEmail());
mapMessage.setString("theme", "激活邮件");
mapMessage.setString("msg", msg);
return mapMessage;
}
});
四.开发消费者
4.1消费者一:
@Component
public class Consumer implements MessageListener {
@Override
public void onMessage(Message message) {
try {
TextMessage textMessage = (TextMessage) message;
String text = textMessage.getText();
System.out.println(text);
} catch (JMSException e) {
e.printStackTrace();
}
}
}
4.2消费者二(邮件发送)
@Component
public class EmailConsumer implements MessageListener {
@Override
public void onMessage(Message message) {
MapMessage mapMessage=(MapMessage) message;
try {
String email = mapMessage.getString("email");
String theme = mapMessage.getString("theme");
String msg = mapMessage.getString("msg");
MailUtils.sendMail(email,theme, msg);
} catch (JMSException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
4.3消费者三(短信发送)
@Component
public class SmsConsumer implements MessageListener{
@Override
public void onMessage(Message message) {
MapMessage mapMessage = (MapMessage) message;
try {
String telephone = mapMessage.getString("telephone");
String msg = mapMessage.getString("msg");
System.out.println(telephone+"======"+msg);
SmsUtils.sendSmsByWebService(telephone, msg);
} catch (JMSException e) {
e.printStackTrace();
}
}
}