PHP session用法其实很简单它能够把用户提交的数据以全局变量形式保存在一个session中而且会生成一个惟一的session_id,这样就是为了多了不会产生混乱了,而且session中同一浏览器同一站点只能有一个session_id,下面咱们一块儿来看看关于session使用方法。
如何使用session,凡是与session有关的,以前必须调用函数session_start();
为session赋值很简单,如:php
在php4.2以后,能够为session直接赋值:浏览器
取消session能够这样:cookie
读取 sessionsession
PHP 内置的 $_SESSION 变量能够很方便的访问设置的 session 变量。函数
检查变量是否被登记为会话变量 session_is_registered
语法:boobean session_is_registered(string name);
这个函数可检查当前的session之中是否已有指定的变量注册,参数name就是要检查的变量名。成功则返回逻辑值true。spa
存取当前会话名称 session_name
语法:boolean session_name(string [name]);
这个函数可取得或从新设置当前session的名称。若无参数name则表示获取当前session名称,加上参数则表示将session名称设为参数name。code
存取当前会话标识号session_id
语法:boolean session_id(string [id]);
这个函数可取得或从新设置当前存放session的标识号。若无参数id则表示只获取当前session的标识号,加上参数则表示将session的标识号设成新指定的id。
设置 Session 的生存期string
session_set_cookie_params:设置 Session 的生存期的,该函数必须在 session_start() 函数调用以前调用。
若是客户端使用 IE 6.0 , session_set_cookie_params(); 函数设置 Cookie 会有些问题,因此咱们仍是手动调用 setcookie 函数来建立 cookie。it
设置 Session 文件的保存路径
session_save_path() :必须在 session_start() 函数调用以前调用。io
<?php
session_start(); //启动Session
$username='nostop';
session_register('username'); //注册一个名为username变量
echo '登记的用户:'.$_SESSION['username']; //登记的用户:nostop 读取Session变量
$_SESSION['age']=23; //声明一个名为age的变量,并赋值
echo '年龄:'.$_SESSION['age']; //年龄:23
session_unregister('username'); //注销Session变量
echo $_SESSION['username']; //空
echo $_SESSION['age'];//23
unset($_SESSION['age']); //注销Session变量
echo '登记的用户:'.$_SESSION['username']; //空
echo '年龄:'.$_SESSION['age']; //空
?>
注意:
1:在调用Session_Start()以前不能有任何输出.例以下面是错误的.
1行
2行 <?PHP
3行 Session_Start();//以前在第一行已经有输出
4行 .....
5行 ?>
提示1:
凡是出现"........headers already sent..........",就是Session_Start()以前向浏览器输出信息.
去掉输出就正常,(COOKIE也会出现这种错误,错误缘由同样)
提示2:
若是你的Session_Start()放在循环语句里,而且很难肯定以前哪里向浏览器输出信息,能够用下面这种方法:
1行 <?PHP Ob_Start(); ?>
........这里是你的程序......
2:这是什么错误
Warning: session_start(): open(/tmpsess_7d190aa36b4c5ec13a5c1649cc2da23f, O_RDWR) failed:....
由于你没有指定session文件的存放路径.
解决方法:
(1)在c盘创建文件夹tmp(2)打开php.ini,找到session.save_path,修改成session.save_path= "c:/tmp"