 2002 Prentice Hall. All rights reserved. Chapter 16: Messaging with JMS Outline 16.1 Introduction 16.2 Installation and Configuration of J2EE 1.3 16.3.

Slides:



Advertisements
Similar presentations
12 Copyright © 2005, Oracle. All rights reserved. Implementing Business Tasks with Session EJBs.
Advertisements

16 Copyright © 2005, Oracle. All rights reserved. Developing Message-Driven Beans.
11 Copyright © 2005, Oracle. All rights reserved. Creating the Business Tier: Enterprise JavaBeans.
Unit 3 Graphical User Interface (GUI) Dr. Magdi AMER.
 2002 Prentice Hall. All rights reserved. Chapter 9: Servlets Outline 9.1 Introduction 9.2 Servlet Overview and Architecture Interface Servlet and.
 2002 Prentice Hall, Inc. All rights reserved. Chapter 14 – Exception Handling Outline 14.1 Introduction 14.2 When Exception Handling Should Be Used 14.3.
A Study in JMS (Java Messaging Service) Chad Beaudin CS 522 Fall Semester 2002.
Java Messaging Services CS-328. Messaging Systems A messaging System allows and promotes the loose coupling of components –allows components to post messages.
Copyright W. Howden1 Lecture 19: Intro to O/O Components.
A Study in JMS (Java Messaging Service) Chad Beaudin CS 522 Fall Semester 2002.
Java Message Service API CSE 487/587 Feb 17, 2005 References: JRun Programmer’s Guide.
 2002 Prentice Hall. All rights reserved. Chapter 29: Introduction to Web Services and SOAP Outline 29.1 Introduction 29.2 Simple Object Access Protocol.
Io package as Java’s basic I/O system continue’d.
Chapter 10 EJB Concepts of EJB Three Components in Creating an EJB Starting/Stopping J2EE Server and Deployment Tool Installation and Configuration of.
EJB. Component Characteristics An enterprise Bean typically contains business logic that operates on the enterprise’s data. An enterprise Bean’s instances.
© Copyright by Deitel & Associates, Inc. and Pearson Education Inc. All Rights Reserved. 1 Outline 16.1 Test-Driving the Flag Quiz Application.
1 Session Bean Chuyên đề Lập trình Java & J2EE Chương 14 Biên soạn: Th.S Nguyễn văn Lành.
J2EE Part 2: Enterprise JavaBeans CSCI 4300 Images and code samples from jGuru EJB tutorial,
Enterprise Java Beans - (EJB)
Writing Enterprise Applications with J2EE (Second lesson) Alessio Bechini June 2002 (based on material by Monica Pawlan)
Advanced Java Session 7 New York University School of Continuing and Professional Studies.
Container-Managed Persistence (CMP) Entity Beans Lesson 3A / Slide 1 of 42J2EE Server Components Objectives In this lesson, you will learn to: Identify.
Java Message Service Sangeetha Chavala. What is Messaging? Method of Communication between software components/applications peer-to-peer facility Not.
Enterprise JavaBeans. Lesson 1: Introduction to Server-Side Component Software.
EJB Framework.  As we know, EJB is the center of the J2EE architecture that provides a sturdy framework for building enterprise applications. The major.
Message-Driven Beans and EJB Security Lesson 4B / Slide 1 of 37 J2EE Server Components Objectives In this lesson, you will learn about: Identify features.
Java Server Pages A JSP page is a text-based document that contains two types of text: static template data, which can be expressed in any text-based format,
Session Beans -) stateless -) stateful. Session Beans A session bean represents a single client inside the J2EE server. To access an application that.
LAB 1CSIS04021 Briefing on Assignment One & RMI Programming February 13, 2007.
Java Messaging Service. An Abstraction for using Messaging Oriented Middleware Purpose is to provide a sophisticated, yet straightforward way to exchange.
1 Java Message Service Манин П Enterprise messaging Key concept: 1. Messages are delivered asynchronously 2. Sender is not required to wait for.
Computer Science and Engineering Department VI I - SEMESTER Subject Name : MIDDLEWARE TECHNOLOGIES LABORATORY Subject Code : IT-404.
© Copyright by Deitel & Associates, Inc. and Pearson Education Inc. All Rights Reserved. 1 Outline 19.1 Test-Driving the Shipping Hub Application.
© Copyright by Deitel & Associates, Inc. and Pearson Education Inc. All Rights Reserved. 1 Tutorial 25 – Ticket Information Application Introducing.
An Introduction to Programming and Object Oriented Design using Java 3 rd Edition. Dec 2007 Jaime Niño Frederick Hosch Chapter 18 Integrating user interface.
Li Tak Sing COMPS311F. RMI callbacks In previous example, only the client can initiate a communication with the server. The server can only response to.
JMS (Java Messaging Service)
Introduction to GUI in 1 Graphical User Interface 2 Nouf Almunyif.
1 GUI programming Graphical user interface-based programming Chapter G1 (pages )
© Copyright by Deitel & Associates, Inc. and Pearson Education Inc. All Rights Reserved. 1 Outline 8.1 Test-Driving the Car Payment Calculator.
 2002 Prentice Hall. All rights reserved. Chapter 19 Enterprise Java Case Study: Business Logic Part 1 Outline 19.1 Introduction 19.2 EJB Architecture.
EJB Overview: Constraint Types and Enforcement in JBoss Elissa Newman Fluid Meeting 6/3/04.
© Copyright by Deitel & Associates, Inc. and Pearson Education Inc. All Rights Reserved. 1 Outline 24.1 Test-Driving the Enhanced Car Payment.
© FPT SOFTWARE – TRAINING MATERIAL – Internal use 04e-BM/NS/HDCV/FSOFT v2/3 JSP Application Models.
© Copyright by Deitel & Associates, Inc. and Pearson Education Inc. All Rights Reserved. 1 Tutorial 4 – Completing the Inventory Application.
Creating a GUI Class An example of class design using inheritance and interfaces.
© Copyright by Deitel & Associates, Inc. and Pearson Education Inc. All Rights Reserved. 1 Outline 5.1 Test-Driving the Enhanced Inventory Application.
Java Programming: Advanced Topics 1 Enterprise JavaBeans Chapter 14.
Enterprise Java Beans N.V.RAJASEKHAR REDDY. Definition of EJB EJBs are the components that are the set of classes and interfaces deployed within a container.
Copyright © 2002 ProsoftTraining. All rights reserved. Enterprise JavaBeans.
Enterprise Java Beans Ye Zhou CS6704 Presentation Virginia Tech.
13 Copyright © 2004, Oracle. All rights reserved. Managing Persistent Data in the Business Tier Entity EJBs.
D Copyright © 2004, Oracle. All rights reserved. BMP Entity EJBs J2EE Connector Architecture.
© Copyright by Deitel & Associates, Inc. and Pearson Education Inc. All Rights Reserved. 1 Outline 17.1 Test-Driving the Student Grades Application.
Chapter 10 - Writing Graphical User Interfaces1 Chapter 10 Writing Graphical User Interfaces.
© Copyright by Deitel & Associates, Inc. and Pearson Education Inc. All Rights Reserved. 1 Outline 28.1 Java Speech API 28.2 Downloading and.
5-1 GUIs and Events Rick Mercer. 5-2 Event-Driven Programming with Graphical user Interfaces  Most applications have graphical user interfaces to respond.
14 Copyright © 2004, Oracle. All rights reserved. Achieving State Management in the Business Tier.
17 Copyright © 2004, Oracle. All rights reserved. Integrating J2EE Components.
© Copyright by Deitel & Associates, Inc. and Pearson Education Inc. All Rights Reserved. 1 Outline 7.1 Test-Driving the Dental Payment Application.
Slide No. 1 of 111 JMS ( J AVA M ESSAGE S ERVICE ) -Dhananjay Singh.
©The McGraw-Hill Companies, Inc. Permission required for reproduction or display. Chapter Chapter 7 ( Book Chapter 14) GUI and Event-Driven Programming.
©NIIT Session Beans Lesson 1B/ Slide 1 of 37J2EE Server Components Objectives In this lesson, you will learn to: Describe the characteristics of session.
Chapter 14: Session EJBs and Distributed Transactions
Java Messaging Service (JMS)
Java Messaging Service (JMS)
Java Messaging Service (JMS)
Objectives In this lesson, you will learn to:
Understanding and Designing with EJB
J2EE Lecture 13: JMS and WebSocket
Presentation transcript:

 2002 Prentice Hall. All rights reserved. Chapter 16: Messaging with JMS Outline 16.1 Introduction 16.2 Installation and Configuration of J2EE Point-To-Point Messaging Voter Application: Overview Voter Application: Sender Side Voter Application: Receiver Side| Voter Application: Configuring and Running 16.4 Publish/Subscribe Messaging Weather Application: Overview Weather Application: Publisher Side Weather Application: Subscriber Side Weather Application: Configuring and Running 16.5 Message-Driven Enterprise JavaBeans Voter Application: Overview Voter Application: Receiver Side\ Voter Application: Configuring and Running

 2002 Prentice Hall. All rights reserved Introduction Message-oriented middleware –enables components to post messages for other components –two types point-to-point messaging model –components send messages to message queue messages sent to one consumer publish/subscribe messaging model –components publish message to topic on server multiple subscribers receive message for given topic

 2002 Prentice Hall. All rights reserved Introduction (cont.) Message –composed of header –message destination –sending time properties (optional) –server determines type of message being sent –clients helps determine what messages to receive body –content of message

 2002 Prentice Hall. All rights reserved Introduction (cont.) –composed of 5 types 1.BytesMessages 2.MapMessages 3.ObjectMessages 4.StreamMessages 5.TextMessages Message-driven beans –Enterprise JavaBeans that support messaging –EJB container uses any message-driven bean for given topic message-driven beans cannot maintain clients state –enable components to receive messages asynchronously

 2002 Prentice Hall. All rights reserved Installation and Configuration of J2EE 1.3 Steps for installing J2EE 1.3 –download and unpack appropriate software bundle –set environment variables according to Fig. 16.1

 2002 Prentice Hall. All rights reserved Installation and Configuration of J2EE 1.3 (cont.)

 2002 Prentice Hall. All rights reserved Point-To-Point Messaging Allows clients send messages to message queue. –receiver connects to queue to consume non-consumed messages Messages intended for one receiver. Messages stored in queue until client consumes messages.

 2002 Prentice Hall. All rights reserved Point-To-Point Messaging (cont.) Fig. 16.2Point-to-point messaging model.

 2002 Prentice Hall. All rights reserved Voter Application: Overview Tallies votes to favorite computer languages. Class Voter –sends votes as messages to Votes queue messages are simple TextMessage objects –body contains candidate name Class VoteCollector –consumes messages and tallies votes –updates display

 2002 Prentice Hall. All rights reserved Voter Application: Overview (cont.) Fig. 16.3Voter application overview.

 2002 Prentice Hall. All rights reserved Voter Application: Sender Side Consists of single class, Voter. –allows user to select programming language –sends vote to Votes queue

 2002 Prentice Hall. All rights reserved. Outline Fig Voter class submits votes as messages to queue. Line 13 1 // Voter.java 2 // Voter is the GUI that allows the client to vote 3 // for a programming language. Voter sends the vote 4 // to the "Votes" queue as a TextMessage. 5 package com.deitel.advjhtp1.jms.voter; 6 7 // Java core packages 8 import java.awt.*; 9 import java.awt.event.*; // Java extension packages 12 import javax.swing.*; 13 import javax.jms.*; 14 import javax.naming.*; public class Voter extends JFrame { private String selectedLanguage; // JMS variables 21 private QueueConnection queueConnection; 22 private QueueSession queueSession; 23 private QueueSender queueSender; // Voter constructor 26 public Voter() 27 { 28 // lay out user interface 29 super( "Voter" ); Container container = getContentPane(); 32 container.setLayout( new BorderLayout() ); 33 contains JMS API classes and interfaces

 2002 Prentice Hall. All rights reserved. Outline Fig Voter class submits votes as messages to queue. 34 JTextArea voteArea = 35 new JTextArea( "Please vote for your\n" + 36 "favorite programming language" ); 37 voteArea.setEditable( false ); 38 container.add( voteArea, BorderLayout.NORTH ); JPanel languagesPanel = new JPanel(); 41 languagesPanel.setLayout( new GridLayout( 0, 1 ) ); // add each language as its own JCheckBox 44 // ButtonGroup ensures exactly one language selected 45 ButtonGroup languagesGroup = new ButtonGroup(); 46 CheckBoxHandler checkBoxHandler = new CheckBoxHandler(); 47 String languages[] = 48 { "C", "C++", "Java", "Lisp", "Python" }; 49 selectedLanguage = ""; // create JCheckBox for each language 52 // and add to ButtonGroup and JPanel 53 for ( int i = 0; i < languages.length; i++ ) { 54 JCheckBox checkBox = new JCheckBox( languages[ i ] ); 55 checkBox.addItemListener( checkBoxHandler ); 56 languagesPanel.add( checkBox ); 57 languagesGroup.add( checkBox ); 58 } container.add( languagesPanel, BorderLayout.CENTER ); // create button to submit vote 63 JButton submitButton = new JButton( "Submit vote!" ); 64 container.add( submitButton, BorderLayout.SOUTH ); 65

 2002 Prentice Hall. All rights reserved. Outline Fig Voter class submits votes as messages to queue. Line 92 Lines // invoke method submitVote when submitButton clicked 67 submitButton.addActionListener ( new ActionListener() { public void actionPerformed ( ActionEvent event ) { 72 submitVote(); 73 } 74 } 75 ); // invoke method quit when window closed 78 addWindowListener( new WindowAdapter() { public void windowClosing( WindowEvent event ) { 83 quit(); 84 } 85 } 86 ); // connect to message queue 89 try { // create JNDI context 92 Context jndiContext = new InitialContext(); // retrieve queue connection factory and 95 // queue from JNDI context 96 QueueConnectionFactory queueConnectionFactory = 97 ( QueueConnectionFactory ) 98 jndiContext.lookup( "VOTE_FACTORY" ); 99 Queue queue = ( Queue ) jndiContext.lookup( "Votes" ); 100 create JNDI contextserver administrator responsible for creating queue connection factory and queue

 2002 Prentice Hall. All rights reserved. Outline Fig Voter class submits votes as messages to queue. Lines Lines Lines 107 Lines Line // create connection, session and sender 102 queueConnection = 103 queueConnectionFactory.createQueueConnection(); 104 queueSession = 105 queueConnection.createQueueSession( false, 106 Session.AUTO_ACKNOWLEDGE ); 107 queueSender = queueSession.createSender( queue ); 108 } // process Naming exception from JNDI context 111 catch ( NamingException namingException ) { 112 namingException.printStackTrace(); 113 System.exit( 1 ); 114 } // process JMS exception from queue connection or session 117 catch ( JMSException jmsException ) { 118 jmsException.printStackTrace(); 119 System.exit( 1 ); 120 } } // end Voter constructor // submit selected vote to "Votes" queue as TextMessage 125 public void submitVote() 126 { 127 if ( selectedLanguage != "" ) { // create text message containing selected language 130 try { 131 TextMessage voteMessage = 132 queueSession.createTextMessage(); 133 voteMessage.setText( selectedLanguage ); 134 create QueueConnection create QueueSession post messages through QueueSender instance message instanceset body of message

 2002 Prentice Hall. All rights reserved. Outline Fig Voter class submits votes as messages to queue. Line 136 Line // send the message to the queue 136 queueSender.send( voteMessage ); 137 } // process JMS exception 140 catch ( JMSException jmsException ) { 141 jmsException.printStackTrace(); 142 } 143 } } // end method submitVote // close client application 148 public void quit() 149 { 150 if ( queueConnection != null ) { // close queue connection if it exists 153 try { 154 queueConnection.close(); 155 } // process JMS exception 158 catch ( JMSException jmsException ) { 159 jmsException.printStackTrace(); 160 } 161 } System.exit( 0 ); } // end method quit 166 send message close connection to queue

 2002 Prentice Hall. All rights reserved. Outline Fig Voter class submits votes as messages to queue. 167 // launch Voter application 168 public static void main( String args[] ) 169 { 170 Voter voter = new Voter(); 171 voter.pack(); 172 voter.setVisible( true ); 173 } // CheckBoxHandler handles event when checkbox checked 176 private class CheckBoxHandler implements ItemListener { // checkbox event 179 public void itemStateChanged( ItemEvent event ) 180 { 181 // update selectedLanguage 182 JCheckBox source = ( JCheckBox ) event.getSource(); 183 selectedLanguage = source.getText(); 184 } 185 } 186 }

 2002 Prentice Hall. All rights reserved Voter Application: Sender Side (cont.) Fig. 16.5Voter application votes for favorite programming language

 2002 Prentice Hall. All rights reserved Voter Application: Receiver Side Class VoteCollector intended receiver –tallies and displays votes Votes queue can be populated before VoteCollector connects.

 2002 Prentice Hall. All rights reserved. Outline Fig VoteCollector class retrieves and tallies votes. 1 // VoteCollector.java 2 // VoteCollector tallies and displays the votes 3 // posted as TextMessages to the "Votes" queue. 4 package com.deitel.advjhtp1.jms.voter; 5 6 // Java core packages 7 import java.awt.*; 8 import java.awt.event.*; 9 import java.util.*; // Java extension packages 12 import javax.swing.*; 13 import javax.jms.*; 14 import javax.naming.*; public class VoteCollector extends JFrame { private JPanel displayPanel; 19 private Map tallies = new HashMap(); // JMS variables 22 private QueueConnection queueConnection; // VoteCollector constructor 25 public VoteCollector() 26 { 27 super( "Vote Tallies" ); Container container = getContentPane(); // displayPanel will display tally results 32 displayPanel = new JPanel(); 33 displayPanel.setLayout( new GridLayout( 0, 1 ) ); 34 container.add( new JScrollPane( displayPanel ) ); 35

 2002 Prentice Hall. All rights reserved. Outline Fig VoteCollector class retrieves and tallies votes. Line 51 Lines Lines Lines // invoke method quit when window closed 37 addWindowListener( new WindowAdapter() { public void windowClosing( WindowEvent event ) { 42 quit(); 43 } 44 } 45 ); // connect to "Votes" queue 48 try { // create JNDI context 51 Context jndiContext = new InitialContext(); // retrieve queue connection factory 54 // and queue from JNDI context 55 QueueConnectionFactory queueConnectionFactory = 56 ( QueueConnectionFactory ) 57 jndiContext.lookup( "VOTE_FACTORY" ); 58 Queue queue = ( Queue ) jndiContext.lookup( "Votes" ); // create connection, session and receiver 61 queueConnection = 62 queueConnectionFactory.createQueueConnection(); 63 QueueSession queueSession = 64 queueConnection.createQueueSession( false, 65 Session.AUTO_ACKNOWLEDGE ); 66 QueueReceiver queueReceiver = 67 queueSession.createReceiver( queue ); 68 create JNDI contextget queue connection factory create QueueSession create votes receiver

 2002 Prentice Hall. All rights reserved. Outline Fig VoteCollector class retrieves and tallies votes. Lines Lines 74 Lines // initialize and set message listener 70 queueReceiver.setMessageListener( 71 new VoteListener( this ) ); // start connection 74 queueConnection.start(); 75 } // process Naming exception from JNDI context 78 catch ( NamingException namingException ) { 79 namingException.printStackTrace(); 80 System.exit( 1 ); 81 } // process JMS exception from queue connection or session 84 catch ( JMSException jmsException ) { 85 jmsException.printStackTrace(); 86 System.exit( 1 ); 87 } } // end VoteCollector constructor // add vote to corresponding tally 92 public void addVote( String vote ) 93 { 94 if ( tallies.containsKey( vote ) ) { // if vote already has corresponding tally 97 TallyPanel tallyPanel = 98 ( TallyPanel ) tallies.get( vote ); 99 tallyPanel.updateTally(); 100 } 101 register listener activate connectionupdates tallies and display. Callback method for VoteListener instance

 2002 Prentice Hall. All rights reserved. Outline Fig VoteCollector class retrieves and tallies votes. Line // add to GUI and tallies 103 else { 104 TallyPanel tallyPanel = new TallyPanel( vote, 1 ); 105 displayPanel.add( tallyPanel ); 106 tallies.put( vote, tallyPanel ); 107 validate(); 108 } 109 } // quit application 112 public void quit() 113 { 114 if ( queueConnection != null ) { // close the queue connection if it exists 117 try { 118 queueConnection.close(); 119 } // process JMS exception 122 catch ( JMSException jmsException ) { 123 jmsException.printStackTrace(); 124 System.exit( 1 ); 125 } } System.exit( 0 ); } // end method quit 132 close queue connection

 2002 Prentice Hall. All rights reserved. Outline Fig VoteCollector class retrieves and tallies votes. 133 // launch VoteCollector 134 public static void main( String args[] ) 135 { 136 VoteCollector voteCollector = new VoteCollector(); 137 voteCollector.setSize( 200, 200 ); 138 voteCollector.setVisible( true ); 139 } 140 }

 2002 Prentice Hall. All rights reserved Voter Application: Receiver Side (cont.) Fig VoteCollector tallies and displays votes.

 2002 Prentice Hall. All rights reserved. Outline Fig VoteListener class receives messages from the queue. Line 11 Line 29 Line 32 1 // VoteListener.java 2 // VoteListener is the message listener for the 3 // receiver of the "Votes" queue. It implements 4 // the specified onMessage method to update the 5 // GUI with the received vote. 6 package com.deitel.advjhtp1.jms.voter; 7 8 // Java extension packages 9 import javax.jms.*; public class VoteListener implements MessageListener { private VoteCollector voteCollector; // VoteListener constructor 16 public VoteListener( VoteCollector collector ) 17 { 18 voteCollector = collector; 19 } // receive new message 22 public void onMessage( Message message ) 23 { 24 TextMessage voteMessage; // retrieve and process message 27 try { if ( message instanceof TextMessage ) { 30 voteMessage = ( TextMessage ) message; 31 String vote = voteMessage.getText(); 32 voteCollector.addVote( vote ); System.out.println( "Received vote: " + vote ); 35 } implements MessageListener interface ensure message of type TextMessage call back

 2002 Prentice Hall. All rights reserved. Outline Fig VoteListener class receives messages from the queue else { 38 System.out.println( "Expecting " + 39 "TextMessage object, received " + 40 message.getClass().getName() ); 41 } 42 } // process JMS exception from message 45 catch ( JMSException jmsException ) { 46 jmsException.printStackTrace(); 47 } } // end method onMessage 50 }

 2002 Prentice Hall. All rights reserved. Outline Fig TallyPanel class displays candidate name and tally. 1 // TallyPanel.java 2 // TallPanel is the GUI component which displays 3 // the name and tally for a vote candidate. 4 package com.deitel.advjhtp1.jms.voter; 5 6 // Java core packages 7 import java.awt.*; 8 9 // Java extension packages 10 import javax.swing.*; public class TallyPanel extends JPanel { private JLabel nameLabel; 15 private JTextField tallyField; 16 private String name; 17 private int tally; // TallyPanel constructor 20 public TallyPanel( String voteName, int voteTally ) 21 { 22 name = voteName; 23 tally = voteTally; nameLabel = new JLabel( name ); 26 tallyField = 27 new JTextField( Integer.toString( tally ), 10 ); 28 tallyField.setEditable( false ); 29 tallyField.setBackground( Color.white ); add( nameLabel ); 32 add( tallyField ); } // end TallyPanel constructor 35

 2002 Prentice Hall. All rights reserved. Outline Fig TallyPanel class displays candidate name and tally. 36 // update tally by one vote 37 public void updateTally() 38 { 39 tally++; 40 tallyField.setText( Integer.toString( tally ) ); 41 } 42 } increments tally by one

 2002 Prentice Hall. All rights reserved Voter Application: Configuring and Running 1.Start J2EE server j2ee –verbose 2.Create Votes queue (in new window) j2eeadmin –addJmsDestination Votes queue 3.Verify queue was created j2eeadmin –listJmsDestination 4.Create connection factory j2eeadmin –addJmsFactory VOTE_FACTORY queue 5.Start VoteCollector java –classpath %J2EE_HOME%\lib\j2ee.jar;. -Djms.properties=%J2EE_HOME%\config\jms_client.properties com.deitel.advjhtp1.jms.voter.VoteCollector 6.Start Voter (in new window) java –classpath %J2EE_HOME%\lib\j2ee.jar;. -Djms.properties=%J2EE_HOME%\config\jms_client.properties com.deitel.advjhtp1.jms.voter.Voter

 2002 Prentice Hall. All rights reserved Voter Application: Configuring and Running (cont.) Once application finished –remove connection factory j2eeadmin –removeJmsFactory VOTE_FACTORY –remote topic j2eeadmin –removeJmsDestination Votes –stop J2EE server j2ee -stop

 2002 Prentice Hall. All rights reserved Publish/Subscribe Messaging Allows multiple clients to –connect to topic on server –send messages –receive messages When client publishes message, message sent to all clients subscribed to topic. Two subscription types: 1.nondurable messages received while subscriptions active 2.durable server maintains messages while subscription inactive –server sends messages when client reactivates

 2002 Prentice Hall. All rights reserved Publish/Subscribe Messaging (cont.) Fig Publish/subscribe messaging model.

 2002 Prentice Hall. All rights reserved Weather Application: Overview Class WeatherPublisher –retrieves weather updates from URL –publishes information as messages to topic Class WeatherSubscriber –provides GUI enables user to select desired cities –subscribes to Weather topic receives corresponding messages uses message selector

 2002 Prentice Hall. All rights reserved Weather Application: Overview (cont.) Fig Weather application overview.

 2002 Prentice Hall. All rights reserved Weather Application: Publisher Side Class WeatherPublisher –retrieves weather updates from National Weather Service –publishes weather updates to Weather topic –messages of type ObjectMessage String property City specifies corresponding city

 2002 Prentice Hall. All rights reserved. Outline Fig WeatherPublisher class publishes messages to Weather topic. 1 // WeatherPublisher.java 2 // WeatherPublisher retrieves weather conditions from the National 3 // Weather Service and publishes them to the Weather topic 4 // as ObjectMessages containing WeatherBeans. The city name is 5 // used in a String property "City" in the message header. 6 package com.deitel.advjhtp1.jms.weather; 7 \ 8 // Java core packages 9 import java.io.*; 10 import java.net.*; 11 import java.util.*; // Java extension packages 14 import javax.jms.*; 15 import javax.naming.*; // Deitel packages 18 import com.deitel.advjhtp1.rmi.weather.WeatherBean; public class WeatherPublisher extends TimerTask { private BufferedReader in; 23 private TopicConnection topicConnection; // WeatherPublisher constructor 26 public WeatherPublisher() 27 { 28 // update weather conditions every minute 29 Timer timer = new Timer(); 30 timer.scheduleAtFixedRate( this, 0, ); // allow user to quit 33 InputStreamReader inputStreamReader = 34 new InputStreamReader( System.in ); 35 char answer = '\0';

 2002 Prentice Hall. All rights reserved. Outline Fig WeatherPublisher class publishes messages to Weather topic // loop until user enters q or Q 38 while ( !( ( answer == 'q' ) || ( answer == 'Q' ) ) ) { // read in character 41 try { 42 answer = ( char ) inputStreamReader.read(); 43 } // process IO exception 46 catch ( IOException ioException ) { 47 ioException.printStackTrace(); 48 System.exit( 1 ); 49 } } // end while // close connections 54 try { // close topicConnection if it exists 57 if ( topicConnection != null ) { 58 topicConnection.close(); 59 } in.close(); // close connection to NWS Web server 62 timer.cancel(); // stop timer 63 } // process JMS exception from closing topic connection 66 catch ( JMSException jmsException ) { 67 jmsException.printStackTrace(); 68 System.exit( 1 ); 69 } 70

 2002 Prentice Hall. All rights reserved. Outline Fig WeatherPublisher class publishes messages to Weather topic. Line 90 Line Line // process IO exception from closing connection 72 // to NWS Web server 73 catch ( IOException ioException ) { 74 ioException.printStackTrace(); 75 System.exit( 1 ); 76 } System.exit( 0 ); } // end WeatherPublisher constructor // get weather information from NWS 83 public void run() 84 { 85 // connect to topic "Weather" 86 try { 87 System.out.println( "Update weather information..." ); // create JNDI context 90 Context jndiContext = new InitialContext(); 91 String topicName = "Weather"; // retrieve topic connection factory and topic 94 // from JNDI context 95 TopicConnectionFactory topicConnectionFactory = 96 ( TopicConnectionFactory ) 97 jndiContext.lookup( "WEATHER_FACTORY" ); Topic topic = 100 ( Topic ) jndiContext.lookup( topicName ); // create connection, session, publisher and message 103 topicConnection = 104 topicConnectionFactory.createTopicConnection(); 105 create JNDI context look up TopicConnectionFactory and Topic create TopicConnection

 2002 Prentice Hall. All rights reserved. Outline Fig WeatherPublisher class publishes messages to Weather topic. Lines Lines Lines TopicSession topicSession = 107 topicConnection.createTopicSession( false, 108 Session.AUTO_ACKNOWLEDGE ); TopicPublisher topicPublisher = 111 topicSession.createPublisher( topic ); ObjectMessage message = 114 topicSession.createObjectMessage(); // connect to National Weather Service 117 // and publish conditions to topic // National Weather Service Travelers Forecast page 120 URL url = new URL( 121 " ); // set up text input stream to read Web page contents 124 in = new BufferedReader( 125 new InputStreamReader( url.openStream() ) ); // helps determine starting point of data on Web page 128 String separator = "TAV12"; // locate separator string in Web page 131 while ( !in.readLine().startsWith( separator ) ) 132 ; // do nothing // strings representing headers on Travelers Forecast 135 // Web page for daytime and nighttime weather 136 String dayHeader = 137 "CITY WEA HI/LO WEA HI/LO"; String nightHeader = 140 "CITY WEA LO/HI WEA LO/HI"; create TopicSession obtain TopicPublisher will contain WeatherBean objects

 2002 Prentice Hall. All rights reserved. Outline Fig WeatherPublisher class publishes messages to Weather topic. Lines Line 173 Lines String inputLine = ""; // locate header that begins weather information 145 do { 146 inputLine = in.readLine(); 147 } while ( !inputLine.equals( dayHeader ) && 150 !inputLine.equals( nightHeader ) ); // create WeatherBean objects for each city's data 153 // publish to Weather topic using city as message's type 154 inputLine = in.readLine(); // get first city's info // the portion of inputLine containing relevant data is 157 // 28 characters long. If the line length is not at 158 // least 28 characters long, done processing data. 159 while ( inputLine.length() > 28 ) { // create WeatherBean object for city 162 // first 16 characters are city name 163 // next six characters are weather description 164 // next six characters are HI/LO temperature 165 WeatherBean weather = new WeatherBean( 166 inputLine.substring( 0, 16 ).trim(), 167 inputLine.substring( 16, 22 ).trim(), 168 inputLine.substring( 23, 29 ).trim() ); // publish WeatherBean object with city name 171 // as a message property, 172 // used for selection by clients 173 message.setObject( weather ); 174 message.setStringProperty( "City", 175 weather.getCityName() ); create WeatherBean object store WeatherBean in MessageObject set City property

 2002 Prentice Hall. All rights reserved. Outline Fig WeatherPublisher class publishes messages to Weather topic. Line topicPublisher.publish( message ); System.out.println( "published message for city: " weather.getCityName() ); inputLine = in.readLine(); // get next city's info 182 } System.out.println( "Weather information updated." ); } // end try // process Naming exception from JNDI context 189 catch ( NamingException namingException ) { 190 namingException.printStackTrace(); 191 System.exit( 1 ); 192 } // process JMS exception from connection, 195 // session, publisher or message 196 catch ( JMSException jmsException ) { 197 jmsException.printStackTrace(); 198 System.exit( 1 ); 199 } // process failure to connect to National Weather Service 202 catch ( java.net.ConnectException connectException ) { 203 connectException.printStackTrace(); 204 System.exit( 1 ); 205 } // process other exceptions 208 catch ( Exception exception ) { 209 exception.printStackTrace(); 210 System.exit( 1 ); publish message to topic

 2002 Prentice Hall. All rights reserved. Outline Fig WeatherPublisher class publishes messages to Weather topic. 211 } } // end method run // launch WeatherPublisher 216 public static void main( String args[] ) 217 { 218 System.err.println( "Initializing server...\n" "Enter 'q' or 'Q' to quit" ); WeatherPublisher publisher = new WeatherPublisher(); 222 } 223 }

 2002 Prentice Hall. All rights reserved Weather Application: Publisher Side (cont.) Fig WeatherPublisher publishing weather update messages.

 2002 Prentice Hall. All rights reserved Weather Application: Subscriber Side Subscribes to Weather topic. –receives weather updates for selected cities Presents GUI for user.

 2002 Prentice Hall. All rights reserved. Outline Fig WeatherSubscribe r class allows user to receive weather updates. 1 // WeatherSubscriber.java 2 // WeatherSubscriber presents a GUI for the client to request 3 // weather conditions for various cities. The WeatherSubscriber 4 // retrieves the weather conditions from the Weather topic; 5 // each message body contains a WeatherBean object. The message 6 // header contains a String property "City," which allows 7 // the client to select the desired cities. 8 package com.deitel.advjhtp1.jms.weather; 9 10 // Java core packages 11 import java.awt.*; 12 import java.awt.event.*; // Java extension packages 15 import javax.swing.*; 16 import javax.naming.*; 17 import javax.jms.*; public class WeatherSubscriber extends JFrame { // GUI variables 22 private WeatherDisplay weatherDisplay; 23 private JList citiesList; 24

 2002 Prentice Hall. All rights reserved. Outline Fig WeatherSubscribe r class allows user to receive weather updates. Line // cities contains cities for which weather 26 // updates are available on "Weather" topic 27 private String cities[] = { "ALBANY NY", "ANCHORAGE", 28 "ATLANTA", "ATLANTIC CITY", "BOSTON", "BUFFALO", 29 "BURLINGTON VT", "CHARLESTON WV", "CHARLOTTE", "CHICAGO", 30 "CLEVELAND", "DALLAS FT WORTH", "DENVER", "DETROIT", 31 "GREAT FALLS", "HARTFORD SPGFLD", "HONOLULU", 32 "HOUSTON INTCNTL", "KANSAS CITY", "LAS VEGAS", 33 "LOS ANGELES", "MIAMI BEACH", "MPLS ST PAUL", "NEW ORLEANS", 34 "NEW YORK CITY", "NORFOLK VA", "OKLAHOMA CITY", "ORLANDO", 35 "PHILADELPHIA", "PHOENIX", "PITTSBURGH", "PORTLAND ME", 36 "PORTLAND OR", "RENO" }; // JMS variables 39 private TopicConnection topicConnection; 40 private TopicSession topicSession; 41 private Topic topic; 42 private TopicSubscriber topicSubscriber; 43 private WeatherListener topicListener; // WeatherSubscriber constructor 46 public WeatherSubscriber() 47 { 48 super( "JMS WeatherSubscriber..." ); 49 weatherDisplay = new WeatherDisplay(); // set up JNDI context and JMS connections 52 try { // create JNDI context 55 Context jndiContext = new InitialContext(); 56 get JNDI context

 2002 Prentice Hall. All rights reserved. Outline Fig WeatherSubscribe r class allows user to receive weather updates. Lines Line 65 Lines Lines Line // retrieve topic connection factory 58 // from JNDI context 59 TopicConnectionFactory topicConnectionFactory = 60 ( TopicConnectionFactory ) jndiContext.lookup( 61 "WEATHER_FACTORY" ); // retrieve topic from JNDI context 64 String topicName = "Weather"; 65 topic = ( Topic ) jndiContext.lookup( topicName ); // create topic connection 68 topicConnection = 69 topicConnectionFactory.createTopicConnection(); // create topic session 72 topicSession = topicConnection.createTopicSession( false, 73 Session.AUTO_ACKNOWLEDGE ); // initialize listener 76 topicListener = new WeatherListener( weatherDisplay ); 77 } // process Naming exception from JNDI context 80 catch ( NamingException namingException ) { 81 namingException.printStackTrace(); 82 } // process JMS exceptions from topic connection or session 85 catch ( JMSException jmsException ) { 86 jmsException.printStackTrace(); 87 } // lay out user interface 90 Container container = getContentPane(); 91 container.setLayout( new BorderLayout() ); obtain TopicConnectionFactory create Topic create TopicConnection create TopicSession initialize WeatherListener

 2002 Prentice Hall. All rights reserved. Outline Fig WeatherSubscribe r class allows user to receive weather updates JPanel selectionPanel = new JPanel(); 94 selectionPanel.setLayout( new BorderLayout() ); JLabel selectionLabel = new JLabel( "Select Cities" ); 97 selectionPanel.add( selectionLabel, BorderLayout.NORTH ); // create list of cities for which users 100 // can request weather updates 101 citiesList = new JList( cities ); 102 selectionPanel.add( new JScrollPane( citiesList ), 103 BorderLayout.CENTER ); JButton getWeatherButton = new JButton( "Get Weather..." ); 106 selectionPanel.add( getWeatherButton, BorderLayout.SOUTH ); // invoke method getWeather when getWeatherButton clicked 109 getWeatherButton.addActionListener ( new ActionListener() { public void actionPerformed ( ActionEvent event ) 114 { 115 getWeather(); 116 } 117 } ); // end call to addActionListener container.add( selectionPanel, BorderLayout.WEST ); 122 container.add( weatherDisplay, BorderLayout.CENTER ); // invoke method quit when window closed 125 addWindowListener( 126

 2002 Prentice Hall. All rights reserved. Outline Fig WeatherSubscribe r class allows user to receive weather updates. Line new WindowAdapter() { public void windowClosing( WindowEvent event ) 130 { 131 quit(); 132 } 133 } ); // end call to addWindowListener } // end WeatherSubscriber constructor // get weather information for selected cities 140 public void getWeather() 141 { 142 // retrieve selected indices 143 int selectedIndices[] = citiesList.getSelectedIndices(); if ( selectedIndices.length > 0 ) { // if topic subscriber exists, method has 148 // been called before 149 if ( topicSubscriber != null ) { // close previous topic subscriber 152 try { 153 topicSubscriber.close(); 154 } // process JMS exception 157 catch ( JMSException jmsException ) { 158 jmsException.printStackTrace(); 159 } 160 remove previous subscriber so that new subscriber can filter newly selected cities

 2002 Prentice Hall. All rights reserved. Outline Fig WeatherSubscribe r class allows user to receive weather updates. Lines Lines Line // clear previous cities from display 162 weatherDisplay.clearCities(); 163 } // create message selector to retrieve specified cities 166 StringBuffer messageSelector = new StringBuffer(); 167 messageSelector.append( 168 "City = '" + cities[ selectedIndices[ 0 ] ] + "'" ); for ( int i = 1; i < selectedIndices.length; i++ ) { 171 messageSelector.append( " OR City = '" cities[ selectedIndices[ i ] ] + "'" ); 173 } // create topic subscriber and subscription 176 try { 177 topicSubscriber = topicSession.createSubscriber( 178 topic, messageSelector.toString(), false ); 179 topicSubscriber.setMessageListener( topicListener ); 180 topicConnection.start(); JOptionPane.showMessageDialog( this, 183 "A weather update should be arriving soon..." ); 184 } // process JMS exception 187 catch ( JMSException jmsException ) { 188 jmsException.printStackTrace(); 189 } } // end if } // end method getWeather 194 create MessageSelector create TopicSubscriber begin receiving messages

 2002 Prentice Hall. All rights reserved. Outline Fig WeatherSubscribe r class allows user to receive weather updates. Line 203 Line // quit WeatherSubscriber application 196 public void quit() 197 { 198 // close connection and subscription to topic 199 try { // close topic subscriber 202 if ( topicSubscriber != null ) { 203 topicSubscriber.close(); 204 } // close topic connection 207 topicConnection.close(); 208 } // process JMS exception 211 catch ( JMSException jmsException ) { 212 jmsException.printStackTrace(); 213 System.exit( 1 ); 214 } System.exit( 0 ); } // end method quit // launch WeatherSubscriber application 221 public static void main( String args [] ) 222 { 223 WeatherSubscriber subscriber = new WeatherSubscriber(); 224 subscriber.pack(); 225 subscriber.setVisible( true ); 226 } 227 } close subscriberclose connection

 2002 Prentice Hall. All rights reserved Weather Application: Subscriber Side (cont.) Fig WeatherSubscriber selecting cities for weather updates.

 2002 Prentice Hall. All rights reserved Weather Application: Subscriber Side (cont.) Fig WeatherSubscriber having received updated weather conditions.

 2002 Prentice Hall. All rights reserved. Outline Fig WeatherListener class subscribes to Weather topic to receive weather forecasts. Line 15 Line 32 1 // WeatherListener.java 2 // WeatherListener is the MessageListener for a subscription 3 // to the Weather topic. It implements the specified onMessage 4 // method to update the GUI with the corresponding city's 5 // weather. 6 package com.deitel.advjhtp1.jms.weather; 7 8 // Java extension packages 9 import javax.jms.*; 10 import javax.swing.*; // Deitel packages 13 import com.deitel.advjhtp1.rmi.weather.WeatherBean; public class WeatherListener implements MessageListener { private WeatherDisplay weatherDisplay; // WeatherListener constructor 20 public WeatherListener( WeatherDisplay display ) 21 { 22 weatherDisplay = display; 23 } // receive new message 26 public void onMessage( Message message ) 27 { 28 // retrieve and process message 29 try { // ensure Message is an ObjectMessage 32 if ( message instanceof ObjectMessage ) { 33 implements MessageListener ensures message of type ObjectMessage

 2002 Prentice Hall. All rights reserved. Outline Fig WeatherListener class subscribes to Weather topic to receive weather forecasts. Lines Line // get WeatherBean from ObjectMessage 35 ObjectMessage objectMessage = 36 ( ObjectMessage ) message; 37 WeatherBean weatherBean = 38 ( WeatherBean ) objectMessage.getObject(); // add WeatherBean to display 41 weatherDisplay.addItem( weatherBean ); } // end if else { 46 System.out.println( "Expected ObjectMessage," + 47 " but received " + message.getClass().getName() ); 48 } } // end try // process JMS exception from message 53 catch ( JMSException jmsException ) { 54 jmsException.printStackTrace(); 55 } } // end method onMessage 58 } obtain WeatherBean display contents

 2002 Prentice Hall. All rights reserved. Outline Fig WeatherDisplay displays WeatherBeans in a Jlist using a WeatherCellRende rer. 1 // WeatherDisplay.java 2 // WeatherDisplay extends JPanel to display results 3 // of client's request for weather conditions. 4 package com.deitel.advjhtp1.jms.weather; 5 6 // Java core packages 7 import java.awt.*; 8 import java.awt.event.*; 9 import java.util.*; // Java extension packages 12 import javax.swing.*; // Deitel packages 15 import com.deitel.advjhtp1.rmi.weather.*; public class WeatherDisplay extends JPanel { // WeatherListModel and Map for storing WeatherBeans 20 private WeatherListModel weatherListModel; 21 private Map weatherItems; // WeatherDisplay constructor 24 public WeatherDisplay() 25 { 26 setLayout( new BorderLayout() ); ImageIcon headerImage = new ImageIcon( 29 WeatherDisplay.class.getResource( 30 "images/header.jpg" ) ); 31 add( new JLabel( headerImage ), BorderLayout.NORTH ); 32

 2002 Prentice Hall. All rights reserved. Outline Fig WeatherDisplay displays WeatherBeans in a Jlist using a WeatherCellRende rer. Lines Lines // use JList to display updated weather conditions 34 // for requested cities 35 weatherListModel = new WeatherListModel(); 36 JList weatherJList = new JList( weatherListModel ); 37 weatherJList.setCellRenderer( new WeatherCellRenderer() ); add( new JScrollPane( weatherJList ), BorderLayout.CENTER ); // maintain WeatherBean items in HashMap 42 weatherItems = new HashMap(); } // end WeatherDisplay constructor // add WeatherBean item to display 47 public void addItem( WeatherBean weather ) 48 { 49 String city = weather.getCityName(); // check whether city is already in display 52 if ( weatherItems.containsKey( city ) ) { // if city is in Map, and therefore in display 55 // remove previous WeatherBean object 56 WeatherBean previousWeather = 57 ( WeatherBean ) weatherItems.remove( city ); 58 weatherListModel.remove( previousWeather ); 59 } // add WeatherBean to Map and WeatherListModel 62 weatherListModel.add( weather ); 63 weatherItems.put( city, weather ); } // end method addItem remove if bean previously existing add new bean to list

 2002 Prentice Hall. All rights reserved. Outline Fig WeatherDisplay displays WeatherBeans in a Jlist using a WeatherCellRende rer // clear all cities from display 68 public void clearCities() 69 { 70 weatherItems.clear(); 71 weatherListModel.clear(); 72 } 73 }

 2002 Prentice Hall. All rights reserved Weather Application: Configuring and Running 1.Start J2EE server j2ee –verbose 2.Create Weather topic (new window) j2eeadmin –addJmsDestination Weather topic 3.Verify topic selected j2eeadmin –listJmsDestination 4.Create connection factory j2eeadmin –addJmsFactory WEATHER_FACTORY topic 5.Start WeatherPublisher java –classpath %J2EE_HOME%\lib\j2ee.jar;. -Djms.properties=%J2EE_HOME%\config\jms_client.properties com.deitel.advjhtp1.jms.weather.WeatherPublisher 6.Start WeatherSubscriber java –classpath %J2EE_HOME%\lib\j2ee.jar;. -Djms.properties=%J2EE_HOME%\config\jms_client.properties com.deitel.advjhtp1.jmx.weather.WeatherSubscriber

 2002 Prentice Hall. All rights reserved Weather Application: Configuring and Running (cont.) To close application 1.remove factory j2eeadmin –removeJmsFactory WEATHER_FACTORY 2.remove topic j2eeadmin –removeJmsDestination Weather 3.stop J2EE server j2ee -stop

 2002 Prentice Hall. All rights reserved Message-Driven Enterprise JavaBeans New type of EJB available in EJB version 2.0. –part of Java 2 Enterprise Edition version 1.3 When message is received –container uses any available message-driven bean message-driven beans handle messages from multiple clients Must not maintain state. Developers provide only bean implementation.

 2002 Prentice Hall. All rights reserved Voter Application: Overview Class Voter –posts vote messages to queue –not concerned with receiver’s implementation benefit of loosely coupled systems Class VoteCollectorEJB –message-bean implementation –delegates message to entity-bean Candidate Class Candidate –tallies votes –stores results in database Voting Class TallyDisplay –presents GUI with tallies from database

 2002 Prentice Hall. All rights reserved Voter Application: Overview (cont.) Fig Voter application overview.

 2002 Prentice Hall. All rights reserved Voter Application: Receiver Side Candidate entity EJB represents –vote candidate for which users vote –number of votes for candidate Uses container managed persistence.

 2002 Prentice Hall. All rights reserved. Outline Fig CandidateHome interface for Candidate EJB. Lines Lines Lines // CandidateHome.java 2 // CandidateHome is the home interface for the Candidate EJB. 3 package com.deitel.advjhtp1.jms.mdb; 4 5 // Java core libraries 6 import java.rmi.*; 7 import java.util.*; 8 9 // Java standard extensions 10 import javax.ejb.*; public interface CandidateHome extends EJBHome { // find Candidate with given name 15 public Candidate findByPrimaryKey( String candidateName ) 16 throws RemoteException, FinderException; // find all Candidates 19 public Collection findAllCandidates() 20 throws RemoteException, FinderException; // create new Candidate EJB 23 public Candidate create( String candidateName ) 24 throws RemoteException, CreateException; 25 } locate particular Candidate locate Collection of Candidate s create new Candidate with given name and 0 votes

 2002 Prentice Hall. All rights reserved. Outline Fig Candidate remote interface for Candidate EJB. Line 15 Line 18 Line 21 1 // Candidate.java 2 // Candidate is the remote interface for the Candidate 3 // EJB, which maintains a tally of votes. 4 package com.deitel.advjhtp1.jms.mdb; 5 6 // Java core libraries 7 import java.rmi.RemoteException; 8 9 // Java standard extensions 10 import javax.ejb.EJBObject; public interface Candidate extends EJBObject { // place vote for this Candidate 15 public void incrementVoteCount() throws RemoteException; // get total vote count for this Candidate 18 public Integer getVoteCount() throws RemoteException; // get Candidate's name 21 public String getCandidateName() throws RemoteException; 22 } add vote to Candidate current vote tallycandidate’s name

 2002 Prentice Hall. All rights reserved. Outline Fig CandidateEJB class to maintain candidate tallies. Lines Lines // CandidateEJB.java 2 // CandidateEJB is an entity EJB that uses container-managed 3 // persistence to persist its Candidate and its vote tally. 4 package com.deitel.advjhtp1.jms.mdb; 5 6 // Java core libraries 7 import java.rmi.RemoteException; 8 9 // Java standard extensions 10 import javax.ejb.*; public class CandidateEJB implements EntityBean { private EntityContext entityContext; // container-managed fields 17 public Integer voteCount; 18 public String name; // place vote for this Candidate 21 public void incrementVoteCount() 22 { 23 int newVoteCount = voteCount.intValue() + 1; 24 voteCount = new Integer( newVoteCount ); 25 } // get total vote count for this Candidate 28 public Integer getVoteCount() 29 { 30 return voteCount; 31 } 32 container-managed fields voteCount and name increment vote tally

 2002 Prentice Hall. All rights reserved. Outline Fig CandidateEJB class to maintain candidate tallies. Lines Lines // get Candidate's name 34 public String getCandidateName() 35 { 36 return name; 37 } // create new Candidate 40 public String ejbCreate( String candidateName ) 41 throws CreateException 42 { 43 name = candidateName; 44 voteCount = new Integer( 0 ); return null; 47 } // do post-creation tasks when creating new Candidate 50 public void ejbPostCreate( String candidateName ) {} // set EntityContext 53 public void setEntityContext( EntityContext context ) 54 { 55 entityContext = context; 56 } // unset EntityContext 59 public void unsetEntityContext() 60 { 61 entityContext = null; 62 } // activate Candidate instance 65 public void ejbActivate() 66 { 67 name = ( String ) entityContext.getPrimaryKey(); return candidate nameinitializes new candidate with specified name and initializes vote count to 0

 2002 Prentice Hall. All rights reserved. Outline Fig CandidateEJB class to maintain candidate tallies. 68 } // passivate Candidate instance 71 public void ejbPassivate() 72 { 73 name = null; 74 } // load Candidate from database 77 public void ejbLoad() {} // store Candidate in database 80 public void ejbStore() {} // remove Candidate from database 83 public void ejbRemove() {} 84 }

 2002 Prentice Hall. All rights reserved. Outline Fig VoteCollectorEJB class tallies votes from Votes queue. Lines // VoteCollectorEJB.java 2 // VoteCollectorEJB is a MessageDriven EJB that tallies votes. 3 package com.deitel.advjhtp1.jms.mdb; 4 5 // Java core packages 6 import java.util.*; 7 import java.rmi.*; 8 9 // Java extension packages 10 import javax.ejb.*; 11 import javax.rmi.*; 12 import javax.jms.*; 13 import javax.naming.*; public class VoteCollectorEJB 16 implements MessageDrivenBean, MessageListener { private MessageDrivenContext messageDrivenContext; // receive new message 21 public void onMessage( Message message ) 22 { 23 TextMessage voteMessage; // retrieve and process message 26 try { if ( message instanceof TextMessage ) { 29 voteMessage = ( TextMessage ) message; 30 String vote = voteMessage.getText(); 31 countVote( vote ); System.out.println( "Received vote: " + vote ); 34 } // end if 35 called by container whenever vote message is placed in queue

 2002 Prentice Hall. All rights reserved. Outline Fig VoteCollectorEJB class tallies votes from Votes queue. Lines else { 37 System.out.println( "Expecting " + 38 "TextMessage object, received " + 39 message.getClass().getName() ); 40 } } // end try // process JMS exception from message 45 catch ( JMSException jmsException ) { 46 jmsException.printStackTrace(); 47 } 48 } // add vote to corresponding tally 51 private void countVote( String vote ) 52 { 53 // CandidateHome reference for finding/creating Candidates 54 CandidateHome candidateHome = null; // find Candidate and increment vote count 57 try { // look up Candidate EJB 60 Context initialContext = new InitialContext(); Object object = initialContext.lookup( 63 "java:comp/env/ejb/Candidate" ); candidateHome = 66 ( CandidateHome ) PortableRemoteObject.narrow( 67 object, CandidateHome.class ); 68 obtain reference to Candidate EJB

 2002 Prentice Hall. All rights reserved. Outline Fig VoteCollectorEJB class tallies votes from Votes queue. Lines Line 74 Lines // find Candidate for whom the user voted 70 Candidate candidate = 71 candidateHome.findByPrimaryKey( vote ); // increment Candidate's vote count 74 candidate.incrementVoteCount(); } // end try // if Candidate not found, create new Candidate 79 catch ( FinderException finderException ) { // create new Candidate and increment its vote count 82 try { 83 Candidate newCandidate = candidateHome.create( vote ); 84 newCandidate.incrementVoteCount(); 85 } // handle exceptions creating new Candidate 88 catch ( Exception exception ) { 89 throw new EJBException( exception ); 90 } } // end FinderException catch // handle exception when looking up OrderProducts EJB 95 catch ( NamingException namingException ) { 96 throw new EJBException( namingException ); 97 } // handle exception when invoking OrderProducts methods 100 catch ( RemoteException remoteException ) { 101 throw new EJBException( remoteException ); 102 } 103 find particular Candidate increment vote count create new Candidate if specified candidate name not found

 2002 Prentice Hall. All rights reserved. Outline Fig VoteCollectorEJB class tallies votes from Votes queue. 104 } // end method countVote // set message driven context 107 public void setMessageDrivenContext( 108 MessageDrivenContext context ) 109 { 110 messageDrivenContext = context; 111 } // create bean instance 114 public void ejbCreate() {} // remove bean instance 117 public void ejbRemove() {} 118 }

 2002 Prentice Hall. All rights reserved. Outline Fig TallyDisplay displays candidate tallies from database. 1 // TallyDisplay.java 2 // TallyDisplay displays the votes from database. 3 package com.deitel.advjhtp1.jms.mdb; 4 5 // Java core packages 6 import java.awt.*; 7 import java.awt.event.*; 8 import java.rmi.*; 9 import java.util.*; 10 import java.util.List; // Java extension packages 13 import javax.swing.*; 14 import javax.ejb.*; 15 import javax.rmi.*; 16 import javax.naming.*; public class TallyDisplay extends JFrame { // TallyDisplay constructor 21 public TallyDisplay() 22 { 23 super( "Vote Tallies" ); Container container = getContentPane(); // displayPanel displays tally results 28 JPanel displayPanel = new JPanel(); 29 displayPanel.setLayout( new GridLayout( 0, 1 ) ); 30 container.add( new JScrollPane( displayPanel ) ); 31

 2002 Prentice Hall. All rights reserved. Outline Fig TallyDisplay displays candidate tallies from database. Lines Lines // find Candidates and display tallies 33 try { // look up Candidate EJB 36 Context initialContext = new InitialContext(); Object object = initialContext.lookup( 39 "Candidate" ); 40 CandidateHome candidateHome = 41 ( CandidateHome ) PortableRemoteObject.narrow( 42 object, CandidateHome.class ); // find all Candidates 45 Collection candidates = 46 candidateHome.findAllCandidates(); // add TallyPanel with candidate name and 49 // vote count for each candidate 50 Iterator iterator = candidates.iterator(); 51 while ( iterator.hasNext() ) { 52 Candidate candidate = ( Candidate ) iterator.next(); // create TallyPanel for Candidate 55 TallyPanel tallyPanel = 56 new TallyPanel( candidate.getCandidateName(), 57 candidate.getVoteCount().intValue() ); 58 displayPanel.add( tallyPanel ); 59 } } // end try // handle exception finding Candidates 64 catch ( FinderException finderException ) { 65 finderException.printStackTrace(); lookup all Candidate s display snapshot of information

 2002 Prentice Hall. All rights reserved. Outline Fig TallyDisplay displays candidate tallies from database. 66 } 67 // handle exception looking up Candidate EJB 68 catch ( NamingException namingException ) { 69 namingException.printStackTrace(); 70 } // handle exception communicating with Candidate 73 catch ( RemoteException remoteException ) { 74 remoteException.printStackTrace(); 75 } } // end TallyDisplay constructor // launch TallyDisplay application 80 public static void main( String args[] ) 81 { 82 TallyDisplay tallyDisplay = new TallyDisplay(); 83 tallyDisplay.setDefaultCloseOperation( EXIT_ON_CLOSE ); 84 tallyDisplay.pack(); 85 tallyDisplay.setVisible( true ); 86 } 87 }

 2002 Prentice Hall. All rights reserved Voter Application: Receiver Side (cont.) Fig TallyDisplay displays candidate tallies from database.

 2002 Prentice Hall. All rights reserved. Outline Fig TallyPanel class displays the name and tally for a candidate. 1 // TallyPanel.java 2 // TallPanel is the GUI component which displays 3 // the name and tally for a vote candidate. 4 package com.deitel.advjhtp1.jms.mdb; 5 6 // Java core packages 7 import java.awt.*; 8 9 // Java extension packages 10 import javax.swing.*; public class TallyPanel extends JPanel { private JLabel nameLabel; 15 private JTextField tallyField; 16 private String name; 17 private int tally; // TallyPanel constructor 20 public TallyPanel( String voteName, int voteTally ) 21 { 22 name = voteName; 23 tally = voteTally; nameLabel = new JLabel( name ); 26 tallyField = 27 new JTextField( Integer.toString( tally ), 10 ); 28 tallyField.setEditable( false ); 29 tallyField.setBackground( Color.white ); add( nameLabel ); 32 add( tallyField );

 2002 Prentice Hall. All rights reserved. Outline Fig TallyPanel class displays the name and tally for a candidate } // end TallyPanel constructor }

 2002 Prentice Hall. All rights reserved Voter Application: Configuring and Running Apply to file resource.properties jdbcDataSource. number.name=jdbc/Voting jdbcDataSource. number.url=jdbc:cloudscape:rmi:VotingDB;create=true where number is next number in jdbcDataSource entries. Start J2EE server j2ee –verbose Create queue j2eeadmin –addJmsDestination Votes queue Create connection factory j2eeadmin –addJmsFactory VOTE_FACTORY queue Run deploy tool deploytool

 2002 Prentice Hall. All rights reserved Voter Application: Configuring and Running (cont.) Within deploy tool, create new application File -> New Application Browse navigate to parent directory of com package structure File enter VoteCollectorApp.ear as file name New Application OK Add Candidate EJB File -> New Enterprise Bean

 2002 Prentice Hall. All rights reserved Voter Application: Configuring and Running (cont.) Fig EJB JAR settings for VoteCollectorApp application.

 2002 Prentice Hall. All rights reserved Voter Application: Configuring and Running (cont.) Fig Add class files for Candidate EJB.

 2002 Prentice Hall. All rights reserved Voter Application: Configuring and Running (cont.) Fig General settings for Candidate EJB.

 2002 Prentice Hall. All rights reserved Voter Application: Configuring and Running (cont.) Fig Entity settings for Candidate EJB.

 2002 Prentice Hall. All rights reserved Voter Application: Configuring and Running (cont.) Fig Entity tab for Candidate EJB.

 2002 Prentice Hall. All rights reserved Voter Application: Configuring and Running (cont.) Fig Database settings for Candidate EJB.

 2002 Prentice Hall. All rights reserved Voter Application: Configuring and Running (cont.) Fig SQL generation for Candidate EJB.

 2002 Prentice Hall. All rights reserved Voter Application: Configuring and Running (cont.) Fig SQL warning for Candidate EJB.

 2002 Prentice Hall. All rights reserved Voter Application: Configuring and Running (cont.) Create VoteCollector File -> New Enterprise Bean

 2002 Prentice Hall. All rights reserved Voter Application: Configuring and Running (cont.) Fig EJB JAR settings for VoteCollector EJB.

 2002 Prentice Hall. All rights reserved Voter Application: Configuring and Running (cont.) Fig Add class file for VoteCollector EJB.

 2002 Prentice Hall. All rights reserved Voter Application: Configuring and Running (cont.) Fig General settings for VoteCollector EJB.

 2002 Prentice Hall. All rights reserved Voter Application: Configuring and Running (cont.) Fig Transaction management settings for the VoteCollector EJB

 2002 Prentice Hall. All rights reserved Voter Application: Configuring and Running (cont.) Fig Message-Driven Bean settings for VoteCollector EJB.

 2002 Prentice Hall. All rights reserved Voter Application: Configuring and Running (cont.) Fig Enterprise Bean References for VoteCollector EJB.

 2002 Prentice Hall. All rights reserved Voter Application: Configuring and Running (cont.) Fig Setting JNDI names for VoteCollectorApp.

 2002 Prentice Hall. All rights reserved Voter Application: Configuring and Running (cont.) Fig Deploying the VoteCollector application.