EJB3.0---Stateless session bean

news/2024/6/29 12:17:30 标签: bean, session, ejb, jboss, include, ant

ejb分为三大类六小类,三大类分别是:entity bean(实体),负责和数据库的连接及ORM,也就是持久层的工作;session bean ,一般用来处理用户业务;message drive bean,用来处理异步消息。其中jboss的entity bean实在Hibernate之上实现的,因此,如果你对之比较了解,那么用起来会得心应手,但是如果从来都没接触过,那么就不免头大了!不果没关系,我会循序渐进,一步一步来的!

那么六小类呢?分别是entity bean 分为CMB和BMB,什么意思?CMB是容器管理bean的意思,BMB是bean管理bean的意思。他们两个的主要分别就是事务的管理有谁负责的问题,顾名思义,看你看到,一个是容器管,另一个是自己管。不过一般推荐CMB,因为这样相对简单,不容易出错;但是,如果CMB无法满足你的要求,那只有用bmb了。

第二组是session bean分为stateless 和stateful两种。分别就是,stateless只有一个实例,也就是说所有的用户如果使用的话,那么点用的就是那唯一的实例(singleton),如果内容上一次有改变,那么下一次调用,无论是谁调用,都可以看到。等一会儿,我们会详细解释。stateful呢?是相对于每个用户都创建一个实例,不同的用户数据互不相干,最经典的应用就是购物车。

第三组是MDB分为主体MDB(topic)和队列MDB(queue)。他们只是发送消息的目的地不一样,队列是发送给一个队列,一般是一个MDB的队列,也就是说对应的是单个的MDB;主题方式则是把消息是发送到主题,凡在监听主题的MDB都可以得到消息。我们上一次最后实验的MDB就是面向队列的。

好了,以上把ejb的总体范围都讲清楚了,下面开始我们的stateless session bean

stateless session bean的生命周期是这样的:一般是在第一次调用时创建,直到应用服务器关闭时销毁,当然,也可以设置服务器,让他超时销毁。

下面我们看一段代码:

package org.jboss.tutorial.stateless.bean;

import Javax.ejb.Stateless;

@Stateless
public class CalculatorBean implements CalculatorRemote, CalculatorLocal
{

int =0;
public int add(int x)
{
return e =x;
}

public int subtract(int x)
{
return e-=x;
}
}

注意到标记@Stateless了吗?就是他指明了是Stateless,比起原来在配置文件中写是不是明了很多?同样还有import javax.ejb.Stateless,这一句可是至关重要的,仔细看看会发现程序中没有别的地方用到这个包,唯一可能用到的就是@Stateless,明白了吗?

标记@Stateless并不是那么简单,它是一个接口的实现描述,也就是说和implements Stateless效果雷同,但是这样醒目方便多了。

stateless一定要实现至少一个接口(local或remote),本例中Both。

来看看借口文件:

package org.jboss.tutorial.stateless.bean;

import javax.ejb.Remote;

@Remote
public interface CalculatorRemote extends Calculator
{

}

-----------------------------------------------------------

package org.jboss.tutorial.stateless.bean;

import javax.ejb.Local;

@Local
public interface CalculatorLocal extends Calculator
{
}

一个远程,一个本地,两个接口, 分别用标记@Remote和@Local来标注!什么?你不知道远程和本地有什么作用?我的天!你该找本书看看,而不是在这看这篇文章。

下面是业务接口:

package org.jboss.tutorial.stateless.bean;

public interface Calculator
{
int add(int x);

int subtract(int x);
}

等一会儿在client中会用到。

下面我们看一看client :

package org.jboss.tutorial.stateless.client;

import org.jboss.tutorial.stateless.bean.Calculator;
import org.jboss.tutorial.stateless.bean.CalculatorRemote;

import javax.naming.InitialContext;

public class Client
{
public static void main(String[] args) throws Exception
{
InitialContext ctx = new InitialContext();
Calculator calculator = (Calculator) ctx.lookup(CalculatorRemote.class.getName());

System.out.println("e 1 = " calculator.add(1));

System.out.println("e - 1 = " calculator.subtract(1));
}
}

我们先解释一下,因为后面的客户端和这个结构基本相同,一劳永逸,何乐而不为呢?

InitialContext ctx = new InitialContext();

这一句是设置环境变量,可以看到没有初始化参数,这是因为默认的参数是本机,可以不设置,以后会有需要设置的地方,我们再讲。

Calculator calculator = (Calculator) ctx.lookup(CalculatorRemote.class.getName());

这一句通过环境变量得到操作句柄。ctx.lookup(CalculatorRemote.class.getName())返回的是一个object对象,需要强制转换。

System.out.println("e 1 = " calculator.add(1));

调用并输出!

OK!

That's all!

下面要编译打包:(使用ANT)

<?XML version="1.0"?>

<!-- ======================================================================= -->
<!-- JBoss build file -->
<!-- ======================================================================= -->

<project name="JBoss" default="ejbjar" basedir=".">

<property environment="env"/>
<property name="src.dir" value="${basedir}/src"/>
<property name="jboss.home" value="${env.JBOSS_HOME}"/> <property name="jboss.server.config" value="all"/>

 

<property name="build.dir" value="${basedir}/build"/>
<property name="build.classes.dir" value="${build.dir}/classes"/>

 

<!-- Build classpath -->
<path id="classpath">
<!-- So that we can get jndi.properties for InitialContext -->
<pathelement location="${basedir}"/>
<fileset dir="${jboss.home}/lib">
<include name="**/*.jar"/>
</fileset>
<fileset dir="${jboss.home}/server/${jboss.server.config}/lib">
<include name="**/*.jar"/>
</fileset>
<fileset dir="${jboss.home}/server/${jboss.server.config}/deploy/ejb3.deployer">
<include name="*.jar"/>
</fileset>
<fileset dir="${jboss.home}/server/${jboss.server.config}/deploy/jboss-aop-JDK50.deployer">
<include name="*.jar"/>
</fileset>
<pathelement location="${build.classes.dir}"/>
</path>

<property name="build.classpath" refid="classpath"/>

<!-- =================================================================== -->
<!-- Prepares the build directory -->
<!-- =================================================================== -->
<target name="prepare">
<mkdir dir="${build.dir}"/>
<mkdir dir="${build.classes.dir}"/>
</target>

<!-- =================================================================== -->
<!-- Compiles the source code -->
<!-- =================================================================== -->
<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/tutorial.ejb3">
<fileset dir="${build.classes.dir}">
<include name="**/*.class"/>
</fileset>
</jar>
<copy file="build/tutorial.ejb3" todir="${jboss.home}/server/${jboss.server.config}/deploy"/>
</target>

<target name="run" depends="ejbjar">
<java classname="org.jboss.tutorial.stateless.client.Client" fork="yes" dir=".">
<classpath refid="classpath"/>
</java>
</target>

<!-- =================================================================== -->
<!-- Cleans up generated stuff -->
<!-- =================================================================== -->
<target name="clean.db">
<delete dir="${jboss.home}/server/${jboss.server.config}/data/hypersonic"/>
</target>

<target name="clean">
<delete dir="${build.dir}"/>
<delete file="${jboss.home}/server/${jboss.server.config}/deploy/tutorial.ejb3"/>
</target>


</project>

哈哈!这是ant的build.xml文件,讲解一下:

我们输入指令ANT时,ant会在当前目录下找build.xml,然后根据文件内容运行。

如果输入的仅仅是ant,则会执行default="ejbjar" 任务,depends="compile"是递归调用,必须在本任务执行之前完成的。

如果输入的是ant run ,则会执行run任务,即上面蓝色的部分。

上面的文件中,还有<copy file="build/tutorial.ejb3" todir="${jboss.home}/server/${jboss.server.config}/deploy"/>

这已经属于部署了,它把文件拷到jboss的部署目录下。jboss只要把文件拷过去,自己可以完成所有部署任务。

ok!

Let's ant!

And then ant run!

what do you see?

error?

要注意上面文件的路径,我忘了讲,自己看看吧!说不定会豁然开朗的!!

——————————END————————————

上一篇: osworkflow api 之 util
下一篇: jsp中 java ,html/javascript 交互

 

http://www.west263.com


http://www.niftyadmin.cn/n/1049891.html

相关文章

JQuery 对checkbox 全选/取消全选

<html> <head> <script language"javascript"> $(document).ready(function(){ $("#qx").click(function() { if ($(this).attr("checked") true) { //全选 $("input[nameyf]").each(function(){ $(this).attr(&quo…

JAVA Excel API 实现对Excel表格的读写更新

package myexceltest; import jxl.*;import Java.io.*;import jxl.write.*;/*** <p>java读取Excel表格,拷贝、更新Excel工作薄 </p>* <p>Description: Java开发人员可以读取Excel文件的内容,更新Excel工作薄,开发人员* 也可以用程序生成新的Excel表格,不过我…

NodeParty杭州站第二期系列讲座

2019独角兽企业重金招聘Python工程师标准>>> http://www.howzhi.com/course/179/lesson/1497 转载于:https://my.oschina.net/u/200898/blog/188992

基于SET协议的电子支付系统模块设计

基于Internet的电子商务以其具有传统商务模式不可比拟的优点而在当今世界蓬勃发展。电子商务发展的关键问题就是交易的安全性&#xff0c;也就是网络上的信息安全&#xff0c;即网上电子支付的安全实现。SET安全电子交易协议是由Visa和MasterCard公司于1997年5月联合开发的&…

jqGrid 属性中文详解(一)

以下内容描述格式是&#xff1a;属性名称   参数值类型   描述内容(可能有多行)   默认值   是否可修改(表示grid创建完成之后&#xff0c;该属性是否能够被修改。也就是说&#xff0c;是否grid的初始化的属性值能够被修改)   ————详细属性列表————   ajax…

Discuz的缓存体系

参考文档&#xff1a;<http://dev.discuz.org/wiki/index.php?title缓存机制> Discuz中涉及数据缓存的地方有&#xff1a; 1. session Dz的session只保存了登陆状态&#xff0c;不是我们理解的保存整个会话状态的概念2. cache3. syscache4. memory 我们通常意义上的缓存…

jqGrid 属性(二)

该属性不能修改   savedRow   array   只读属性。本属性用在Inline Editing和Cell Editing模式下&#xff0c;用来在编辑行或者单元格之前保存数据。   默认值:empty array   该属性不能修改 scroll   boolean or integer   创建一个动态滚动的grid。如果本属性可…

Java Socket

所谓socket通常也称作"套接字"&#xff0c;用于描述IP地址和端口&#xff0c;是一个通信链的句柄。应用程序通常通过"套接字"向网络发出请求或者应答网络请求。本文将Java Socket编程分为三个学习步骤&#xff0c;逐一为您讲解。 第一步 充分理解Socket 1…