官术网_书友最值得收藏!

  • EJB 3 Developer Guide
  • Michael Sikora
  • 526字
  • 2021-07-02 11:34:54

Local Interfaces

Up to this point all our examples have used the session bean remote interface, as the clients have run in their own JVM outside the EJB container. Behind the scenes, a remote interface uses the RMI-IIOP protocol for network operations. This protocol stipulates that method arguments are passed by value and not by reference. Passing by value means that an object being passed from the client to the remote bean, or vice versa, is first serialized then passed over the network then deserialized. This all has an impact in terms of performance. Even if our client is a session bean invoking another in the same container there is a performance overhead if we use a remote interface because of the serialization and deserialization taking place. For this reason EJB technology provides a local interface option for session beans. Method arguments are passed by reference and not by value so improving performance.

To illustrate all this we shall create a stateless session bean which will be invoked by and run in the same EJB container, as our original TimeServiceBean. This invoked bean will just return the string Have a Nice Day. First we define the beans interface, NiceDayService :

package ejb30.session;
import javax.ejb.Local;
@Local
public interface NiceDayService {
public String getMessage();
}

Note that we have prefixed the interface definition with the @Local annotation. This indicates to the EJB container that this bean may only be invoked by a local client running in the same container. The interface consists of just one method definition, getMessage(). Next we look at the bean implementation, NiceDayServiceBean :

package ejb30.session;
import java.util.*;
import javax.ejb.Stateless;
@Stateless
public class NiceDayServiceBean implements NiceDayService {
public String getMessage() {
return " - Have a Nice Day";
}
}

This is all straightforward. We note that the session bean is stateless and the getMessage() method returns the string - Have a Nice Day.

Now let's look as to how we might modify the TimeServiceBean to invoke NiceDayService. The TimeServiceBean will append the NiceDayService message to the current time. Here is the modified code for TimeServiceBean :

package ejb30.session;
import java.util.*;
import javax.ejb.Stateless;
import javax.ejb.EJB;
@Stateless
public class TimeServiceBean implements TimeService {
private @EJB NiceDayService niceDay;
public String getTime() {
Formatter fmt = new Formatter();
Calendar cal = Calendar.getInstance();
fmt.format("%tr", cal);
return fmt.toString() +
niceDay.getMessage();
}
}

We use the @EJB annotation to instruct the container to lookup the NiceDayService bean and inject a bean reference into the niceDay field. Recall this is an example of field injection. We can then invoke the niceDay.getMessage() method.

An alternative to field injection is setter injection. In this case a method rather than a field is annotated. The following version of TimeServiceBean uses setter injection:

@Stateless
public class TimeServiceBean implements TimeService {
private NiceDayService niceDay;
public String getTime() {
Formatter fmt = new Formatter();
Calendar cal = Calendar.getInstance();
fmt.format("%tr", cal);
return fmt.toString() + niceDay.getMessage();
}
@EJB public void setNiceDay(NiceDayService niceDay) { this.niceDay = niceDay; }
}

By annotating the setNiceDay() method with the @EJB annotation, we are instructing the container to lookup the NiceDayService bean, then invoke the setNiceDay() method passing the NiceDayService bean reference as a parameter to setNiceDay().

主站蜘蛛池模板: 高雄市| 土默特右旗| 武强县| 常山县| 海宁市| 常山县| 临夏市| 新宁县| 舒兰市| 友谊县| 威宁| 金沙县| 肇东市| 永州市| 桓台县| 西贡区| 房产| 长武县| 郎溪县| 微博| 华容县| 清镇市| 南宫市| 巴中市| 黔南| 吉林市| 涡阳县| 四平市| 正蓝旗| 呼玛县| 万荣县| 彭阳县| 巴彦淖尔市| 丰镇市| 梅河口市| 襄樊市| 内江市| 青神县| 兰溪市| 志丹县| 云南省|