| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268 | <?php// +----------------------------------------------------------------------// | ThinkPHP [ WE CAN DO IT JUST THINK ]// +----------------------------------------------------------------------// | Copyright (c) 2006~2018 http://thinkphp.cn All rights reserved.// +----------------------------------------------------------------------// | Licensed ( http://www.apache.org/licenses/LICENSE-2.0 )// +----------------------------------------------------------------------// | Author: liu21st <liu21st@gmail.com>// +----------------------------------------------------------------------namespace think;class Cookie{    /**     * @var array cookie 设置参数     */    protected static $config = [        'prefix'    => '', // cookie 名称前缀        'expire'    => 0, // cookie 保存时间        'path'      => '/', // cookie 保存路径        'domain'    => '', // cookie 有效域名        'secure'    => false, //  cookie 启用安全传输        'httponly'  => false, // httponly 设置        'setcookie' => true, // 是否使用 setcookie    ];    /**     * @var bool 是否完成初始化了     */    protected static $init;    /**     * Cookie初始化     * @access public     * @param  array $config 配置参数     * @return void     */    public static function init(array $config = [])    {        if (empty($config)) {            $config = Config::get('cookie');        }        self::$config = array_merge(self::$config, array_change_key_case($config));        if (!empty(self::$config['httponly'])) {            ini_set('session.cookie_httponly', 1);        }        self::$init = true;    }    /**     * 设置或者获取 cookie 作用域(前缀)     * @access public     * @param  string $prefix 前缀     * @return string|     */    public static function prefix($prefix = '')    {        if (empty($prefix)) {            return self::$config['prefix'];        }        return self::$config['prefix'] = $prefix;    }    /**     * Cookie 设置、获取、删除     * @access public     * @param  string $name   cookie 名称     * @param  mixed  $value  cookie 值     * @param  mixed  $option 可选参数 可能会是 null|integer|string     * @return void     */    public static function set($name, $value = '', $option = null)    {        !isset(self::$init) && self::init();        // 参数设置(会覆盖黙认设置)        if (!is_null($option)) {            if (is_numeric($option)) {                $option = ['expire' => $option];            } elseif (is_string($option)) {                parse_str($option, $option);            }            $config = array_merge(self::$config, array_change_key_case($option));        } else {            $config = self::$config;        }        $name = $config['prefix'] . $name;        // 设置 cookie        if (is_array($value)) {            array_walk_recursive($value, 'self::jsonFormatProtect', 'encode');            $value = 'think:' . json_encode($value);        }        $expire = !empty($config['expire']) ?        $_SERVER['REQUEST_TIME'] + intval($config['expire']) :        0;        if ($config['setcookie']) {            setcookie(                $name, $value, $expire, $config['path'], $config['domain'],                $config['secure'], $config['httponly']            );        }        $_COOKIE[$name] = $value;    }    /**     * 永久保存 Cookie 数据     * @access public     * @param  string $name   cookie 名称     * @param  mixed  $value  cookie 值     * @param  mixed  $option 可选参数 可能会是 null|integer|string     * @return void     */    public static function forever($name, $value = '', $option = null)    {        if (is_null($option) || is_numeric($option)) {            $option = [];        }        $option['expire'] = 315360000;        self::set($name, $value, $option);    }    /**     * 判断是否有 Cookie 数据     * @access public     * @param  string      $name   cookie 名称     * @param  string|null $prefix cookie 前缀     * @return bool     */    public static function has($name, $prefix = null)    {        !isset(self::$init) && self::init();        $prefix = !is_null($prefix) ? $prefix : self::$config['prefix'];        return isset($_COOKIE[$prefix . $name]);    }    /**     * 获取 Cookie 的值     * @access public     * @param string      $name   cookie 名称     * @param string|null $prefix cookie 前缀     * @return mixed     */    public static function get($name = '', $prefix = null)    {        !isset(self::$init) && self::init();        $prefix = !is_null($prefix) ? $prefix : self::$config['prefix'];        $key    = $prefix . $name;        if ('' == $name) {            // 获取全部            if ($prefix) {                $value = [];                foreach ($_COOKIE as $k => $val) {                    if (0 === strpos($k, $prefix)) {                        $value[$k] = $val;                    }                }            } else {                $value = $_COOKIE;            }        } elseif (isset($_COOKIE[$key])) {            $value = $_COOKIE[$key];            if (0 === strpos($value, 'think:')) {                $value = json_decode(substr($value, 6), true);                array_walk_recursive($value, 'self::jsonFormatProtect', 'decode');            }        } else {            $value = null;        }        return $value;    }    /**     * 删除 Cookie     * @access public     * @param  string      $name   cookie 名称     * @param  string|null $prefix cookie 前缀     * @return void     */    public static function delete($name, $prefix = null)    {        !isset(self::$init) && self::init();        $config = self::$config;        $prefix = !is_null($prefix) ? $prefix : $config['prefix'];        $name   = $prefix . $name;        if ($config['setcookie']) {            setcookie(                $name, '', $_SERVER['REQUEST_TIME'] - 3600, $config['path'],                $config['domain'], $config['secure'], $config['httponly']            );        }        // 删除指定 cookie        unset($_COOKIE[$name]);    }    /**     * 清除指定前缀的所有 cookie     * @access public     * @param  string|null $prefix cookie 前缀     * @return void     */    public static function clear($prefix = null)    {        if (empty($_COOKIE)) {            return;        }        !isset(self::$init) && self::init();        // 要删除的 cookie 前缀,不指定则删除 config 设置的指定前缀        $config = self::$config;        $prefix = !is_null($prefix) ? $prefix : $config['prefix'];        if ($prefix) {            foreach ($_COOKIE as $key => $val) {                if (0 === strpos($key, $prefix)) {                    if ($config['setcookie']) {                        setcookie(                            $key, '', $_SERVER['REQUEST_TIME'] - 3600, $config['path'],                            $config['domain'], $config['secure'], $config['httponly']                        );                    }                    unset($_COOKIE[$key]);                }            }        }    }    /**     * json 转换时的格式保护     * @access protected     * @param  mixed  $val  要转换的值     * @param  string $key  键名     * @param  string $type 转换类别     * @return void     */    protected static function jsonFormatProtect(&$val, $key, $type = 'encode')    {        if (!empty($val) && true !== $val) {            $val = 'decode' == $type ? urldecode($val) : urlencode($val);        }    }}
 |