public class MessageTag extends HtmlEscapingAwareTag implements ArgumentAware
<message>
tag looks up a message in the scope of this page.
Messages are resolved using the ApplicationContext and thus support
internationalization.
Detects an HTML escaping setting, either on this tag instance, the page level,
or the web.xml
level. Can also apply JavaScript escaping.
If "code" isn't set or cannot be resolved, "text" will be used as default message. Thus, this tag can also be used for HTML escaping of any texts.
Message arguments can be specified via the arguments
attribute or by using nested <spring:argument>
tags.
Attribute | Required? | Runtime Expression? | Description |
---|---|---|---|
arguments | false | true | Set optional message arguments for this tag, as a (comma-)delimited String (each String argument can contain JSP EL), an Object array (used as argument array), or a single Object (used as single argument). |
argumentSeparator | false | true | The separator character to be used for splitting the arguments string value; defaults to a 'comma' (','). |
code | false | true | The code (key) to use when looking up the message. If code is not provided, the text attribute will be used. |
htmlEscape | false | true | Set HTML escaping for this tag, as boolean value. Overrides the default HTML escaping setting for the current page. |
javaScriptEscape | false | true | Set JavaScript escaping for this tag, as boolean value. Default is false. |
message | false | true | A MessageSourceResolvable argument (direct or through JSP EL). Fits nicely when used in conjunction with Spring’s own validation error classes which all implement the MessageSourceResolvable interface. For example, this allows you to iterate over all of the errors in a form, passing each error (using a runtime expression) as the value of this 'message' attribute, thus effecting the easy display of such error messages. |
scope | false | true | The scope to use when exporting the result to a variable. This attribute is only used when var is also set. Possible values are page, request, session and application. |
text | false | true | Default text to output when a message for the given code could not be found. If both text and code are not set, the tag will output null. |
var | false | true | The string to use when binding the result to the page, request, session or application scope. If not specified, the result gets outputted to the writer (i.e. typically directly to the JSP). |
setCode(java.lang.String)
,
setText(java.lang.String)
,
HtmlEscapingAwareTag.setHtmlEscape(boolean)
,
setJavaScriptEscape(boolean)
,
HtmlEscapeTag.setDefaultHtmlEscape(boolean)
,
WebUtils.HTML_ESCAPE_CONTEXT_PARAM
,
ArgumentTag
,
Serialized FormModifier and Type | Field and Description |
---|---|
static String |
DEFAULT_ARGUMENT_SEPARATOR
Default separator for splitting an arguments String: a comma (",").
|
logger, REQUEST_CONTEXT_PAGE_ATTRIBUTE
id, pageContext
EVAL_BODY_AGAIN
EVAL_BODY_INCLUDE, EVAL_PAGE, SKIP_BODY, SKIP_PAGE
Constructor and Description |
---|
MessageTag() |
Modifier and Type | Method and Description |
---|---|
void |
addArgument(Object argument)
Callback hook for nested spring:argument tags to pass their value
to the parent tag.
|
int |
doEndTag()
Resolves the message, escapes it if demanded,
and writes it to the page (or exposes it as variable).
|
protected int |
doStartTagInternal()
Called by doStartTag to perform the actual work.
|
protected MessageSource |
getMessageSource()
Use the current RequestContext's application context as MessageSource.
|
protected String |
getNoSuchMessageExceptionDescription(NoSuchMessageException ex)
Return default exception message.
|
void |
release() |
protected Object[] |
resolveArguments(Object arguments)
Resolve the given arguments Object into an arguments array.
|
protected String |
resolveMessage()
Resolve the specified message into a concrete message String.
|
void |
setArguments(Object arguments)
Set optional message arguments for this tag, as a comma-delimited
String (each String argument can contain JSP EL), an Object array
(used as argument array), or a single Object (used as single argument).
|
void |
setArgumentSeparator(String argumentSeparator)
Set the separator to use for splitting an arguments String.
|
void |
setCode(String code)
Set the message code for this tag.
|
void |
setJavaScriptEscape(boolean javaScriptEscape)
Set JavaScript escaping for this tag, as boolean value.
|
void |
setMessage(MessageSourceResolvable message)
Set the MessageSourceResolvable for this tag.
|
void |
setScope(String scope)
Set the scope to export the variable to.
|
void |
setText(String text)
Set the message text for this tag.
|
void |
setVar(String var)
Set PageContext attribute name under which to expose
a variable that contains the resolved message.
|
protected void |
writeMessage(String msg)
Write the message to the page.
|
htmlEscape, isDefaultHtmlEscape, isHtmlEscape, isResponseEncodedHtmlEscape, setHtmlEscape
doCatch, doFinally, doStartTag, getRequestContext
doAfterBody, findAncestorWithClass, getId, getParent, getValue, getValues, removeValue, setId, setPageContext, setParent, setValue
public static final String DEFAULT_ARGUMENT_SEPARATOR
public void setMessage(MessageSourceResolvable message)
If a MessageSourceResolvable is specified, it effectively overrides any code, arguments or text specified on this tag.
public void setCode(String code)
public void setArguments(Object arguments)
public void setArgumentSeparator(String argumentSeparator)
setArguments(java.lang.Object)
public void addArgument(@Nullable Object argument) throws JspTagException
ArgumentAware
addArgument
in interface ArgumentAware
argument
- the result of the nested spring:argument
tagJspTagException
public void setText(String text)
public void setVar(String var)
public void setScope(String scope)
public void setJavaScriptEscape(boolean javaScriptEscape) throws JspException
JspException
protected final int doStartTagInternal() throws JspException, IOException
RequestContextAwareTag
doStartTagInternal
in class RequestContextAwareTag
JspException
IOException
TagSupport.doStartTag()
public int doEndTag() throws JspException
doEndTag
in interface Tag
doEndTag
in class TagSupport
JspException
resolveMessage()
,
HtmlUtils.htmlEscape(String)
,
JavaScriptUtils.javaScriptEscape(String)
,
writeMessage(String)
public void release()
release
in interface Tag
release
in class TagSupport
protected String resolveMessage() throws JspException, NoSuchMessageException
JspException
NoSuchMessageException
@Nullable protected Object[] resolveArguments(@Nullable Object arguments) throws JspException
arguments
- the specified arguments ObjectJspException
- if argument conversion failedsetArguments(java.lang.Object)
protected void writeMessage(String msg) throws IOException
Can be overridden in subclasses, e.g. for testing purposes.
msg
- the message to writeIOException
- if writing failedprotected MessageSource getMessageSource()
protected String getNoSuchMessageExceptionDescription(NoSuchMessageException ex)