php中session的用法
来源:互联网 发布:使命召唤12渣优化 编辑:程序博客网 时间:2024/06/15 00:46
PHP session 变量用于存储有关用户会话的信息,或更改用户会话的设置。Session 变量保存的信息是单一用户的,并且可供应用程序中的所有页面使用。
开始 PHP Session
在您把用户信息存储到 PHP session 中之前,首先必须启动会话。
注释:session_start() 函数必须位于 <html> 标签之前:
<?php session_start(); ?><html><body></body></html>
上面的代码会向服务器注册用户的会话,以便您可以开始保存用户信息,同时会为用户会话分配一个 UID。
存储 Session 变量
存储和取回 session 变量的正确方法是使用 PHP $_SESSION 变量:
<?phpsession_start();// store session data$_SESSION['views']=1;?><html><body><?php//retrieve session dataecho "Pageviews=". $_SESSION['views'];?></body></html>
输出:
Pageviews=1
在下面的例子中,我们创建了一个简单的 page-view 计数器。isset() 函数检测是否已设置 "views" 变量。如果已设置 "views" 变量,我们累加计数器。如果 "views" 不存在,则我们创建 "views" 变量,并把它设置为 1:
<?phpsession_start();if(isset($_SESSION['views'])) $_SESSION['views']=$_SESSION['views']+1;else $_SESSION['views']=1;echo "Views=". $_SESSION['views'];?>
终结 Session
如果您希望删除某些 session 数据,可以使用 unset() 或 session_destroy() 函数。
unset() 函数用于释放指定的 session 变量:
<?phpunset($_SESSION['views']);?>
您也可以通过 session_destroy() 函数彻底终结 session:
<?phpsession_destroy();?>
注释:session_destroy() 将重置 session,您将失去所有已存储的 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
(一)开始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);”就可以了。
实例:
<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中session的用法
- php中session的用法
- php中session的用法
- php中session的用法
- PHP中session用法的略谈
- PHP中cookie、localStorage、session、的用法
- php session的用法
- php中session用法小结
- php里session的用法
- PHP中SESSION和COOKIE用法
- Hibernate中session的用法
- C# 中Session的用法
- jsp中session的用法
- JSP中session的用法
- Session中StateServer的用法
- java中session的用法
- Flask中session的用法
- 让割草类游戏更有趣的攻击动作设计技巧
- 需要进一步学习的知识点和总结
- html5 新元素 canvas 绘制基础图形
- COM组件开发实践(八)---多线程ActiveX控件和自动调整ActiveX控件大小(下)
- ln: 创建符号链接 “asm”: 不支持的操作
- php中session的用法
- Java - 继承
- String特性之 “字符串驻留池”
- Android两种网络访问方式(HttpClient HttpUrlConnection)的比较及三种传参方式介绍
- iOS 开发之照片框架详解之 PhotoKit 详解(上)
- Error: Error parsing D:\android-sdk-windows\sdk\system-images\android-22\android-wear\x86\devices.xm
- 渗透总结
- Hadoop搭建注意事项
- Android Studio :Rendering Problems图形界面渲染加载失败