Spring ELResolver für Unified Expression Language und JSF 1.2
Seit der Version 1.2 von Java Server Faces sind die alten PropertyResolver und VariableResolver deprecated. Stattdessen sollte man einen ELResolver verwenden. Das hat ausserdem den Vorteil, dass ein ELResolver auch ausserhalb von JSF funktioniert (ab JSP 2.1).
Der vorgestellte ELResolver exponiert den kompletten WebApplicationContext mit allen SpringBeans und kommt darüber hinaus noch mit Support für Springs MessageSources, so dass ein Ausdruck #{bundle.key}
direkt auf die MessageSource zu greifen kann.
Dieser ELResolver macht den alten DelegatingVariableResolver von Spring überflüssig. Inspiriert von Rick Hightowers MessageSourcePropertyResolver
kann der Resolver direkt auf MessageSources zugreifen und die entsprechende Message zurückliefern.
In Spring 2.1 ist ein ähnlicher Resolver auch schon enthalten, allerdings ohne die Möglichkeit auf MessageSources zuzugreifen.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 | package org.springframework.web.jsf; import java.beans.FeatureDescriptor; import java.util.Iterator; import javax.el.ELContext; import javax.el.ELResolver; import javax.faces.context.FacesContext; import org.springframework.context.MessageSource; import org.springframework.web.context.WebApplicationContext; /** * new style ELResolver for JSF 1.2. Exposes all spring beans to el expressions. * has additional support for message sources. * @author Stefan Rinke */ public class MessageSourceELResolver extends ELResolver { /** * No Arguments to message source. */ private static final Object[] NO_ARGS = new Object[] {}; @Override public Class<?> getCommonPropertyType(ELContext elContext, Object base) { return base instanceof MessageSource ? String. class : Object. class ; } @Override public Iterator<FeatureDescriptor> getFeatureDescriptors(ELContext elContext, Object base) { return null ; } @Override public Class<?> getType(ELContext ctx, Object base, Object val) { if ( null != base && base instanceof MessageSource) { ctx.setPropertyResolved( true ); return String. class ; } return null ; } @Override public Object getValue(ELContext elContext, Object base, Object property) { // If we have a non-null base object, function as a PropertyResolver if (base != null ) { if (base instanceof MessageSource) { elContext.setPropertyResolved( true ); FacesContext context = (FacesContext) elContext.getContext(FacesContext. class ); return ((MessageSource) base).getMessage((String) property, NO_ARGS, context.getViewRoot().getLocale()); } } else { // act as variable resolver if ( property instanceof String ) { FacesContext context = (FacesContext) elContext.getContext(FacesContext. class ); WebApplicationContext webCtx = FacesContextUtils.getRequiredWebApplicationContext(context); if ( webCtx.containsBean((String) property) ) { elContext.setPropertyResolved( true ); return webCtx.getBean((String) property); } } } return null ; } @Override public boolean isReadOnly(ELContext elContext, Object base, Object property) { if ( base instanceof MessageSource ) { elContext.setPropertyResolved( true ); } return false ; } @Override public void setValue(ELContext arg0, Object arg1, Object arg2, Object arg3) { } } |