Session有12个函数分别是:

01 session_start:  初始 session
02 session_destroy: 结束 session
03 session_unset: 释放session内存
04 session_name: 存取目前 session 名称
05 session_module_name: 存取目前 session 模块
06 session_save_path: 存取目前 session 路径
07 session_id: 存取目前 session 代号
08 session_register: 注册新的变量
09 session_unregister: 删除已注册变量
10 session_is_registered: 检查变量是否注册
11 session_decode: Session 资料解码
12 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
session_start();
switch ( $_GET['action'] ){ //登陆验证,假定session储存的秘密应该等于123才为正确 case "loginif";
if ($_SESSION['pass']=="123"){
echo "密码正确 您可以执行注销";
}
else{
echo "密码错误,您可以重新登陆";
}
break; //注销登陆 case "logout";
session_unset();
session_destroy();
echo "注销成功!可以判断一下密码是否正确来看看是不是成功注销";
break; //写入session以供验证, case "login";
$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);”就可以了。

注意:在进行(二)(三)(四)(五)之前一定要先进行(一)。

下面给出一个例子:

1 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>

2 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/>";
?>

3 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;
}
?>

4 logout.php

代码如下:

<?php
session_start();
session_unregister(login);
header("location:index.htm");
?>

PHP_Session的更多相关文章

  1. PHP_SESSION学习小结

    PHP Session PHP session 变量用于存储关于用户会话(session)的信息,或者更改用户会话(session)的设置.Session 变量存储单一用户的信息,并且对于应用程序中的 ...

  2. 如何安装一个优秀的BUG管理平台——真的是手把手教学!

    前言 就BUG管理而言,国内的禅道做得很不错,而且持续有更新.我们来看看如何从头到尾安装禅道,各位要注意的是,不是文章深或者浅,而是文章如何在遇到问题的时候,从什么途径和用什么方法解决问题的.现在发觉 ...

  3. PHP分布式中Redis实现Session

    方法一:找到配置文件php.ini,修改为下面内容,保存并重启服务 session.save_handler = redis session.save_path = "tcp://127.0 ...

  4. JQuery Cross Domain

    frontend: first :add $.support.cors=true; in front of the Ajax code. seconde: add the crossDomain:tr ...

  5. 文件存储之-内存文件系统tmpfs

    前言 我们都知道,对于单台服务器来说,除了 CPU ,内存就是我们存储数据最快的设备.如果可以把数据直接存储在内存中,对于性能的提升就不言而喻了.那么我们先来讲讲如何使用内存来存储文件. 首先,我们先 ...

  6. php session_set_save_handler 函数的用法(mysql)(转)

    <?php /*============================文件说明======================================== @filename:     s ...

  7. 如何安装一个优秀的BUG管理平台(转)

    前言 就BUG管理而言,国内的禅道做得很不错,而且持续有更新.我们来看看如何从头到尾安装禅道,各位要注意的是,不是文章深或者浅,而是文章如何在遇到问题的时候,从什么途径和用什么方法解决问题的.现在发觉 ...

  8. php+redis实现多台服务器内网存储session并读取

    大型网站由于大并发的问题会导致系统出现诡异的崩溃性问题这着实让人很是蛋疼,首先考虑的就是负载均衡服务器来处理这个,当然数据库的性能也是非常非常重要的,今天就说下在负载均衡情况下对于session这个问 ...

  9. php配置可被设定范围

    PHP中的每个指令都有其所属的模式,这些模式决定这一个PHP指定在何时何地.是否能被设定.例如有些指令可以在 PHP 脚本中用 ini_set() 来设定,而有些则只能在php.ini 或 httpd ...

随机推荐

  1. C++ 如何重复利用一个内存地址块

    #include<iostream> using namespace std; ; }; int main(int argv ,char * args[]) { double *p1,*p ...

  2. hdu----(1402)A * B Problem Plus(FFT模板)

    A * B Problem Plus Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Other ...

  3. iOS开发之内购-AppStore

    本文会给大家详细介绍iOS内购,虽然之前网上也有内购的教程,但是还不够详细,我重新整理出一份教程,希望对大家有所帮助. 基于Xcode7.1.1版本,模拟器iphone6,9.1系统.部分地方直接摘自 ...

  4. 各种浏览器hack

    Hack是针对不同的浏览器去写不同的CSS样式,从而让各浏览器能达到一致的渲染效果,那么针对不同的浏览器写不同的CSS CODE的过程,就叫CSS HACK,同时也叫写CSS Hack.然后将Hack ...

  5. mapreduce 输入输出类型

    默认的mapper是IdentityMapper,默认的reducer是IdentityReducer,它们将输入的键和值原封不动地写到输出中. 默认的partitioner是HashPartitin ...

  6. Java: constructor 构造代码块

    构造器与类同名 每个类可以有1一个以上的构造器 构造器可以有0个,1个或者多个参数 构造器没有返回值,不可以写return 构造器总是伴随着new操作一起调用 构造函数的作用:可以用于给对象进行初始化 ...

  7. FFT一周目开坑!

    先来一段非递归! #include<bits/stdc++.h> using namespace std; #define N ((1<<18)+3) ); struct ve ...

  8. S1:对象与JSON

    JSON全称为JavaScript对象表示法(JavaScript Object Notation). JSON是JavaScript中对象的字面量,是对象的表示方法,通过使用JSON,可以减少中间变 ...

  9. php解密java的DES加密

    echo openssl_decrypt( $密文 ,"des-ecb" , $密钥 );

  10. jquery表单提交和重置

    $('#myform').submit() 表单提交 $('#myform')[0].reset() 表单重置