当您运行一个应用程序时,您会打开它,做些更改,然后关闭它。这很像一次会话。计算机清楚你是谁。它知道你何时启动应用程序,并在何时终止。但是在因特网上,存在一个问题:服务器不知道你是谁以及你做什么,这是由于 HTTP 地址不能维持状态。
通过在服务器上存储用户信息以便随后使用,PHP session 解决了这个问题(比如用户名称、购买商品等)。不过,会话信息是临时的,在用户离开网站后将被删除。如果您需要永久储存信息,可以把数据存储在数据库中。
把手册抄一下,然后每个都试试然后写出来,方便自己查阅滴,谁让咱刚学呢。Session大概有12个函数分别是:
session_start: 初始 session。
session_destroy: 结束 session。
session_unset: 释放session内存。
session_name: 存取目前 session 名称。
session_module_name: 存取目前 session 模块。
session_save_path: 存取目前 session 路径。
session_id: 存取目前 session 代号。
session_register: 注册新的变量。
session_unregister: 删除已注册变量。
session_is_registered: 检查变量是否注册。
session_decode: Session 资料解码。
session_encode: Session 资料编码。
还有个全局变量就是:$_SESSION
在您把用户信息存储到 PHP session 中之前,首先必须启动会话。
注释:session_start() 函数必须位于 标签之前:
<?php session_start(); ?><br><br><BR><body><br><br><BR><BR>
存储 Session 变量
<?php<BR>session_start();<BR>// store session data<BR>$_SESSION['views']=1;<BR>?> <BR><BR><body><br><br><?php<BR>//retrieve session data<BR>echo "Pageviews=". $_SESSION['views'];<BR>?><br><br><BR><BR> [html] </P><P>终结 Session<BR>unset() 函数用于释放指定的 session 变量:</P><P>[code]<BR><?php<BR>unset($_SESSION['views']);<BR>?><BR>
您也可以通过 session_destroy() 函数彻底终结 session:
<?php<BR>session_destroy();<BR>?><BR>
实例:
<?php <BR>session_start(); <BR>switch ( $_GET['action'] ){ <BR>case "loginif"; <BR>//登陆验证,假定session储存的秘密应该等于123才为正确 <BR>if ($<strong>+本文来源gao@daima#com搞(%代@#码网</strong><pre>搞代gaodaima码
_SESSION[‘pass’]==”123″){echo “密码正确 您可以执行注销”;}else{echo “密码错误,您可以重新登陆”;}
break;
case “logout”;
//注销登陆
session_unset();
session_destroy();
echo “注销成功!可以判断一下密码是否正确来看看是不是成功注销”;
break;
case “login”;
//写入session以供验证,
$pass=”123″;//密码
$_SESSION[‘pass’]=$pass;
echo “写入登陆密码了 去判断密码成功与否吧。”;
break;
}
?>
假定本页名为temp.php
用户进行登陆post,程序处理写入session
判断用户密码是否正确
登陆成功的用户注销登陆
我总结了一下php中session的用法。
(一)开始session
在每一次使用session之前,都要加上这一句:“session_start();”。顾名思义,这个函数的作用就是开始使用session。
(二)注册session
首先要建立一个global(注意,一定要定义为global,不然在其它页面用不了)数组,如$login,其中$login[‘name’]=”Victor”,$login[‘pwd’]=”111111″,然后调用函数“session_register(login);”,session就成功注册了。
(三)使用session里面的变量
和注册session类似,都要先建立一个global数组,然后就和使用一般数组一样了。
(四)判断session是否注册
很简单,用“if (session_is_registered(login))”判断就可以了。
(五)卸载session
也很简单,“session_unregister(login);”就可以了。
注意:在进行(二)(三)(四)(五)之前一定要先进行(一)。
下面给出一个例子:
index.htm
<BR> <BR><title>测试</title> <BR> <BR><body> <BR> <BR>用户名:<br /> <BR>密码:<br /> <BR> <BR> <BR> <BR><BR>
login.php
<BR><?php <BR>global $login; <BR>if ($_POST['name']!="Victor" || $_POST['pwd']!="111111") <BR>{ <BR> echo "登陆失败"; <BR> echo "请返回"; <BR> exit; <BR>} <BR>$login = array('name'=>$_POST['name'], <BR> 'pwd'=>$_POST['pwd']); <BR>session_start(); <BR>session_register(login); <BR>echo "查看信息<br />"; <BR>echo "退出登陆<br />"; <BR>?><BR>
info.php
<BR><?php <BR>session_start(); <BR>if (session_is_registered(login)) <BR>{ <BR> global $login; <BR> echo "hello,".$login['name']."<br />"; <BR> echo "退出登陆<br />"; <BR>} <BR>else <BR>{ <BR> echo "非法操作<br />"; <BR> exit; <BR>} <BR>?><BR>
logout.php
<?php <BR>session_start(); <BR>session_unregister(login); <BR>header("location:index.htm"); <BR>?><BR>