在所有的EJB3.0规范中定义的EJB,都不必实现Home接口。
一个会话Bean必须有一个业务接口,这个接口由会话Bean来实现,或者也可以由会话Bean来产生。这样,你可以只写一个文件,就可以生成业务逻辑实现类、远程接口、本地接口等。
…
@Remote
@Local
@Stateless
public class CounterBean
{
……
}
在目前jboss的实现中,必须要有一个独立的业务接口。
这个接口不必实现EJBObject或者EJBLocalObject。
一个无状态会话Bean 必须使用Stateless注释,以表明它是一个无状态的会话Bean。EJB容器将根据这个注释来判定它的类型。或者实现javax.ejb.SessionBean接口。
一个无状态的会话Bean可以实现setSessionContext方法,也可以不实现。
一个无状态的会话Bean可以实现ejbCreate/ejbRemove方法。
一个无状态的会话Bean可以通过依赖注入(Dependency Injection)也就是现在吵得挺火的IOC获取容器的资源和环境属性。详细介绍请看后面的章节。
在Eclipse中导入本文提供的例子Stateless。
这个例子是一个计数器的例子,它实现了两个业务方法add和getNumber,add方法就是给计数器加上一个整数值,getNumber方法将得到计数器的当前值。
这个例子主要有5个文件:
Counter.java:业务接口。
CounterBean.java:业务实现类。将来我们开发的EJB也都是这样命名(在接口名上加上Bean)。
Client.java:测试EJB的客户端类。
jndi.properties:jndi属性文件,提供访问jdni的基本配置属性。
Build.xml:ant 配置文件,用以编译、发布、测试、清除EJB。
下面针对每个文件的内容做一个介绍。
Counter.java
package com.kuaff.ejb3.stateless;
import javax.ejb.Remote;
@Remote
public interface Counter
{
public int add(int i);
public int getNumber();
}
这个接口很简单,定义了上面介绍的两个业务方法,同时,我们为这个接口加上了Remote注释,这样我们的远程客户端就可以通过JNDI名称查找到它,并调用它的业务方法。
它的JNDI名称怎么配置呢?
你不必配置它的JNDI名称,也不必写它的配置文件。在JBOSS实现的EJB3.0中,你不必写任何的EJB部署文件和jboss部署文件。JBOSS默认使用接口的全称作为它的JNDI名。在上面的例子中,它的全称就是:
com.kuaff.ejb3.stateless.Counter,你也可以通过Counter.class.forName()得到。
CounterBean.java
package com.kuaff.ejb3.stateless;
import javax.ejb.Stateless;
@Stateless
public class CounterBean implements Counter
{
private int number = 0;
//给计数器加上i
public int add(int i)
{
number += i;
return number;
}
//得到当前的计数
public int getNumber()
{
return number;
}
}
这个是计数器的实现类。注意这个类使用Stateless做了注释,这是必须的。
Client.java
package com.kuaff.ejb3.stateless;
import javax.naming.InitialContext;
import javax.naming.NamingException;
public class Client
{
public static void main(String[] args)
{
InitialContext ctx;
try
ctx = new InitialContext();
Counter counter = (Counter) ctx.lookup(Counter.class.getName());
counter.add(10);
System.out.println("当前的number:" + counter.getNumber());
counter.add(10);
System.out.println("当前的number:" + counter.getNumber());
Counter counter2 = (Counter) ctx.lookup(Counter.class.getName());
counter2.add(10);
System.out.println("当前的number:" + counter2.getNumber());
catch (NamingException e)
{
e.printStackTrace();
}
}
}
这个类用来测试我们发布的计数器EJB。首先通过ctx = new InitialContext();得到上下文,然后通过lookup查找计数器,然后给计数器加10,显示当前的计数器信息。
jndi.properties
java.naming.factory.initial=org.jnp.interfaces.NamingContextFactory
java.naming.factory.url.pkgs=org.jboss.naming:org.jnp.interfaces
java.naming.provider.url=localhost
这个文件配置了JNDI操作所需的属性,因为我们是测试本机的EJB服务,所以不必修改上面的属性。
Build.xml
<project name="kuaff_ejb3_tutorial" default="ejbjar" basedir=".">
<property environment="env"/>
<property name="src.dir" value="${basedir}/src"/>
<property name="jboss.home" value="${env.JBOSS_HOME}"/>
<property name="build.dir" value="${basedir}/build"/>
<property name="build.classes.dir" value="${build.dir}/classes"/>
<path id="classpath">
<fileset dir="${jboss.home}/lib">
<include name="**/*.jar"/>
</fileset>
<fileset dir="${jboss.home}/server/all/lib">
<include name="**/*.jar"/>
</fileset>
<fileset dir="${jboss.home}/server/all/deploy/ejb3.deployer">
<include name="*.jar"/>
</fileset>
<fileset dir="${jboss.home}/server/all/deploy/jboss-aop.deployer">
<include name="*.jar"/>
</fileset>
<pathelement location="${build.classes.dir}"/>
<pathelement location="${basedir}"/>
</path>
<property name="build.classpath" refid="classpath"/>
<target name="prepare">
<mkdir dir="${build.dir}"/>
<mkdir dir="${build.classes.dir}"/>
</target>
<target name="compile" depends="prepare">
<javac srcdir="${src.dir}"
destdir="${build.classes.dir}"
debug="on"
deprecation="on"
optimize="off"
includes="**">
<classpath refid="classpath"/>
</javac>
</target>
<target name="ejbjar" depends="compile">
<jar jarfile="build/StatelessSample.ejb3">
<fileset dir="${build.classes.dir}">
<include name="**/*.class"/>
</fileset>
</jar>
<copy file="build/StatelessSample.ejb3" todir="${jboss.home}/server/all/deploy"/>
</target>
<target name="run" depends="ejbjar">
<java classname="com.kuaff.ejb3.stateless.Client" fork="yes" dir=".">
<classpath refid="classpath"/>
</java>
</target>
<target name="clean.db">
<delete dir="${jboss.home}/server/all/data/hypersonic"/>
</target>
<target name="clean">
<delete dir="${build.dir}"/>
<delete file="${jboss.home}/server/all/deploy/StatelessSample.ejb3"/>
</target>
</project>
请运行{$JBOSS_HOME}/bin目录下的run.bat: run –c all,启动JBOSS。
在Eclipse的Ant视图中执行ejbjar target。或者在命令行下,进入到此工程目录下,执行ant ejbjar,将编译打包发布此EJB。
在Eclipse的Ant视图中执行run target。或者在命令行下,进入到此工程目录下,执行ant run,测试这个EJB。
分享到:
相关推荐
### EJB3.0开发指南知识点详解 #### 一、EJB3.0概述与特点 EJB(Enterprise JavaBeans)3.0是Java EE平台的一部分,用于构建可移植、健壮、重用性强的企业级应用程序。相比于之前的版本,EJB 3.0引入了大量的简化...
通过这个教程,开发者可以了解到EJB 3.0中如何使用定时服务创建无状态会话Bean,以及如何编写和测试客户端代码。这有助于理解EJB 3.0的简化编程模型,以及如何利用定时服务实现定时任务,这对于构建可扩展的、健壮的...
接着,我们看到`StudentDAOBean`是一个无状态会话Bean,它不保留任何会话信息,负责调用实体Bean的方法。`StudentDAO`是业务接口,定义了操作实体Bean的方法,而`StudentDAOBean`是其实现类。客户端类`Client`用于...
Eclipse 开发 EJB 3.0 是一个基于 Eclipse 平台的企业级 JavaBean(EJB)开发指南。本教程将指导读者如何使用 Eclipse 创建一个 EJB 3.0 项目,从创建项目到部署到Application Server 的整个过程。 一、创建 EJB ...
6. 无状态和有状态会话Bean:@Stateless和@Stateful注解分别用于标记无状态和有状态的会话Bean。无状态Bean适用于简单、无会话状态的服务,而有状态Bean可以保持客户端上下文信息。 7. 异步方法:EJB 3.0允许在会话...
- `StudentDAO.java`和`StudentDAOBean.java`:分别为会话Bean的业务接口和实现,用于操作实体Bean。 - `Client.java`:客户端测试代码,用于调用会话Bean的方法。 - `jndi.properties`:配置JNDI(Java Naming ...
例如,@Stateless、@Stateful、@Singleton、@MessageDriven等注解分别用于声明无状态会话Bean、有状态会话Bean、单例Bean和消息驱动Bean。 EJB 3.0中的另一个重要改进是引入了JPA,它是ORM(Object-Relational ...
4. 无状态会话bean(@Stateless)和有状态会话bean(@Stateful):无状态bean用于执行独立的操作,而有状态bean可以记住客户端的状态信息。 5. 消息驱动bean(@MessageDriven):处理消息队列中的消息,支持JMS...
书中通过具体实例讲解了两种会话Bean的开发过程,包括创建只包含远程接口、本地接口或两者都包含的无状态会话Bean的方法,以及有状态会话Bean的开发流程。此外,还探讨了会话Bean的生命周期管理、JNDI名称的修改、...
本指南结合了EJB3.0的最新规范,以及JBoss应用程序服务器的实践经验,旨在帮助读者掌握EJB3.0开发的精髓。 EJB3.0标准带来了许多显著的改进,其中最重要的是简化了API,降低了开发复杂性。它引入了注解...
4. **无状态会话Bean和有状态会话Bean**:EJB 3.0支持无状态会话Bean,用于执行独立的操作,以及有状态会话Bean,用于维护客户端会话状态。通过注解可以轻松地定义这些Bean的行为。 5. **消息驱动Bean**:消息驱动...
- **无状态和有状态会话Bean**:这两种类型的Bean分别用于处理独立的业务操作和保持用户会话状态。EJB 3.0对它们的使用和管理进行了优化。 - **消息驱动Bean**:这种类型的Bean用于处理异步消息,是实现解耦和响应式...
2. **会话Bean(Session Beans)**:会话Bean负责业务逻辑处理,分为无状态会话Bean和有状态会话Bean。无状态会话Bean适用于不维护会话状态的情况,而有状态会话Bean可以保存用户会话信息。EJB 3.0中,会话Bean也...
6. **无状态会话bean和有状态会话bean**:`@Stateless` bean不保存实例变量,适合一次性操作;`@Stateful` bean可以保存实例变量,适用于需要保持用户会话或计算状态的场景。 7. **消息驱动bean**:`@MessageDriven...
无状态会话Bean(@Stateless)不保存任何客户端特定的信息,适合执行无状态的业务逻辑。而有状态会话Bean(@Stateful)可以维护与客户端的会话状态,适合于需要记住用户状态的应用场景。开发者可以根据需求选择合适...
通过本文档,我们了解了EJB 3.0的开发环境搭建过程,以及如何编写和部署一个简单的无状态会话bean。同时,也介绍了客户端如何调用服务器端的服务。EJB 3.0通过其简洁的API和注解支持大大简化了企业级Java应用的开发...
EJB3.0的核心特性包括注解驱动、实体Bean的简化、容器管理的持久性(CMP)以及无状态会话Bean和有状态会话Bean的增强。 1. **MyEclipse7.0**:这是一款强大的Java EE集成开发工具,支持多种服务器配置,包括JBoss。在...