开发工具:用JBuiler玩转petstore

王朝other·作者佚名  2008-05-19
窄屏简体版  字體: |||超大  

开发j2ee应用一直用Jbuiler(两个月前因工作关系开始用eclipse了),仓促开发了所谓数千万的项目(政府的),在banq的指点下,才突然发现petstore中有很多可借鉴的东西。

而Jbuiler下玩petstore不是件很容易的事,本人在暑假期间花了三天时间解决了这个问题,愿与大家共享。本文只包括ejb部分。petstore的版本是bea提供的,因为我用的是weblogic,带来的一个附加的优点是学习了ejb的继承。

首先从以下地址下载petstore源码。

ftp://edownload:BUY_ME@ftpna2.bea.com/pub/downloads/petstore_1.3.1_02_bea.zip

0.按JBuilder标准拷贝文件至src目录

1.packagecom.sun.j2ee.blueprints.waf.view.taglibs.smart;

开始位置在com.sun.j2ee.bluprints.taglibs.smart,改。

2.新建petstoreWebApp,自然引入原有的Webpacakage

3.配好pointbase数据源:EnterpriseSetup--DatabasePoilet(URL中要注意去掉jdbc:)--JBuiler中配数据源(一直不能看到table,不知何原因。重启后没反应,删除jndi-definations.xml后,又乱改了一下密码,refresh才行。)

4.可以开始importejb了,import所有带ejb子目录下的ejb。注意!primarykeyclass手工写为java.lang.String报错:ErrorParsingEJBfile:Sourcefilenotfoundforclass:null。是指的String类找不到!麻烦!而写为com.sun.j2ee.blueprint.xxx.xxPK!也出错:包不对:com.sun.j2ee.blueprint.xxx.String。改为:com.sun.j2ee.blueprint.xxx.WeblogicxxPK。又出错!

"estore.jar":Unabletoloadaclassspecifiedinyourejb-jar.xml:UnabletoloadPrimaryKeyclass:'String'.Possiblecauses:1:

ThePrimaryKeyclassisaJavaLanguagePrimitive;

thisisnotallowed.2:IfthePrimaryKeyisaCompoundKey,

theCompoundPrimaryKeyclassisnotintheJARfilebeingcompiled.

3:Theclasspathisincorrect.

此问题最后手工改:petstore.ejbgrpx中的java.lang.String解决。

注意:WeblogicXXXEJB的Inheritence选项中指定EJB的父类。引完后必须手工选择Table,TableSchema要把后缀EJB去掉,不然EJB-QL语句会出错。手工选择对应数据库的column,不然会报错:ejb-jar.xml中的cmp-field必须在weblogic-rdbms-jar中有对应元素。

另外,CustomerEJB中account,profile都选对应的field为account_primarykey,profile_primarykey而不是同名的field!

5.一路顺利,但OPCAdminFacadeEJB报告名称冲突。原因是建立了错误的EJB,找到那个打了叉的EJB视图。

6.EJB-QL书写。找到Primiry-key之外的方法,搜索ejb-jar.xml中包括EJB名称的文件(有很多ejb-jar文件)。拷贝相应的ejb-ql语句。

7.ejbCreat方法必须返回primary-key类型的值。此问题的解决办法是在LocalHomeInterface中定义主键时,使用(Objectkey),JBuiler有时会自动改,再改回来!

8.把WeblogicXXEJB的primarykey的Integer类型改为String类型,否则会说主键描述和定义的不一样。不能改父类的定义,只能这么改了,不知有无副作用。

9.console-security-user中把admin等用户的用户名改为petstore,以便登录

10.

(1)JMSstores

MyJMSFileStore,JMSFileStore

MyJMSFileStorePersist,P_JMSFileStore

(2)JMSServer

MyJMSServer

注意选择PersistentStore,pagingstore

(3)ConnectionFactorys

jms/opc/QueueConnectionFactoryjms/opc/QueueConnectionFactoryn/a400

jms/petstore/QueueConnectionFactoryjms/petstore/QueueConnectionFactoryn/a400

jms/supplier/QueueConnectionFactoryjms/supplier/QueueConnectionFactoryn/a400

jms/supplier/TopicConnectionFactoryjms/supplier/TopicConnectionFactoryn/a400

Weblogicdefaultconnectionfactory:weblogic.jms.ConnectFactory

(4)JMSServerDestinction

//jms/opc/MailCompletedOrderQueueJMSQueuejms/opc/MailCompletedOrderQueuen/adefault0

//jms/opc/MailOrderApprovalQueueJMSQueuejms/opc/MailOrderApprovalQueuen/adefault0

//jms/opc/MailQueueJMSQueuejms/opc/MailQueuen/adefault0

//jms/opc/OrderApprovalQueueJMSQueuejms/opc/OrderApprovalQueuen/adefault0

jms/opc/OrderQueueJMSQueuejms/opc/OrderQueuen/adefault0

jms/petstore/AsyncSenderQueueJMSQueuejms/petstore/AsyncSenderQueuen/adefault0

//jms/supplier/PurchaseOrderQueueJMSQueuejms/supplier/PurchaseOrderQueuen/adefault0

//jms/opc/InvoiceTopicJMSTopicjms/opc/InvoiceTopicn/adefault0

//jms/opc/MailInvoiceTopicJMSTopicjms/opc/MailInvoiceTopicn/adefault0

11.mdb

it'ssostrange:mailinvoicetopicandinvoicetopicnocorrecponddingconncetionfactory,

iusejms/supplier/TopicConnectionFactory

12.

[EJB:011031]TheEntityEJBrequiresthetable:MANAGEREJBtobeaccessible.

Pleaseensurethatthistableexistsandisaccessible.

更改weblogic-cmp-rdbms.jar中的所有table名,前面加上secame名:PETSTORE

13.如果数据库中没有对应field,则persistence选false即可。

WeblogicXXXEJB中的primaryKeyfield没有值,参照源码中的weblogic-cmp-rdbms.jar改为primaryKey。

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
 
 
© 2005- 王朝網路 版權所有 導航