用户名:
密 码: 记住
您当前的位置:首页 > 网络编程 > php教程

PHP Session 变量用法详解与实例教程

时间:2015-01-23  来源:西部数据  作者:西部数据

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

  1. <?php session_start(); ?> 
  2. <html> 
  3. <body> 
  4. </body> 
  5. </html> 

存储 Session 变量,代码如下:

  1. <?php 
  2. session_start(); 
  3. // store session data 
  4. $_SESSION['views']=1; 
  5. ?>
  6. <html> 
  7. <body>
  8. <?php 
  9. //retrieve session data 
  10. echo "Pageviews="$_SESSION['views']; 
  11. ?>
  12. </body> 
  13. </html> 

终结 Session,unset() 函数用于释放指定的 session 变量,代码如下:

  1. <?php 
  2. unset($_SESSION['views']); 
  3. ?> 

您也可以通过 session_destroy() 函数彻底终结 session,代码如下:

  1. <?php 
  2. session_destroy(); 
  3. ?> 

一个较为完整的PHP实例,代码如下:

  1. <?php  
  2. session_start();  
  3. switch ( $_GET['action'] ){  
  4. case "loginif";  
  5. //登陆验证,假定session储存的秘密应该等于123才为正确  
  6. if ($_SESSION['pass']=="123"){echo "密码正确 您可以执行注销";}else{echo "密码错误,您可以重新登陆";}  
  7. break;  
  8. case "logout";  
  9. //注销登陆  
  10. session_unset();  
  11. session_destroy();  
  12. echo "注销成功!可以判断一下密码是否正确来看看是不是成功注销";  
  13. break;  
  14. case "login";  
  15. //写入session以供验证,  
  16. $pass="123";//密码  
  17. $_SESSION['pass']=$pass;  
  18. echo "写入登陆密码了 去判断密码成功与否吧。";  
  19. break;  
  20. }  
  21. ?>  
  22. <p>假定本页名为temp.php </p>  
  23. <p><a href="temp.php?action=login">用户进行登陆post,程序处理写入session</a></p>  
  24. <p><a href="temp.php?action=loginif">判断用户密码是否正确</a></p>  
  25. <p><a href="temp.php?action=logout">登陆成功的用户注销登陆</a></p> 

我总结了一下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代码如下:

  1. <html>  
  2. <head>  
  3. <title>测试</title>  
  4. </head>  
  5. <body>  
  6. <FORM METHOD=POST ACTION="login.php">  
  7. 用户名:<INPUT TYPE="text" NAME="name"><br/>  
  8. 密码:<INPUT TYPE="password" name="pwd"><br/>  
  9. <INPUT TYPE="submit" value="提交">  
  10. </FORM>  
  11. </body>  
  12. </html> 

login.php代码如下:

  1. <?php  
  2. global $login;  
  3. if ($_POST['name']!="Victor" || $_POST['pwd']!="111111")  
  4. {  
  5.         echo "登陆失败";  
  6.         echo "请<a href=index.htm>返回</a>";  
  7.         exit;  
  8. }  
  9. $login = array('name'=>$_POST['name'],  
  10.                            'pwd'=>$_POST['pwd']);  
  11. session_start();  
  12. session_register(login);  
  13. echo "<a href=info.php>查看信息</a><br/>";  
  14. echo "<a href=logout.php>退出登陆</a><br/>";  
  15. ?> 

info.php代码如下:

  1. <?php  
  2. session_start();  
  3. if (session_is_registered(login))  
  4. {  
  5.         global $login;  
  6.         echo "hello,".$login['name']."<br/>";  
  7.         echo "<a href=logout.php>退出登陆</a><br/>";  
  8. }  
  9. else  
  10. {  
  11.         echo "非法操作<br/>";  
  12.         exit;  
  13. }  
  14. ?> 

logout.php代码如下:

  1. <?php  
  2. session_start();  
  3. session_unregister(login);  
  4. header("location:index.htm");  
  5. ?> 
来顶一下
返回首页
返回首页
推荐资讯
WiFi太不安全:7岁女孩11分钟内入侵公共网络 WiFi太不安全:7岁女孩11分钟内入侵近期刚刚发布研究说WiFi网络能获得人们手机里多少私人信息,
不服跑个分?人工智能也出现“刷分”乱象 不服跑个分?人工智能也出现“刷分2014年,人工智能领域突然爆发,成为了科研和科技创业的热门
相关文章
栏目更新
栏目热门