TrailBlazer第8天--Message Driven POJOs

一、定义服务接口,并用@Producer标注
Calculator.java 

package  trail.mdpojo;
 
import  org.jboss.annotation.ejb.Producer;
 @Producer
 
public   interface  Calculator {
 
   
public   void  doCalculation ( long  sent,  int  start,  int  end,
                              
double  growthrate,
                              
double  saving); 
 } 


二、定义服务实现,并用@Consumer标注,同MDB一样,如果所监听的消息队列不存在,JBoss会自动创建一个,不需要任何XML配置文件
MdpojoCalculator.java 

  package  trail.mdpojo;
 
import  org.jboss.annotation.ejb.Consumer;
 
import  javax.ejb. * ;
 
import  java.sql.Timestamp;
 
 @Consumer(activationConfig 
=
 {
   @ActivationConfigProperty(propertyName
= " destinationType " ,
     propertyValue
= " javax.jms.Queue " ),
   @ActivationConfigProperty(propertyName
= " destination " ,
     propertyValue
= " queue/mdpojo " )
 })
 
public   class  MdpojoCalculator  implements  Calculator {
 
   
public   void  doCalculation ( long  sent,  int  start,  int  end,  double  growthrate, 

double  saving) {
 
     
double  result  =  calculate (start, end, growthrate, saving);
     RecordManager.addRecord (
new  Timestamp(sent), result);
 
     System.out.println (
" The MD POJO is invoked " );
   }
   
//
 }  

三、Message Driven POJOs的使用
       如果要使用MDPOJO,你首先需要从JNDI中查找@Producer接口所对应的stub object,
这个stub object实现了Producer接口的同时还实现了ProducerObject接口。你需要用ProducerObject.getProducerManager()得到一个ProducerManager然后调用manager.connect().它会创建一个JMS连接。接下来就可以使用@Producer中定义的服务了。
calculator.jsp 

  <% @ page  import = " trail.mdpojo.*, javax.naming.*, java.text.*,
                  org.jboss.ejb3.mdb. * " %>
 
 
<%
   
if  ( " send " .equals(request.getParameter ( " action " ))) {
 
     
int  start  =  Integer.parseInt(request.getParameter ( " start " ));
     
int  end  =  Integer.parseInt(request.getParameter ( " end " ));
     
double  growthrate  =  Double.parseDouble(request.getParameter ( " growthrate " ));
     
double  saving  =  Double.parseDouble(request.getParameter ( " saving " ));
 
     
//  The sent timestamp acts as the message's ID
      long  sent  =  System.currentTimeMillis();
 
     Calculator cal 
=   null ;
     ProducerManager manager 
=   null ;
     
try  {
 
       InitialContext ctx 
=   new  InitialContext();
       cal 
=  (Calculator) ctx.lookup(
                   Calculator.
class .getName());
       
//  cal = (Calculator) ctx.lookup(
       
//              "EJB3Trail/MdpojoCalculator/remote");
      ProducerObject po  =  (ProducerObject) cal;
       manager 
=  po.getProducerManager();
 
     } 
catch  (Exception e) {
       e.printStackTrace ();
     }
 
     manager.connect(); 
//  internally create a JMS connection
      try  {
       cal.doCalculation(sent, start, end,
                         growthrate, saving);
     } 
finally  {
       manager.close(); 
//  clean up the JMS connection
     }
 
%>  


 



你可能感兴趣的:(TrailBlazer第8天--Message Driven POJOs)