JMS小问题

问题描述

大家好,我参照http://qjyong.javaeye.com/blog/215171这个文章,一步步的把代码粘贴到工作空间,之后,在publicUserreceiveMessage(){//参数为Destination的JNDI名字去掉前面的模式类型标识MapMessagemsg=(MapMessage)jmsTemplate.receive("registerUserTopic");Useruser=newUser();try{user.setId(msg.getInt("id"));user.setUsername(msg.getString("username"));user.setPassword(msg.getString("password"));user.setEmail(msg.getString("email"));}catch(JMSExceptione){e.printStackTrace();}returnuser;}

中,提示msg.getInt("id")空指针,在消息发送的时候,没有发生异常,publicvoidsendMessage(finalUseruser){//调用模板的send来发送消息jmsTemplate.send(newMessageCreator(){publicMessagecreateMessage(Sessionsession)throwsJMSException{//构造一个要发送的消息MapMessagemessage=session.createMapMessage();message.setInt("id",user.getId());message.setString("username",user.getUsername());message.setString("password",user.getPassword());message.setString("email",user.getEmail());System.out.println("sendsuccess!!");returnmessage;}});

。请各位帮帮忙,大概问题出在哪了。。

时间: 2025-01-26 15:30:25

JMS小问题的相关文章

JMS小问题20090722

问题描述 调式了个jmsDEMO小代码,控制台打印BoundConnectionManager'jboss.jca:service=ConnectionFactoryBinding,name=JmsXA'toJNDIname'java:JmsXA'请问这个JNDIname'java:JmsXA'是在哪文件下配置的,我没配置过..jboss服务器...

详细解析Tomcat下应用JMS开发技巧

技巧 JMS做为J2EE的高级部分一直蒙着一层神秘的面纱,作为JMS的定制者SUN只规定了JMS规范,象很多其他SUN产品一样被多家厂商提供了具体的实现.但是作为tomcat和RESIN(今年初宣布全部支持J2EE规范).这些面向低端但却被广泛应用的服务器本身并不对JMS提供支持.庆幸的是openjms和activeMQ两家开源软件提供了插件式的支持. 在应用了一些开发框架如spring的项目里如果要使用到JMS,虽然SPRING提供了部分对JMS的支持但经过我一段时间的应用发现,OO的封装在某

Tomcat下绑定JMS应用服务器的实例讲解

服务器 JMS做为J2EE的高级部分一直蒙着一层神秘的面纱,作为JMS的定制者SUN只规定了JMS规范,象很多其他SUN产品一样被多家厂商提供了具体的实现.但是作为tomcat和RESIN(今年初宣布全部支持J2EE规范).这些面向低端但却被广泛应用的服务器本身并不对JMS提供支持.庆幸的是openjms和activeMQ两家开源软件提供了插件式的支持. 在应用了一些开发框架如spring的项目里如果要使用到JMS,虽然SPRING提供了部分对JMS的支持但经过我一段时间的应用发现,OO的封装在

J2EE探索者:用JMS进行企业消息传递[Z]

j2ee 在本期的J2EE探索者( J2EE pathfinder)中,Java 开发者和咨询顾问Kyle Gabhart 解释了为什么消息服务对于企业的体系结构来说是至关重要的,您的解决方案必须克服什么类型的障碍,以及 除了Java消息服务(Java Message Service ,JMS)之外,还有哪些替代的解决方案.在本文的结尾,他分析了三种可用的解决方案(简单JMS客户机(Simple JMS Client).结合JMS使用的会话bean, 以及消息驱动bean),并且提供了一些特定的

JMS、XML和异构企业

如今,大多数计算环境更多地是由不同平台组成,而不是固守任何一个平台. Java 消息服务 (JMS) ,与可扩展标记语言 (XML) 一起,满足了这种异构环境集成的愿望.这篇文章演示了如何使用 JMS 来创建基于 XML 的消息并将这些消息同样分发到 Java 和非 Java 应用程序. 经过几年构建.扩展和维护庞大的分布式应用之后,程序员逐步体会到平台无关的行为和平台无关的数据的好处了. Java 编程语言已经向满足平台无关的行为(尽管例如 TCL 这样的脚本语言在一段或更长时间内还受到关注)

spring整合activeMq并调试JMS

本文是关于spring和activeMq一种简单的整合方式,只做参考学习只用,侧重于对概念的理解. 1:JMS是Sun公司开发的一套访问面向消息的中间件(MOM)的标准的API,本文采用的MOM组件是 activeMq.大家可以到http://activemq.apache.org/download.html网站下载activemq的程序包, 它使用非常简单,解压缩之后直接运行D:\activemq-4.1.1\bin目录下的activemq.bat文件,启动服务就 可以了. 而且我们只是简单的

使用Spring JMS轻松实现异步消息传递

异步进程通信是面向服务架构(SOA)一个重要的组成部分,因为企业里很多系统通信,特别是与外部组织间的通信,实质上都是异步的.Java消息服务(JMS)是用于编写使用异步消息传递的JEE应用程序的API.传统的使用JMS API进行消息传递的实现包括多个步骤,例如JNDI查询队列连接工厂和Queue资源,在实际发送和接收消息前创建一个JMS会话. Spring框架则简化了使用JEE组件(包括JMS)的任务.它提供的模板机制隐藏了典型的JMS实现的细节,这样开发人员可以集中精力放在处理消息的实际工作

如何获取消息?使用JMS技术作为数据复制的解决方案

背景 在思考消息传递解决方案时,您可能会想到一个通过远程消息调用机制来集成两个不同应用程序的系统.一般来讲,对于不常通信的分布式实体以及数据传输量不是很多这样的情况,常常使用这种耦合.较经典的示例是,连接到异构后端和入口的同构接口,这些后端和入口指派进行用户请求的后端处理,然后为最终用户表示而对那些请求进行重新格式化. 消息传递方法中的公共线程一直有这样的假定:虽然消息传递解决方案在系统之间提供健壮.高度可用的通信,但它基本上效率很低,只用来作为在无法避免与外部系统通信时的最后一种手段.在出现远

【转载】 JMS 概述

本文转载自http://shift-alt-ctrl.iteye.com/blog/1902820   一.JMS使用场景:    JMS是为"消息"而生,从使用的角度来说,任何可以与业务解耦的数据均可以作为"消息"存储;任何结构化(格式严格,适合解析)但未索引化(不能被随意检索)的数据均可以交付给JMS存储,但尽管JMS不是为存储而生.     1) 异构系统(应用)中,如果数据的交互无法通过DB共享/调用接口等方式实现时,可以考虑使用JMS作为数据的中转中心,并