12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394 |
- <?php
- /**
- * CHttpCookie class file.
- *
- * @author Qiang Xue <qiang.xue@gmail.com>
- * @link http://www.yiiframework.com/
- * @copyright 2008-2013 Yii Software LLC
- * @license http://www.yiiframework.com/license/
- */
- /**
- * A CHttpCookie instance stores a single cookie, including the cookie name, value, domain, path, expire, and secure.
- *
- * @author Qiang Xue <qiang.xue@gmail.com>
- * @package system.web
- * @since 1.0
- */
- class CHttpCookie extends CComponent
- {
- /**
- * @var string name of the cookie
- */
- public $name;
- /**
- * @var string value of the cookie
- */
- public $value='';
- /**
- * @var string domain of the cookie
- */
- public $domain='';
- /**
- * @var integer the timestamp at which the cookie expires. This is the server timestamp. Defaults to 0, meaning "until the browser is closed".
- */
- public $expire=0;
- /**
- * @var string the path on the server in which the cookie will be available on. The default is '/'.
- */
- public $path='/';
- /**
- * @var boolean whether cookie should be sent via secure connection
- */
- public $secure=false;
- /**
- * @var boolean whether the cookie should be accessible only through the HTTP protocol.
- * By setting this property to true, the cookie will not be accessible by scripting languages,
- * such as JavaScript, which can effectly help to reduce identity theft through XSS attacks.
- * Note, this property is only effective for PHP 5.2.0 or above.
- */
- public $httpOnly=false;
- /**
- * Constructor.
- * @param string $name name of this cookie
- * @param string $value value of this cookie
- * @param array $options the configuration array consisting of name-value pairs
- * that are used to configure this cookie
- */
- public function __construct($name,$value,$options=array())
- {
- $this->name=$name;
- $this->value=$value;
- $this->configure($options);
- }
- /**
- * This method can be used to configure the CookieObject with an array
- * Note: you cannot use this method to set the name and/or the value of the cookie
- * @param array $options the configuration array consisting of name-value pairs
- * that are used to configure this cookie
- * @since 1.1.11
- */
- public function configure($options=array())
- {
- foreach($options as $name=>$value)
- {
- if($name==='name'||$name==='value')
- continue;
- $this->$name=$value;
- }
- }
- /**
- * Magic method to use the cookie object as a string without having to call value property first.
- * <code>
- * $value = (string)$cookies['name'];
- * </code>
- * Note, that you still have to check if the cookie exists.
- * @return string The value of the cookie. If the value property is null an empty string will be returned.
- * @since 1.1.11
- */
- public function __toString()
- {
- return (string)$this->value;
- }
- }
|