Preloader image

{note} This document and the related feature is considered a prototype and will change based on user feedback. All comments suggestions welcome. {note}

Introduction

The OpenEJB Spring integration makes all Spring defined beans injectable to Java EE components, and all Java EE components can be injected to Spring beans. The injection system supports arbitrarily complex nesting (e.g., Spring bean injected into a Java EE component, which is then injected into another Spring bean), including:

  • @Resouce injection of any Spring bean into EJB

  • Injection of any Java EE resource into a Spring bean, including: EJB 3.0 beans EJB 3.1 Singleton Bean JDBC Connector JMS Connector JMS Queue and Topic Generic Java EE Connector (JCA)

In addition, the OpenEJB Spring integration add support for discovery and deployment of standard Java EE packages within a Spring context, including:

  • EAR

  • EJB Jar

  • Persistence Unit

  • RAR

Requirements: * OpenEJB 3.1+ * Spring X.X * Java 1.5 or 1.6

Spring Beans

The following beans are usable in any spring xml file.

Class

Description

org.apache.openejb.spring.ClassPathApplication

Scrapes the classpath for all EJB, RAR, and Persistence applications, deploys them, and imports them into the current ApplicationContext. All applications found are treated as one big EAR unless the classpathAsEar property is set to false

org.apache.openejb.spring.Application

Scrapes an individual jar file for EJB, RAR, and Persistence applications, deploys them, and imports them into the current ApplicationContext. The 'jarFile' property is required. The application is treated as it’s own self-contained EAR, separate from other uses of 'Application'

org.apache.openejb.spring.Resource

Allows an OpenEJB to be declared in the Spring ApplicationContext

org.apache.openejb.spring.OpenEJBResource

A FactoryBean that imports a Resource from OpenEJB into the Spring ApplicationContext. Has the following properties: type such as javax.sql.DataSource, and resourceId. In the future this bean will not be required and all OpenEJB Resources will automatically be imported into the Spring ApplicationContext

org.apache.openejb.spring.BmpContainer

Allows an OpenEJB BMP to be declared in the Spring ApplicationContext. Has the following properties: poolSize

org.apache.openejb.spring.CmpContainer

Allows an OpenEJB CMP to be declared in the Spring ApplicationContext.

org.apache.openejb.spring.SingletonContainer

Allows an OpenEJB Singleton to be declared in the Spring ApplicationContext. Has the following properties: accessTimeout

org.apache.openejb.spring.StatefulContainer

Allows an OpenEJB Stateful to be declared in the Spring ApplicationContext. Has the following properties: timeOut

org.apache.openejb.spring.StatelessContainer

Allows an OpenEJB Stateful to be declared in the Spring ApplicationContext. Has the following properties: timeOut, poolSize, and strictPooling

org.apache.openejb.spring.MdbContainer

Allows an OpenEJB Message-Driven to be declared in the Spring ApplicationContext. Has the following properties: resourceAdapter, messageListenerInterface, activationSpecClass, and instanceLimit

org.apache.openejb.spring.EJB

A FactoryBean that imports an EJB from OpenEJB into the Spring ApplicationContext. One of these is automatically created for each interface of each EJB, but explicit use can be nice if you desire to import an EJB with a specific name. Has the following properties: deploymentId, interface

Examples

See the Spring EJB and JPA page for example code and a working Spring xml file.

\{anchor:problems} Problems?

If you are having problems with the installation, please send a message to the OpenEJB users mailing list containing any error message(s) and the following information:

  • OpenEJB Version

  • Spring Version

  • Java Version (execute java -version)

  • Operating System Type and Version

Limitations

JavaAgent - OpenEJB uses OpenJPA to provide JPA and CMP persistence, and OpenJPA currently requires a JavaAgent to function properly in a Java 1.5 environment. OpenJPA does not require a JavaAgent in Java 1.6. Use Hibernate as your the provider in your persistence.xml files if you wish to avoid this requirement.

EntityManager - Having an OpenEJB created EntityManager or EntityManagerFactory injected into Spring beans is currently not supported. This will be added to the next release. A small workaround for this is to use an EJB as a factory by adding a 'getEntityManager' method an using it as a Spring instance factory method .