|
||||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |
java.lang.Object org.springframework.web.util.WebUtils
public abstract class WebUtils
Miscellaneous utilities for web applications. Used by various framework classes.
Field Summary | |
---|---|
static String |
CONTENT_TYPE_CHARSET_PREFIX
Prefix of the charset clause in a content type String: ";charset=" |
static String |
DEFAULT_CHARACTER_ENCODING
Default character encoding to use when request.getCharacterEncoding
returns null , according to the Servlet spec. |
static String |
DEFAULT_WEB_APP_ROOT_KEY
Default web app root key: "webapp.root" |
static String |
HTML_ESCAPE_CONTEXT_PARAM
HTML escape parameter at the servlet context level (i.e. a context-param in web.xml ): "defaultHtmlEscape". |
static String |
SESSION_MUTEX_ATTRIBUTE
Key for the mutex session attribute |
static String[] |
SUBMIT_IMAGE_SUFFIXES
Name suffixes in case of image buttons |
static String |
TEMP_DIR_CONTEXT_ATTRIBUTE
Standard Servlet spec context attribute that specifies a temporary directory for the current web application, of type java.io.File . |
static String |
WEB_APP_ROOT_KEY_PARAM
Web app root key parameter at the servlet context level (i.e. a context-param in web.xml ): "webAppRootKey". |
Constructor Summary | |
---|---|
WebUtils()
|
Method Summary | |
---|---|
static void |
exposeRequestAttributes(ServletRequest request,
Map attributes)
Expose the given Map as request attributes, using the keys as attribute names and the values as corresponding attribute values. |
static String |
extractFilenameFromUrlPath(String urlPath)
Extract the URL filename from the given request URL path. |
static Cookie |
getCookie(HttpServletRequest request,
String name)
Retrieve the first cookie with the given name. |
static Object |
getOrCreateSessionAttribute(HttpSession session,
String name,
Class clazz)
Get the specified session attribute, creating and setting a new attribute if no existing found. |
static Map |
getParametersStartingWith(ServletRequest request,
String prefix)
Return a map containing all parameters with the given prefix. |
static String |
getRealPath(ServletContext servletContext,
String path)
Return the real path of the given path within the web application, as provided by the servlet container. |
static Object |
getRequiredSessionAttribute(HttpServletRequest request,
String name)
Check the given request for a session attribute of the given name. |
static Object |
getSessionAttribute(HttpServletRequest request,
String name)
Check the given request for a session attribute of the given name. |
static String |
getSessionId(HttpServletRequest request)
Determine the session id of the given request, if any. |
static Object |
getSessionMutex(HttpSession session)
Return the best available mutex for the given session: that is, an object to synchronize on for the given session. |
static File |
getTempDir(ServletContext servletContext)
Return the temporary directory for the current web application, as provided by the servlet container. |
static boolean |
hasSubmitParameter(ServletRequest request,
String name)
Check if a specific input type="submit" parameter was sent in the request, either via a button (directly with name) or via an image (name + ".x" or name + ".y"). |
static boolean |
isDefaultHtmlEscape(ServletContext servletContext)
Return whether default HTML escaping is enabled for the web application, i.e. the value of the "defaultHtmlEscape" context-param in web.xml
(if any). |
static boolean |
isIncludeRequest(ServletRequest request)
Determine whether the given request is an include request, that is, not a top-level HTTP request coming in from the outside. |
static void |
removeWebAppRootSystemProperty(ServletContext servletContext)
Remove the system property that points to the web app root directory. |
static void |
setSessionAttribute(HttpServletRequest request,
String name,
Object value)
Set the session attribute with the given name to the given value. |
static void |
setWebAppRootSystemProperty(ServletContext servletContext)
Set a system property to the web application root directory. |
Methods inherited from class java.lang.Object |
---|
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait |
Field Detail |
---|
public static final String CONTENT_TYPE_CHARSET_PREFIX
public static final String DEFAULT_CHARACTER_ENCODING
request.getCharacterEncoding
returns null
, according to the Servlet spec.
public static final String TEMP_DIR_CONTEXT_ATTRIBUTE
java.io.File
.
public static final String HTML_ESCAPE_CONTEXT_PARAM
web.xml
): "defaultHtmlEscape".
public static final String WEB_APP_ROOT_KEY_PARAM
web.xml
): "webAppRootKey".
public static final String DEFAULT_WEB_APP_ROOT_KEY
public static final String[] SUBMIT_IMAGE_SUFFIXES
public static final String SESSION_MUTEX_ATTRIBUTE
Constructor Detail |
---|
public WebUtils()
Method Detail |
---|
public static void setWebAppRootSystemProperty(ServletContext servletContext) throws IllegalStateException
web.xml
. Default is "webapp.root".
Can be used for tools that support substition with System.getProperty
values, like Log4J's "${key}" syntax within log file locations.
servletContext
- the servlet context of the web application
IllegalStateException
- if the system property is already set,
or if the WAR file is not expandedWEB_APP_ROOT_KEY_PARAM
,
DEFAULT_WEB_APP_ROOT_KEY
,
WebAppRootListener
,
Log4jWebConfigurer
public static void removeWebAppRootSystemProperty(ServletContext servletContext)
servletContext
- the servlet context of the web applicationsetWebAppRootSystemProperty(javax.servlet.ServletContext)
public static boolean isDefaultHtmlEscape(ServletContext servletContext)
web.xml
(if any).
servletContext
- the servlet context of the web application
public static File getTempDir(ServletContext servletContext)
servletContext
- the servlet context of the web application
public static String getRealPath(ServletContext servletContext, String path) throws FileNotFoundException
Prepends a slash if the path does not already start with a slash,
and throws a FileNotFoundException if the path cannot be resolved to
a resource (in contrast to ServletContext's getRealPath
,
which returns null).
servletContext
- the servlet context of the web applicationpath
- the path within the web application
FileNotFoundException
- if the path cannot be resolved to a resourceServletContext.getRealPath(java.lang.String)
public static String getSessionId(HttpServletRequest request)
request
- current HTTP request
null
if nonepublic static Object getSessionAttribute(HttpServletRequest request, String name)
request
- current HTTP requestname
- the name of the session attribute
null
if not foundpublic static Object getRequiredSessionAttribute(HttpServletRequest request, String name) throws IllegalStateException
request
- current HTTP requestname
- the name of the session attribute
null
if not found
IllegalStateException
- if the session attribute could not be foundpublic static void setSessionAttribute(HttpServletRequest request, String name, Object value)
request
- current HTTP requestname
- the name of the session attributevalue
- the value of the session attributepublic static Object getOrCreateSessionAttribute(HttpSession session, String name, Class clazz) throws IllegalArgumentException
session
- current HTTP sessionname
- the name of the session attributeclazz
- the class to instantiate for a new attribute
IllegalArgumentException
- if the session attribute could not be instantiatedpublic static Object getSessionMutex(HttpSession session)
Returns the session mutex attribute if available; usually,
this means that the HttpSessionMutexListener needs to be defined
in web.xml
. Falls back to the HttpSession itself
if no mutex attribute found.
The session mutex is guaranteed to be the same object during
the entire lifetime of the session, available under the key defined
by the SESSION_MUTEX_ATTRIBUTE
constant. It serves as a
safe reference to synchronize on for locking on the current session.
In many cases, the HttpSession reference itself is a safe mutex as well, since it will always be the same object reference for the same active logical session. However, this is not guaranteed across different servlet containers; the only 100% safe way is a session mutex.
session
- the HttpSession to find a mutex for
null
)SESSION_MUTEX_ATTRIBUTE
,
HttpSessionMutexListener
public static void exposeRequestAttributes(ServletRequest request, Map attributes) throws IllegalArgumentException
request
- current HTTP requestattributes
- the attributes Map
IllegalArgumentException
- if an invalid key is found in the Mappublic static Cookie getCookie(HttpServletRequest request, String name)
request
- current servlet requestname
- cookie name
null
if none is foundpublic static boolean isIncludeRequest(ServletRequest request)
Checks the presence of the "javax.servlet.include.request_uri" request attribute. Could check any request attribute that is only present in an include request.
request
- current servlet requestpublic static boolean hasSubmitParameter(ServletRequest request, String name)
request
- current HTTP requestname
- name of the parameter
SUBMIT_IMAGE_SUFFIXES
public static Map getParametersStartingWith(ServletRequest request, String prefix)
For example, with a prefix of "spring_", "spring_param1" and "spring_param2" result in a Map with "param1" and "param2" as keys.
Similar to Servlet 2.3's ServletRequest.getParameterMap
,
but more flexible and compatible with Servlet 2.2.
request
- HTTP request in which to look for parametersprefix
- the beginning of parameter names
(if this is null or the empty string, all parameters will match)
ServletRequest.getParameterNames()
,
ServletRequest.getParameterValues(java.lang.String)
,
ServletRequest.getParameterMap()
public static String extractFilenameFromUrlPath(String urlPath)
urlPath
- the request URL path (e.g. "/index.html")
|
||||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |