ThinkPHP函数详解:cookie方法

cookie函数也是一个多元化操作函数,完成cookie的设置、获取和删除操作。

Cookie 用于Cookie 设置、获取、删除操作

用法
cookie($name, $value='', $option=null)

参数
name(必须):要操作的cookie变量
value(可选):要设置的cookie值
option(可选):传入的cookie设置参数,默认为空

返回值
见详(根据具体的用法返回不同的值)

Cookie设置
  1. cookie('name','value'); //设置cookie
  2. cookie('name','value',3600); // 指定cookie保存时间

复制代码

3.1版本开始,cookie方法增加对数组的支持(采用轻量级的json编码格式保存 减少存储空间),例如:[-more-]

  1. cookie('name',array('name1','name2'));

复制代码

还可以支持参数传入的方式完成复杂的cookie赋值,下面是对cookie的值设置3600秒有效期,并且加上cookie前缀think_

  1. cookie('name','value',array('expire'=>3600,'prefix'=>'think_'))

复制代码

数组参数可以采用query形式参数

  1. cookie('name','value','expire=3600&prefix=think_')

复制代码

和上面的用法等效。
传入的option参数支持prefix,expire,path,domain四个索引参数,如果没有传入或者传入空值的话,会默认取COOKIE_PREFIX、COOKIE_EXPIRE、COOKIE_PATH和COOKIE_DOMAIN四个配置参数。如果只传入个别参数,那么也会和默认的配置参数合并。

Cookie获取
获取cookie很简单,无论是怎么设置的cookie,只需要使用:
  1. $value = cookie('name');

复制代码

如果没有设置cookie前缀的话 相当于

  1. $value = $_COOKIE['name']

复制代码

如果设置了cookie前缀的话,相当于

  1. $value = $_COOKIE['前缀+name']

复制代码

Cookie删除
删除某个cookie的值,使用:
  1. cookie('name',null);

复制代码

要删除所有的Cookie值,可以使用

  1. cookie(null); // 清空当前设定前缀的所有cookie值
  2. cookie(null,'think_'); //  清空指定前缀的所有cookie值