php中sisson用法,PHP Session 变量的使用方法详解与实例代码

在php中Session经常用来验证用户注册或登录之后的验证了,下面我来总结session变量的一些常用实例与用法介绍

当您运行一个应用程序时,您会打开它,做些更改,然后关闭它。这很像一次会话。计算机清楚你是谁。它知道你何时启动应用程序,并在何时终止。但是在因特网上,存在一个问题:服务器不知道你是谁以及你做什么,这是由于 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() 函数必须位于 标签之前:

存储 Session 变量

session_start();

// store session data

$_SESSION['views']=1;

?>

//retrieve session data

echo "Pageviews=". $_SESSION['views'];

?>

[html]

终结 Session

unset() 函数用于释放指定的 session 变量:

[code]

unset($_SESSION['views']);

?>

您也可以通过 session_destroy() 函数彻底终结 session:

session_destroy();

?>

实例:

session_start();

switch ( $_GET['action'] ){

case "loginif";

//登陆验证,假定session储存的秘密应该等于123才为正确

if ($_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

测试

用户名:

密码:

login.php

global $login;

if ($_POST['name']!="Victor" || $_POST['pwd']!="111111")

{

echo "登陆失败";

echo "请返回";

exit;

}

$login = array('name'=>$_POST['name'],

'pwd'=>$_POST['pwd']);

session_start();

session_register(login);

echo "查看信息
";

echo "退出登陆
";

?>

info.php

session_start();

if (session_is_registered(login))

{

global $login;

echo "hello,".$login['name']."
";

echo "退出登陆
";

}

else

{

echo "非法操作
";

exit;

}

?>

logout.php

session_start();

session_unregister(login);

header("location:index.htm");

?>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值