local stateless session hello
Stateless sessions make database queries and updates robust by setting transaction boundaries at each business method. This bean example annotates a single business method with a SUPPORTS transaction attribute, marking the method as a read-only transaction boundary.A Hello, World example for EJB 3.0 is much simpler than for earlier versions of EJB. To implement the EJB you need to implement:
To configure Resin to be a server for the EJB you need to:
In this tutorial, a simple "Hello" EJB is created and deployed within Resin.
The remote interface defines the client view of the bean.
It declares all the business methods. Our
only business method is the package example; public interface Hello { public String hello(); } The second class for EJBs is the bean implementation class. It implements the functionality provided by the remote interface. package example; import javax.ejb.Stateless; import javax.ejb.TransactionAttribute; import static javax.ejb.TransactionAttributeType.SUPPORTS; import javax.inject.Named; @Stateless public class HelloBean implements Hello { @Inject @Named("greeting") private String _greeting; @TransactionAttribute(SUPPORTS) public String hello() { return _greeting; } } @StatelessThe @Stateless annotation marks the bean as a stateless session
bean. Resin will create a stub implementing The @Stateless annotation can have an optional @NameThe @com.caucho.config.Name annotation tells Resin to lookup the
greeting In this example, the greeting is configured with an <env-entry> in the web.xml. Alternate Dependency InjectionIn some cases, it may be clearer to configure the session bean directly, rather than using Java Injection injection. Instead of creating a separate <env-entry>, you can configure the greeting value using XML straight from the resin-web.xml file. <web-app xmlns="http://caucho.com/ns/resin"> <qa:TestBean xmlns:qa="urn:java:qa"> <qa:greeting>Hello, World from web.xml</qa:greeting> </qa:TestBean> </web-app> @TransactionAttributeManaging transactions is the primary purpose of stateless
session beans. Transactions are a more powerful version of
a @javax.ejb.TransactionAttribute(SUPPORTS) public String hello() The The REQUIRED transaction value starts up a new transaction if none already exists. It's used when updating database values.
<web-app xmlns="http://caucho.com/ns/resin" xmlns:qa="urn:java:qa" xmlns:lang="urn:java:java.lang" xmlns:ee="urn:java:ee"> <lang:String ee:Named="greeting"> Hello, World </lang:String> <qa:TestBean> <ee:Stateless/> </qa:TestBean> </web-app> The <qa:TestBean> can optionally configure the bean directly with its properites as described in the alternate dependency injection section. import javax.inject.Inject; public class HelloServlet extends GenericServlet { @Inject private Hello _hello; public void service(HttpServletRequest req, HttpServletResponse res) throws IOException, ServletException { PrintWriter out = res.getWriter(); out.println(_hello.hello()); } } @EJBThe @Inject annotation tells
Resin to look for a The servlet could also lookup the Hello bean with JNDI in the
<web-app xmlns="http://caucho.com/ns/resin"> <servlet servlet-name="hello" servlet-class="example.HelloServlet"> <init hello="${Hello}"/> </servlet>
|