View Javadoc

1   /***
2    * Redistribution and use of this software and associated documentation
3    * ("Software"), with or without modification, are permitted provided
4    * that the following conditions are met:
5    *
6    * 1. Redistributions of source code must retain copyright
7    *    statements and notices.  Redistributions must also contain a
8    *    copy of this document.
9    *
10   * 2. Redistributions in binary form must reproduce the
11   *    above copyright notice, this list of conditions and the
12   *    following disclaimer in the documentation and/or other
13   *    materials provided with the distribution.
14   *
15   * 3. The name "Exolab" must not be used to endorse or promote
16   *    products derived from this Software without prior written
17   *    permission of Exoffice Technologies.  For written permission,
18   *    please contact jima@intalio.com.
19   *
20   * 4. Products derived from this Software may not be called "Exolab"
21   *    nor may "Exolab" appear in their names without prior written
22   *    permission of Exoffice Technologies. Exolab is a registered
23   *    trademark of Exoffice Technologies.
24   *
25   * 5. Due credit should be given to the Exolab Project
26   *    (http://www.exolab.org/).
27   *
28   * THIS SOFTWARE IS PROVIDED BY EXOFFICE TECHNOLOGIES AND CONTRIBUTORS
29   * ``AS IS'' AND ANY EXPRESSED OR IMPLIED WARRANTIES, INCLUDING, BUT
30   * NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND
31   * FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL
32   * EXOFFICE TECHNOLOGIES OR ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT,
33   * INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
34   * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
35   * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
36   * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
37   * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
38   * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED
39   * OF THE POSSIBILITY OF SUCH DAMAGE.
40   *
41   * Copyright 2004-2005 (C) Exoffice Technologies Inc. All Rights Reserved.
42   *
43   * $Id: Listener.java,v 1.2 2005/11/18 03:28:00 tanderson Exp $
44   */
45  import java.io.BufferedReader;
46  import java.io.IOException;
47  import java.io.InputStreamReader;
48  
49  import javax.naming.Context;
50  import javax.naming.InitialContext;
51  import javax.naming.NamingException;
52  
53  import javax.jms.JMSException;
54  import javax.jms.Destination;
55  import javax.jms.Connection;
56  import javax.jms.ConnectionFactory;
57  import javax.jms.MessageConsumer;
58  import javax.jms.Session;
59  
60  
61  /***
62   * Asynchronous <code>MessageConsumer</code> example.
63   *
64   * @author <a href="mailto:tma@netspace.net.au">Tim Anderson</a>
65   * @version $Revision: 1.2 $ $Date: 2005/11/18 03:28:00 $
66   */
67  public class Listener {
68  
69      /***
70       * Main line.
71       *
72       * @param args command line arguments
73       */
74      public static void main(String[] args) {
75          Context context = null;
76          ConnectionFactory factory = null;
77          Connection connection = null;
78          String factoryName = "ConnectionFactory";
79          String destName = null;
80          Destination dest = null;
81          Session session = null;
82          MessageConsumer receiver = null;
83          BufferedReader waiter = null;
84  
85          if (args.length != 1) {
86              System.out.println("usage: Listener <destination>");
87              System.exit(1);
88          }
89  
90          destName = args[0];
91  
92          try {
93              // create the JNDI initial context.
94              context = new InitialContext();
95  
96              // look up the ConnectionFactory
97              factory = (ConnectionFactory) context.lookup(factoryName);
98  
99              // look up the Desination
100             dest = (Destination) context.lookup(destName);
101 
102             // create the connection
103             connection = factory.createConnection();
104 
105             // create the session
106             session = connection.createSession(
107                 false, Session.AUTO_ACKNOWLEDGE);
108 
109             // create the receiver
110             receiver = session.createConsumer(dest);
111 
112             // register a listener
113             receiver.setMessageListener(new SampleListener());
114 
115             // start the connection, to enable message receipt
116             connection.start();
117 
118             System.out.println("Waiting for messages...");
119             System.out.println("Press [return] to quit");
120 
121             waiter = new BufferedReader(new InputStreamReader(System.in));
122             waiter.readLine();
123         } catch (IOException exception) {
124             exception.printStackTrace();
125         } catch (JMSException exception) {
126             exception.printStackTrace();
127         } catch (NamingException exception) {
128             exception.printStackTrace();
129         } finally {
130             // close the context
131             if (context != null) {
132                 try {
133                     context.close();
134                 } catch (NamingException exception) {
135                     exception.printStackTrace();
136                 }
137             }
138 
139             // close the connection
140             if (connection != null) {
141                 try {
142                     connection.close();
143                 } catch (JMSException exception) {
144                     exception.printStackTrace();
145                 }
146             }
147         }
148     }
149 }