269 lines
		
	
	
		
			7.5 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			269 lines
		
	
	
		
			7.5 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
<?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);
 | 
						|
        }
 | 
						|
    }
 | 
						|
}
 |