在做此文档的相关操作之前,请各位要先保证以下几点。
(一)准备工作
1 首先jb和weblogic已经保证集成,我的版本是jb7+weblogic6.1
2 有正确的数据源,最好是之前你已经在你的weblogic里面已经成功配置了连接池。
3 最好您以前已经对jbuilder里面使用JDBC有一些心得。
此两步可以参见文档
http://www.csdn.net/develop/article/15/15250.shtm
(二)工程的建立
1 首先建立一个工程叫CmpTest,选一下你工程所在路径,其他不用选,直接finished
2 现在new一个EJB2.0 DESIGNER,如果你的cmp不能建立,请首先保证是否准备工作做了,
还有一个问题可能是本工程的server还是tomcat4,在工程属性里修改server为weblogic就可以了。
3 弹出一个框,点new,命名为CMP1然后OK,再OK
(三)Database的建立和CMP的建立
1 CMP建立好了之后,在左下角会出现一个database,右击,import from schema database.
此时可以选择Driver,URL,user,password,JDNIname等参数。
2 如果你的driver是红色的,你需要做下面操作。
Tools->Enterprise Setup,单击Database Drivers页上的Add, 在弹出的对话框中单击New,然后加入你的driver,OK。
3 紧接着第一步,如果各个参数填写正确,那么你会看到一个等待过程,在database下面你可以看到你填写的JDNI的名字。
展开你可以看到数据库所有的表都被导了进来。
4 展开你需要建立CMP的表(我的表是AhUser),右击Create CMP 2.0 EntityBean,
第一次你选一个只有一个主键的表,这样系统不会跟你生成一个主键类。这样你应该看到三个文件
AhUser.java AhUserHome.java AhUserBean.java,分别是你的bean类,远程接口和home接口。
到现在为止,你的cmp已经能够发布了,简单吧。
5 等一等,如果你现在发布,系统会告诉你的你datasource没有注册,所以,你要在在weblogic中有一个和当前datasource
相同名字的ds,这样才成。
(四)建立无状态的sessionbean来调用你的cmp
1 在面板上右击 Create EJB->session bean,在第一行写的sessionbean的名字,我的叫BeanQueryAH
2 右击 add methord,写你的方法名称 把intefaces改为remote用远程调用
3 return type 选一下 java.lang.String
4 input parameters 输入 java.lang.String mobile,这个时候,远程的方法就好了。
5 右击该bean,view bean source.查看代码可以看到你建立的这个方法和其中的参数,我的是这样
public java.lang.String queryAH(java.lang.String mobile) {
return null;
}
在这个方法里面,我们将生成对CMP的引用,向如下修改方法。其中AhUserHome,AhUser 是上面我生成的cmp的bean类和home接口。
public java.lang.String queryAH(java.lang.String mobile) {
String sReturn = "none";
try {
AhUserHome ahh = (AhUserHome) (new InitialContext().lookup("java:/comp/env/cmp1"));
AhUser ahuser = ahh.findByPrimaryKey(mobile);
sReturn = ahuser.getLogintime();
}
catch (Exception ex) {
ex.printStackTrace();
sReturn ="ERROR";
}
return sReturn
}
大家注意这句话 AhUserHome ahh = (AhUserHome) (new InitialContext().lookup("java:/comp/env/cmp1"));
由于在同一个容器当中,调用cmp不需要rmi远程调用。采用写环境变量的方法,上面的话要运行成功,必须做以下操作。
选中你的BeanQueryAH这个bean,选中右下的 EJB Local References,Add,填入名字cmp1,这时候生成一行,把islink选上
link里面选上ahuser,type 选entity.
这样上面的那句就可以通过这个环境变量本地调用你这个ejb了。
当然,大家可以根据自己的数据库来修改这两句话来返回不同的值。
AhUser ahuser = ahh.findByPrimaryKey(mobile);
sReturn = ahuser.getLogintime();
(五)客户端的建立
1 在jb里面new 一个ejb client test,默认的下面的4个复选框是勾上三个,ok
2 找到main方法是这样写的
public static void main(String[] args) {
BeanQueryAHTestClient1 client = new BeanQueryAHTestClient1();
// Use the client object to call one of the Home interface wrappers
// above, to create a Remote interface reference to the bean.
// If the return value is of the Remote interface type, you can use it
// to access the remote interface methods. You can also just use the
// client object to call the Remote interface wrappers.
}
3 修改
public static void main(String[] args) {
BeanQueryAHTestClient1 client = new BeanQueryAHTestClient1();
// Use the client object to call one of the Home interface wrappers
// above, to create a Remote interface reference to the bean.
// If the return value is of the Remote interface type, you can use it
// to access the remote interface methods. You can also just use the
// client object to call the Remote interface wrappers.
client.create();
System.out.print(client.queryAH("13956261950")) ;
System.out.print(client.queryAH("13955177766")) ;
System.out.print(client.queryAH("13956395757")) ;
System.out.print(client.queryAH("13956536656")) ;
}
(六) 运行
1 编译后,生成*.jar文件,启动weblogic,把*.jar部署上去
2 运行client ,命令控制台里面就打印
-- Initializing bean access.
-- Succeeded initializing bean access.
-- Execution time: 2274 ms.
-- Calling create()
-- Succeeded: create()
-- Execution time: 70 ms.
-- Return value from create(): ClusterableRemoteRef(172.16.58.178 [172.16.58.178])/270.
-- Calling queryAH(13956261950)
-- Succeeded: queryAH(13956261950)
-- Execution time: 170 ms.
-- Return value from queryAH(13956261950): 020924122246.
020924122246-- Calling queryAH(13955177766)
-- Succeeded: queryAH(13955177766)
-- Execution time: 10 ms.
-- Return value from queryAH(13955177766): 020914085733.
020914085733-- Calling queryAH(13956395757)
-- Succeeded: queryAH(13956395757)
-- Execution time: 30 ms.
-- Return value from queryAH(13956395757): 020913163627.
020913163627-- Calling queryAH(13956536656)
-- Succeeded: queryAH(13956536656)
-- Execution time: 10 ms.
-- Return value from queryAH(13956536656): 020913162439.
020913162439
3 查看你的weblogic页面
EJBName Idle Beans Count Beans In Use Count Waiter Total Count Timeout Total Count Cached Beans Current Count Cache Access Count Cache Hit Count Activation Count Passivation Count Lock Entries Current Count Lock Manager Access Count Waiter Total Count Timeout Total Count
AhUser 1 4 0 0 4 16 12 4 0 0 0 0 0
可以看到这个实体bean的一些信息。
所有过程作者都亲自试过,环境jb7+weblogic6.1,有什么问题请联系jiangyz@hoten.com,转载请说明出处。谢谢
待续(如何实现jsp+javabean+sessionbean+cmp)