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

javax.servlet.http.HttpServletResponse Maven / Gradle / Ivy

There is a newer version: 4.0.66
Show newest version
/*
 * Copyright (c) 1998-2012 Caucho Technology -- all rights reserved
 *
 * This file is part of Resin(R) Open Source
 *
 * Each copy or derived work must preserve the copyright notice and this
 * notice unmodified.
 *
 * Resin Open Source is free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published by
 * the Free Software Foundation; either version 2 of the License, or
 * (at your option) any later version.
 *
 * Resin Open Source is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE, or any warranty
 * of NON-INFRINGEMENT.  See the GNU General Public License for more
 * details.
 *
 * You should have received a copy of the GNU General Public License
 * along with Resin Open Source; if not, write to the
 *
 *   Free Software Foundation, Inc.
 *   59 Temple Place, Suite 330
 *   Boston, MA 02111-1307  USA
 *
 * @author Scott Ferguson
 */

package javax.servlet.http;

import javax.servlet.ServletResponse;
import java.io.IOException;
import java.util.Collection;

/**
 * HttpServletResponse extends ServletResponse allowing servlets to
 * set the status and headers.
 *
 * 

Useful Headers

* * *
Expires * Lets clients cache the page. Resin can use Expires to * internally cache the page. *
*/ public interface HttpServletResponse extends ServletResponse { public final static int SC_ACCEPTED = 202; public final static int SC_BAD_GATEWAY = 502; public final static int SC_BAD_REQUEST = 400; public final static int SC_CONFLICT = 409; public final static int SC_CONTINUE = 100; public final static int SC_CREATED = 201; public final static int SC_EXPECTATION_FAILED = 417; public final static int SC_FORBIDDEN = 403; public final static int SC_GATEWAY_TIMEOUT = 504; public final static int SC_GONE = 410; public final static int SC_HTTP_VERSION_NOT_SUPPORTED = 505; public final static int SC_INTERNAL_SERVER_ERROR = 500; public final static int SC_LENGTH_REQUIRED = 411; public final static int SC_METHOD_NOT_ALLOWED = 405; public final static int SC_MOVED_PERMANENTLY = 301; public final static int SC_MOVED_TEMPORARILY = 302; public final static int SC_FOUND = 302; public final static int SC_MULTIPLE_CHOICES = 300; public final static int SC_NO_CONTENT = 204; public final static int SC_NON_AUTHORITATIVE_INFORMATION = 203; public final static int SC_NOT_ACCEPTABLE = 406; public final static int SC_NOT_FOUND = 404; public final static int SC_NOT_IMPLEMENTED = 501; public final static int SC_NOT_MODIFIED = 304; public final static int SC_OK = 200; public final static int SC_PARTIAL_CONTENT = 206; public final static int SC_PAYMENT_REQUIRED = 402; public final static int SC_PRECONDITION_FAILED = 412; public final static int SC_PROXY_AUTHENTICATION_REQUIRED = 407; public final static int SC_REQUEST_ENTITY_TOO_LARGE = 413; public final static int SC_REQUEST_TIMEOUT = 408; public final static int SC_REQUEST_URI_TOO_LONG = 414; public final static int SC_REQUESTED_RANGE_NOT_SATISFIABLE = 416; public final static int SC_RESET_CONTENT = 205; public final static int SC_SEE_OTHER = 303; public final static int SC_SERVICE_UNAVAILABLE = 503; public final static int SC_SWITCHING_PROTOCOLS = 101; public final static int SC_UNAUTHORIZED = 401; public final static int SC_UNSUPPORTED_MEDIA_TYPE = 415; public final static int SC_USE_PROXY = 305; public final static int SC_TEMPORARY_REDIRECT = 307; /** * Sets the HTTP status * * @param sc the HTTP status code */ public void setStatus(int sc); /** * Sends an HTTP error page based on the status code * * @param sc the HTTP status code */ public void sendError(int sc, String msg) throws IOException; /** * Sends an HTTP error page based on the status code * * @param sc the HTTP status code */ public void sendError(int sc) throws IOException; /** * Redirects the client to another page. * * @param location the location to redirect to. */ public void sendRedirect(String location) throws IOException; /** * Sets a header. This will override a previous header * with the same name. * * @param name the header name * @param value the header value */ public void setHeader(String name, String value); /** * Adds a header. If another header with the same name exists, both * will be sent to the client. * * @param name the header name * @param value the header value */ public void addHeader(String name, String value); /** * Returns true if the output headers include name * * @param name the header name to test */ public boolean containsHeader(String name); /** * Sets a header by converting a date to a string. * *

To set the page to expire in 15 seconds use the following: *


   * long now = System.currentTime();
   * response.setDateHeader("Expires", now + 15000);
   * 
* * @param name name of the header * @param date the date in milliseconds since the epoch. */ public void setDateHeader(String name, long date); /** * Adds a header by converting a date to a string. * * @param name name of the header * @param date the date in milliseconds since the epoch. */ public void addDateHeader(String name, long date); /** * Sets a header by converting an integer value to a string. * * @param name name of the header * @param value the value as an integer */ public void setIntHeader(String name, int value); /** * Adds a header by converting an integer value to a string. * * @param name name of the header * @param value the value as an integer */ public void addIntHeader(String name, int value); /** * Sends a new cookie to the client. */ public void addCookie(Cookie cookie); /** * Encodes session information in a URL. Calling this will enable * sessions for users who have disabled cookies. * * @param url the url to encode * @return a url with session information encoded */ public String encodeURL(String url); /** * Encodes session information in a URL suitable for * sendRedirect() * * @param name the url to encode * @return a url with session information encoded */ public String encodeRedirectURL(String name); /** * @deprecated */ public void setStatus(int sc, String msg); /** * @deprecated */ public String encodeUrl(String url); /** * @deprecated */ public String encodeRedirectUrl(String url); /** * Returns the current status code of this response * * @return */ public int getStatus(); /** * Retuns value of header with a given name * * @param name * @return */ public String getHeader(String name); /** * Returns an Iterable for header values with a given name * * @param name * @return */ public Collection getHeaders(String name); /** * Returns an Iterable for header names set via {@link #setHeader}, {@link * #addHeader}, {@link #setDateHeader}, {@link #addDateHeader}, {@link * #setIntHeader}, or {@link #addIntHeader}, respectively. * * @return */ public Collection getHeaderNames(); }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy