动网论坛,站长建站首选,国内使用量最多的论坛软件 动网论坛官方技术讨论区 站长工具 申请属于您自己的免费论坛
首页 | 新闻资讯 | 网站运营 | 网络编程 | 数据库 | 服务器 | 网页设计 | 图像媒体 | 网络应用 | 搜索优化 | 资源下载 | 动网主机 | DVBOX
    本站内  互联网 ASP论坛  ASP.Net论坛  PHP论坛
  
   PHP → 阅读文章

 简单易懂,Session的工作方式

作者来源: 
阅读 1395 人次 , 2006-3-29 4:10:00 


下面我们来看一下session是如何工作的。不知你是否知道通过cookie来实现身份认证的吧。首先生成一个独一无二的cookie作为用户身份的标志,并在数据库中进行注册。然后通过用户传递来的cookie和数据库中注册的cookie进行对照以确定用户的身份。
session的工作原理也是这样。
首先,php为建立session的用户产生一个独一无二的字符串,用来标志这个用户的session。一般将这个字符串称作session id。然后“sess”+session id为文件名(例如一个session id为111,那么文件名为sess_111)在服务器的文件系统中建立一个文件,在文件中保存用户在session所定义的全局变量的变量名和值。然后再将session id作为一个名为phpsession的cookie保存在用户端的文件系统中。
然后,当用户再次连接服务器访问一个php脚本时,php从用户发来的peesession这个cookie中得到用户所在session的session id,并根据session id从服务器的文件系统中保存session信息的文件。最后从这个文件中读出用户在上次连接时所设置的全局变量的值。
因此,我们可以看到session的工作原理和我们上一节所介绍的身份认证的工作原理是一样的。所不同的只是session将信息保存在了服务器的文件系统中,而我们将信息保存在了数据库中。当然使用session好处就是数据的保存和获取是由php自动完成的,而直接使用cookie的话就需要自己动手进行数据的保存和获取。
session利用cookie的身份标志功能,将用户在浏览网站时需要保存的信息保存在服务器上。这样session既克服了http协议的缺陷,又防止了信息的泄漏,而且方便了编程者的使用,是一个非常好的解决方案。不过,session的功能只有php4支持,php3是不支持session的。因此使用php3进行网站构建的读者只能采用直接使用cookie的方式。

 本文Tagssession  
 收藏本文  打印本文  论坛讨论  关闭窗口
· 上一篇:关于session的几个补充函数
· 下一篇:php的计数器程序
· 利用Editplus2的用户工具功能来即时调试PHP
· 用PHP处理多个同名复选框
· PHP VS ASP
· 初学者必读 PHP常用开发工具分析
· 用IE远程创建Mysql数据库的简易程序


关于本站 | 联系我们 | 业务合作 | 客户案例 | 诚聘英才 | 广告合作 | 收藏本站
海口动网先锋网络科技有限公司版权所有
Copyright © 2000 - 2006 Cndw.Com
中华人民共和国电信与信息服务业务经营许可证编号 琼 ICP 020077