📄 cookie.java
字号:
/* * Copyright (c) 1998-2008 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;/** * Encapsulates HTTP cookies. * * <p/>Cookies are use to keep track of users for sessions and to * recognize users back for personalization. * * <p/>When deleting cookies or changing the time, it's important to * set the same domain and path as originally passed. Browsers distinguish * cookies with different domain and path. * * <code><pre> * Cookie myCookie = new Cookie("mycookie", "myvalue"); * myCookie.setPath("/path"); * myCookie.setDomain("mydom.com"); * // will live for a month * myCookie.setMaxAge(60 * 24 * 3600); * response.addCookie(myCookie); * </pre></code> * * <p/>To delete the above cookie, you'll need to do something like the * following: * * <code><pre> * Cookie myCookie = new Cookie("mycookie", "myvalue"); * myCookie.setPath("/path"); * myCookie.setDomain("mydom.com"); * // kill the cookies * myCookie.setMaxAge(0); * response.addCookie(myCookie); * </pre></code> */public class Cookie implements Cloneable { private String _key; private String _value; private String _comment; private int _maxAge = -1; private String _path; private boolean _secure; private String _name; private String _domain; private int _version = 0; private boolean _isHttpOnly; /** * Create a new cookie with the specified name and value. * * @param name name of the cookie * @param value value of the cookie */ public Cookie(String name, String value) { int length = name.length(); for (int i = length - 1; i >= 0; i--) { char ch = name.charAt(i); if (ch >= 0x7f || ! validChar[ch]) throw new IllegalArgumentException("illegal cookie name: " + name); else if (ch == '$' && i == 0) throw new IllegalArgumentException("cookie can't start with '$'"); } _name = name; _value = value; } /** * Sets the cookie comment * * @param comment comment string */ public void setComment(String comment) { _comment = comment; } /** * Gets the cookie comment */ public String getComment() { return _comment; } /** * Sets the cookie domain. A site which uses multiple machines, e.g. * with DNS round robin, but a single site will want to set the domain. * * <code><pre> * cookie.setDomain("yahoo.com"); * </pre></code> * * @param domain DNS domain name */ public void setDomain(String domain) { _domain = domain; } /** * Returns the cookie's domain */ public String getDomain() { return _domain; } /** * True for HttpOnly request * * @since Servlet 3.0 */ public boolean isHttpOnly() { return _isHttpOnly; } /** * True for HttpOnly request * * @since Servlet 3.0 */ public void setHttpOnly(boolean isHttpOnly) { _isHttpOnly = isHttpOnly; } /** * Sets the max age of a cookie. Setting <code>maxAge</code> to zero * deletes the cookie. Setting it to something large makes the cookie * persistent. If <code>maxAge</code> is not set, the cookie will only * last for the session. * * @param maxAge lifetime of the cookie in seconds. */ public void setMaxAge(int maxAge) { _maxAge = maxAge; } /** * Returns the max age of the cookie in seconds. */ public int getMaxAge() { return _maxAge; } /** * Sets the URL path of a cookie. Normally, cookies will just use * the root path. */ public void setPath(String path) { _path = path; } /** * Gets the URL path of a cookie. */ public String getPath() { return _path; } /** * Tells the browser that this cookie should only be passed over a * secure connection like SSL. */ public void setSecure(boolean secure) { _secure = secure; } /** * Returns true if the cookie must be over a secure connection. */ public boolean getSecure() { return _secure; } /** * Returns the cookie's name. */ public String getName() { return _name; } /** * Sets the cookie's value. Normally this will be a random unique * string to lookup the cookie in a database. */ public void setValue(String value) { _value = value; } /** * Returns the cookie's value. */ public String getValue() { return _value; } /** * Returns cookie protocol version. */ public int getVersion() { return _version; } /** * Sets cookie protocol version, defaulting to 0. */ public void setVersion(int version) { _version = version; } /** * Returns a clone of the cookie */ public Object clone() { try { return super.clone (); } catch (CloneNotSupportedException e) { throw new RuntimeException (e.getMessage ()); } } /** * Converts the cookie to a string for debugging. */ public String toString() { StringBuffer sb = new StringBuffer(); sb.append("Cookie[" + _name + "=" + _value); if (_path != null) sb.append(",path=" + _path); if (_domain != null) sb.append(",domain=" + _domain); if (_maxAge > 0) sb.append(",max-age=" + _maxAge); if (_secure) sb.append(",secure"); if (_isHttpOnly) sb.append(",httpOnly"); sb.append("]"); return sb.toString(); } private static boolean []validChar; static { validChar = new boolean[128]; for (int i = 33; i < 127; i++) validChar[i] = true; validChar[','] = false; validChar[';'] = false; /* * Disabled to match jakarta * validChar['('] = false; validChar[')'] = false; validChar['<'] = false; validChar['>'] = false; validChar['@'] = false; validChar[':'] = false; validChar['\\'] = false; validChar['"'] = false; validChar['/'] = false; validChar['['] = false; validChar[']'] = false; validChar['?'] = false; validChar['='] = false; validChar['{'] = false; validChar['}'] = false; */ }}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -