|
|||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||
SUMMARY: REQUIRED | OPTIONAL | DETAIL: ELEMENT |
@Target(value={TYPE,FIELD,METHOD}) @Retention(value=RUNTIME) public @interface Resource
The Resource annotation marks a resource that is needed by the application. This annotation may be applied to an application component class, or to fields or methods of the component class. When the annotation is applied to a field or method, the container will inject an instance of the requested resource into the application component when the component is initialized. If the annotation is applied to the component class, the annotation declares a resource that the application will look up at runtime.
Even though this annotation is not marked Inherited, deployment tools are required to examine all superclasses of any component class to discover all uses of this annotation in all superclasses. All such annotation instances specify resources that are needed by the application component. Note that this annotation may appear on private fields and methods of superclasses; the container is required to perform injection in these cases as well.
Optional Element Summary | |
---|---|
Resource.AuthenticationType |
authentication
The authentication type to use for this resource. |
String |
description
Description of this resource. |
String |
mappedName
A product specific name that this resource should be mapped to. |
String |
name
The JNDI name of the resource. |
boolean |
shareable
Indicates whether this resource can be shared between this component and other components. |
Class |
type
The Java type of the resource. |
public abstract String name
public abstract Class type
public abstract Resource.AuthenticationType authentication
public abstract boolean shareable
public abstract String mappedName
name
element or defaulted, is a name that is local to the application
component using the resource. (It's a name in the JNDI
java:comp/env
namespace.) Many application servers
provide a way to map these local names to names of resources
known to the application server. This mapped name is often a
global JNDI name, but may be a name of any form. Application servers are not required to support any particular form or type of mapped name, nor the ability to use mapped names. The mapped name is product-dependent and often installation-dependent. No use of a mapped name is portable.
public abstract String description
|
|||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||
SUMMARY: REQUIRED | OPTIONAL | DETAIL: ELEMENT |
Copyright 2007 Sun Microsystems, Inc. All rights reserved. Use is subject to license terms.