PHP session的使用简介
2017-03-01 14:12
260 查看
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"); ?>
相关文章推荐
- 抛开cookie使用session-PHP中SESSION不能跨页传递问题的解决办法
- IIS中使用PHP的SESSION的一个奇怪现象
- PHP 会话(session 时间设定)使用入门
- 比较全的PHP 会话(session 时间设定)使用入门代码
- 比较全的PHP 会话(session 时间设定)使用入门代码
- 关于在php中如何使用session```Cookies~``
- PHP使用无限生命期Session的方法
- 优化使用mysql存储session的php代码
- PHP - Manual手册 - CXLIX. Session 会话处理函数 - session.use_only_cookies指定是否在客户端仅仅使用 cookie 来存放会话 ID
- 关于在php中如何使用session和Cookies
- PHP 会话 (Session) 使用入门
- PHP 会话 (Session) 使用入门
- php下使用无限生命期Session的方法
- 优化使用mysql存储session的php代码
- PHP 会话 (Session) 使用入门
- php session使用初探
- PHP中session使用方法详解第1/2页
- 抛开Cookie使用SESSION-PHP中SESSION不能跨页传递问题的解决办法(转载)
- PHP中使用无限生命期Session的方法
- PHP使用无限生命期Session的方法