Interface JspApplicationContext
-
public interface JspApplicationContextStores application-scoped information relevant to JSP containers.The JSP container must create a single instance of
JspApplicationContextfor eachServletContextinstance.An instance of
JspApplicationContextis obtained by invoking the staticJspFactory.getJspApplicationContext(jakarta.servlet.ServletContext)method, passing theServletContextof the corresponding web application.The
JspApplicationContextprovides the following services to JSP applications:- Allows registration of
ELResolvers, which are used to resolve variables in EL expressions contained in JSP pages and tag files. - Provides an instance of
ExpressionFactoryfor those applications or frameworks that need to perform programmatic evaluation of EL expressions instead of allowing the JSP container to do it for them. - Allows the attachment of
ELContextListenerinstances for notification whenever a newELContextis created. This is necessary when an application wishes to make custom context objects available to their pluggableELResolvers.
- Since:
- JSP 2.1
- See Also:
ServletContext,JspFactory,ELResolver,ExpressionFactory,ELContextListener
- Allows registration of
-
-
Method Summary
All Methods Instance Methods Abstract Methods Modifier and Type Method Description voidaddELContextListener(ELContextListener listener)Registers aELContextListeners so that context objects can be added whenever a newELContextis created.voidaddELResolver(ELResolver resolver)Adds anELResolverto affect the way EL variables and properties are resolved for EL expressions appearing in JSP pages and tag files.ExpressionFactorygetExpressionFactory()Returns a factory used to createValueExpressions andMethodExpressions so that EL expressions can be parsed and evaluated.
-
-
-
Method Detail
-
addELResolver
void addELResolver(ELResolver resolver)
Adds anELResolverto affect the way EL variables and properties are resolved for EL expressions appearing in JSP pages and tag files.For example, in the EL expression ${employee.lastName}, an
ELResolverdetermines what object "employee" references and how to find its "lastName" property.When evaluating an expression, the JSP container will consult a set of standard resolvers as well as any resolvers registered via this method. The set of resolvers are consulted in the following order:
ImplicitObjectELResolverELResolvers registered via this method, in the order in which they are registered.MapELResolverListELResolverArrayELResolverBeanELResolverScopedAttributeELResolver
It is illegal to register an
ELResolverafter the application has received any request from the client. If an attempt is made to register anELResolverafter that time, anIllegalStateExceptionis thrown.This restriction is in place to allow the JSP container to optimize for the common case where no additional
ELResolvers are in the chain, aside from the standard ones. It is permissible to addELResolvers before or after initialization to aCompositeELResolverthat is already in the chain.It is not possible to remove an
ELResolverregistered with this method, once it has been registered.- Parameters:
resolver- The newELResolver- Throws:
IllegalStateException- if an attempt is made to call this method after allServletContextListeners have had theircontextInitializedmethods invoked.
-
getExpressionFactory
ExpressionFactory getExpressionFactory()
Returns a factory used to createValueExpressions andMethodExpressions so that EL expressions can be parsed and evaluated.- Returns:
- A concrete implementation of the an
ExpressionFactory.
-
addELContextListener
void addELContextListener(ELContextListener listener)
Registers aELContextListeners so that context objects can be added whenever a newELContextis created.At a minimum, the
ELContextobjects created will contain a reference to theJspContextfor this request, which is added by the JSP container. This is sufficient for all the defaultELResolvers listed inaddELResolver(jakarta.el.ELResolver). Note thatJspContext.classis used as the key to ELContext.putContext() for theJspContextobject reference.This method is generally used by frameworks and applications that register their own
ELResolverthat needs context other thanJspContext. The listener will typically add the necessary context to theELContextprovided in the event object. Registering a listener that adds context allows theELResolvers in the stack to access the context they need when they do a resolution.- Parameters:
listener- The listener to be notified when a newELContextis created.
-
-