分享
 
 
 

XDoclet:EJB开发好帮手

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

??使用XDoclet,你能够在J2EE环境下更加高效地工作,你所看到的Bean以及Bean之间的关系将更加简单,许多繁杂的事情将远离你的EJB开发过程。本文讨论的是如何使用和扩展XDoclet。在这篇文章中,我们将创建一个使用Javadoc标记的会话Bean,然后利用XDoclet处理这个Bean。

一、什么是XDoclet

XDoclet从Rickard Oberg创建的EJBDoclet工具发展而来,它的设想很简单:避免为每个EJB提供多个文件,而是从单一Bean类文件中提供组件需要的所有信息。那么,这是如何实现的呢?Java没有.NET吹嘘的“属性”,但Java有Javadoc标记。我们可以把一个特殊的@标记放入Javadoc注释,然后让一个Doclet工具处理这些标记。由工具为指定的Bean生成合适的XML描述器文件和接口文件。XDoclet建立在EJBDoclet思想的基础上,但适用范围不再局限于EJB。现在,我们已经可以用XDoclet生成Web服务、Web应用描述器,甚至还可以对它进行扩展,满足自己的特殊需要。

@标记有一个标准的格式,包含一个“名称空间”以及一个属于该名称空间的“标记名称”。标记的属性以“名字=值”的形式在标记中指定。下面是一个例子:

/**

* @namespace:tag name="value" name2="value2" ...

*/

当前可用的名称空间包括:

ejb

标准的EJB信息(非厂商私有的信息)

jboss

面向JBoss应用服务器的信息。

weblogic

面向BEA Weblogic应用服务器的信息。

webSphere

面向IBM WebSphere应用服务器的信息。

orion

面向Orion应用服务器(Oracle)的信息。

castor

为Castor框架生成映射信息。

mvcsoft

为MVCSoft EJB 2.0持久化管理器生成文件。

soap

生成SOAP描述器。

struts

生成struts-config.xml。

web

为Web应用生成web.xml配置文件。

jsp

生成标记库扩展描述器信息。

从上面的清单可以看出,除了EJB之外,XDoclet还提供了许多其它方面的支持(因此它的名字也从EJBDoclet变成了XDcolet)。

二、用Javadoc标记标注会话Bean

前面我们讨论了XDoclet工具的基本情况,下面来看一个实例。我们从一个会话EJB开始。这个EJB是XBeans框架的一部分,但对于本文来说,Bean有什么样的功能其实无关紧要。我们关心的是如何在Bean类的基础上,用Javadoc标记进行适当的标注,然后用XDoclet生成我们需要的各种文件。

ReceiverBean.java文件包含了一个documentReady(Document doc)方法,这个方法接收一个DOM文档并把它传递给链上面的下一个XBean。

2.1 在类这一级上的定义

在类这一层次上,我们必须定义:

声明Bean的类型,本例是无状态会话Bean。

JNDI名称。

环境变量。

面向厂商的信息(例如WebLogic 缓冲池信息)。

2.1.1 @ejb:bean标记

该标记唯一必需的属性是把Bean的名字告诉XDoclet。此外,我们还将定义Bean的类型、JNDI名称和显示的名称(display-name):

/**

* This is the EJB Receiver Xbean

*

* @ejb:bean type="Stateless"

* name="ejbReceiver"

* jndi-name="org.xbeans.ejb.receiver.Receiver"

* display-name="EJB Receiver Xbean"

*

* ... 其他javadoc标记 ...

*/

public class ReceiverBean implements SessionBean, DOMSource {

ejb:Bean标记最常用的属性是:

name

EJB的名字(用于描述器)。

type

定义Bean的类型。对于会话Bean,Bean的类型是Stateful或者Stateless;对于实体Bean,它是CMP或BMP。

jndi-name

提供Bean的JNDI名字,它将被用于厂商私有的部署描述器(用于远程接口)。

local-jndi-name

与jndi-name相同,但用于本地接口。

view-type

表示应当支持哪一种Bean的“视图”。可以是remote或local,或者both。

要查看所有标记的完整说明,请访问XDoclet的文档。

2.1.2 @ejb:env-entry标记

这个标记定义了将在JNDI中通过java:comp/env上下文配置的环境变量。下面我们将定义一个环境变量,Bean用它来查找链上面的下一个XBean:

/**

* This is the EJB Receiver Xbean

*

* ... 其他javadoc标记 ...

*

* @ejb:env-entry name="channelBean" type="java.lang.String"

* value="com.your.ChannelBean"

*

* ... 其他javadoc标记 ...

*/

public class ReceiverBean implements SessionBean, DOMSource {

2.1.3 @weblogic:pool标记

下面我们将配置面向特定厂商的缓冲池特征,为便于讨论,我们将使用WebLogic。为表示声明仅对特定厂商有效,我们先声明weblogic名称空间:

/**

* This is the EJB Receiver Xbean

*

* ... 其他javadoc标记 ...

*

* @weblogic:pool max-beans-in-free-pool="1000"

* initial-beans-in-free-pool="10"

*

* ... 其他javadoc标记 ...

*/

public class ReceiverBean implements SessionBean, DOMSource {

这个标记将在面向WebLogic的部署描述器(weblogic-ejb-jar.xml)中配置缓冲池参数。

还有其他许多类这一级的标记,这些标记使得我们能够调整任何可以在部署描述器中指定的选项。下面概要地介绍了可能在部署过程中要用到的一些“标准”标记:

@ejb:bean:唯一必需的标记,配置有关Bean的基本信息。

@ejb:home:提供有关Home接口的信息。可以要求XDoclet扩展一个定制的接口,或者把接口放入指定的包,等等。

@ejb:interface:类似于home标记,但用来配置与组件接口(远程的和/或本地的)有关的信息。

@ejb:finder:在实体Bean Home接口上定义查找器方法。

@ejb:select:在实体Bean Home接口上定义select方法。

@ejb:pk:为实体Bean定义主键。XDoclet能够生成主键类。

@ejb:data-object:数据对象(也就是值对象)可以通过这个标记自动生成。

@ejb:ejb-ref:配置EJB引用。

@ejb:ejb-external-ref:配置对其他应用中的EJB的引用,这里必需指定Bean的类型等信息。

@ejb:resource-ref:配置资源引用。

@ejb:security-role-ref:配置安全角色引用。

@ejb:transaction:为当前Bean的Home接口和Remote接口中的所有方法定义事务属性。可以通过为单个方法提供的事务标记覆盖。

@ejb:permission:允许role-name中指定的角色调用该Bean的Home接口和Remote接口中的所有方法。

@ejb:security-identity:指定是否用调用者的安全标识符执行EJB的方法,还是用另外一个特定的安全标识符。

2.2 在方法这一级上的定义

下面我们来看看方法级的标记。要让某个方法成为远程接口的一部分,我们只需通过一个方法级的标记告诉XDoclet:

/**

* The method that the sender uses to pass the Document

*

* @ejb:interface-method view-type="remote"

*/

public void documentReady(Document incomingDocument) {

这个标记经常要用到。一般地,我们依次检查Bean类里面每一个方法,如果某个方法应该让客户程序调用,则在该方法声明的前面加上这个标记。如果希望客户程序通过本地接口访问这个方法,只需把view-type值改成local就可以了。

下面是另外几个常用的EJB方法级的标记:

@ejb:relation:为EJB 2.0 CMP实体Bean定义一个关系。

@ejb:home-method:把方法定义为ejbHome*方法。

@ejb:pk-field:标示主键域。

@ejb:transaction:为当前的方法定义事务行为(指定一个合法的事务属性:NotSupported,Supports,Required,RequiresNew,Mandatory,或者Never)。

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有