ObjectMessage.setObject() 无缘无故抛出 javax.jms.JMSException
ObjectMessage.setObject() throws javax.jms.JMSException for no apparently reason
有这样的自定义对象:
package Messages;
import java.io.Serializable;
import javax.jms.TextMessage;
public class MessageObject implements Serializable{
private static final long serialVersionUID = 1L;
private TextMessage message;
private String state;
private String sender;
private String receiver;
public MessageObject() {
}
public TextMessage getMessage() {
return message;
}
public void setMessage(TextMessage message) {
this.message = message;
}
* the rest of the getters and setters *
}
然后我创建并尝试向我的 jms 队列发送一个包含我的自定义消息对象的 ObjectMessage:
try {
Context context = new InitialContext();
QueueConnectionFactory factory =
(QueueConnectionFactory)context.lookup("tiwconnectionfactory");
Queue queue = (Queue) context.lookup("tiwqueue");
Connection connection = factory.createConnection();
connection.start();
Session session= connection.createSession(false,
javax.jms.Session.AUTO_ACKNOWLEDGE);
MessageProducer producer = session.createProducer(queue);
MessageObject mymessage = new MessageObject();
ObjectMessage object = session.createObjectMessage();
TextMessage message = session.createTextMessage();
message.setText("Hi");
mymessage.setState("still not read");
mymessage.setMessage(message);
mymessage.setSender("Peter");
mymessage.setReceiver("John");
object.setObject(mymessage);
producer.send(object);
尝试运行代码时,抛出的异常是:
[2018-11-11T19:20:07.270+0100] [glassfish 5.0] [SEVERE] [] [] [tid: _ThreadID=28 _ThreadName=Thread-9] [timeMillis: 1541960407270] [levelValue: 1000] [[ javax.jms.JMSException:MQJMSRA_DM4001::Exception:ObjectMessage.setObject()object=Messages.MessageObject@d8b66e3:message=com.sun.messaging.jms.ra.DirectTextPacktatcom.sun.messaging.jms.ra.DirectObjectPacket.setObject(DirectObjectPacket.java:218)
那么问题是什么?我在我的代码中没有发现任何错误,而且我的对象是可序列化的。
我用google来分析你的错误信息:
[2018-11-11T19:20:07.270+0100] [glassfish 5.0] [SEVERE] [] [] [tid: _ThreadID=28 _ThreadName=Thread-9] [timeMillis: 1541960407270] [levelValue: 1000]
[[ javax.jms.JMSException:MQJMSRA_DM4001::Exception:ObjectMessage.setObject()
object=Messages.MessageObject@d8b66e3:
message=com.sun.messaging.jms.ra.DirectTextPacket
at com.sun.messaging.jms.ra.DirectObjectPacket.setObject(DirectObjectPacket.java:218)
看来TextMessage
对象实际上是com.sun.messaging.jms.ra.DirectTextPacket
的一个实例。
但是,要使您的 MessageObject
可序列化,其所有字段也需要可序列化。由于 DirectTextPacket
不可序列化,因此您的 MessageObject
不可序列化。
回答问题"why do you get this exception instead of NotSerializableException
"?
这是因为 JMS 将类似 NotSerializableException
的异常包装到它自己的异常中。
我不明白的是:你为什么要 MessageObject
包含一个包装的 TextMessage
?为什么不将文本本身添加到您的 MessageObject
中?
有这样的自定义对象:
package Messages;
import java.io.Serializable;
import javax.jms.TextMessage;
public class MessageObject implements Serializable{
private static final long serialVersionUID = 1L;
private TextMessage message;
private String state;
private String sender;
private String receiver;
public MessageObject() {
}
public TextMessage getMessage() {
return message;
}
public void setMessage(TextMessage message) {
this.message = message;
}
* the rest of the getters and setters *
}
然后我创建并尝试向我的 jms 队列发送一个包含我的自定义消息对象的 ObjectMessage:
try {
Context context = new InitialContext();
QueueConnectionFactory factory =
(QueueConnectionFactory)context.lookup("tiwconnectionfactory");
Queue queue = (Queue) context.lookup("tiwqueue");
Connection connection = factory.createConnection();
connection.start();
Session session= connection.createSession(false,
javax.jms.Session.AUTO_ACKNOWLEDGE);
MessageProducer producer = session.createProducer(queue);
MessageObject mymessage = new MessageObject();
ObjectMessage object = session.createObjectMessage();
TextMessage message = session.createTextMessage();
message.setText("Hi");
mymessage.setState("still not read");
mymessage.setMessage(message);
mymessage.setSender("Peter");
mymessage.setReceiver("John");
object.setObject(mymessage);
producer.send(object);
尝试运行代码时,抛出的异常是:
[2018-11-11T19:20:07.270+0100] [glassfish 5.0] [SEVERE] [] [] [tid: _ThreadID=28 _ThreadName=Thread-9] [timeMillis: 1541960407270] [levelValue: 1000] [[ javax.jms.JMSException:MQJMSRA_DM4001::Exception:ObjectMessage.setObject()object=Messages.MessageObject@d8b66e3:message=com.sun.messaging.jms.ra.DirectTextPacktatcom.sun.messaging.jms.ra.DirectObjectPacket.setObject(DirectObjectPacket.java:218)
那么问题是什么?我在我的代码中没有发现任何错误,而且我的对象是可序列化的。
我用google来分析你的错误信息:
[2018-11-11T19:20:07.270+0100] [glassfish 5.0] [SEVERE] [] [] [tid: _ThreadID=28 _ThreadName=Thread-9] [timeMillis: 1541960407270] [levelValue: 1000]
[[ javax.jms.JMSException:MQJMSRA_DM4001::Exception:ObjectMessage.setObject()
object=Messages.MessageObject@d8b66e3:
message=com.sun.messaging.jms.ra.DirectTextPacket
at com.sun.messaging.jms.ra.DirectObjectPacket.setObject(DirectObjectPacket.java:218)
看来TextMessage
对象实际上是com.sun.messaging.jms.ra.DirectTextPacket
的一个实例。
但是,要使您的 MessageObject
可序列化,其所有字段也需要可序列化。由于 DirectTextPacket
不可序列化,因此您的 MessageObject
不可序列化。
回答问题"why do you get this exception instead of NotSerializableException
"?
这是因为 JMS 将类似 NotSerializableException
的异常包装到它自己的异常中。
我不明白的是:你为什么要 MessageObject
包含一个包装的 TextMessage
?为什么不将文本本身添加到您的 MessageObject
中?