php学习之cookie

简介:

php学习之cookie

Cookie介绍:

  Cookie是浏览用户访问某些网站时、web服务器在客户端写入的一些小文件、换句话说就是Cookie是存放在客户端的内存或磁盘里.

Cookie可以记录用户浏览的个人信息、像用户访问网站时间、做过哪些事、购物车内有商品变动等、这样、用户下次再访问网站时、就可以直接从Cookie调用以前的数据。

     Cookie优点:

 1、Cookie默认的生命周期起始于浏览器开始运行时、结束于浏览器终止时、此时cookie是存放在客户端的内存中、你还可以设置cookie的生命周期、以秒数计算、将它写入客户端的磁盘里、这样就不会担心cookie自动消失。

 2、Cookie存放在客户端的内存或磁盘里、不会占用web服务器的资源。

 3、cookie可以记录用户浏览的个人信息、网站可以根据Cookie记录信息、设计出个人风格的网页。


     Cookie缺点:

 1、如果有不支持cookie的浏览器、或者浏览用户禁止web服务器在客户端写入cooke、那么cookie就会失效。

 2、cookie存放在客户端、可能会被浏览用户删除或拒绝写入。

 3、cookie可能会造成安全上的威胁、导致个人用户信息窃取。


cookie工作原理

   当客户访问某个网站时,在PHP中可以使用setcookie函数生成一个cookie,系统经处理把这

个cookie发送到客户端并保存在c:\Documents and Settings\用户名\Cookies
目录下。cookie是HTTP标头的一部分,因此setcookie函数必须在任何内容送到浏览器之前调

用。这种限制与header()函数一样。当客户再次访问该网站时,浏览器会
自动把c:\Documents and Settings\用户名\Cookies目录下与该站点对应的cookie发送到服

务器,服务器则把从客户端传来的cookie将自动地转化成一个PHP变量。
通过$_COOKIE['xxx']读取客户端发来的cookie。


写入Cookie

 Setcookie(string name[, string value[, int expire[, string path[, string domain[, bool secure ]]]]]);

 Setrawcookie(string name[, string value[, int expire[, string path[, string domain[, bool secure ]]]]]);

name:用来设置cookie的名称、不能省略。

value:用来设置cookie的值、可以为"",表示删除cookie.

expire:用来设置cooke的生存时间、例如:time()+60*60*24.以秒为单位。

path:用来设置cookie在客户端的存放路径、xp路径在C:\Documents and Settings\Administrator\Cookies.不同操作系统不一样,

这个文件是隐藏的。

domain:用于设置能够访问cookie的域名。

secure:用于设置是否由安全套接层协议层SSL,HTTPS传送cookie,默认是false.


例如:

one.php

<?php

setcookie("username", "blog.51ou.com", time()+60*60*24); //保存时间为一天

setcookie("userage", 22, time()+60*60);//保存时间为一个小时

?>

这样当我们在浏览器打开one.php、然后在C:\Documents and Settings\Administrator\Cookies 会找到相应的cookie信息、这里cookie

都是经过编码的、如果想看到cookie的值可以使用setrawcookie


例如:

two.php

<?php

setcookie("name", "51ou.com", time()+60*60*24); //保存时间为一天

setcookie("age", 22, time()+60*60);//保存时间为一个小时

?>

这样当我们在浏览器打开two.php、然后在C:\Documents and Settings\Administrator\Cookies 会找到相应的明码cookie信息。


此外、cookie必须放在任何输出动作的前面、不然会出错、如果非要这样做可以用这样一对函数:ob_start(); ob_end_flush();

例如:

three.php

<?php

ob_start();//如果前面没有这个函数在setcookie有echo就会出错、

echo "blog.51ou.com";

setcookie("username", "ssw");

ob_end_flush();

?>


访问Cookie


当我们设置好cookie后我们可以用全局这量$_COOKIE['']来访问cookie

例如:

four.php

<?php

setcookie("sitename", "blog.51ou.com");

echo $_COOKIE['sitename'];

?>

在浏览器打开four.php你就会看到blog.51ou.com.


OK到此Cookie到止结束、

Linux命令大全


本文转自 sswqzx 51CTO博客,原文链接:http://blog.51cto.com/sswqzx/1313086
相关文章
|
2月前
|
安全 PHP
从建站到拿站 -- PHP(Cookie设置)
从建站到拿站 -- PHP(Cookie设置)
20 0
|
3月前
|
存储 安全 PHP
php案例 解决cookie失效后使用session的问题
php案例 解决cookie失效后使用session的问题
php案例 解决cookie失效后使用session的问题
|
3月前
|
存储 Web App开发 安全
PHP会话技术跟踪和记录用户?使用cookie会话你必须掌握
PHP会话技术跟踪和记录用户?使用cookie会话你必须掌握
35 0
|
4月前
|
存储 JavaScript 前端开发
百度搜索:蓝易云【php设置和获取Cookie教程。】
需要注意的是,为了确保在向浏览器发送任何输出之前设置Cookie,应该在 `<html>`标签之前或PHP脚本的顶部设置Cookie。
73 0
|
4月前
|
前端开发 PHP 数据安全/隐私保护
【PHP学习】—利用ajax原理实现密码修改功能(九)
【PHP学习】—利用ajax原理实现密码修改功能(九)
|
4月前
|
前端开发 JavaScript PHP
【PHP学习】—利用ajax原理实现登录功能(八)
【PHP学习】—利用ajax原理实现登录功能(八)
|
4月前
|
PHP 数据库
【PHP学习】—PHP连接数据库实现表单页面的验证功能(七)
【PHP学习】—PHP连接数据库实现表单页面的验证功能(七)