1.创建factory
< amq:connectionFactory id="jmsFactory" brokerURL ="failover:(tcp://localhost:61616)" />
2.创建队列
<amq:queue name="user_registerInformation" physicalName "union.user.registerInformation.queue"></amq:queue >
3.创建发送方
<bean id ="userRegisterInformationMessageProducer" class="com.UserRegisterInformationMessageProducer" >
<property name="jmsTemplate" ref="jmsTemplate" ></property>
<property name="destination" ref="user_registerInformation" ></property>
</bean >
<bean id ="jmsTemplate" class="org.springframework.jms.core.JmsTemplate" >
<property name ="connectionFactory" >
<bean class="org.springframework.jms.connection.SingleConnectionFactory" >
<property name ="targetConnectionFactory" ref="jmsFactory" />
</bean>
</property>
<!-- 增加默认目的地 -->
<property name ="defaultDestination" ref="user_registerInformation" />
</bean>
4.创建接收方
<bean id ="jmsTransactionManager"
class="org.springframework.jms.connection.JmsTransactionManager" >
<property name ="connectionFactory" ref="jmsFactory" />
</bean>
<bean id="userRegisterInformationMessageConsumer" class ="com.UserRegisterInformationMessageConsumer" />
<!--注册 监听器 -->
<bean class="org.springframework.jms.listener.DefaultMessageListenerContainer" >
<property name ="connectionFactory" ref="jmsFactory" />
<!-- 消息队列来源 -->
<property name ="destination" ref="user_registerInformation" />
<!-- 监听类 -->
<property name ="messageListener" ref="userRegisterInformationMessageConsumer" />
<property name ="sessionTransacted" value="true" /> <!-- 本地事务 -->
<property name ="transactionManager" ref="jmsTransactionManager" /><!-- 数据库-->
<property name ="concurrentConsumers" value="1" ></property>
<property name ="maxConcurrentConsumers" value="10" ></property>
</bean>
5.实现类:
public class UserRegisterInformationMessageProducer {
private JmsTemplate jmsTemplate ;
private Destination destination ;
public void sendMessage() {
jmsTemplate.send(new MessageCreator() {
public Message createMessage(Session session) throws JMSException {
MapMessage mm = session. createMapMessage();
mm. setString("name", "张三");
mm. setString("accountActivationCode", "工");
mm. setString("email", "472218316@qq.com");
return mm;
}
});
}
public static void main(String[] args) {
ApplicationContext applicationContext = new ClassPathXmlApplicationContext(new String[]{"./applicationContext.xml" ,"./applicationContext-jms.xml" });
UserRegisterInformationMessageProducer userRegisterInformationMessageProducer = (UserRegisterInformationMessageProducer) applicationContext.getBean("userRegisterInformationMessageProducer" );
userRegisterInformationMessageProducer.sendMessage();
System. out.println("成功发送了一条JMS消息" );
}
public JmsTemplate getJmsTemplate() {
return jmsTemplate ;
}
public void setJmsTemplate(JmsTemplate jmsTemplate) {
this.jmsTemplate = jmsTemplate;
}
public Destination getDestination() {
return destination ;
}
public void setDestination(Destination destination) {
this.destination = destination;
}
}
public class UserRegisterInformationMessageConsumer implements MessageListener {
public void onMessage(Message message) {
// TODO Auto-generated method stub
MapMessage mm = (MapMessage) message;
try {
System. out.println("开始接收信息:" );
String username = mm.getString( "name");
String accountActivationCode = mm.getString("accountActivationCode" );
String email = mm.getString( "email");
System. out.println("name:" +username);
System. out.println("email:" +email);
try {
Thread.sleep(5*1000);
} catch (InterruptedException e) {
e.printStackTrace();
}
} catch (JMSException e) {
e.printStackTrace();
}
}
}
相关推荐
Classes contained in javax.jms.jar: javax.transaction.xa.XAResource.class javax.jms.BytesMessage.class javax.jms.Message.class javax.jms.JMSException.class javax.jms.Destination.class javax.jms....
**JMS583芯片详解** JMS583是一款由JMicron科技公司设计的高性能USB 3.1 Gen 2至PCIe Gen3x2桥接芯片,旨在为存储设备提供高速数据传输能力。这款芯片是针对现代数据密集型应用而优化的,如SSD固态硬盘和外部存储...
`javax.jms.jar` 文件中包含了如`javax.jms.Queue`, `javax.jms.Topic`, `javax.jms.MessageProducer`, `javax.jms.MessageConsumer`, `javax.jms.ConnectionFactory`等关键接口,以及其他辅助类和异常类,开发者...
Java消息服务(Java Message Service,简称JMS)是Java平台中用于企业级应用间异步通信的标准接口。它提供了一种可靠的消息传递机制,允许应用程序创建、发送、接收和读取消息。`jms-1.1.jar` 是一个包含了JMS 1.1...
Java消息服务(Java Message Service,简称JMS)是Java平台中用于企业级应用集成的API,它定义了一组标准接口,允许应用程序创建、发送、接收和读取消息。`javax.jms`包是JMS规范的核心部分,包含了各种与消息传递...
**JMS583 USB转PCIE桥接芯片方案** JMS583是一款由JMicron科技公司设计的高效能USB到PCI Express (PCIe)桥接芯片,旨在为电子设备提供一种灵活的方式来实现高速数据传输。这款芯片能够将USB接口转换成PCIe接口,以...
《JMS 1.1 API详解与应用实践》 Java消息服务(Java Message Service,简称JMS)是Java平台中用于企业级应用间异步通信的一种标准接口。JMS 1.1是其一个重要的版本,它为分布式系统中的应用程序提供了一种可靠的...
标题中的“USB转SATA硬盘盒JMS583量产工具”是指一种专门用于将USB接口转换为SATA接口的硬件设备,其中JMS583是该转换器的主控芯片。这种硬盘盒允许用户将传统的SATA硬盘通过USB接口连接到电脑上,方便数据迁移、...
【JMS583量产工具】是一款专门针对JMS583芯片进行批量生产操作的软件工具,主要用于USB闪存盘的制作与修复。这款工具的全称可能为"JMS583 Mass Production Tool",它允许用户一次性对多个JMS583芯片驱动的USB设备...
javax.jms.BytesMessage.class javax.jms.Connection.class javax.jms.ConnectionConsumer.class javax.jms.ConnectionFactory.class javax.jms.ConnectionMetaData.class javax.jms.DeliveryMode.class javax.jms....
Java消息服务(Java Message Service,简称JMS)是Java平台中用于企业级应用集成的API,主要用于在分布式环境中传递消息。JMS1.1规范是该API的一个版本,提供了标准接口,使得不同的消息中间件(Message Oriented ...
标题中的“USB3.0移动硬盘盒 JMS578 固件2018最新固件, G-Technology 移动硬盘盒固件 for JMS578”揭示了这个压缩包文件主要关注的是一个特定型号的USB3.0移动硬盘盒,该盒子采用JMS578主控芯片,并且提供了2018年...
`javax.jms-1.1.jar` 是一个Java Message Service(JMS)的API库,它属于Java标准版(Java Standard Edition, Java SE)的一部分。JMS是Java平台上的一个规范,用于在分布式环境中进行异步消息传递。这个库主要用于...
文件包含: 13个不同固件 两个固件升级工具 其中一个是量产工具可以修改休眠时间和盒子信息 TRIM检查工具 有几个固件版本为全网首发,别人没有的资源 固件列表: JMS578_00.01.00.05 ...JMS578_254.02.03.09_NoUAS
WebLogic Server是一款由Oracle公司提供的企业级应用服务器,它支持Java Message Service (JMS) 规范,允许在分布式环境中可靠地发送和接收消息。JMS是Java平台上的标准接口,用于实现应用程序间的异步通信。本文将...
Weblogic JMS 依赖jar包是Oracle公司的中间件产品Weblogic Server中用于实现Java Message Service (JMS) 功能的关键组件。JMS是一种标准API,它允许应用程序在分布式环境中发送和接收消息,提供了异步通信的能力。在...
JMS(JMS(JMS(JMS(JMS(JMS(JMS(JMS(JMS(JMS(JMS(JMS(JMS(JMS(JMS(JMS(JMS(JMS(JMS(JMS(JMS(JMS(JMS(JMS(JMS(JMS(JMS(JMS(JMS(JMS(JMS(JMS(JMS(JMS(JMS
标题“JMS577主控通刷固件”指的是针对希捷移动硬盘中采用JMS577主控芯片的固件更新解决方案。在IT领域,固件是存储在硬件设备上的软件部分,它控制设备的操作并提供与主机系统的交互。JMS577是一种常见的硬盘主控...