php中的会话机制(1)

646 查看

①什么是会话机制:

这个太过抽象,也挺复杂的,只能说一下自己的理解。在b/s架构下,会话机制,其实就是服务器(server)和浏览器(browser)之间的对话的一种方式!这种对话方式,能够使得web站点能够对用户的行为进行追踪,在同一个站点下用户所需的数据实现共享!

②为什么要使用会话机制

归根到底是由于,b/s的访问方式是基于http协议的,而http协议本身又是无状态的,所谓无状态,就是指服务器端无法区分发起请求的是否是同一个人(有兴趣的同学可以自己好好研究一下http的无状态性)!每次请求都会被当做独立的请求,并不能将两次访问联系到一起!

③核心设计思想

核心设计思想:允许服务器对同一个客户端的的连续请求进行跟踪,对同一个访问者的请求数据,在多个页面之间实现共享!

④php中实现会话机制的方法:

1)在两个页面(较少页面之间)通过$_GET或者$_POST数组之间实现数据的共享!
2)使用cookie将用户的信息存放在客户端的计算机中,用于保存并不重要的数据
3)通过session将用户的信息保存在服务器中

通过$_GET和$_POST方式获得数据较为简单,这里就不再介绍!


cookie会话机制实现的注意点

1)当我们通过setCookie()函数来新增或者改变cookie中的值的时候,setCookie()函数前面不能够有任何实际的输出,即使是空格也不可以!
这是因为setCookie()函数最终是改变http响应头信息我们有理由相信setCookie()方法,底层就是通过header()方法进行的设置的头信息,我们都应该知道在header函数前面是不能够有任何实际的输出的(除非是开启了ob缓存)!

2)在cookie中是只能够保存字符串的,但是,如果我们想将一个数组变量保存到cookie中,在不进行序列化的情况下,其实也是可以办到的,代码如下:

<?php
$expires = time()+3600;
setcookie('user["name"]["xing"]','liang');
setcookie('user["name"]["ming"]', 'bo');

setcookie('user["age"]', '23', $expires);
setcookie('user["addr"]','吉林', $expires);
?>

<?php
$name = $_COOKIE['name'];
var_dump($name);
?>

> 得到的结果如下:
>     array(3) {
>       [""name""]=>
>           array(2) {
>             [""xing""]=>
>             string(5) "liang"
>             [""ming""]=>
>             string(2) "bo"
>           }
>       [""age""]=>
>       string(2) "23"
>       [""addr""]=>
>       string(6) "吉林"
>     }

3)cookie的$path参数,只有在指定的路径下的网页才可以获取cookie中的值!demo如下:

<?php
if(!$_COOKIE['name']) {
$expires = time()+3600;
setcookie('name','liangbo', $expires, '/talkphp/secondtalk/');
}
?>

该页面所处的路径"/",也就是网站的根目录!

接受的代码如下:

<?php
    header('Content-type:text/html;charset=utf-8');
    $name = $_COOKIE['user'];
    var_dump($name);
?>

改代码文件所在的路径如下:/talkphp/secondtalk/
执行结果如下:string(7) "liangbo"

同样的接受代码:但是所处的路径不同,是在根目录“/”下,
得到的结果如下:null

4)cookie的跨域问题:
个人认为跨域问题,主要是值存在同一个网站下,有多个二级域名,在多个二级域名下cookie数据的共享问题!
在cookie中,如果设置的domain参数是一级域名的话,那么cookie中的数据在各个二级域名之间是都可用的!demo如下:

<?php
if(!$_COOKIE['name']) {
$expires = time()+3600;
setcookie('name','liangbo', $expires, '/talkphp/secondtalk/', '.test.com');
}
?>

<?php
    $name = $_COOKIE['name'];
    var_dump($name);
?>

该代码所在的网站域名是:php.test.com 页面路径是:/talkphp/secondtalk/getcookie.php
运行结果如下:string(7) "liangbo"

同样的代码,该代码所在的域名是:jquery.test.com 页面所在的路径是:/talkphp/secondtalk/getcookie.php
运行结果如下:string(7) "liangbo"
可见,如果domain参数中设置的是一级域名的话,那么在各个二级域名之间$_COOKIE中的数据是可以共享的
在一级域名中.test.com,中test前的"."其实是可以省略的,但是加上的话,浏览器的兼容会更好!

我们来看另外一种情况:

<?php
if(!$_COOKIE['name']) {
$expires = time()+3600;
setcookie('name','liangbo', $expires, '/talkphp/secondtalk/','php.test.com');
}
?>

这里,我们将domain设置为了二级域名php.test.com

<?php
    $name = $_COOKIE['name'];
    var_dump($name);
?>

该代码所在的网站域名是:php.test.com 页面路径是:/talkphp/secondtalk/getcookie.php
运行结果如下:string(7) "liangbo"

同样的代码,该代码所在的域名是:jquery.test.com 页面所在的路径是:/talkphp/secondtalk/getcookie.php
运行的结果如下:null
可见,如果设置的domain参数是二级域名的话,那么cookie中的数据只能够在该二级域名下面使用!