因为HTTP本身是无状态的连接协议,所以为了记忆一些用户的信息,我们就需要Cookie和Session这样的会话管理,所以会话管理在任何Web开发语言中都是必不可少的。不过Cookie和Session的内容比较多,今天就总结一些PHP中Cookie的使用方法,加深一下记忆。
Cookie和Session不同的是Session默认是保存在服务器端和客户端的(也可以保存在客户端的硬盘上),而Cookie是保存在硬盘上的,所以使用Cookies之前我们必须先了解Cookie的几个重要注意事项,以免使用过程中造成不必要的问题。
1. 切记不要使用Cookie保存重要的信息,尤其是神马银行卡、密码等信息。我的习惯是保存一条记录中无关紧要主键或者用户名为Cookie值,否则不管是360啊、瑞星啊都有可能把这些信息扫描了去。
2. 单一的域不能有超过20个Cookie,并且每个Cookis的长度为4K字节。也就是说虽然Cookie也可以作为页面间传值的方法之一,但是不要滥用Cookie,否则老的Cookie会被自动覆盖,而超出4K字节的Cookie也会被截取,也就会造成错误了。
3. 使用Cookie前检查客户端浏览器是否支持Cookie,并且必须检查要使用的Cookie是否存在,比如判断isset($_COOKIE["userID"])。
然后我们就可以使用Cookie了,PHP里面设置Cookie的函数为setcookie()函数:bool setcookie ( string $name [, string $value [, int $expire = 0 [, string $path [, string $domain [, bool $secure = false [, bool $httponly = false ]]]]]] )。其中string $name是要设置的cookie的名字,string $value是cookie的值,int $expire是cookie的过期时间,格式为Linux时间戳,默认为0,$path是指cookie起作用的目录,如果设置为“/”,那么cookie在整个$domain都有作用,如果设置为“/foo/”,那么cookie只在$domain下的foo文件夹起作用,string $domain,cookie起作用的域,例如“feiyan.com”,bool $secure,是否仅作用域https://,bool $httponly,如果为true那么cookie仅能用在HTTP协议,JavaScript不能引用PHP的cookie,可以有效避免黑客的攻击。最后,如果成功设置cookie,setcookie就会返回true。
下面是一个通用的cookie使用类来说明cookie的详细用法:
/**
* @author FeiYan
* @copyright FeiYan.Info
* @name Cookie通用类
*/
class cookie
{
private $cookieName; //cookie名称
private $cookieValue; //cookie值
private $cookieExpire; //cookie过期时间
function __construct(){
//构造函数
if(func_num_args()>0)
{
$args = func_get_args();
//获取参数并赋值
$this->cookieName = $args[0];
$this->cookieValue = $args[1];
$this->cookieExpire = $args[2];
$this->cookieMake();
}
}
public function cookieMake()
{
try
{
if($this->cookieName!=“” && $this->cookieValue!=“” && $this->cookieExpire!=“”)
{
setcookie($this->cookieName,$this->cookieValue,time()+$this->cookieExpire);
//创建Cookie,设置Cookie名字、值和有效期
}
else
{
throw new exception(“您必须设置Cookie名字和有效期”);
}
}
catch(exception $e)
{
echo $e->getmessage();
}
}
/**
* 修改指定Cookie的值
* @param string $newValue
* @return null
*/
public function changeCookie($newValue)
{
$_COOKIE["$this->cookieName"] = $newValue;
}
/**
* 从指定Cookie获取值
* @return string
*/
public function getCookieValue()
{
return $_COOKIE["$this->cookieName"];
}
/**
* 删除Cookie中的某个值
*/
public function removeCookie()
{
setcookie($this->cookieName,$this->cookieValue,time()-3600);
}
}
?>
接下来就是使用这个类了,下面的代码是使用这个类的示例:
$cookie = new cookie(“userName”,“飞晏”,3600);
echo “Cookie的值是:”.$cookie->getCookieValue().“<br />”;
//输出:Cookie的值是:飞晏
$cookie->changeCookie(“晏飞”);
//改变Cookie的值
echo “Cookie的值是:”.$cookie->getCookieValue().“<br />”;
//输出:Cookie的值是:晏飞
?>
在大量使用Cookie的时候,可以把一些列的Cookie数据存入到一个PHP数组中,代码如下:
setcookie(“userInfo[userName]“, “飞晏”);
setcookie(“userInfo[userGender]“, “男”);
setcookie(“userInfo[userHobby]“, “女”);
if(isset($_COOKIE["userInfo"]))
{
foreach($_COOKIE["userInfo"] as $k=>$v)
{
echo $k.“:”.$v.“<br />”;
}
}
?>
PHP中操作Cookie的基本用法也就这么多了,相比C#里面的Cookie的用法原理基本上一致的,只不过微软提供了更多的封装,赶明儿得空继续总结PHP中的Session的用法。