用cookies来跟踪识别用户


Posted in PHP onOctober 09, 2006

让我们来看看保存在浏览器中的内容。如果你用的是IE5,在windows目录下有一个cookies的目录,里面有很多文本文件,文件名都是类似于wudong@15seconds[1].txt这样的,这就是浏览器用来保存值的cookies了。在以前的IE版本中,cookies的内容是可以察看的,但现在内容已经被编码了。在浏览器得到一个Web页面之前,它会先看这个页面的域名,是否在cookie中存在,如果有相比配的,浏览器会先把匹配的cookie传送到服务器,然后才接受处理服务器传送过来的页面。


先举个cookies应用的例子:当我连接到Amazon.com时,浏览器在接受第一个页面之前会把它以前设置的cookies的内容传送给Amazon。然后Amazon.com对传送过来的内容加以检查,看看在数据库中有没有相关资料,在匹配之后,在为我建立一个定制的页面传送到过来。

为cookies赋值


必须在服务器传送任何内容给客户浏览器之前为Cookies赋值。要做到这一点,cookies的设置就必须放在<HEAD>标签内:

<?php

setcookie("CookieID",$USERID);

?>

<HTML>

<BODY>

</BODY>

</HTML>

setcookie函数一共有六个参数,用逗号来分隔:


cookie的名称,是一个字符串,例如:"CookieID"。其间不允许有冒号,逗号和空格。这个参数是必须的,而其它的所有参数都是可选的。如果只有这一个参数被给出,那么这个cookie将被删除。


cookie的值,通常是一个字符串变量,例如:$USERID。也可以为它赋一个??来略过值的设置。


cookie失效的时间。如果被省略(或者被赋值为零),cookie将在这个对话期(session)结束后失效。这个参数可以是一个绝对的时间,用DD-Mon-YYHH:MM:SS来表示,比如:"24-Nov-9908:26:00"。而更常用的是设置一个相对时间。这是通过time()函数或者mktime函数来实现的。比如time()+3600将使得cookie在一个小时后失效。


一个路径,用来匹配cookie的。当在一个服务器上有多个同名的cookie的设置,为避免混淆,就要用到这个参数了。使用"/"路径的和省略这个参数的效果是一样的。要注意的是Netscape的cookie定义是把域名放在路径的前面的,而PHP则与之相反。


服务器的域名,也是用来匹配cookie的。要注意的是:在服务器的域名前必须放上一个点(.)。例如:".friendshipcenter.com"。因为除非有两个以上的点存在,否者这个参数是不能被接受的。


cookie的安全级,是一个整数。1表示这个cookie只能通过“安全”的网络来传送。0或者省略则表示任何类型的网络都可以。


Cookies和变量


当PHP脚本从客户浏览器提取了一个cookie后,它将自动的把它转换成一个变量。例如:一个名为CookieID的cookie将变成变量$CookieID.


Cookies的内容被报存在HTTP_COOKIE_VARS数组中,你还可以通过这个数组和cookie的名称来存取指定的cookie值:


print$HTTP_COOKIE_VARS[CookieID];


记住每一个用户


回过头在来看看上面的submitform.php3文件,它的作用是把客户的姓名添加到数据库中,现在我想为它添加一些东西。我想为每个用户都分配一个唯一的用户标志,然后把这个标志放在Cookies中,这样每当用户访问我的网站的时候,通过cookie和其中的用户标志,我就能够知道他是谁了。


MySQL能够被设置成为每一个新的纪录自动的分配一个数字,这个数字从1开始,以后每次自动加1。用一行SQL语句,你就可以轻松的为数据表添加这样的一个字段,我把它叫做USERID:

ALTERTABLEdbname

ADDCOLUMN

USERIDINT(11)NOTNULL

PRIMARYKEYAUTO_INCREMENT;


对这个字段我们作了一些特别的设置。首先,通过“INT(11)”定义它的类型为11位的整数;然后用“NOTNULL”关键字让这个字段的值不能为NULL;再用“PRIMARYKEY”把它设置为索引字段,这样搜索起来就会更快;最后,“AUTO_INCREMENT”定义它为自动增一的字段。


当把用户的姓名插入到数据库后,就应该在他们的浏览器上设置cookie了。这时利用的就是刚才我们谈到的USERID字段的值:


<?php

mysql_connect(localhost,username,password);

mysql_select_db(dbname);

mysql_query("INSERTINTOtablename(first_name,last_name)

VALUES('$first_name','$last_name')

");

setcookie("CookieID",

mysql_insert_id(),

time()+94608000,

"/");/*三年后cookie才会失效*/

?>


PHP函数mysql_insert_id()返回在最后一次执行了INSERT查询后,由AUTO_INCREMENT定义的字段的值。这样,只要你不清除掉浏览器的Cookies,网站就会永远“记住”你了


读取cookie


我们来写一个像Amazon.com所作的那样的脚本。首先,PHP脚本会先检查客户浏览器是否发送了cookie过来,如果是那样的话,用户的姓名就会被显示出来。如果没找到cookie的话,就显示一个表单,让客户登记他们的姓名,然后把他添加到数据库中,并在客户浏览其中设置好cookie。


首先,先来显示cookie的内容:

<?php

print$CookieID;

?>

然后,就可以把名字显示出来了:

<?php

mysql_connect(localhost,username,password);

mysql_select_db(dbname);

$selectresult=mysql_query("SELECT*FROMtablename

WHEREUSERID='$CookieID'

");

$row=mysql_fetch_array($selectresult);

echo"欢迎你的光临",$row[first_name],"!";

?>

就是这样的了。我在其中没有作判断,交给你自己来完成好了  

PHP 相关文章推荐
php 保留小数点
Apr 21 PHP
网页游戏开发入门教程三(简单程序应用)
Nov 02 PHP
一步一步学习PHP(7) php 字符串相关应用
Mar 05 PHP
php中jQuery插件autocomplate的简单使用笔记
Jun 14 PHP
php中计算未知长度的字符串哪个字符出现的次数最多的代码
Aug 14 PHP
有关PHP性能优化的介绍
Jun 20 PHP
PHP cdata 处理(详细介绍)
Jul 05 PHP
分享PHP函数实现数字与文字分页代码
Jul 28 PHP
PHP 设计模式系列之 specification规格模式
Jan 10 PHP
PHP使用fopen与file_get_contents读取文件实例分享
Mar 04 PHP
PHP中Static(静态)关键字功能与用法实例分析
Apr 05 PHP
laravel Validator ajax返回错误信息的方法
Sep 29 PHP
使用sockets:从新闻组中获取文章(一)
Oct 09 #PHP
使用sockets:从新闻组中获取文章(三)
Oct 09 #PHP
PHP+MYSQL的文章管理系统(二)
Oct 09 #PHP
使用sockets:从新闻组中获取文章(二)
Oct 09 #PHP
通过ODBC连接的SQL SERVER实例
Oct 09 #PHP
如何对PHP程序中的常见漏洞进行攻击(下)
Oct 09 #PHP
模拟OICQ的实现思路和核心程序(三)
Oct 09 #PHP
You might like
PHP4和PHP5性能测试和对比 测试代码与环境
2007/08/17 PHP
php判断输入不超过mysql的varchar字段的长度范围
2011/06/24 PHP
Wordpress ThickBox 添加“查看原图”效果代码
2010/12/11 Javascript
JQueryiframe页面操作父页面中的元素与方法(实例讲解)
2013/11/19 Javascript
jquery 通过name快速取值示例
2014/01/24 Javascript
JavaScript中使用指数方法Math.exp()的简介
2015/06/15 Javascript
jQuery中通过ajax的get()函数读取页面的方法
2016/02/29 Javascript
JavaScript简单下拉菜单特效
2016/09/13 Javascript
详解vue渲染从后台获取的json数据
2017/07/06 Javascript
详解webpack2+node+react+babel实现热加载(hmr)
2017/08/24 Javascript
js中的数组对象排序分析
2018/12/11 Javascript
微信小程序实现获取准确的腾讯定位地址功能示例
2019/03/27 Javascript
详解vue开发中调用微信jssdk的问题
2019/04/16 Javascript
微信小程序JS加载esmap地图的实例详解
2019/09/04 Javascript
[47:21]Liquid vs TNC Supermajor 胜者组 BO3 第一场 6.4
2018/06/05 DOTA
[42:11]TNC vs Pain 2018国际邀请赛小组赛BO2 第二场 8.17
2018/08/20 DOTA
Python完全新手教程
2007/02/08 Python
python常规方法实现数组的全排列
2015/03/17 Python
Python+django实现简单的文件上传
2016/08/17 Python
Python优化技巧之利用ctypes提高执行速度
2016/09/11 Python
Python实现的中国剩余定理算法示例
2017/08/05 Python
Python读取系统文件夹内所有文件并统计数量的方法
2018/10/23 Python
Python从单元素字典中获取key和value的实例
2018/12/31 Python
Python直接赋值、浅拷贝与深度拷贝实例分析
2019/06/18 Python
python按行读取文件并找出其中指定字符串
2019/08/08 Python
python调用函数、类和文件操作简单实例总结
2019/11/29 Python
Python计算指定日期是今年的第几天(三种方法)
2020/03/26 Python
利用pipenv和pyenv管理多个相互独立的Python虚拟开发环境
2020/11/01 Python
业务副厂长岗位职责
2014/01/03 职场文书
大学开学计划书
2014/04/30 职场文书
法人代表证明书
2014/09/18 职场文书
加强作风建设心得体会
2014/10/22 职场文书
风之谷观后感
2015/06/11 职场文书
师德师风心得体会(2016精选篇)
2016/01/12 职场文书
原生CSS实现文字无限轮播的通用方法
2021/03/30 HTML / CSS
数据库的高级查询六:表连接查询:外连接(左外连接,右外连接,UNION关键字,连接中ON与WHERE的不同)
2021/04/05 MySQL