目前有这样一个需求,在一个域名下 如:http://example.com 下,有两个项目,
example.com/a/
,example.com/b/
,这两个项目是相互独立的程序,有不一样的会员登陆机制,可是咱们知道,在同一个域名下,它的session
会话是共享的,也就是你在a站登陆后,b站也会出现你在a站的session信息,由于默认的session_id
名字是PHPSESSID
,即当你第一访问a项目时,它会自动生成一个名为PHPSESSID
的session_id,并在服务器端建立一个以session_id 命名的文件,而后发送session_id到浏览器的cookie里保存,当下一次访问时,则会携带该cookie
信息,服务器端拿到session_id,而后再继续会话。这样就会出现会话信息共享的局面,应该怎样独立出两个不一样的会话信息呢?php
其实很简单的,只需在b项目的初始化文件中使用session时,修改下 session_name
就能够了。浏览器
example.com/a/init.php
服务器
session_start(); // ...
example.com/b/init.php
cookie
// session_id('123456'); // 能够自定义session_id,默认是系统本身生成的 session_name('EBCP_SID'); // session_name 必须定义在session_start() 前 session_start(); // ...
example.com/a/test.php
session
<?php // a项目测试页面 define("IN_EB", true); include_once("./init.php"); if($_SESSION['nickname']) { // dump("session 页面- 欢迎你继续回来 {$_SESSION['nickname']} " . date("Y-m-d H:i:s")); } else { $_SESSION['nickname'] = "Corwien"; dump("session 页面- 你是第一次登陆 {$_SESSION['nickname']} " . date("Y-m-d H:i:s")); }
输出结果:测试
session 页面- 欢迎你继续回来 Corwien 2017-09-22 07:49:15
a项目的浏览器cookie:spa
example.com/b/test.php
code
<?php // b项目测试页面 define("IN_EB", true); include_once("./init.php"); if($_SESSION['nickname']) { // dump("session_v2 页面- 欢迎你继续回来 {$_SESSION['nickname']} " . date("Y-m-d H:i:s")); } else { $_SESSION['nickname'] = "JackMa"; dump("session_v2 页面- 你是第一次登陆 {$_SESSION['nickname']} " . date("Y-m-d H:i:s")); }
输出结果:blog
session_v2 页面- 欢迎你继续回来 JackMa 2017-09-22 07:49:15
b项目的浏览器cookie:ip