:class=ExamplesTable}

- javax.ejb.Local - javax.ejb.Stateless - javax.ejb.Stateful - javax.annotation.PreDestroy - javax.ejb.ConcurrencyManagement - javax.ejb.Lock - javax.ejb.Singleton - javax.ejb.Startup - javax.ejb.ConcurrencyManagementType.BEAN - javax.ejb.LockType.READ - javax.ejb.LockType.WRITE - javax.ejb.EJBHome - javax.ejb.EJBLocalHome - javax.ejb.EJBLocalObject - javax.ejb.EJBObject - javax.ejb.Init - javax.ejb.Local - javax.ejb.LocalHome - javax.ejb.Remote - javax.ejb.RemoteHome - javax.ejb.Remove - javax.ejb.Stateful - javax.ejb.Local - javax.ejb.Remote - javax.ejb.Stateful - javax.ejb.Stateless - javax.ejb.Local - javax.ejb.Remote - javax.ejb.Stateless - javax.annotation.Resource - javax.ejb.Stateful - javax.sql.DataSource - javax.persistence.Entity - javax.persistence.EntityManager - javax.persistence.PersistenceContext - javax.persistence.PersistenceContextType.EXTENDED - javax.persistence.Query - javax.ejb.Stateless - javax.ejb.TransactionAttribute - javax.ejb.TransactionAttributeType.MANDATORY - javax.ejb.TransactionAttributeType.REQUIRES_NEW - javax.persistence.Entity - javax.persistence.EntityManager - javax.persistence.PersistenceContext - javax.persistence.PersistenceContextType.TRANSACTION - javax.persistence.Query - javax.annotation.security.RolesAllowed - javax.annotation.security.RunAs - javax.ejb.EJBAccessException - javax.ejb.Stateful - javax.ejb.Stateless - javax.ejb.TransactionAttribute - javax.ejb.TransactionAttributeType.SUPPORTS - javax.persistence.Entity - javax.persistence.EntityManager - javax.persistence.PersistenceContext - javax.persistence.PersistenceContextType.EXTENDED - javax.persistence.Query - javax.ejb.Stateful - javax.ejb.EJBLocalHome - javax.ejb.EJBLocalObject - javax.ejb.LocalHome - javax.ejb.Stateless
}
title description APIs used
{div:class=Cel1}*[Simple Stateless](simple-stateless-example.html) *{div} Simple EJB3 *@Stateless* bean with local and remote business interfaces and unit test. - javax.ejb.Remote
*[Simple Stateful](simple-stateful-example.html) * Simple EJB3 *@Stateful* bean with local and remote business interfaces and unit test. - javax.ejb.Remote
*[EJB 3.1 Singleton](singleton-example.html) * Shows two EJB 3.1 *@Singleton* beans. One configured to load on startup via *@Startup* and using Bean-Managed Concurrency and synchronization. Another using Container-Managed Concurrency via *@Lock(READ)* and *@Lock(WRITE)*. - javax.annotation.PostConstruct
*[EJB 2.1 Compatibility](ejb-2.1-compatibility-example.html) * Shows an EJB 3.0 Stateful bean with Business interfaces and EJB 2.1 interfaces (now called "component" interfaces) using the *@LocalHome* and *@RemoteHome*. Four interfaces in total. - javax.ejb.CreateException
*[Injection of env-entry](injection-of-env-entry-example.html) * Shows how *@Resource* can be used to inject **env-entry** values declared in an ejb-jar.xml file - javax.annotation.Resource
*[Injection of env-entry 2](custom-injection.html) * Same as the above example but shows how to use a *properties file* to declare the injection values and demonstrates how to get injection of *more types* such as java.util.Date, java.lang.Class, java.net.URI and more. _OpenEJB specific feature_. - javax.annotation.Resource
*[Injection of other EJBs](injection-of-other-ejbs-example.html) * Shows use of *@EJB* in a Stateless to have another Stateless bean injected into it. - javax.ejb.EJB
*[Injection of DataSource](injection-of-datasource-example.html) * Shows use of *@Resource* to have a JDBC *DataSource* injected into a Stateful bean. The Stateful bean does basic INSERT, SELECT and DELETE SQL operations. - javax.annotation.PostConstruct
*[Injection of EntityManager](injection-of-entitymanager-example.html) * Shows use of *@PersistenceContext* to have an *EntityManager* with an *EXTENDED* persistence context injected into a @Stateful bean. An EJB 3 *@Entity* bean is used with the EntityManager to create, persist and merge data to a database. - javax.ejb.Stateful
*[Testing Transactions](testing-transactions-example.html) * Shows use of @PersistenceContext to have an *EntityManager* with an *TRANSACTION* persistence context injected into a *@Stateful* bean using the *@TransactionAttribute* annotation and a TestCase that runs test code in a JTA *Transaction*. An EJB 3 @Entity bean is used with the EntityManager to create, persist and merge data to a database. - javax.ejb.Stateful
*[Testing Security](testing-security-example.html) * Builds upon the [Injection of EntityManager Example] but adds the use of *@RolesAllowed* and *@PermitAll* in the @Stateful bean to restrict who can perform create, persist and remove operations on the EntityManager. Shows a TestCase using the *@RunAs* annotation to execute and test the bean code as various users. - javax.annotation.security.PermitAll
*[Embedded and Remotable](embedded-and-remotable.html) * Demonstrates how to use an OpenEJB feature that allows people embedding OpenEJB into their applications to support remote clients in other VMs. This is not required for unit testing. - javax.ejb.Remote
*[Helloworld Weblogic](helloworld-weblogic.html) * Demonstrates OpenEJBs ability to understand and support the WebLogic deployment descriptors so people using that platform in production can still use OpenEJB in their IDE or build to unit test their EJB applications. - javax.ejb.CreateException
*[JSF Injection Support](jsf-injection-support.html) * Demonstrates OpenEJBs ability to inject EJB's into JSF managed beans. - javax.ejb.Stateless
*[Struts with OpenEJB and Tomcat](struts-with-openejb-and-tomcat.html) * Demonstrates the usage of Struts within an OpenEJB + Tomcat environment. - javax.ejb.Stateless
*[Applets with OpenEJB](applets-with-openejb.html) * Demonstrates how an applet can communicate with a remote stateless session bean. The stateless session bean is deployed in an OpenEJB + Tomcat environment - javax.ejb.Stateless

Copyright © 1999-2016 The Apache Software Foundation, Licensed under the Apache License, Version 2.0. Apache TomEE, TomEE, Apache, the Apache feather logo, and the Apache TomEE project logo are trademarks of The Apache Software Foundation. All other marks mentioned may be trademarks or registered trademarks of their respective owners.