Spring mvc JNDI中JMS连接工厂查找中的ClassCastException
我不熟悉排队。我在JBOSS 5.1 EAP中设置了我的队列,现在在尝试注入队列时,我得到了一个Spring mvc JNDI中JMS连接工厂查找中的ClassCastException,spring-mvc,jms,jndi,jboss5.x,Spring Mvc,Jms,Jndi,Jboss5.x,我不熟悉排队。我在JBOSS 5.1 EAP中设置了我的队列,现在在尝试注入队列时,我得到了一个ClassCastException(在查找JNDI时),我在前端使用flex,并使用Spring framework for flex。当使用quartz作业注入队列时,它运行良好。quartz的工作是一个单独的项目,与flex和spring无关 我读过一些可能是jar问题的文章,我在春季使用了JMS jar,我尝试移除、替换所有类型的jar,但运气不好 // Step 1. Cre
ClassCastException
(在查找JNDI时),我在前端使用flex,并使用Spring framework for flex。当使用quartz作业注入队列时,它运行良好。quartz的工作是一个单独的项目,与flex和spring无关
我读过一些可能是jar问题的文章,我在春季使用了JMS jar,我尝试移除、替换所有类型的jar,但运气不好
// Step 1. Create an initial context to perform the JNDI lookup.
InputStream in = this.getClass().getResourceAsStream(
"/clv2.properties");
Properties configProp = new Properties();
configProp.load(in);
IpAddress = configProp.getProperty("ipaddress");
port = configProp.getProperty("port");
inQueueName = configProp.getProperty("inQueueName");
Properties props = new Properties();
props.setProperty("java.naming.factory.initial",
"org.jnp.interfaces.NamingContextFactory");
props.setProperty("java.naming.factory.url.pkgs",
"org.jboss.naming");
// props.setProperty("java.naming.provider.url", host + ":" + port);
props.setProperty("java.naming.provider.url", "localhost" + ":"
+ 1099);
// props.setProperty("java.naming.provider.url",
// "16.181.233.61:1399");
initialContext = new InitialContext(props);
// Step 3. Perform a lookup on the Connection Factory
QueueConnectionFactory cf = (QueueConnectionFactory) initialContext
.lookup("/ConnectionFactory");
Queue queue = (Queue) initialContext
.lookup(/* "/queue/CLVInboundQueue" */inQueueName);
// Step 4.Create a JMS Connection
connection = (QueueConnection) cf.createConnection();
// Step 5. Create a JMS Session
session = (QueueSession) connection.createSession(false,
Session.AUTO_ACKNOWLEDGE);
// Step 6. Create a JMS Message Producer
// MessageProducer producer = session.createProducer(queue);
QueueSender queueSender = session.createSender(queue);
TextMessage textMessage = session.createTextMessage(message);
textMessage.setLongProperty("Rejected_Message_ID",
rejected_Message_Id);
/*
* BufferedReader reader = new BufferedReader(new
* InputStreamReader(ClassLoader.class.getResourceAsStream(file)));
* StringBuilder sb = new StringBuilder(); String line = null;
*
*
* while ((line = reader.readLine()) != null) { sb.append(line +
* "\n"); } String announcementmsg = sb.toString();
*/
commonlogger.info(textMessage);
connection.start();
// producer.send(session.createTextMessage(announcementmsg));
queueSender.send(textMessage);
这是我要注入队列的一段代码。我在“//步骤3”中得到异常。在“连接工厂”上执行查找,这是我的堆栈跟踪
09:22:20,730 ERROR [STDERR] java.lang.ClassCastException: org.jboss.jms.client.JBossConnectionFactory cannot be cast to javax.jms.QueueConnectionFactory
09:22:20,731 ERROR [STDERR] at com.cat.clv.util.InQueueReinjectMessage.sendMessage(InQueueReinjectMessage.java:63)
09:22:20,731 ERROR [STDERR] at com.cat.clv.util.RejectedMessageReinject.reProcessedMessage(RejectedMessageReinject.java:65)
09:22:20,731 ERROR [STDERR] at com.cat.clv.service.ReinjectMessagesServiceImpl.reinjectRejectedMessages(ReinjectMessagesServiceImpl.java:106)
09:22:20,731 ERROR [STDERR] at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
09:22:20,731 ERROR [STDERR] at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)
09:22:20,732 ERROR [STDERR] at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
09:22:20,732 ERROR [STDERR] at java.lang.reflect.Method.invoke(Unknown Source)
09:22:20,732 ERROR [STDERR] at flex.messaging.services.remoting.adapters.JavaAdapter.invoke(JavaAdapter.java:421)
09:22:20,732 ERROR [STDERR] at flex.messaging.services.RemotingService.serviceMessage(RemotingService.java:183)
09:22:20,732 ERROR [STDERR] at flex.messaging.MessageBroker.routeMessageToService(MessageBroker.java:1503)
如果您查看的源代码,那么您将看到它实现了 因此,此类强制转换异常可能是因为:
您是否可以先试用选项2,看看它是否有效,如果无效,您是否可以检查这些示例在您的jboss安装中是否有效。在查找时获取classCast异常: classcastexception:weblogic.jms.client.JMSconnectionFactory无法强制转换为javax.jms.QueueConnectionFactory initialContext=新的initialContext(道具)
// Step 3. Perform a lookup on the Connection Factory
QueueConnectionFactory cf = (QueueConnectionFactory) initialContext
.lookup("/ConnectionFactory");
Queue queue = (Queue) initialContext
.lookup(/* "/queue/CLVInboundQueue" */inQueueName);
// Step 4.Create a JMS Connection
connection = (QueueConnection) cf.createConnection();
// Step 5. Create a JMS Session
session = (QueueSession) connection.createSession(false,
Session.AUTO_ACKNOWLEDGE);
// Step 6. Create a JMS Message Producer
// MessageProducer producer = session.createProducer(queue);
QueueSender queueSender = session.createSender(queue);
TextMessage textMessage = session.createTextMessage(message);
textMessage.setLongProperty("Rejected_Message_ID",
rejected_Message_Id);
/*
* BufferedReader reader = new BufferedReader(new
* InputStreamReader(ClassLoader.class.getResourceAsStream(file)));
* StringBuilder sb = new StringBuilder(); String line = null;
*
*
* while ((line = reader.readLine()) != null) { sb.append(line +
* "\n"); } String announcementmsg = sb.toString();
*/
commonlogger.info(textMessage);
connection.start();
// producer.send(session.createTextMessage(announcementmsg));
queueSender.send(textMessage);