好得很程序员自学网

<tfoot draggable='sEl'></tfoot>

PHP Session 变量用法详解与实例教程 - php会话

PHP 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() 函数必须位于标签之前,代码如下:

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

存储 Session 变量,代码如下:

<?php  session_start();  // store session data   $_SESSION [ 'views' ]=1;  ?> <html>  <body> <?php  //retrieve session data   echo   "Pageviews=" .  $_SESSION [ 'views' ];  ?> </body>  </html> 

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

<?php  unset( $_SESSION [ 'views' ]);  ?> 

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

<?php  session_destroy();  ?> 

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

<?php   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 ;   }   ?>   <p>假定本页名为temp.php </p>   <p><a href= "temp.php?action=login" >用户进行登陆post,程序处理写入session</a></p>   <p><a href= "temp.php?action=loginif" >判断用户密码是否正确</a></p>   <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代码如下:

< html >    < head >    < title > 测试 </ 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' ]!= "Victor"  ||  $_POST [ 'pwd' ]!= "111111" )   {            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" );   ?> 

查看更多关于PHP Session 变量用法详解与实例教程 - php会话的详细内容...

  阅读:42次