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

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

主站蜘蛛池模板: 长宁县| 武义县| 兰溪市| 通山县| 大竹县| 招远市| 巴彦县| 清新县| 商河县| 彰化市| 灌阳县| 峡江县| 邳州市| 衡南县| 葫芦岛市| 兴仁县| 台前县| 若羌县| 淮南市| 灌云县| 衡南县| 宕昌县| 二连浩特市| 德清县| 鄱阳县| 什邡市| 都江堰市| 天水市| 花垣县| 什邡市| 子洲县| 电白县| 翁源县| 长海县| 乌什县| 汝阳县| 东光县| 玛纳斯县| 黎平县| 南汇区| 贵德县|