PHP 的 Cookies

Cookie 是什么?
cookie 常用于识别用户。cookie 是服务器留在用户计算机中的小文件。每当相同的计算机通过浏览器请求页面时,它同时会发送 cookie。通过 PHP,您能够创建并取回 cookie 的值。

如何创建 cookie?
setcookie() 函数用于设置 cookie。
注:setcookie() 函数必须位于 标签之前。

语法:
setcookie(name, value, expire, path, domain);

注:在发送 cookie 时,cookie 的值会自动进行 URL 编码,在取回时进行自动解码(为防止 URL 编码,请使用 setrawcookie() 取而代之)。

如何取回 Cookie 的值?
PHP 的 $_COOKIE 变量用于取回 cookie 的值。

下面我们来看看示例,使用 isset() 函数判断是否设置了Cookie,在进行显示,常用在用户登陆的地方,登陆之前显示默认语句,登陆后显示用户相关信息,代码如下:

<html>
<body>

<?php
if (isset($_COOKIE["user"]))
  echo "Welcome " . $_COOKIE["user"] . "!<br />";
else
  echo "Welcome guest!<br />";
?>

</body>
</html>

如何删除 cookie?
当删除 cookie 其实很简单,只需要把使用日期改为过去的时间点就可以啦!代码如下:

<?php 
// set the expiration date to one hour ago
setcookie("user", "", time()-3600);
?>

如果浏览器不支持 cookie 该怎么办?
如果您的应用程序涉及不支持 cookie 的浏览器,您就不得不采取其他方法在应用程序中从一张页面向另一张页面传递信息。一种方式是从表单传递数据(有关表单和用户输入的内容,之前我们已经在聊过啦,感兴趣的朋友可以去翻阅一下)。

下面这个表单在用户单击提交按钮时向 “welcome.php” 传递了用户输入信号,代码如下:

<html>
<body>

<form action="welcome.php" method="post">
Name: <input type="text" name="name" />
Age: <input type="text" name="age" />
<input type="submit" />
</form>

</body>
</html>



//取回 "welcome.php" 中的值:
<html>
<body>

Welcome <?php echo $_POST["name"]; ?>.<br />
You are <?php echo $_POST["age"]; ?> years old.

</body>
</html>

如果你发现错误或有其他见解,请给www.zhuei.com留言,我们会尽快更新本文!

发表评论

邮箱地址不会被公开。 必填项已用*标注