您的位置:首页 > 编程语言 > PHP开发

PHP会话管理之Cookie的使用

2011-02-10 15:03 267 查看
因为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的详细用法:

PHP语言:
<?php

/**

* @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);

}

}

?>

接下来就是使用这个类了,下面的代码是使用这个类的示例:

PHP语言:
<?php

$cookie = new cookie(“userName”,“飞晏”,3600);

echo “Cookie的值是:”.$cookie->getCookieValue().“<br />”;

//输出:Cookie的值是:飞晏

$cookie->changeCookie(“晏飞”);

//改变Cookie的值

echo “Cookie的值是:”.$cookie->getCookieValue().“<br />”;

//输出:Cookie的值是:晏飞

?>
在大量使用Cookie的时候,可以把一些列的Cookie数据存入到一个PHP数组中,代码如下:

PHP语言:
<?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的用法。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  PHP 职场 Cookie 休闲