频道直达 - 专题 - 新闻 - 技巧 - 组网 - 开发 - 安全 - web编程 - 图像 - 操作系统 - 数据库 - 教育 - 旅游 - 健康 - 时尚 - 驱动 - 软件 - 游戏 - 多媒体 - ERP - 讨论组

关于session的几个补充函数解析

来源: 作者: 出处:巧巧读书 2006-08-06 进入讨论组

  在PHP下,关于session的讨论很多,其实在PHP4中还有几个函数是我们平时没有注意到的。
  
  下面我把它们介绍给大家吧。
  
  其中的session_set_save_handler()可真是个好东西。
  
  //********************
  session_unset (PHP4 >= 4.0b4)
  
  void session_unset(void);
  
  这个函数可以把当然注册的所有的session变量置为空。注意它不是unregister,也不同于destroy。
  
  下面这个例子,对此函数做了很好的说明。
  
  <?php
  
  session_register('a','b','c'); //auto-session-start
  $a=1;
  $b=2;
  $c=3;
  session_unregister('a'); //unregistrered $a
  echo "A: $a - reg:".session_is_registered('a')."
  "; // but the global $a remains
  session_unset(); // unsets $b und $c
  echo "B:$b - reg:".session_is_registered('b')."
  "; // the registration remains !
  echo "C:$c - reg:".session_is_registered('c')."
  ";
  echo session_encode();
  ?>
  
  输出:
  A: 1 - reg:
  B: - reg:1
  C: - reg:1
  !b|!c|
  
  //********************************
  session_get_cookie_params (PHP4 >= 4.0RC2)
  
  array session_get_cookie_params (void);
  
  返回一个数组,记录了当前session的cookie的一些信息。
  有:
  
  "lifetime" - cookie的生存期。
  
  "path" - cookie的保存路径。
  
  "domain" - cookie的域。
  
  //*******************************
  session_set_cookie_params (PHP4 >= 4.0b4)
  
  void session_set_cookie_params (int lifetime [, string path [, string domain]])
  
  设置session的cookie的一些参参数,类似于php.ini中的设置,但本函数所作的设置,只对当前脚本文件有效。
  
  //*******************************
  
  下面要介绍的这个函数应是对大家都很有用的,你是不是对自定义一个不用cookie来保存的session有兴趣呢?这个函数就可以实现你这样的设想。
  
  让我想想,如果不用cookie的好处是什么?至少一点,你不用担心客户端的的cookie的功能是否打开了,对吧。
  
  session_set_save_handler (PHP4 >= 4.0b4)
  
  void session_set_save_handler (string open, string close, string read, string write, string destroy, string gc)
  
  这个函数可以定义用户级的session的保存函数(打开、关闭、写入等)。
  比如,我们想把session保存在本地的一个数据库中时,本函数就很有用了。
  
  !!!注意:使用本函数前,先要配置php.ini文件,session.save_hadler=user ,否则,session_set_save_handler()不会生效。
  
  此外,根据我的测试,你如果想让这样的session跨页面使用,还要在每一个用到session的脚本文件中加入你自定的函数及session_set_save_handler,所以,最好的方法是做成一个单独的文件,在每一个要用到session的脚本中用include来包含进来。
  
  下面这个例子提供了一个最基本的session保存法,类似于默认的files方法。
  如果你想用数据库来实现,这也是很容易做到的。
  
  Example 1. session_set_save_handler() example
  
  <?php
  
  function open ($save_path, $session_name) {
  global $sess_save_path, $sess_session_name;
  
  $sess_save_path = $save_path;
  $sess_session_name = $session_name;
  return(true);
  }
  
  function close() {
  return(true);
  }
  
  function read ($id) {
  global $sess_save_path, $sess_session_name;
  
  $sess_file = "$sess_save_path/sess_$id";
  if ($fp = @fopen($sess_file, "r")) {
  $sess_data = fread($fp, filesize($sess_file));
  return($sess_data);
  } else {
  return("");
  }
  
  }
  
  function write ($id, $sess_data) {
  global $sess_save_path, $sess_session_name;
  
  $sess_file = "$sess_save_path/sess_$id";
  if ($fp = @fopen($sess_file, "w")) {
  return(fwrite($fp, $sess_data));
  } else {
  return(false);
  }
  
  }
  
  function destroy ($id) {
  global $sess_save_path, $sess_session_name;
  
  $sess_file = "$sess_save_path/sess_$id";
  return(@unlink($sess_file));
  }
  
  /*********************************************
  * WARNING - You will need to implement some *
  * sort of garbage collection routine here. *
  *********************************************/
  function gc ($maxlifetime) {
  return true;
  }
  
  session_set_save_handler ("open", "close", "read", "write", "destroy", "gc");
  
  session_start();
  
  // proceed to use sessions normally
  // 现在你就可以象往常一样地使用session了。
  
  ?>
  
  //***************************************
  
  session_cache_limiter (PHP4 CVS only)
  
  string session_cache_limiter ([string cache_limiter])
  
  本函数可以设置或取得session.cache_limiter的值。
  在php.ini中也可以做同样的设置。其值有 nocache,public,private。
  
  本函数是通过HTTP的header发送到客户端的。如果为nocache,将禁止任何客户端的cache。而public将允许cache,但是private相对public而言,更为安全一点。
  
  缺省值是在php.ini中的设置,如果你要使用它,必须在每次调用session_start()之前调用本函数。
  
  此函数现在只能在CVS模式下运行,但是PHP4.0.3将支持它。
  
  Example 1. session_cache_limiter() examples
  
  <?php
  
  # set the cache limiter to 'private'
  
  session_cache_limiter('private);
  $cache_limiter = session_cache_limiter();
  
  echo "The cache limiter is now set to $cache_limiter<p>";
  ?>
  
  //*****************************

   巧巧读书:http://www.qqread.com/linux/2006/08/d150195061.html

进入讨论组讨论。
收藏此文】【 】【打印】【关闭
相关图文阅读
频道图文推荐
健 康 咨 询
时 尚 咨 询
巧巧读书宗旨
相关专题
讨论组问题推荐
站内各频道最新更新文档
站内最新制作专题
热门关键字导读
Photoshop教 程照片处理 照片制作 PS快捷键 抠图
计 算 机 故 障XP系统修复
艺 术 与 设 计设计 流媒体 设计欣赏 边框
计 算 机 安 全ARP
站内频道文章精选
巧巧电脑频道编辑信箱  告诉我们您想看的专题或文章