php的setcookie使用详解

来源:互联网 发布:手机自动解锁软件 编辑:程序博客网 时间:2024/05/16 13:07

# setcookie(name, value, expire, path, domain); // is a functionfor set cookie but path and domain areoptional

# 打印cookie信息 print_r($_COOKIE);

先来讲讲php中setcookie的相关定义:

setcookie() 定义一个和其余的 HTTP 标头一起发送的 cookie。和其它标头一样,cookie必须在脚本的任何其它输出之前发送(这是协议限制)。这需要将本函数的调用放到任何输出之前,包括 和

标签以及任何空格。如果在调用 setcookie() 之前有任何输出,本函数将失败并返回 FALSE。如果 setcookie()函数成功运行,将返回 TRUE。这并不说明用户是否接受了 cookie。

函数定义:

bool setcookie (string name [, string value [, int expire [, string path [, stringdomain [, bool secure]]]]] )

setcookie() 参数详解

参数说明举例nameCookie 的名字。使用 $_COOKIE['cookiename'] 调用名为cookiename 的 cookie。valueCookie 的值。此值保存在客户端,不要用来保存敏感数据。假定 name 是'cookiename',可以通过$_COOKIE['cookiename'] 取得其值。expireCookie 过期的时间。这是个 Unix 时间戳,即从 Unix纪元开始的秒数。换而言之,通常用 time() 函数再加上秒数来设定cookie 的失效期。或者用mktime()来实现。time()+60*60*24*30 将设定 cookie 30天后失效。如果未设定,cookie 将会在会话结束后(一般是浏览器关闭)失效。pathCookie 在服务器端的有效路径。如果该参数设为 '/' 的话,cookie就在整个 domain 内有效,如果设为 '/foo/',cookie就只在 domain 下的 /foo/ 目录及其子目录内有效,例如 /foo/bar/。默认值为设定cookie 的当前目录。domain该 cookie 有效的域名。要使 cookie 能在如 example.com域名下的所有子域都有效的话,该参数应该设为 '.example.com'。虽然 . 并不必须的,但加上它会兼容更多的浏览器。如果该参数设为www.example.com 的话,就只在 www 子域内有效。细节见Cookie规范中的 tail matching。secure指明 cookie 是否仅通过安全的 HTTPS 连接传送。当设成 TRUE 时,cookie仅在安全的连接中被设置。默认值为FALSE0 或 1

 

下面一些例子说明了如何发送 cookie:

例子 1. setcookie() 发送例子

$value = 'something from somewhere';

setcookie("TestCookie", $value);
setcookie("TestCookie",$value,time()+3600); 
setcookie("TestCookie", $value,time()+3600, "/~rasmus/",".utoronto.ca", 1);  
 


注意 cookie 中值的部分在发送的时候会被自动用 urlencode 编码并在接收到的时候被自动解码并把值赋给与自己同名的cookie 变量。如果不想这样并且在使用 PHP 5 的话,可以用 setrawcookie()来代替。下面这个简单的例子可以得到刚才所设定的 cookie 的值:

 

0 0
原创粉丝点击