通行证: 用户 密码 网站建设  下载中心 社区论坛 信息公告 MY小屋
联系我们
设为首页
加入收藏

 

QQ,ASP,PHP,JSP,XML,SQL,.Net,编程 程序 网页图象 建站经验 私服
首页 | 新闻资讯 | 编程开发 | 网页设计 | 图形图象 | 网络媒体 | 网站模板 | 数 据 库 | 投稿
论坛 | 操作系统 | 系统优化 | 网络安全 | 黑客技术 | 硬件学堂 | 硬件报价 | 服 务 器 | 地图
专题 | 应用软件 | 聊天通讯 | Q Q 专栏 | 建站经验 | 在线工具 | 站长Club | 注 册 表 | 旧版
社会 | 游戏娱乐 | 设计欣赏 | 疑难解答 | 社区论坛 | 韩国素材 | 素材图库 | 广告服务 | 服务
当前位置:首页>>编程开发>>PHP专区>>正文 新版上线![旧版]
注:打开慢时请稍等

PHP5:session会话的使用和分析

http://www.iyit.net  日期:2006-11-18 12:48:37  来源:iyit.net  点击:
参加讨论

  session_decode

  函数功能:sesssion信息解码

  函数原型:boolean session_decode (string data)

  返回值:布尔值

  功能说明:这个函数可将session信息解码,成功则返回逻辑值true

  Php5不再使用session_id,而是把它变成一个常量SID,并保存在cookie中。如果客户端禁用了cookie,php会自动通过url自动传动传递SID,其条件是设置php.ini中的session.use_trans_sid = 1。此时即使客户端即使禁用了cookie也没关系了。

  用 strip_tags() 来输出 SID 以避免 XSS 相关的攻击。
 Session跨页传递问题:

  session跨页传递需要考虑三种情况:

  ①客户端禁用了cookie。

  ②浏览器出现问题,暂时无法存取cookie

  ③php.ini中的session.use_trans_sid = 0或者编译时没有打开--enable-trans-sid选项

  为什么会这样呢?下面解释一下原因:

  Session文件分为两部分:session变量保存在服务器端(默认以文件方式存储session);而session id则以cookie形式保存在客户端。(注意:session默认是基于cookie的)。

  当用户的浏览器向服务器提出请求时,同时发送包含session id的cookie(默认情况下)。服务器根据客户端提供的session id来得到用户的文件,即保存在服务器端的session变量值。事实上,session id可以使用客户端的Cookie或者Http1.1协议的Query_String(就是访问的URL的“?”后面的部分)来传送给服务器,然后服务器读取Session的目录……。也就是说,session id是取得存储在服务上的session变量的身份证。当代码session_start();运行的时候,就在服务器上产生了一个session文件,随之也产生了与之唯一对应的一个session id,定义session变量以一定形式存储在刚才产生的session文件中。通过session id,可以取出定义的变量。跨页后,为了使用session,你必须又执行session_start();将又会产生一个session文件,与之对应产生相应的session id,用这个session id是取不出前面提到的第一个session文件中的变量的,因为这个session id不是打开它的“钥匙”。如果在session_start();之前加代码session_id($session id);将不产生新的session文件,直接读取与这个id对应的session文件。

  PHP中的session在默认情况下是使用客户端的Cookie来保存session id的,所以当客户端的cookie出现问题的时候就会影响session了。必须注意的是:session不一定必须依赖cookie,这也是session相比cookie的高明之处。当客户端的Cookie被禁用或出现问题时,PHP会自动把session id附着在URL中,这样再通过session id就能跨页使用session变量了。但这种附着也是有一定条件的,其一:“php.ini中的session.use_trans_sid = 1或者编译时打开打开了--enable-trans-sid选项”;其二:运行PHP的服务器必须是unix/linux系统,windows不具备此项功能。

  明白了以上的道理,我们就可以得出解决session跨页传递问题的三条途径:

  1、设置php.ini中的session.use_trans_sid = 1或者编译时打开打开了--enable-trans-sid选项,让PHP自动跨页传递session id。

  2、手动通过URL传值、隐藏表单传递session id。

  3、用文件、数据库等形式保存session_id,在跨页过程中手动调用。

  下面举例说明:

  第一种情况:

  page1.php

<?php
session_start();
$_SESSION['var1']="中华人民共和国";
$url="<a href="."\"s2.php\">下一页</a>";
echo $url;
?>

  page2.php

<?php
session_start();
echo "传递的session变量var1的值为:".$_SESSION['var1'];
?>

  运行以上代码,在客户端cookie正常的情况下,应该可以在得到结果“中华人民共和国”。

  现在你手动关闭客户端的cookie,再运行,可能得不到结果了吧。如果得不到结果,再“设置php.ini中的session.use_trans_sid = 1或者编译时打开打开了--enable-trans-sid选项”,又得到结果“中华人民共和国”

本新闻共5页,当前在第4页  1  2  3  4  5  


编辑:iyit.net [发送给好友] [打印本页] [关闭窗口] [返回顶部]
上一篇:PHP和ASP上传漏洞探究
下一篇:IIS环境下安装PHP5手记全攻略
转载请注明来源:www.iyit.net
特别声明: 本站除部分特别声明禁止转载的专稿外的其他文章可以自由转载,但请务必注明出处和原始作者。文章版权归文章原始作者所有。对于被本站转载文章的个人和网站,我们表示深深的谢意。如果本站转载的文章有版权问题请联系编辑人员,我们尽快予以更正。

 相关文章
Win2000下PHP服务器安装攻略 IIS环境下安装PHP5手记全攻略 PHP编程常用技巧四则 
PHP编程与应用 用PHP编程读取汉字点阵数据 用PHP编程语言开发动态WAP页面
PHP编程之高级技巧——利用Mysql函数 用PHP编程开发“虚拟域名”系统 用PHP编程语言开发动态WAP页面
php编程命名规则 PHP编程常用技巧 PHP编程网上游
PHP程序员的自我修炼:PHP编程风格 文件下载统计php编程 PHP编程常用技巧四则 
最新更新 热点排行 推荐新闻
Win2000下PHP服务器安装攻略
IIS环境下安装PHP5手记全攻略
PHP5:session会话的使用和分析
PHP和ASP上传漏洞探究
php作wap开发时遇到的问题 
Win2000下PHP服务器安装攻略
IIS环境下安装PHP5手记全攻略
PHP5:session会话的使用和分析
CN代理年末促销大战第一枪打响
稳定VDNS域名解析系统为代理护航 
MY SQL常用命令
如何远程连接SQL Server数据库
Photoshop:巧用路径工具做流线字
Photoshop:栅格效果
Photoshop:银币效果
PHP和ASP上传漏洞探究
php作wap开发时遇到的问题 
Win2000下PHP服务器安装攻略
IIS环境下安装PHP5手记全攻略
PHP5:session会话的使用和分析
破解QQ密码如此简单 
DOS教程 DOS命令基础应用
永久免费网游《刀OL》11月3日开放新服
最新永久免费网游年列表,免费3d网游
低格、分区、高格的应对--DOS命令应用
合并VCD片断、快速删除文件夹--DOS命令
一劳永逸--批处理命令(一)
SQL Server安装文件挂起错误解决办法
远程破解盗窃QQ密码的各种方法
破解Windows密码如此简单!
Win2000下PHP服务器安装攻略
IIS环境下安装PHP5手记全攻略
PHP5:session会话的使用和分析
PHP和ASP上传漏洞探究
Win2000下PHP服务器安装攻略
IIS环境下安装PHP5手记全攻略
PHP5:session会话的使用和分析
Photoshop:巧用路径工具做流线字
浪漫摄影后期之工笔画风
Maya精彩实例:世界杯足球“团队之星”
网站优化建议
5种Alexa世界排名作弊方式
免费搜索引擎登录入口
网页里插入视频文件方法大全

设置首 页 - 版权声明 - 广告服务 - 关于我们 - 联系我们 - 友情连接
Copyrights © 2004-2006 iYiT.Net All Rights Reserved.
网站合作、广告联系QQ:147007642、466949678
易特网络技术 点击这里给我发消息