您好,登錄后才能下訂單哦!
本篇內容主要講解“如何實現session跨域共享”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“如何實現session跨域共享”吧!
通過cookie
設置php.ini中的session.use_trans_sid=1,讓PHP自動跨頁傳遞session id
手動通過url或隱藏表單傳值
用文件或數據庫方式傳遞,在通過其他key對應取值
數據庫
memcache
共享文件
通過服務器(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'];
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.寫好服務器端的代碼
<?php //callback參數是jquery生成的 $callBack = $_GET['callback']; $data = array('responseCode'=>'101', 'responseMessage'=>'success'); //下面的格式,才會被jquery解析 $responseData = $callBack.'('.json_encode($data).')'; echo $responseData;?>
到此,相信大家對“如何實現session跨域共享”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。