Package examples.ejb20.basic.statefulSession
This example is a package that demonstrates an EJB written to the EJB 2.0 specification.See:
Interface Summary
Trader The methods in this interface are the public face of TraderBean. TraderHome This interface is the home interface for the TraderBean.java, which in WebLogic is implemented by the code-generated container class TraderBeanC.
Class Summary
Client This class illustrates calling a stateful SessionBean and performing the following exercises: Create a Trader Buy some shares using the Trader Sell some shares using the Trader Remove the Trader TraderBean TraderBean is a stateful SessionBean. TradeResult This class reflects the results of a buy/sell transaction.
Exception Summary
ProcessingErrorException This class is used with the examples.ejb20.statefulSession package. Package examples.ejb20.basic.statefulSession Description
This example is a package that demonstrates an EJB written to the EJB 2.0 specification. The example is a stateful session EJB called TraderBean.
The example demonstrates:
- Usage of a session EJB written to the EJB 2.0 specification
- Stateful persistence
- Using application-defined exceptions and utilities
- Client Application
Pre-Built Examples
This EJB 2.0 example is shipped pre-built. However, if you want to re-run this example, you can build it following the instructions in Build the example and then re-run it following the instructions in Run the example.
Client Application
The Client application performs these steps:The application demonstrates how repeated calls to the same session EJB have a persistent state -- the change in the cash account -- that is maintained across all the calls. Notice that neither the client nor the EJB do anything to maintain that state: the container handles it transparently. All the logic for the cash account is encapsulated in the EJB, unlike the stateless session example, where all persistence is provided by the client.
- Contacts the Trader home ("TraderHome") through JNDI to find the EJB
- Creates a Trader
- Sells shares of "MSFT"
- Buys shares of "BEAS"
- Gets the change in the cash account
(The EJB does not actually "buy" or "sell"; it simulates the actions of accessing a database)- Removes the Trader
To get the most out of this example, first read through the source code files to see what is happening.
Start with the XML deployment files ejb-jar.xml and weblogic-ejb-jar.xml to find the general structure of the EJB, which classes are used for the different objects and interfaces, then look at Client.java to see how the application works.
- Client applications
- Client.java
- Interfaces
- Trader.java
- TraderHome.java
- TradeResult.java
- Deployment
- ejb-jar.xml
- weblogic-ejb-jar.xml
- Exception
- ProcessingErrorException.java
- Server (EJBean)
- TraderBean.java
These three sections cover what to do:
Build the example
Set up your development shell as described in Setting up your environment.We provide a build script for you to build the example:
The build script is build.xml.
Run the build script using the following Java ant command:
prompt> antThe script will build the example and place the files in the correct locations in your WebLogic Server distribution:
- Client.jar file: in SAMPLES_HOME\server\examples\build\clientclasses
- EJB (in EAR file): in SAMPLES_HOME\domains\examples\applications\ejb20_basic_statefulSession.ear
Running the build script places the EJB in the %applications% directory, where it automatically deploys once the server is started. If you are already running the server and build another EJB, it is automatically placed in this directory and instantly deployed.
Additional information on using the build scripts is found in More About Building Examples.
Start the Examples server
Run the example
- Run the client in a separate command line window. Set up your client as described in Setting up your environment, and then run the client by entering:
prompt> ant run
- You should receive output similar to this:
Beginning statefulSession.Client... Creating trader Selling 200 of MSFT 200 shares sold at a price of 150.0 Buying 250 of BEAS 250 shares bought at a price of 100.0 Change in Cash Account: $5000.0 Removing trader End statefulSession.Client...There's more...
Read more about EJB in BEA WebLogic Server Enterprise Java Beans.