EJB Annotations: Difference between revisions
Line 50: | Line 50: | ||
=@PreDestroy= | =@PreDestroy= | ||
The @PreDestroy annotation is used on a method to be invoked by the container when it intents the remove the component instance. Such methods are typically used to release resources that the component has been holding. This annotation must be supported by all container managed components that support [[#|@PostConstruct]]. | The @PreDestroy annotation is used on a method to be invoked by the container when it intents the remove the component instance. Such methods are typically used to release resources that the component has been holding. This annotation must be supported by all container managed components that support [[#.40javax.annotation.PostConstruct|@PostConstruct]]. | ||
Revision as of 00:40, 6 April 2017
Internal
Overview
If an XML deployment descriptor containing the same semantics exists, the XML content overrides the annotation.
@javax.ejb.EJB
Used to request the container to inject a reference to an EJB.
@EJB private MyBusinessInterface myEjb;
The @EJB annotation is processed as follows:
- The JAR of the referencing bean is searched for an EJB with the interface used in the @EJB injection. If there are more than one EJB that publishes the same business interface, an exception is thrown, otherwise the matching bean is returned.
- The EAR of the deployment is searched. If there are duplicates, an exception is thrown, otherwise the matching bean is returned.
- Search globally in the JBoss instance runtime for an EJB of that interface. If there are duplicates, an exception is thrown, otherwise the matching bean is returned.
beanName
The value optionally specified here corresponds to <ejb-link>. If beanName is defined, the algorithm described above is used, except that beanName is used as key in the search. The "#" syntax allows to put a relative path to a jar in the EAR where the EJB you are referencing is located. More details in the EJB 3.1 specification.
mappedName
The annotation has a "mappedName()" attribute. The specification designates it as vendor specific metadata. JBoss uses this metadata to specify the global JNDI name of the EJB. If mappedName() is specified, all other attributes (name, description, beanName, beanInterface, lookup) are ignored and this global JNDI name is used for binding.
@EJB(mappedName = "/somehting/something") private MyBusinessInterface myEjb;
For a working example, see Session EJB and Servlet in Different Deployment Units on Same JBoss Instance.
@javax.annotation.Resource
@javax.ejb.Remote
@javax.ejb.Local
@javax.annotation.PostConstruct
The @PostConstruct annotation is used on a method that needs to be executed after dependency injection is done into the component. The method such annotated is understood to perform initialization of the component. Only one method per component can be annotated with this annotation. The annotated method must not have any parameters (except in the case of interceptors in which case it takes an InvocationContext instance. The method may be public, protected, package private or private, but not static. It can be declared final. If the method throws an unchecked exception, the component must not be put into service except in the case of EJBs where the EJB can handle exceptions.
@PreDestroy
The @PreDestroy annotation is used on a method to be invoked by the container when it intents the remove the component instance. Such methods are typically used to release resources that the component has been holding. This annotation must be supported by all container managed components that support @PostConstruct.
that needs to be executed after dependency injection is done into the component. The method such annotated is understood to perform initialization of the component. Only one method per component can be annotated with this annotation. The annotated method must not have any parameters (except in the case of interceptors in which case it takes an InvocationContext instance. The method may be public, protected, package private or private, but not static. It can be declared final. If the method throws an unchecked exception, the component must not be put into service except in the case of EJBs where the EJB can handle exceptions.
* except the application client container in Java EE 5. The method on which * the PreDestroy annotation is applied MUST fulfill all of the following * criteria:
*