package org.glassfish.test.jms.jmsxdeliverycount.ejb; import java.util.logging.Logger; import javax.annotation.Resource; import javax.ejb.*; import javax.inject.Inject; import javax.jms.*; /** * * @author LILIZHAO */ @Stateless(mappedName="MySessionBean/remote") public class MySessionBean implements MySessionBeanRemote { @Resource(mappedName = "jms/jms_unit_test_Queue") private Queue queue; @Resource(mappedName = "jms/jms_unit_result_Queue") private Queue resultQueue; @Resource(mappedName = "jms/jms_unit_test_QCF") private ConnectionFactory myQueueFactory; @Inject @JMSConnectionFactory("jms/jms_unit_test_QCF") @JMSSessionMode(JMSContext.AUTO_ACKNOWLEDGE) private JMSContext jmsContext; @Resource EJBContext ctx; @Override public void sendMessage(String text) { try { JMSProducer producer = jmsContext.createProducer(); TextMessage msg = jmsContext.createTextMessage(text); producer.send(queue, msg); } catch (Exception e) { throw new EJBException(e); } } @Override public boolean checkMessage(String text) { Connection conn = null; Session session = null; try { conn = myQueueFactory.createConnection(); conn.start(); session = conn.createSession(); MessageConsumer consumer = session.createConsumer(resultQueue); TextMessage msg = (TextMessage) consumer.receive(10000); if (msg == null) { Logger.getLogger("MySessionBean").severe("No result message received."); return false; } else { String result = msg.getText(); if (result.startsWith("true")) { return true; } else { String errMsg = result.substring(result.indexOf(":") + 1); Logger.getLogger("MySessionBean").severe(errMsg); return false; } } } catch (Exception e) { throw new EJBException(e); } finally { try { session.close(); conn.close(); }catch(Exception e) { throw new EJBException(e); } } } }