・客户端与服务端必须有一致的基于字符串的名字.它没有在编译时得到认证或在布署时得到检查.
・从JNDI返回的服务对象的类型没有在编译时进行检查,有可能在运行时出现转换(casting)错误.
・冗长的查找代码,有着自己的try-catch代码块,在应用之间是重复的和杂乱的
EJB 3.0,对任何POJO,提供了一个简单的和优雅的方法来解藕服务对象和资源.使用@EJB注释,你可以将EJB存根对象注入到任何EJB 3.0容器管理的POJO中.如果注释用在一个属性变量上,容器将会在它被第一次访问之前赋值给它.在Jboss下一版本中@EJB注释从javax.annotation包移到了javax.ejb .
下面的例子演示了怎样把HelloWorldBean无状态session bean的存根注入到InjectionBean类中.
java 代码
- InjectionBean.java
- package com.foshanshop.ejb3.impl;
- import com.foshanshop.ejb3.HelloWorld;
- import com.foshanshop.ejb3.Injection;
- import javax.annotation.EJB;
- import javax.ejb.Remote;
- import javax.ejb.Stateless;
- @Stateless
- @Remote ({Injection.class})
- public class InjectionBean implements Injection {
- @EJB (beanName="HelloWorldBean")
- HelloWorld helloworld;
- public String SayHello() {
- return helloworld.SayHello("注入者");
- }
- }
@EJB注释的beanName属性指定EJB的类名(不带包名),他的另一个属性mappedName指定Bean实例的JNDI名.
下面的片断演示了如何使用beanName或mappedName属性查找HelloWorldBean 会话bean
java 代码
- public class InjectionBean implements Injection {
- @EJB (beanName="HelloWorldBean")
- //@EJB (mappedName="HelloWorldBean/remote")
- HelloWorld helloworld;
- ..
@EJB注释如果被用在JavaBean风格的setter方法上时,容器会在属性第一次使用之前,自动地用正确的参数调
用bean的setter方法.下面的片断演示了这是如何做的
java 代码
- public class InjectionBean implements Injection {
- HelloWorld helloworld;
- @EJB (beanName="HelloWorldBean")
- public void setHelloworld(HelloWorld helloworld) {
- this.helloworld = helloworld;
- }
- ..