Enables customization of variable, property and method call resolution behavior for EL expression evaluation.
While evaluating an expression, the ELResolver
associated with the {@link ELContext} is consulted to do the initial resolution of the first variable of an expression. It is also consulted when a .
or []
operator is encountered.
For example, in the EL expression ${employee.lastName}
, the ELResolver
determines what object employee
refers to, and what it means to get the lastName
property on that object.
Most methods in this class accept a base
and property
parameter. In the case of variable resolution (e.g. determining what employee
refers to in ${employee.lastName}
), the base
parameter will be null
and the property
parameter will always be of type String
. In this case, if the property
is not a String
, the behavior of the ELResolver
is undefined.
In the case of property resolution, the base
parameter identifies the base object and the property
object identifies the property on that base. For example, in the expression ${employee.lastName}
, base
is the result of the variable resolution for employee
and property
is the string "lastName"
. In the expression ${y[x]}
, base
is the result of the variable resolution for y
and property
is the result of the variable resolution for x
.
In the case of method call resolution, the base
parameter indentifies the base object and the method
parameter identifies a method on that base. In the case of overloaded methods, the paramTypes
parameter can be optionally used to identify a method. The params
parameter are the parameters for the method call, and can also be used for resolving overloaded methods when the paramTypes
parameter is not specified.
Though only a single ELResolver
is associated with an ELContext
, there are usually multiple resolvers considered for any given variable or property resolution. ELResolver
s are combined together using {@link CompositeELResolver}s, to define rich semantics for evaluating an expression.
For the {@link #getValue}, {@link #getType}, {@link #setValue} and{@link #isReadOnly} methods, an ELResolver
is notresponsible for resolving all possible (base, property) pairs. In fact, most resolvers will only handle a base
of a single type. To indicate that a resolver has successfully resolved a particular (base, property) pair, it must set the propertyResolved
property of the ELContext
to true
. If it could not handle the given pair, it must leave this property alone. The caller must ignore the return value of the method if propertyResolved
is false
.
The {@link #getFeatureDescriptors} and {@link #getCommonPropertyType}methods are primarily designed for design-time tool support, but must handle invocation at runtime as well. The {@link java.beans.Beans#isDesignTime} method can be used to determine if the resolver is being consulted at design-time or runtime.
@see CompositeELResolver
@see ELContext#getELResolver
@since JSP 2.1