很久之前写给一个朋友看的,在JR发过,试发下,测试下这个blog
开发及调试环境为 JBOSS4.0+ECLIPSE3.1,软件下载配置安装我就不多说了,相信大家都会很轻易搞定。
开发流程,写一个简单的stateful session bean,进行远程调用,计算出某一特定正整数的Fibonacci值。
所创建的project下引入jbossall-client.jar,在JBOSS_HOME/client目录下
分别用eclipse写出EJB远程调用的home接口,remote接口和相对应的Bean
———1. home接口———
package com.terry.ejbsample;
import java.rmi.RemoteException;
import javax.ejb.CreateException;
import javax.ejb.EJBHome;
/**
* @author terry
*
*/
public interface FibonacciHome extends EJBHome
{
Fibonacci create() throws RemoteException, CreateException;
}
———2. remote 接口———
package com.terry.ejbsample;
import java.rmi.RemoteException;
import javax.ejb.EJBObject;
/**
* @author terry
*
*/
public interface Fibonacci extends EJBObject
{
public long getFibonacci(int n) throws RemoteException;
}
———3. FibonacciBean———
package com.terry.ejbsample;
import javax.ejb.CreateException;
import javax.ejb.SessionBean;
import javax.ejb.SessionContext;
/**
* @author terry
*
*/
public class FibonacciBean implements SessionBean
{
public long getFibonacci(int n)
{
if (n==0) return 1;
else if (n==1) return 1;
else
return getFibonacci(n - 1) + getFibonacci(n - 2);
}
public void ejbCreate() throws CreateException
{
System.out.println(“Bean created”);
}
public void ejbRemove(){}
public void ejbActivate(){}
public void ejbPassivate(){}
public void setSessionContext(SessionContext ctx){}
}
配置相对应的ejb-jar.xml和jboss.xml文件
———1. ejb-jar.xml———
xmlns:xsi=""
xsi:schemaLocation="
/ejb-jar_2_1.xsd"
version="2.1">
Fibonacci
com.terry.ejbsample.FibonacciHome
com.terry.ejbsample.Fibonacci
com.terry.ejbsample.FibonacciBean
Stateful
Container
———2. jboss.xml———
Fibonacci
FibonacciHome
在
Eclipse中配置所需package的jar包,将class文件以及xml描述文件分别添加进去,注意正确的前缀,xml文件必须在根目录下的
META-INF文件夹中。或者你可以在console窗口使用jar命令进行打包(如 jar cf ff.jar *)
将刚刚打包的ff.jar放入JBOSS_HOME/server/default/deploy,启动jboss的默认服务器,如果一切顺利的话,你会在console窗口中看到你刚刚所写的FibonacciBean已经被成功部署到jboss中了。
写一个简单的测试程序
———FibonacciClient.java———
package com.terry.ejbsample;
import javax.naming.Context;
import javax.naming.InitialContext;
import javax.rmi.PortableRemoteObject;
/**
* @author terry
*
*/
public class FibonacciClient
{
public static void main(String[] args)
{
try
{
java.util.Properties p = new java.util.Properties();
p.put(Context.INITIAL_CONTEXT_FACTORY,
"org.jnp.interfaces.NamingContextFactory");
p.put(Context.URL_PKG_PREFIXES, "jboss.naming:org.jnp.interfaces");
p.put(Context.PROVIDER_URL, "localhost:1099");
Context jndiContext = new InitialContext(p);
Object ref = jndiContext.lookup("FibonacciHome");
FibonacciHome home = (FibonacciHome) PortableRemoteObject.narrow(
ref, FibonacciHome.class);
Fibonacci ff = home.create();
long result;
for (int i = 40; i >= 0; i--)
{
result = ff.getFibonacci(i);
System.out.println("Fibonacci of" + i + " is " + result);
}
} catch (java.rmi.RemoteException re)
{
re.printStackTrace();
} catch (Throwable t)
{
t.printStackTrace();
}
}
}
解析此例
J2EE
应用说白了其实原理也很简单,J2EE是分布式系统,意味着server与client是通过RMI-IIOP和JNDI进行交互的。简单来说就是提供给
client一种可以远程调用server端程序的方法,当然其中的细节会比较复杂,不过这些都是你深入之后才会接触到的东西。
本文示例,客户端通过JNDI利用Home接口创建出一个Remote object,再通过调用Remote object 中的方法与FibonacciBean进行交互,处理逻辑。客户端并不是直接与Bean进行交互。
程序中的ejb-jar.xml是用来描述EJB属性的,jboss.xml是用来定义ejb-jar.xml中Bean所对应的JNDI信息。
阅读(726) | 评论(0) | 转发(0) |