会话Bean开发全解析:从基础到高级特性
立即解锁
发布时间: 2025-08-18 02:36:47 订阅数: 3 

### 会话 Bean 开发全解析:从基础到高级特性
在企业应用开发中,会话 Bean 是非常重要的组件,它能够帮助我们更高效地实现业务逻辑。下面将详细介绍会话 Bean 开发中的关键知识点和操作方法。
#### 1. 完成客户端开发
要完成客户端开发,只需在远程接口上添加对 `echo()` 方法的调用。执行客户端的步骤如下:
- 右键单击企业应用项目,选择“Run”。
- 几秒后,会弹出一个信息对话框,显示会话 Bean 方法的输出。
这种部署方式的客户端利用了 Java Web Start 技术,它可以在客户端工作站上运行,也可以通过 URL 执行。NetBeans 企业应用客户端模块的 Web Start URL 默认格式为企业项目名称加上应用客户端模块名称。例如:`http://localhost:8080/SessionBeanIntro/SessionBeanIntro-app-client`。不过需要注意的是,在撰写本文时,此过程在 Google Chrome 中无法正常工作。
#### 2. 会话 Bean 事务管理
EJB 的一个优势是能自动处理事务,但为了更好地控制事务管理,仍需进行一些配置。事务允许我们执行方法中的所有步骤,如果其中一个步骤失败(例如抛出异常),则回滚该方法中所做的更改。
主要需要配置的是,当事务正在进行时调用 Bean 的方法,该方法应如何处理。可以通过 `@TransactionAttribute` 注解来配置这些行为,该注解允许我们控制 EJB 方法在事务进行中和无事务进行时的行为。以下是 `@TransactionAttribute` 注解的不同取值及其含义:
| @TransactionAttribute 值 | 事务进行时调用方法 | 无事务时调用方法 |
| --- | --- | --- |
| TransactionAttributeType.MANDATORY | 方法成为现有事务的一部分 | 抛出 TransactionRequiredException |
| TransactionAttributeType.NEVER | 抛出 RemoteException | 方法在无事务支持下执行 |
| TransactionAttributeType.NOT_SUPPORTED | 客户端事务暂时挂起,方法在无事务支持下执行,然后恢复客户端事务 | 方法在无事务支持下执行 |
| TransactionAttributeType.REQUIRED | 方法成为现有事务的一部分 | 为该方法创建一个新事务 |
| TransactionAttributeType.REQUIRES_NEW | 客户端事务暂时挂起,为该方法创建一个新事务,然后恢复客户端事务 | 为该方法创建一个新事务 |
| TransactionAttributeType.SUPPORTS | 方法成为现有事务的一部分 | 方法在无事务支持下执行 |
`@TransactionAttribute` 注解可以用于修饰 EJB 的类声明,也可以用于修饰单个方法。如果用于修饰类声明,声明的事务行为将应用于 Bean 中的所有方法;如果用于修饰单个方法,则仅影响该修饰的方法。如果 Bean 在类级别和方法级别都有 `@TransactionAttribute` 注解,方法级别的注解优先。如果未为方法指定事务属性,则默认使用 `TransactionAttributeType.REQUIRED` 属性。
以下是使用 `@TransactionAttribute` 注解的示例代码:
```java
package com.ensode.sessionbeanintro.ejb;
import javax.ejb.Stateless;
import javax.ejb.TransactionAttribute;
import javax.ejb.TransactionAttributeType;
@Stateless
public class Echo
@override
@TransactionAttribute(
TransactionAttributeType.REQUIRES_NEW)
public String echo(String.saying) {
return "echoing: " + saying;
}
}
```
#### 3. 使用拦截器实现面向切面编程(AOP)
有时候,我们希望在方法的主要逻辑执行前后执行一些逻辑,例如测量方法的执行时间以跟踪性能问题,或者在每次进入和离开方法时记录日志以方便调试。传统的方法是在每个方法的开头和结尾添加代码来实现这些逻辑,但这种方法存在一些问题,如逻辑需要多次实现,且后续修改或移除功能时需要修改多个方法。
AOP 是一种编程范式,它通过在单独的类中实现方法主要逻辑前后执行的逻辑,解决了上述问题。EJB 3.0 引入了通过拦截器实现 AOP 的功能,具体步骤如下:
- **实现拦截器类**:拦截器是一个标准的 Java 类,必须有一个具有以下签名的方法:
```java
@AroundInvoke
public Object methodName(InvocationContext invocationContext) throws Exception
```
该方法必须用 `@AroundInvoke` 注解修饰,`InvocationContext` 参数可用于获取被拦截方法的信息,如方法名、参数、声明该方法的类等。`InvocationContext` 还有一个 `proceed()` 方法,用于指示何时执行方法逻辑。
以下是一些常用的 `InvocationContext` 方法:
| 方法名 | 描述 |
| --- | --- |
| getMethod() | 返回 `java.lang.reflect.Method` 类的实例,可用于内省被拦截的方法 |
| getParameters() | 返回包含传递给被拦截方法的参数的对象数组 |
| getTarget() | 返回包含正在调用的方法的对象,返回值类型为 `java.lang.Object` |
| proceed() | 调用被拦截的方法 |
以下是一个简单的拦截器类示例:
```java
package com.ensode.sessionbeanintro.ejb;
import java.lang.reflect.Method;
import javax.interceptor.AroundInvoke;
import javax.interceptor.InvocationContext;
public class LoggingInterceptor {
@AroundInvoke
public Object logMethodCall(
InvocationContext invocationContext)
throws Exception {
Object interceptedObject =
invocationContext.getTarget();
Method interceptedMethod =
invocationContext.getMethod();
System.out.println("Entering " +
interceptedObject.getClass().getName() + "." +
interc
```
0
0
复制全文
相关推荐









