用户名:
密 码: 记住
您当前的位置:首页 > 网络编程 > php教程

php自定文件保存session实现方法

时间:2015-01-23  来源:西部数据  作者:西部数据

session.inc.php文件:定义session的文件存储,session解决方案,就是要提供在php脚本中定义全局变量的方法,使得这个全局变量在同一个session中对于所有的php脚本都有效,上面我们提到了,session不是一个简单的时间概念,一个session中还包括了特定的用户和服务器,因此更详细地讲,在一个session定义的全局变量的作用范围,是指这个session所对应的用户所访问的所有php,例如a用户通过session定义了一个全局变量$user=“wind”中,而b用户通过session定义的全局变量$user=“jane”,那么在a用户所访问的php脚本中,$user的值就是wind.

php如何创建session

开始介绍如何创建 session,非常简单,启动 session 会话,并创建一个 $admin 变量:

启动 session:session_start();   

声明一个名为 admin 的变量,并赋空值:$_session["admin"] = null; 

如果你使用了 seesion,或者该 php 文件要调用 session 变量,那么就必须在调用 session 之前启动它,使用 session_start() 函数,其它都不需要你设置了,php 自动完成 session 文件的创建,执行完这个程序后,我们可以到系统临时文件夹找到这个 session 文件,一般文件名形如:sess_4c83638b3b0dbf65583181c2f89168ec,后面是 32 位编码后的随机字符串,用编辑器打开它,看一下它的内容:admin|n;,PHP实例代码如下:

  1. <?php 
  2. //定义一个超全局数组 
  3.  
  4. $_session = array(); 
  5.  
  6. //定义文件句柄 
  7.  
  8. $fp = null; 
  9.  
  10.  
  11. //用户自定义的开启session函数 
  12.  
  13. function session_file_start() { 
  14.  
  15.  
  16.  
  17. //1. 首先判断浏览器有没有发送cookie值 
  18.  
  19. if (isset($_cookie['fileid'])) { 
  20.  
  21.  
  22.  
  23. //2. 接收cookie值 
  24.  
  25. $filename = $_cookie['fileid']; 
  26.  
  27.  
  28. //3. 打开文件,用于读写 
  29.  
  30. if (file_exists($filename)) { 
  31.  
  32. $globals['fp'] = fopen($filename'r+'); 
  33.  
  34. else { 
  35.  
  36. $globals['fp'] = fopen($filename'w+'); 
  37.  
  38.  
  39.  
  40. else { 
  41.  
  42.  
  43.  
  44. //2. 设置一个文件,并把该文件名放到cookie中 
  45.  
  46. $filename = date('ymdhis'); 
  47.  
  48. setcookie('fileid'$filename, time()+60*60*24); 
  49.  
  50.  
  51. //3. 打开文件,用于读写 
  52.  
  53. $globals['fp'] = fopen($filename'w+'); 
  54.  
  55.  
  56. //end of if-else 
  57.  
  58.  
  59. //4. 把文件中的数据存储到超全局数组$_session中 
  60.  
  61. while (!feof($globals['fp'])) { 
  62.  
  63. //读取文件中的一行 
  64.  
  65. $buffer = fgets($globals['fp']); 
  66.  
  67. //处理所读取的这一行 
  68.  
  69. $tmparr = explode('=', trim($buffer'rn')); 
  70.  
  71.  
  72. //添加到session数组中 
  73.  
  74. if (count($tmparr) == 2) { 
  75.  
  76. $globals['_session'][$tmparr[0]] = $tmparr[1]; 
  77.  
  78.  
  79. //end of while 
  80.  
  81.  
  82. //end of session_file_start() 
  83.  
  84.  
  85. //注册会话变量的函数 
  86.  
  87. function session_file_register($key$val) { 
  88.  
  89.  
  90.  
  91. //设定session变量 
  92.  
  93. $globals['_session'][$key] = $val
  94.  
  95.  
  96. //把该变量放到文件中 
  97.  
  98. fseek($globals['fp'], 0, seek_end); 
  99.  
  100. fwrite($globals['fp'], "$key=$valrn"); 
  101. //end of session_file_register() 
  102. //结束会话变量 
  103. function session_file_destroy() { 
  104. //1. 关闭文件指针 
  105. fclose($globals['fp']); 
  106. $fp = null; 
  107. //2. 设置session数组为空 
  108. $globals['_session'] = array(); 
  109. //end of session_file_destroy() 
  110. //测试代码文件:1.php 
  111. <?php 
  112. //确定编码格式 
  113. header('content-type: text/html; charset=utf-8'); 
  114. include("session-file.php"); 
  115. //测试函数: 
  116. //开启会话 
  117. session_file_start(); 
  118. //注册会话变量 
  119. $key = 'username'
  120. $val = 'lsl'
  121. session_file_register($key$val); 
  122. session_file_register('username''lisa'); 
  123. //打印session数组 
  124. echo $_session['username']; 
  125. ?> 
  126. <a href="2.php">下一页</a> 
  127. //测试文件:2.php 
  128. <?php 
  129. //确定编码格式 
  130. header('content-type: text/html; charset=utf-8'); 
  131. include("session-file.php"); 
  132. //测试函数: 
  133. //开启会话 
  134. session_file_start(); 
  135. echo $_session['username']; 
  136. ?> 
来顶一下
返回首页
返回首页
推荐资讯
WiFi太不安全:7岁女孩11分钟内入侵公共网络 WiFi太不安全:7岁女孩11分钟内入侵近期刚刚发布研究说WiFi网络能获得人们手机里多少私人信息,
不服跑个分?人工智能也出现“刷分”乱象 不服跑个分?人工智能也出现“刷分2014年,人工智能领域突然爆发,成为了科研和科技创业的热门
相关文章
    无相关信息
栏目更新
栏目热门