如何实现session跨域共享
本篇内容主要讲解“如何实现session跨域共享”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“如何实现session跨域共享”吧!

成都创新互联-专业网站定制、快速模板网站建设、高性价比庆安网站开发、企业建站全套包干低至880元,成熟完善的模板库,直接使用。一站式庆安网站制作公司更省心,省钱,快速模板网站建设找我们,业务覆盖庆安地区。费用合理售后完善,十年实体公司更值得信赖。
1.传递session_id有4种方法
通过cookie
设置php.ini中的session.use_trans_sid=1,让PHP自动跨页传递session id
手动通过url或隐藏表单传值
用文件或数据库方式传递,在通过其他key对应取值
2.保存session信息有3种方法
数据库
memcache
共享文件
3.跨域访问的方法
通过服务器(php脚本)
通过JavaScript
由于,各种原因。我选择的方案是:
cookie传递session_id
文件保存sesson信息
通过服务器脚本跨域
啥也不说了,上代码了。这两段代码都是用php脚本设置的
设置允许跨域的域名:
$origin = isset($_SERVER['HTTP_ORIGIN'])? $_SERVER['HTTP_ORIGIN'] : '';
$allow_origin = array(
'http://two.google.com', 'http://three.google.com');
header("Access-Control-Allow-Credentials: true");if(in_array($origin, $allow_origin)){
header('Access-Control-Allow-Origin:'.$origin);
}设置跨域的cookie
if(!isset($_COOKIE['session_idx'])){
$session_id = session_id();
setcookie("session_idx", $session_id, time()+3600*24*365*10, "/", ".google.com");//这里.google.com的作用是让www.google.com、two.google.com等二级域名可以共享这可cookie
$_SESSION['userName'] = 'ok';
}else{
session_id($_COOKIE['session_idx']);
}echo $_SESSION['userName'];访问跨域的api时,不附带cookie问题的解决代码,需要操作两个步骤:(使用jquery的ajax方法)
1.写好客户端的js代码
$("#getCodeBtn").click(function(){ var phone = $("#phoneNum").val();
$.ajax({ type: "POST", url: 'http://www.google.com/index.php/register/getCode', dataType: 'jsonp', data: {'phoneNum':phone, 'crossDomain':true}, xhrFields: { withCredentials: true
}, crossDomain: true, success:function(data){ if(data.responseCode == '101'){
alert('成功');
}else if(data.responseCode == '100'){
alert('失败');
}
}, error:function(data1, data2, data3){
alert(data1+'--'+data2+'--'+data3);
}
});
});2.写好服务器端的代码
'101', 'responseMessage'=>'success'); //下面的格式,才会被jquery解析
$responseData = $callBack.'('.json_encode($data).')'; echo $responseData;?>到此,相信大家对“如何实现session跨域共享”有了更深的了解,不妨来实际操作一番吧!这里是创新互联网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!
文章题目:如何实现session跨域共享
URL链接:http://www.jxjierui.cn/article/piesjg.html


咨询
建站咨询
