All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.frameworkset.web.servlet.mvc.WebRequest Maven / Gradle / Ivy

Go to download

bboss is a j2ee framework include aop/ioc,mvc,persistent,taglib,rpc,event ,bean-xml serializable and so on.http://www.bbossgroups.com

There is a newer version: 6.2.7
Show newest version
/*
 *  Copyright 2008 biaoping.yin
 *
 *  Licensed under the Apache License, Version 2.0 (the "License");
 *  you may not use this file except in compliance with the License.
 *  You may obtain a copy of the License at
 *
 *      http://www.apache.org/licenses/LICENSE-2.0
 *
 *  Unless required by applicable law or agreed to in writing, software
 *  distributed under the License is distributed on an "AS IS" BASIS,
 *  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 *  See the License for the specific language governing permissions and
 *  limitations under the License.
 */
package org.frameworkset.web.servlet.mvc;

import java.security.Principal;
import java.util.Iterator;
import java.util.Locale;
import java.util.Map;

import org.frameworkset.web.servlet.context.RequestAttributes;

/**
 * 

Title: WebRequest.java

*

Description:

*

bboss workgroup

*

Copyright (c) 2008

* @Date 2010-10-15 * @author biaoping.yin * @version 1.0 */ public interface WebRequest extends RequestAttributes { /** * Return the request header of the given name, or {@code null} if none. *

Retrieves the first header value in case of a multi-value header. * @since 3.0 * @see javax.servlet.http.HttpServletRequest#getHeader(String) */ String getHeader(String headerName); /** * Return the request header values for the given header name, * or {@code null} if none. *

A single-value header will be exposed as an array with a single element. * @since 3.0 * @see javax.servlet.http.HttpServletRequest#getHeaders(String) */ String[] getHeaderValues(String headerName); /** * Return a Iterator over request header names. * @since 3.0 * @see javax.servlet.http.HttpServletRequest#getHeaderNames() */ Iterator getHeaderNames(); /** * Return the request parameter of the given name, or {@code null} if none. *

Retrieves the first parameter value in case of a multi-value parameter. * @see javax.servlet.http.HttpServletRequest#getParameter(String) */ String getParameter(String paramName); /** * Return the request parameter values for the given parameter name, * or {@code null} if none. *

A single-value parameter will be exposed as an array with a single element. * @see javax.servlet.http.HttpServletRequest#getParameterValues(String) */ String[] getParameterValues(String paramName); /** * Return a Iterator over request parameter names. * @see javax.servlet.http.HttpServletRequest#getParameterNames() * @since 3.0 */ Iterator getParameterNames(); /** * Return a immutable Map of the request parameters, with parameter names as map keys * and parameter values as map values. The map values will be of type String array. *

A single-value parameter will be exposed as an array with a single element. * @see javax.servlet.http.HttpServletRequest#getParameterMap() */ Map getParameterMap(); /** * Return the primary Locale for this request. * @see javax.servlet.http.HttpServletRequest#getLocale() */ Locale getLocale(); /** * Return the context path for this request * (usually the base path that the current web application is mapped to). * @see javax.servlet.http.HttpServletRequest#getContextPath() */ String getContextPath(); /** * Return the remote user for this request, if any. * @see javax.servlet.http.HttpServletRequest#getRemoteUser() */ String getRemoteUser(); /** * Return the user principal for this request, if any. * @see javax.servlet.http.HttpServletRequest#getUserPrincipal() */ Principal getUserPrincipal(); /** * Determine whether the user is in the given role for this request. * @see javax.servlet.http.HttpServletRequest#isUserInRole(String) */ boolean isUserInRole(String role); /** * Return whether this request has been sent over a secure transport * mechanism (such as SSL). * @see javax.servlet.http.HttpServletRequest#isSecure() */ boolean isSecure(); /** * Check whether the request qualifies as not modified given the * supplied last-modified timestamp (as determined by the application). *

This will also transparently set the appropriate response headers, * for both the modified case and the not-modified case. *

Typical usage: *

	 * public String myHandleMethod(WebRequest webRequest, Model model) {
	 *   long lastModified = // application-specific calculation
	 *   if (request.checkNotModified(lastModified)) {
	 *     // shortcut exit - no further processing necessary
	 *     return null;
	 *   }
	 *   // further request processing, actually building content
	 *   model.addAttribute(...);
	 *   return "myViewName";
	 * }
*

Note: you can use either * this {@code #checkNotModified(long)} method; or * {@link #checkNotModified(String)}. If you want enforce both * a strong entity tag and a Last-Modified value, * as recommended by the HTTP specification, * then you should use {@link #checkNotModified(String, long)}. *

If the "If-Modified-Since" header is set but cannot be parsed * to a date value, this method will ignore the header and proceed * with setting the last-modified timestamp on the response. * @param lastModifiedTimestamp the last-modified timestamp that * the application determined for the underlying resource * @return whether the request qualifies as not modified, * allowing to abort request processing and relying on the response * telling the client that the content has not been modified */ boolean checkNotModified(long lastModifiedTimestamp); /** * Check whether the request qualifies as not modified given the * supplied {@code ETag} (entity tag), as determined by the application. *

This will also transparently set the appropriate response headers, * for both the modified case and the not-modified case. *

Typical usage: *

	 * public String myHandleMethod(WebRequest webRequest, Model model) {
	 *   String eTag = // application-specific calculation
	 *   if (request.checkNotModified(eTag)) {
	 *     // shortcut exit - no further processing necessary
	 *     return null;
	 *   }
	 *   // further request processing, actually building content
	 *   model.addAttribute(...);
	 *   return "myViewName";
	 * }
*

Note: you can use either * this {@code #checkNotModified(String)} method; or * {@link #checkNotModified(long)}. If you want enforce both * a strong entity tag and a Last-Modified value, * as recommended by the HTTP specification, * then you should use {@link #checkNotModified(String, long)}. * @param etag the entity tag that the application determined * for the underlying resource. This parameter will be padded * with quotes (") if necessary. * @return whether the request qualifies as not modified, * allowing to abort request processing and relying on the response * telling the client that the content has not been modified */ boolean checkNotModified(String etag); /** * Check whether the request qualifies as not modified given the * supplied {@code ETag} (entity tag) and last-modified timestamp, * as determined by the application. *

This will also transparently set the "ETag" and "Last-Modified" * response headers, for both the modified case and the not-modified case. *

Typical usage: *

	 * public String myHandleMethod(WebRequest webRequest, Model model) {
	 *   String eTag = // application-specific calculation
	 *   long lastModified = // application-specific calculation
	 *   if (request.checkNotModified(eTag, lastModified)) {
	 *     // shortcut exit - no further processing necessary
	 *     return null;
	 *   }
	 *   // further request processing, actually building content
	 *   model.addAttribute(...);
	 *   return "myViewName";
	 * }
*

Note: The HTTP specification recommends * setting both ETag and Last-Modified values, but you can also * use {@code #checkNotModified(String)} or * {@link #checkNotModified(long)}. * @param etag the entity tag that the application determined * for the underlying resource. This parameter will be padded * with quotes (") if necessary. * @param lastModifiedTimestamp the last-modified timestamp that * the application determined for the underlying resource * @return whether the request qualifies as not modified, * allowing to abort request processing and relying on the response * telling the client that the content has not been modified * @since 4.2 */ boolean checkNotModified(String etag, long lastModifiedTimestamp); /** * Get a short description of this request, * typically containing request URI and session id. * @param includeClientInfo whether to include client-specific * information such as session id and user name * @return the requested description as String */ String getDescription(boolean includeClientInfo); }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy