📄 baserequest.java
字号:
/* ========================================================================= * * * * The Apache Software License, Version 1.1 * * * * Copyright (c) 1999-2001 The Apache Software Foundation. * * All rights reserved. * * * * ========================================================================= * * * * Redistribution and use in source and binary forms, with or without modi- * * fication, are permitted provided that the following conditions are met: * * * * 1. Redistributions of source code must retain the above copyright notice * * notice, this list of conditions and the following disclaimer. * * * * 2. Redistributions in binary form must reproduce the above copyright * * notice, this list of conditions and the following disclaimer in the * * documentation and/or other materials provided with the distribution. * * * * 3. The end-user documentation included with the redistribution, if any, * * must include the following acknowlegement: * * * * "This product includes software developed by the Apache Software * * Foundation <http://www.apache.org/>." * * * * Alternately, this acknowlegement may appear in the software itself, if * * and wherever such third-party acknowlegements normally appear. * * * * 4. The names "The Jakarta Project", "Jk", and "Apache Software * * Foundation" must not be used to endorse or promote products derived * * from this software without prior written permission. For written * * permission, please contact <apache@apache.org>. * * * * 5. Products derived from this software may not be called "Apache" nor may * * "Apache" appear in their names without prior written permission of the * * Apache Software Foundation. * * * * THIS SOFTWARE IS PROVIDED "AS IS" AND ANY EXPRESSED OR IMPLIED WARRANTIES * * INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY * * AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL * * THE APACHE SOFTWARE FOUNDATION OR ITS CONTRIBUTORS BE LIABLE FOR ANY * * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL * * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS * * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) * * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, * * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN * * ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE * * POSSIBILITY OF SUCH DAMAGE. * * * * ========================================================================= * * * * This software consists of voluntary contributions made by many indivi- * * duals on behalf of the Apache Software Foundation. For more information * * on the Apache Software Foundation, please see <http://www.apache.org/>. * * * * ========================================================================= *//*************************************************************************** * Description: Base http request object. * * Author: Keving Seguin [seguin@apache.org] * * Version: $Revision: 1.5 $ * ***************************************************************************/package org.apache.tomcat.util.http;import java.io.PrintWriter;import java.io.StringWriter;import java.util.HashMap;import java.util.Iterator;import org.apache.tomcat.util.buf.MessageBytes;/** * A general-purpose object for representing an HTTP * request. */public class BaseRequest { // scheme constants public static final String SCHEME_HTTP = "http"; public static final String SCHEME_HTTPS = "https"; // request attributes MessageBytes method = new MessageBytes(); MessageBytes protocol = new MessageBytes(); MessageBytes requestURI = new MessageBytes(); MessageBytes remoteAddr = new MessageBytes(); MessageBytes remoteHost = new MessageBytes(); MessageBytes serverName = new MessageBytes(); int serverPort = 80; MessageBytes remoteUser = new MessageBytes(); MessageBytes authType = new MessageBytes(); MessageBytes queryString = new MessageBytes(); MessageBytes authorization = new MessageBytes(); String scheme = SCHEME_HTTP; boolean secure = false; int contentLength = 0; MessageBytes contentType = new MessageBytes(); MimeHeaders headers = new MimeHeaders(); Cookies cookies = new Cookies(); HashMap attributes = new HashMap(); MessageBytes tomcatInstanceId = new MessageBytes(); /** * Recycles this object and readies it further use. */ public void recycle() { method.recycle(); protocol.recycle(); requestURI.recycle(); remoteAddr.recycle(); remoteHost.recycle(); serverName.recycle(); serverPort = 80; remoteUser.recycle(); authType.recycle(); queryString.recycle(); authorization.recycle(); scheme = SCHEME_HTTP; secure = false; contentLength = 0; contentType.recycle(); headers.recycle(); cookies.recycle(); attributes.clear(); tomcatInstanceId.recycle(); } /** * Get the method. * @return the method */ public MessageBytes method() { return method; } /** * Get the protocol * @return the protocol */ public MessageBytes protocol() { return protocol; } /** * Get the request uri * @return the request uri */ public MessageBytes requestURI() { return requestURI; } /** * Get the remote address * @return the remote address */ public MessageBytes remoteAddr() { return remoteAddr; } /** * Get the remote host * @return the remote host */ public MessageBytes remoteHost() { return remoteHost; } /** * Get the server name * @return the server name */ public MessageBytes serverName() { return serverName; } /** * Get the server port * @return the server port */ public int getServerPort() { return serverPort; } /** * Set the server port * @param i the server port */ public void setServerPort(int i) { serverPort = i; } /** * Get the remote user * @return the remote user */ public MessageBytes remoteUser() { return remoteUser; } /** * Get the auth type * @return the auth type */ public MessageBytes authType() { return authType; } /** * Get the query string * @return the query string */ public MessageBytes queryString() { return queryString; } /** * Get the authorization credentials * @return the authorization credentials */ public MessageBytes authorization() { return authorization; } /** * Get the scheme * @return the scheme */ public String getScheme() { return scheme; } /** * Set the scheme. * @param s the scheme */ public void setScheme(String s) { scheme = s; } /** * Get whether the request is secure or not. * @return <code>true</code> if the request is secure. */ public boolean getSecure() { return secure; } /** * Set whether the request is secure or not. * @param b <code>true</code> if the request is secure. */ public void setSecure(boolean b) { secure = b; } /** * Get the content length * @return the content length */ public int getContentLength() { return contentLength; } /** * Set the content length * @param i the content length */ public void setContentLength(int i) { contentLength = i; } /** * Get the content type * @return the content type */ public MessageBytes contentType() { return contentType; } /** * Get this request's headers * @return request headers */ public MimeHeaders headers() { return headers; } /** * Get cookies. * @return request cookies. */ public Cookies cookies() { return cookies; } /** * Set an attribute on the request * @param name attribute name * @param value attribute value */ public void setAttribute(String name, Object value) { if (name == null || value == null) { return; } attributes.put(name, value); } /** * Get an attribute on the request * @param name attribute name * @return attribute value */ public Object getAttribute(String name) { if (name == null) { return null; } return attributes.get(name); } /** * Get iterator over attribute names * @return iterator over attribute names */ public Iterator getAttributeNames() { return attributes.keySet().iterator(); } /** * Get the host id ( or jvmRoute ) * @return the jvm route */ public MessageBytes instanceId() { return tomcatInstanceId; } // backward compat - jvmRoute is the id of this tomcat instance, // used by a load balancer on the server side to implement sticky // sessions, and on the tomcat side to format the session ids. public MessageBytes jvmRoute() { return tomcatInstanceId; } private Object notes[]=new Object[16]; public final Object getNote(int id) { return notes[id]; } public final void setNote(int id, Object cr) { notes[id]=cr; } /** * ** SLOW ** for debugging only! */ public String toString() { StringWriter sw = new StringWriter(); PrintWriter pw = new PrintWriter(sw); pw.println("=== BaseRequest ==="); pw.println("method = " + method.toString()); pw.println("protocol = " + protocol.toString()); pw.println("requestURI = " + requestURI.toString()); pw.println("remoteAddr = " + remoteAddr.toString()); pw.println("remoteHost = " + remoteHost.toString()); pw.println("serverName = " + serverName.toString()); pw.println("serverPort = " + serverPort); pw.println("remoteUser = " + remoteUser.toString()); pw.println("authType = " + authType.toString()); pw.println("queryString = " + queryString.toString()); pw.println("scheme = " + scheme.toString()); pw.println("secure = " + secure); pw.println("contentLength = " + contentLength); pw.println("contentType = " + contentType); pw.println("attributes = " + attributes.toString()); pw.println("headers = " + headers.toString()); pw.println("cookies = " + cookies.toString()); pw.println("jvmRoute = " + tomcatInstanceId.toString()); return sw.toString(); } }
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -