关于ActiveMQ ObjectMessage不能被序列化的解决办法
错误截图:
解决办法:
将ConnectionFactory改为ActiveMQConnectionFactory,并且设置信任所有包
ActiveMQConnectionFactory connectionFactory = new ActiveMQConnectionFactory("admin", "admin", "tcp://192.168.139.141:61616");
connectionFactory.setTrustAllPackages(true);
参考代码:
生产者:
package com.producter;
import javax.jms.Connection;
import javax.jms.ConnectionFactory;
import javax.jms.Destination;
import javax.jms.JMSException;
import javax.jms.Message;
import javax.jms.MessageProducer;
import javax.jms.Session;
import org.apache.activemq.ActiveMQConnectionFactory;
import com.bjsxt.pojo.User;
public class UserProducer {
/**
* 生产消息
*
* @param msgTest
*/
public void sendHelloWorldActivityMQ(User u) {
// 定义链接工厂
ActiveMQConnectionFactory connectionFactory = null;
// 定义链接对象
Connection connection = null;
// 定义会话
Session session = null;
// 定义目的地
Destination destination = null;
// 定义消息的发送者
MessageProducer messageProducer = null;
// 定义消息
Message message = null;
try {
/**
* userName:访问ActiveMQ服务的用户名。用户密码。默认的为admin。用户名可以通过
* jetty-ream.properties文件进行修改
* password:访问ActiveMQ服务的用户名。用户密码。默认的为admin。用户名可以通过
* jetty-ream.properties文件进行修改 brokerURL:访问ActiveMQ服务的路径地址。
* 路径结构为:协议名://主机地址:端口号
*/
connectionFactory = new ActiveMQConnectionFactory("admin", "admin", "tcp://192.168.139.141:61616");
//创建connection
connection=connectionFactory.createConnection();
//启动连接
connection.start();
/**
* transacted:是否使用事务 可选值为:
true|false
* true:使用事务 当设置次变量
值。Session.SESSION_TRANSACTED
* false:不适用事务,设置次变量则acknowledgeMode参数必须设置
* acknowledgeMode:
* Session.AUTO_ACKNOWLEDGE:自动消息确认机制
* Session.CLIENT_ACKNOWLEDGE:客户端确认
机制
* Session.DUPS_OK_ACKNOWLEDGE:有副本的客
户端确认消息机制
*/
//创建session
session=connection.createSession(false, Session.AUTO_ACKNOWLEDGE);
//创建队列(目的地)
destination=session.createQueue("my-user");
//创建消息生产者
messageProducer =session.createProducer(destination);
//创建消息对象
message=session.createObjectMessage(u);
//发送消息
messageProducer.send(message);
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}finally{
if (messageProducer!=null) {
try {
messageProducer.close();
} catch (JMSException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
if (session!=null) {
try {
session.close();
} catch (JMSException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
if (connection!=null) {
try {
connection.close();
} catch (JMSException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
}
}
生产者测试代码:
package com.test;
import com.pojo.User;
import com.producter.UserProducer;
public class DemoTest {
public static void main(String[] args) {
//对象类型进行传递
User u=new User(12,"zhangsan",89);
UserProducer up=new UserProducer();
up.sendHelloWorldActivityMQ(u);
}
}
消费者:
package com.consumer;
import javax.jms.Connection;
import javax.jms.ConnectionFactory;
import javax.jms.Destination;
import javax.jms.JMSException;
import javax.jms.Message;
import javax.jms.MessageConsumer;
import javax.jms.ObjectMessage;
import javax.jms.Session;
import org.apache.activemq.ActiveMQConnectionFactory;
import com.bjsxt.pojo.User;
public class UserConsumer {
public void receiveHelloWorldActivityMQ() {
// 定义链接工厂
ActiveMQConnectionFactory connectionFactory = null;
// 定义链接
Connection connection = null;
// 定义会话
Session session = null;
// 定义目的地
Destination destination = null;
// 定义消息的接收者
MessageConsumer consumer = null;
// 定义消息
Message message = null;
try {
// 创建连接工厂
connectionFactory = new ActiveMQConnectionFactory("admin", "admin", "tcp://192.168.139.141:61616");
connectionFactory.setTrustAllPackages(true);
// 创建连接
connection = connectionFactory.createConnection();
// 启动连接
connection.start();
// 创建会话
session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE);
// 创建消息队列
destination = session.createQueue("my-user");
// 创建消息接收者
consumer = session.createConsumer(destination);
// 创建消息
message = consumer.receive();
// 获取消息并处理
ObjectMessage objMsg=(ObjectMessage) message;
User u=(User) objMsg.getObject();
System.out.println(u);
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
} finally {
if (consumer != null) {
try {
consumer.close();
} catch (JMSException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
if (session != null) {
try {
session.close();
} catch (JMSException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
if (connection != null) {
try {
connection.close();
} catch (JMSException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
}
}
消费者测试代码:
package com.test;
import com.consumer.UserConsumer;
public class DemoTest {
public static void main(String[] args) {
//对象类型进行传递
UserConsumer uc=new UserConsumer();
uc.receiveHelloWorldActivityMQ();
}
}