类 XsltView
- 所有已实现的接口:
cn.taketoday.beans.factory.Aware,cn.taketoday.beans.factory.BeanNameAware,cn.taketoday.beans.factory.InitializingBean,cn.taketoday.context.ApplicationContextAware,View
The XSLT Source object is supplied as a parameter in the model and then
detected during response rendering. Users can either specify
a specific entry in the model via the sourceKey property or
have Framework locate the Source object. This class also provides basic conversion
of objects into Source implementations. See here
for more details.
All model parameters are passed to the XSLT Transformer as parameters.
In addition the user can configure output properties
to be passed to the Transformer.
- 从以下版本开始:
- 4.0
- 作者:
- Rob Harrop, Juergen Hoeller
-
字段概要
字段修饰符和类型字段说明private Templatesprivate booleanprivate ErrorListenerprivate booleanprivate Propertiesprivate Stringprivate TransformerFactoryprivate Class<? extends TransformerFactory>private URIResolver从类继承的字段 cn.taketoday.web.view.AbstractView
DEFAULT_CONTENT_TYPE从类继承的字段 cn.taketoday.context.support.ApplicationObjectSupport
applicationContext, log, messageSourceAccessor从接口继承的字段 cn.taketoday.web.view.View
RESPONSE_STATUS_ATTRIBUTE, SELECTED_CONTENT_TYPE -
构造器概要
构造器 -
方法概要
修饰符和类型方法说明private voidcloseSourceIfNecessary(Source source) Close the underlying resource managed by the suppliedSourceif applicable.protected final voidconfigureIndentation(Transformer transformer) Configure the indentation settings for the suppliedTransformer.protected voidconfigureResponse(Map<String, Object> model, RequestContext response, Transformer transformer) Configure the suppliedRequestContext.protected voidconfigureTransformer(Map<String, Object> model, RequestContext response, Transformer transformer) Configure the suppliedTransformerinstance.protected SourceconvertSource(Object sourceObject) protected final voidcopyModelParameters(Map<String, Object> model, Transformer transformer) Copy all entries from the supplied Map into theparameter setof the suppliedTransformer.protected final voidcopyOutputProperties(Transformer transformer) Copy the configured outputProperties, if any, into theoutput property setof the suppliedTransformer.protected ResultcreateResult(RequestContext response) Create the XSLTResultused to render the result of the transformation.protected TransformercreateTransformer(Templates templates) Create theTransformerinstance used to prefer the XSLT transformation.protected Class<?>[]protected SourceGet the XSLTSourcefor the XSLT template under theconfigured URL.protected final TransformerFactoryReturn the TransformerFactory that this XsltView uses.protected voidInitialize this XsltView's TransformerFactory.private TemplatesLoad theTemplatesinstance for the stylesheet at the configured location.protected SourcelocateSource(Map<String, Object> model) Locate theSourceobject in the supplied model, converting objects as required.protected TransformerFactorynewTransformerFactory(Class<? extends TransformerFactory> transformerFactoryClass) Instantiate a new TransformerFactory for this view.protected voidrenderMergedOutputModel(Map<String, Object> model, RequestContext request) Subclasses must implement this method to actually render the view.voidsetCacheTemplates(boolean cacheTemplates) Turn on/off the caching of the XSLTTemplatesinstance.voidsetErrorListener(ErrorListener errorListener) Set an implementation of theErrorListenerinterface for custom handling of transformation errors and warnings.voidsetIndent(boolean indent) Set whether the XSLT transformer may add additional whitespace when outputting the result tree.voidsetOutputProperties(Properties outputProperties) Set arbitrary transformer output properties to be applied to the stylesheet.voidsetSourceKey(String sourceKey) Set the name of the model attribute that represents the XSLT Source.voidsetTransformerFactoryClass(Class<? extends TransformerFactory> transformerFactoryClass) Specify the XSLT TransformerFactory class to use.voidsetUriResolver(URIResolver uriResolver) Set the URIResolver used in the transform.从类继承的方法 cn.taketoday.web.view.AbstractUrlBasedView
afterPropertiesSet, checkResource, getUrl, isUrlRequired, setUrl, toString从类继承的方法 cn.taketoday.web.view.AbstractView
addStaticAttribute, createMergedOutputModel, createTemporaryOutputStream, exposeModelAsRequestAttributes, formatViewName, generatesDownloadContent, getAttributesMap, getBeanName, getContentType, getRequestContextAttribute, getRequestContextToExpose, getStaticAttributes, isExposePathVariables, prepareResponse, render, setAttributes, setAttributesCSV, setAttributesMap, setBeanName, setContentType, setExposeContextBeansAsAttributes, setExposedContextBeanNames, setExposeOutputRedirectModel, setExposePathVariables, setRequestContextAttribute, setResponseContentType, writeToResponse从类继承的方法 cn.taketoday.context.support.ApplicationObjectSupport
getApplicationContext, getMessageSourceAccessor, initApplicationContext, isContextRequired, obtainApplicationContext, requiredContextClass, setApplicationContext, unwrapContext, unwrapFactory
-
字段详细资料
-
transformerFactoryClass
-
sourceKey
-
uriResolver
-
errorListener
-
indent
private boolean indent -
outputProperties
-
cacheTemplates
private boolean cacheTemplates -
transformerFactory
-
cachedTemplates
-
-
构造器详细资料
-
XsltView
public XsltView()
-
-
方法详细资料
-
setTransformerFactoryClass
Specify the XSLT TransformerFactory class to use.The default constructor of the specified class will be called to build the TransformerFactory for this view.
-
setSourceKey
Set the name of the model attribute that represents the XSLT Source. If not specified, the model map will be searched for a matching value type.The following source types are supported out of the box:
Source,Document,Node,Reader,InputStreamandResource. -
setUriResolver
Set the URIResolver used in the transform.The URIResolver handles calls to the XSLT
document()function. -
setErrorListener
Set an implementation of theErrorListenerinterface for custom handling of transformation errors and warnings.If not set, a default
SimpleTransformErrorListeneris used that simply logs warnings using the logger instance of the view class, and rethrows errors to discontinue the XML transformation. -
setIndent
public void setIndent(boolean indent) Set whether the XSLT transformer may add additional whitespace when outputting the result tree.Default is
true(on); set this tofalse(off) to not specify an "indent" key, leaving the choice up to the stylesheet.- 另请参阅:
-
setOutputProperties
Set arbitrary transformer output properties to be applied to the stylesheet.Any values specified here will override defaults that this view sets programmatically.
-
setCacheTemplates
public void setCacheTemplates(boolean cacheTemplates) Turn on/off the caching of the XSLTTemplatesinstance.The default value is "true". Only set this to "false" in development, where caching does not seriously impact performance.
-
initApplicationContext
protected void initApplicationContext() throws cn.taketoday.beans.BeansExceptionInitialize this XsltView's TransformerFactory.- 覆盖:
initApplicationContext在类中cn.taketoday.context.support.ApplicationObjectSupport- 抛出:
cn.taketoday.beans.BeansException
-
newTransformerFactory
protected TransformerFactory newTransformerFactory(@Nullable Class<? extends TransformerFactory> transformerFactoryClass) Instantiate a new TransformerFactory for this view.The default implementation simply calls
TransformerFactory.newInstance(). If a"transformerFactoryClass"has been specified explicitly, the default constructor of the specified class will be called instead.Can be overridden in subclasses.
- 参数:
transformerFactoryClass- the specified factory class (if any)- 返回:
- the new TransactionFactory instance
- 另请参阅:
-
getTransformerFactory
Return the TransformerFactory that this XsltView uses.- 返回:
- the TransformerFactory (never
null)
-
renderMergedOutputModel
protected void renderMergedOutputModel(Map<String, Object> model, RequestContext request) throws Exception从类复制的说明:AbstractViewSubclasses must implement this method to actually render the view.The first step will be preparing the request: In the JSP case, this would mean setting model objects as request attributes. The second step will be the actual rendering of the view, for example including the JSP via a RequestDispatcher.
- 指定者:
renderMergedOutputModel在类中AbstractView- 参数:
model- combined output Map (nevernull), with dynamic values taking precedence over static attributesrequest- current HTTP request context- 抛出:
Exception- if rendering failed
-
createResult
Create the XSLTResultused to render the result of the transformation.The default implementation creates a
StreamResultwrapping the supplied RequestContext'sOutputStream.- 参数:
response- current HTTP response- 返回:
- the XSLT Result to use
- 抛出:
Exception- if the Result cannot be built
-
locateSource
Locate the
Sourceobject in the supplied model, converting objects as required. The default implementation first attempts to look under the configuredsource key, if any, before attempting to locate an object ofsupported type.- 参数:
model- the merged model Map- 返回:
- the XSLT Source object (or
nullif none found) - 抛出:
Exception- if an error occurred during locating the source- 另请参阅:
-
getSourceTypes
Return the array ofClassesthat are supported when converting to an XSLTSource.Currently supports
Source,Document,Node,Reader,InputStreamandResource.- 返回:
- the supported source types
-
convertSource
- 参数:
sourceObject- the original source object- 返回:
- the adapted XSLT Source
- 抛出:
IllegalArgumentException- if the given Object is not of a supported typeException
-
configureTransformer
protected void configureTransformer(Map<String, Object> model, RequestContext response, Transformer transformer) Configure the suppliedTransformerinstance.The default implementation copies parameters from the model into the Transformer's
parameter set. This implementation also copies theoutput propertiesinto theTransformeroutput properties. Indentation properties are set as well.- 参数:
model- merged output Map (nevernull)response- current HTTP responsetransformer- the target transformer- 另请参阅:
-
configureIndentation
Configure the indentation settings for the suppliedTransformer.- 参数:
transformer- the target transformer- 另请参阅:
-
TransformerUtils.enableIndenting(Transformer)TransformerUtils.disableIndenting(Transformer)
-
copyOutputProperties
Copy the configured outputProperties, if any, into theoutput property setof the suppliedTransformer.- 参数:
transformer- the target transformer
-
copyModelParameters
Copy all entries from the supplied Map into theparameter setof the suppliedTransformer.- 参数:
model- merged output Map (nevernull)transformer- the target transformer
-
configureResponse
protected void configureResponse(Map<String, Object> model, RequestContext response, Transformer transformer) Configure the suppliedRequestContext.The default implementation of this method sets the
content typefrom the "media-type" and "encoding" output properties specified in theTransformer.- 参数:
model- merged output Map (nevernull)response- current HTTP responsetransformer- the target transformer
-
loadTemplates
Load theTemplatesinstance for the stylesheet at the configured location.- 抛出:
cn.taketoday.context.ApplicationContextException
-
createTransformer
protected Transformer createTransformer(Templates templates) throws TransformerConfigurationException Create theTransformerinstance used to prefer the XSLT transformation.The default implementation simply calls
Templates.newTransformer(), and configures theTransformerwith the customURIResolverif specified.- 参数:
templates- the XSLT Templates instance to create a Transformer for- 返回:
- the Transformer object
- 抛出:
TransformerConfigurationException- in case of creation failure
-
getStylesheetSource
Get the XSLTSourcefor the XSLT template under theconfigured URL.- 返回:
- the Source object
-
closeSourceIfNecessary
Close the underlying resource managed by the suppliedSourceif applicable.Only works for
StreamSources.- 参数:
source- the XSLT Source to close (may benull)
-