更新時間:2022-01-25 11:38:16 來源:動力節(jié)點(diǎn) 瀏覽1331次
要讓session跨域共享,需要解決三個問題:
通過什么方法來傳遞session_id?
通過什么方法來保存session信息?
通過什么方法來進(jìn)行跨域?
通過cookie
設(shè)置php.ini中的session.use_trans_sid=1,讓PHP自動跨頁傳遞session id
手動通過url或隱藏表單傳值
用文件或數(shù)據(jù)庫方式傳遞,在通過其他key對應(yīng)取值
數(shù)據(jù)庫
memcache
共享文件
通過服務(wù)器(php腳本)
通過JavaScript
由于,各種原因。我選擇的方案是:
cookie傳遞session_id
文件保存sesson信息
通過服務(wù)器腳本跨域
啥也不說了,上代碼了。這兩段代碼都是用php腳本設(shè)置的
設(shè)置允許跨域的域名:
$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);
}
設(shè)置跨域的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'];
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.寫好服務(wù)器端的代碼
<?php //callback參數(shù)是jquery生成的
$callBack = $_GET['callback'];
$data = array('responseCode'=>'101', 'responseMessage'=>'success'); //下面的格式,才會被jquery解析
$responseData = $callBack.'('.json_encode($data).')';
echo $responseData;
?>
這種方案,有不能跨服務(wù)器的缺陷。跨域還有些坑,有待發(fā)掘。如果您想了解更多相關(guān)知識,不妨來關(guān)注一下動力節(jié)點(diǎn)的Java在線學(xué)習(xí),里面的課程內(nèi)容全面細(xì)致,適合沒有基礎(chǔ)的小白學(xué)習(xí),希望對大家能夠有所幫助。
初級 202925
初級 203221
初級 202629
初級 203743