package com.oreilly.jent.ejb.stateful;
/**
* In general, you may use the code in this book in your programs and
* documentation. You do not need to contact us for permission unless
* you're reproducing a significant portion of the code. For example,
* writing a program that uses several chunks of code from this book does
* not require permission. Selling or distributing a CD-ROM of examples
* from O'Reilly books does require permission. Answering a question by
* citing this book and quoting example code does not require permission.
* Incorporating a significant amount of example code from this book into
* your product's documentation does require permission.
*
* We appreciate, but do not require, attribution. An attribution usually
* includes the title, author, publisher, and ISBN. For example:
*
* "Java Enterprise in a Nutshell, Third Edition,
* by Jim Farley and William Crawford
* with Prakash Malani, John G. Norman, and Justin Gehtland.
* Copyright 2006 O'Reilly Media, Inc., 0-596-10142-2."
*
* If you feel your use of code examples falls outside fair use or the
* permission given above, feel free to contact us at
* permissions@oreilly.com.
*/
import java.util.Collection;
import java.util.HashMap;
import java.util.Iterator;
import java.util.Map;
import java.util.Properties;
import javax.ejb.SessionBean;
import javax.ejb.SessionContext;
import com.oreilly.jent.ejb.NoSuchPersonException;
// A stateful session Profile, which provides profile information
// for a named person.
// Indicate this is a stateful session bean
@Stateful(name="ProfileEJB3")
// Specify deployed resources this bean depends on
@Resource(name="ProfileDB",
resourceType="javax.sql.DataSource",
jndiName="jdbc/ProfileDB")
// Note: No need to extend the SessionBean interface
public class ProfileBeanEJB3 {
// Name of the person owning the profile
private String mName = "";
// Entries in the profile (name/value pairs)
private Properties mEntries = new Properties();
// Annotate this method as a "post-construct" lifecycle method, called
// just after the container constructs the bean
@PostConstruct initiateProfileBean() {
// Do some intialization stuff...
}
// No activate, passivate methods - we don't need them,
// no need to write them.
// Tag this as a business method, so it appears in the generated
// client interface(s)
@BusinessMethod
// Also tag this as a web method, so it will be callable from
// the SOAP interface. Note that this annotation is actually
// defined in the new JAX-RPC 2.0 spec, not in the EJB 3.0 spec.
@WebMethod
public String getName() {
return mName;
}
}
|