📄 httpcookie.h
字号:
//// HTTPCookie.h//// $Id: //poco/1.2/Net/include/Poco/Net/HTTPCookie.h#1 $//// Library: Net// Package: HTTP// Module: HTTPCookie//// Definition of the HTTPCookie class.//// Copyright (c) 2005-2006, Applied Informatics Software Engineering GmbH.// and Contributors.//// Permission is hereby granted, free of charge, to any person or organization// obtaining a copy of the software and accompanying documentation covered by// this license (the "Software") to use, reproduce, display, distribute,// execute, and transmit the Software, and to prepare derivative works of the// Software, and to permit third-parties to whom the Software is furnished to// do so, all subject to the following:// // The copyright notices in the Software and this entire statement, including// the above license grant, this restriction and the following disclaimer,// must be included in all copies of the Software, in whole or in part, and// all derivative works of the Software, unless such copies or derivative// works are solely in the form of machine-executable object code generated by// a source language processor.// // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,// FITNESS FOR A PARTICULAR PURPOSE, TITLE AND NON-INFRINGEMENT. IN NO EVENT// SHALL THE COPYRIGHT HOLDERS OR ANYONE DISTRIBUTING THE SOFTWARE BE LIABLE// FOR ANY DAMAGES OR OTHER LIABILITY, WHETHER IN CONTRACT, TORT OR OTHERWISE,// ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER// DEALINGS IN THE SOFTWARE.//#ifndef Net_HTTPCookie_INCLUDED#define Net_HTTPCookie_INCLUDED#include "Poco/Net/Net.h"namespace Poco {namespace Net {class NameValueCollection;class Net_API HTTPCookie /// This class represents a HTTP Cookie. /// /// A cookie is a small amount of information sent by a Web /// server to a Web browser, saved by the browser, and later sent back /// to the server. A cookie's value can uniquely identify a client, so /// cookies are commonly used for session management. /// /// A cookie has a name, a single value, and optional attributes such /// as a comment, path and domain qualifiers, a maximum age, and a /// version number. /// /// This class supports both the Version 0 (by Netscape) and Version 1 /// (by RFC 2109) cookie specifications. By default, cookies are created /// using Version 0 to ensure the best interoperability.{public: HTTPCookie(); /// Creates an empty HTTPCookie. explicit HTTPCookie(const std::string& name); /// Creates a cookie with the given name. /// The cookie never expires. explicit HTTPCookie(const NameValueCollection& nvc); /// Creates a cookie from the given NameValueCollection. HTTPCookie(const std::string& name, const std::string& value); /// Creates a cookie with the given name and value. /// The cookie never expires. HTTPCookie(const HTTPCookie& cookie); /// Creates the HTTPCookie by copying another one. ~HTTPCookie(); /// Destroys the HTTPCookie. HTTPCookie& operator = (const HTTPCookie& cookie); /// Assigns a cookie. void setVersion(int version); /// Sets the version of the cookie. /// /// Version must be either 0 (denoting a Netscape cookie) /// or 1 (denoting a RFC 2109 cookie). int getVersion() const; /// Returns the version of the cookie, which is /// either 0 or 1. void setName(const std::string& name); /// Sets the name of the cookie. const std::string& getName() const; /// Returns the name of the cookie. void setValue(const std::string& value); /// Sets the value of the cookie. /// /// According to the cookie specification, the /// size of the value should not exceed 4 Kbytes. const std::string& getValue() const; /// Returns the value of the cookie. void setComment(const std::string& comment); /// Sets the comment for the cookie. /// /// Comments are only supported for version 1 cookies. const std::string& getComment() const; /// Returns the comment for the cookie. void setDomain(const std::string& domain); /// Sets the domain for the cookie. const std::string& getDomain() const; /// Returns the domain for the cookie. void setPath(const std::string& path); /// Sets the path for the cookie. const std::string& getPath() const; /// Returns the path for the cookie. void setSecure(bool secure); /// Sets the value of the secure flag for /// the cookie. bool getSecure() const; /// Returns the value of the secure flag /// for the cookie. void setMaxAge(int maxAge); /// Sets the maximum age in seconds for /// the cookie. /// /// A value of -1 causes the cookie to /// never expire on the client. /// /// A value of 0 deletes the cookie on /// the client. int getMaxAge() const; /// Returns the maximum age in seconds for /// the cookie. std::string toString() const; /// Returns a string representation of the cookie, /// suitable for use in a Set-Cookie header.private: int _version; std::string _name; std::string _value; std::string _comment; std::string _domain; std::string _path; bool _secure; int _maxAge;};//// inlines//inline int HTTPCookie::getVersion() const{ return _version;}inline const std::string& HTTPCookie::getName() const{ return _name;}inline const std::string& HTTPCookie::getValue() const{ return _value;}inline const std::string& HTTPCookie::getComment() const{ return _comment;}inline const std::string& HTTPCookie::getDomain() const{ return _domain;}inline const std::string& HTTPCookie::getPath() const{ return _path;}inline bool HTTPCookie::getSecure() const{ return _secure;}inline int HTTPCookie::getMaxAge() const{ return _maxAge;}} } // namespace Poco::Net#endif // Net_HTTPCookie_INCLUDED
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -