Class StaticFieldELResolver
- java.lang.Object
- 
- jakarta.el.ELResolver
- 
- jakarta.el.StaticFieldELResolver
 
 
- 
 public class StaticFieldELResolver extends ELResolver AnELResolverfor resolving static fields, enum constants and static methods. Also handles constructor calls as a special case.The resolver handles base objects of the type ELClass, which is usually generated by a Jakarta Expression Language implementation.- Since:
- Jakarta Expression Language 3.0
- See Also:
- ELClass
 
- 
- 
Field Summary- 
Fields inherited from class jakarta.el.ELResolverRESOLVABLE_AT_DESIGN_TIME, TYPE
 
- 
 - 
Constructor SummaryConstructors Constructor Description StaticFieldELResolver()
 - 
Method SummaryAll Methods Instance Methods Concrete Methods Deprecated Methods Modifier and Type Method Description Class<?>getCommonPropertyType(ELContext context, Object base)Returns the type of the property.Iterator<FeatureDescriptor>getFeatureDescriptors(ELContext context, Object base)Deprecated, for removal: This API element is subject to removal in a future version.This method will be removed without replacement in EL 6.0Class<?>getType(ELContext context, Object base, Object property)Returns the type of a static field.ObjectgetValue(ELContext context, Object base, Object property)Returns the value of a static field.Objectinvoke(ELContext context, Object base, Object methodName, Class<?>[] paramTypes, Object[] params)Invokes a public static method or the constructor for a class.booleanisReadOnly(ELContext context, Object base, Object property)Inquires whether the static field is writable.voidsetValue(ELContext context, Object base, Object property, Object value)Attempts to write to a static field.- 
Methods inherited from class jakarta.el.ELResolverconvertToType
 
- 
 
- 
- 
- 
Method Detail- 
getValuepublic Object getValue(ELContext context, Object base, Object property) Returns the value of a static field. If the base object is an instance of If the property is a public static field of class specified inELClassand the property is String, thepropertyResolvedproperty of theELContextobject must be set totrueby this resolver, before returning. If this property is nottrueafter this method is called, the caller should ignore the return value.ELClass, return the value of the static field. An Enum constant is a public static field of an Enum object, and is a special case of this.- Specified by:
- getValuein class- ELResolver
- Parameters:
- context- The context of this evaluation.
- base- An- ELClass.
- property- A static field name.
- Returns:
- If the propertyResolvedproperty ofELContextwas set totrue, then the static field value.
- Throws:
- NullPointerException- if context is- null.
- PropertyNotFoundException- if the specified class does not exist, or if the field is not a public static filed of the class, or if the field is inaccessible.
 
 - 
setValuepublic void setValue(ELContext context, Object base, Object property, Object value) Attempts to write to a static field. If the base object is an instance of ELClassand the property is String, aPropertyNotWritableExceptionwill always be thrown, because writing to a static field is not allowed.- Specified by:
- setValuein class- ELResolver
- Parameters:
- context- The context of this evaluation.
- base- An- ELClass
- property- The name of the field
- value- The value to set the field of the class to.
- Throws:
- NullPointerException- if context is- null
- PropertyNotWritableException- if base object instance of- ELClassand- propertyinstance of String
 
 - 
invokepublic Object invoke(ELContext context, Object base, Object methodName, Class<?>[] paramTypes, Object[] params) Invokes a public static method or the constructor for a class.If the base object is an instance of ELClassand the method is a String, thepropertyResolvedproperty of theELContextobject must be set totrueby the resolver, before returning. If this property is nottrueafter this method is called, the caller should ignore the return value.Invoke the public static method specified by method.The process involved in the method selection is the same as that used in BeanELResolver.As a special case, if the name of the method is "<init>", the constructor for the class will be invoked. - Overrides:
- invokein class- ELResolver
- Parameters:
- base- An- ELClass
- methodName- When coerced to a- String, the simple name of the method.
- paramTypes- An array of Class objects identifying the method's formal parameter types, in declared order. Use an empty array if the method has no parameters. Can be- null, in which case the method's formal parameter types are assumed to be unknown.
- params- The parameters to pass to the method, or- nullif no parameters.
- context- The context of this evaluation.
- Returns:
- The result of the method invocation (nullif the method has avoidreturn type).
- Throws:
- MethodNotFoundException- if no suitable method can be found.
- ELException- if an exception was thrown while performing (base, method) resolution. The thrown exception must be included as the cause property of this exception, if available. If the exception thrown is an- InvocationTargetException, extract its- causeand pass it to the- ELExceptionconstructor.
 
 - 
getTypepublic Class<?> getType(ELContext context, Object base, Object property) Returns the type of a static field.If the base object is an instance of ELClassand the property is a String, thepropertyResolvedproperty of theELContextobject must be set totrueby the resolver, before returning. If this property is nottrueafter this method is called, the caller can safely assume no value has been set.- Specified by:
- getTypein class- ELResolver
- Parameters:
- context- The context of this evaluation.
- base- An- ELClass.
- property- The name of the field.
- Returns:
- If the propertyResolvedproperty ofELContextwas set totrue, thennull; otherwise undefined.
- Throws:
- NullPointerException- if context is- null.
- PropertyNotFoundException- if field is not a public static filed of the class, or if the field is inaccessible.
 
 - 
isReadOnlypublic boolean isReadOnly(ELContext context, Object base, Object property) Inquires whether the static field is writable. If the base object is an instance of ELClassand the property is a String, thepropertyResolvedproperty of theELContextobject must be set totrueby the resolver, before returning. If this property is nottrueafter this method is called, the caller can safely assume no value has been set.Always returns a truebecause writing to a static field is not allowed.- Specified by:
- isReadOnlyin class- ELResolver
- Parameters:
- context- The context of this evaluation.
- base- An- ELClass.
- property- The name of the bean.
- Returns:
- true
- Throws:
- NullPointerException- if context is- null.
 
 - 
getFeatureDescriptors@Deprecated(forRemoval=true, since="5.0") public Iterator<FeatureDescriptor> getFeatureDescriptors(ELContext context, Object base) Deprecated, for removal: This API element is subject to removal in a future version.This method will be removed without replacement in EL 6.0Returns the properties that can be resolved. Always returnsnull, since there is no reason to iterate through a list of one element: field name.- Overrides:
- getFeatureDescriptorsin class- ELResolver
- Parameters:
- context- The context of this evaluation.
- base- An- ELClass.
- Returns:
- null.
- See Also:
- FeatureDescriptor
 
 - 
getCommonPropertyTypepublic Class<?> getCommonPropertyType(ELContext context, Object base) Returns the type of the property. Always returnsString.class, since a field name is a String.- Specified by:
- getCommonPropertyTypein class- ELResolver
- Parameters:
- context- The context of this evaluation.
- base- An- ELClass.
- Returns:
- String.class.
 
 
- 
 
-