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

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().

主站蜘蛛池模板: 北安市| 清苑县| 镇康县| 白朗县| 集安市| 河北区| 郸城县| 峨山| 襄城县| 阿坝| 克山县| 湛江市| 遂川县| 武邑县| 卫辉市| 泰和县| 措美县| 宜州市| 霍山县| 南漳县| 怀集县| 遂川县| 尼勒克县| 西宁市| 南投市| 宜丰县| 泗洪县| 牡丹江市| 阿克苏市| 富锦市| 漯河市| 南京市| 怀来县| 河曲县| 静海县| 涿鹿县| 怀化市| 珠海市| 景谷| 延长县| 基隆市|