PHP session的使用简介

PHP Session 变量的定义:

当您运行一个应用程序时,您会打开它,做些更改,然后关闭它。这很像一次会话。计算机清楚你是谁。它知道你何时启动应用程序,并在何时终止。但是在因特网上,存在一个问题:服务器不知道你是谁以及你做什么,这是由于 HTTP 地址不能维持状态。
通过在服务器上存储用户信息以便随后使用,PHP session 解决了这个问题(比如用户名称、购买商品等)。不过,会话信息是临时的,在用户离开网站后将被删除。如果您需要永久储存信息,可以把数据存储在数据库中。
Session 的工作机制是:为每个访问者创建一个唯一的 id (UID),并基于这个 UID 来存储变量。UID 存储在 cookie 中,亦或通过 URL 进行传导。

session常用函数:

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

完整函数参见:session函数

用法简介:

1. 开启session功能
  在使用session之前加上“session_start();”。这个函数的作用就是开始使用session。 (session_start() 函数必须位于 标签之前)
  

<?php session_start(); ?>
<html>
<body>
</body>
</html>

  
2. 存储 Session 变量
  存储和取回 session 变量的正确方法是使用 PHP $_SESSION 变量:
  

<?php
session_start();
// store session data
$_SESSION['views']=1;
?> 
<html>
<body>
<?php
//retrieve session data
echo "Pageviews=". $_SESSION['views'];
?>
</body>
</html>
//在使用session变量时如果未用引号则会提示类似
//“Notice: Use of undefined constant username
// - assumed 'username' in C:\xampp\htdocs\test\temp.php on line 4”
//- 的信息,但不影响使用。要关闭此提示可以在使用语句前加上“@”或在变量上加引号,如上。

  
3. 终结 Session
  unset() 函数用于释放指定的 session 变量
  

<?php
unset($_SESSION['views']);
?>
或者通过 session_destroy() 函数彻底终结 session:
<?php
session_destroy();
?>

  用法实例:

//temp.php
<?php 
session_start(); 

switch ($_GET['action']){ 
    case "loginif":
        if ($_SESSION['pass']=="123"){
            echo "密码正确,执行注销";
        }else{
            echo "密码错误,重新登陆";
            } 
        break; 

    case "logout": 
        session_unset(); 
        session_destroy(); 
        echo "注销成功!"; 
        break; 

    case "login":
        $pass="123";
        $_SESSION['pass']=$pass; 
        echo "已经存储了登陆密码。"; 
        break; 
} 
?> 
<p><a href="temp.php?action=login">密码写入session</a></p> 
<p><a href="temp.php?action=loginif">判断用户密码是否正确</a></p> 
<p><a href="temp.php?action=logout">注销登陆</a></p>
  • session注册

    先建立一个global的数组,如 login login[‘name’]=”Tom”,$login[‘pwd’]=”888888”,然后调用函数“session_register(login);”,完成session注册。
      

  • 判断是否注册session

    用“if (session_is_registered(login))”判断。

  • 卸载session

    使用“session_unregister(login);”

实例:

index.htm

<html> 
<head> 
<title>测试session</title> 
</head> 
<body> 
<FORM METHOD=POST ACTION="login.php"> 
用户名:<INPUT TYPE="text" NAME="name"><br/> 
密码:<INPUT TYPE="password" name="pwd"><br/> 
<INPUT TYPE="submit" value="提交"> 
</FORM> 
</body> 
</html>

login.php

<?php 
global $login; 
if ($_POST['name']!="Tom" || $_POST['pwd']!="888888") 
{ 
        echo "登陆失败"; 
        echo "请<a href=index.htm>返回</a>"; 
        exit; 
} 
$login = array('name'=>$_POST['name'],'pwd'=>$_POST['pwd']); 
session_start(); 
session_register(login); 
echo "<a href=info.php>查看信息</a><br/>"; 
echo "<a href=logout.php>退出登陆</a><br/>"; 
?>

info.php

<?php 
session_start(); 
if (session_is_registered(login)) 
{ 
    global $login; 
    echo "hello,".$login['name']."<br/>"; 
    echo "<a href=logout.php>退出登陆</a><br/>"; 
} 
else 
{ 
    echo "非法操作<br/>"; 
    exit; 
} 
?>

logout.php

<?php 
session_start(); 
session_unregister(login); 
header("location:index.htm"); 
?>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值