当前位置: 网学 > 编程文档 > PHP > 正文

PHP开发中session应用详解

来源:Http://myeducs.cn 联系QQ:点击这里给我发消息 作者: 用户投稿 来源: 网络 发布时间: 12/10/17
下载{$ArticleTitle}原创论文样式
ion
 echo $welcome;//显示第一页中定义的$welcome
 page_close();//保存状态信息
?> 

  注册完一个变量,当页面最后调用page_close()函数后,各个session变量会被写回到数据库中。如果忘记调用page_close()函数的话,变量就不会被写回数据库,这样将出现不可预知的后果。当变量被使用完毕,不再需要用到时,可以调用以下函数将变量删除:

<?php
 page_open(array("sess" => "Test _Session"));
 ……
 $sess->unregister( "variable_name");
 ……
 page_close();
?> 

  在PHP4版本中是如何实现session的?

  php4的session也靠cookies保存session id,用文件系统保存变量(默认情况下),因此,它的session变量不能保存对象。当然也可以将session保存在数据库中。

  在php4中有关session的函数很多(详见php.ini配置一文),通常情况下我们只需要调用三个函数即可:sesssion_start()、session_register()、session_is_registered()。

  在需要用到session的每一页的最开始处调用session_start()函数, 例如:

<?session_start()?>
<html><body>
<?
 $welcome="hello world !";
 session_register("welcome");//注册$welcome变量,注意没有$符号
 if(session_is_registered("welcome"))//检查$welcome变量是否注册
  echo "welcome变量已经注册了!";
 else
  echo "welcome变量还没有注册!";
?>
</body></html> 

  php4中session处理的定制

  我们需要扩充6个函数:

  ·sess_open($sess_path, $session_name);

    这个函数被session处理程序调用来作初始化工作。
    参数$sess_path对应php.ini文件中的session.save_path选项
    参数$session_name对应php.ini中的session.name 选项。

  ·sess_close();

    这个函数在页面结束执行并且session处理程序需要关闭时被调用

  ·sess_read($key);

    这个函数在session处理程序读取指定session键值($key)时,检索并返回标识为$key的session数据.(注意:序列化是将变量或对象在程序结束或需要时保存在文件中,在下次程序运行或需要时再调入内存的技术,有别于只保存数据的方法。)

  ·sess_write($key, $val);

    这个函数据在session处理程序需要将数据保存时调用,这种情况经常在程序结束时发生。它负责将数据保存在下次能用sess_read($key)函数检索的地方。

  ·sess_destroy($key);

    这个函数在需要消毁session时。它负责删除session并且清除环境。

  ·sess_gc($maxlifetime);

    这个函数负责清理碎片。在这种情况下,它负责删除过时的session数据。session处理程序会偶尔调用它们。

  定制程序可以用mysql数据库或DBM文件保存session数据,视具体的情况而定。如果使用mysql作支持,那还需要进行以下的步骤:

  首先在mysql中创建一个sessions数据库,并且创建一个sessions表:

mysql> CREATE DATABASE sessions;
mysql> GRANT select, insert, update, delete ON sessions.* TO phpsession@localhost
  -> IDENTIFIED BY ''phpsession'';
mysql> CREATE TABLE sessions (
  -> sesskey char(32) not null,
  -> expiry int(11) unsigned not null,
  -> value text not null,
  -> PRIMARY KEY (sesskey)
  -> ); 

  下一步,修改session_mysql.php文件的$SESS_DB* 变量使其匹配你机器上的数据库设置:

<?
$SESS_DBHOST = "localhost"; /* 数据库主机名 */
$SESS_DBNAME = "sessions"; /* 数据库名 */
$SESS_DBUSER = "phpsession"; /* 数据库用户名 */
$SESS_DBPASS = "phpsession"; /

  • 上一篇资讯: PHP关于SQL注入攻击
  • 网学推荐

    免费论文

    原创论文

    浏览:
    设为首页 | 加入收藏 | 论文首页 | 论文专题 | 设计下载 | 网学软件 | 论文模板 | 论文资源 | 程序设计 | 关于网学 | 站内搜索 | 网学留言 | 友情链接 | 资料中心
    版权所有 QQ:3710167 邮箱:3710167@qq.com 网学网 [Myeducs.cn] 您电脑的分辨率是 像素
    Copyright 2008-2015 myeducs.Cn www.myeducs.Cn All Rights Reserved
    湘ICP备09003080号