开发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。