php的sso單點登入實現方法,phpsso單點登入
本文執行個體講述了php的sso單點登入實現方法。分享給大家供大家參考。具體分析如下:
這裡詳細講到了幾點:
1、點擊登入跳轉到SSO登入頁面並帶上當前應用的callback地址
2、登入成功後產生COOKIE並將COOKIE傳給callback地址
3、callback地址接收SSO的COOKIE並設定在當前域下再跳回到應用1即完成登入
4、再在應用程式需要登入的地方嵌入一個iframe用來即時檢測登入狀態,代碼如下:
index.php 應用程式頁面:
複製代碼 代碼如下:<?php
header('Content-Type:text/html; charset=utf-8');
$sso_address = 'http://XXXX.com/sso/login.php'; //你SSO所在的網域名稱
$callback_address = 'http://'.$_SERVER['HTTP_HOST']
.str_replace('index.php','',$_SERVER['SCRIPT_NAME'])
.'callback.php'; //callback地址用於回調設定cookie
if(isset($_COOKIE['sign'])){
exit("歡迎您{$_COOKIE['sign']} 退出");
}else{
echo '您還未登入 點此登入';
}
?>
login.php SSO登入頁面:
複製代碼 代碼如下:<?php
header('Content-Type:text/html; charset=utf-8');
if(isset($_GET['logout'])){
setcookie('sign','',-300);
unset($_GET['logout']);
header('location:index.php');
}
if(isset($_POST['username']) && isset($_POST['password'])){
setcookie('sign',$_POST['username'],0,'');
header("location:".$_POST['callback']."?sign={$_POST['username']}");
}
if(emptyempty($_COOKIE['sign'])){
?>
<?php
}else{
$query = http_build_query($_COOKIE);
echo "系統檢測到您已登入 {$_COOKIE['sign']} 授權 退出";
}
?>
callback.php 回調頁面用來設定跨域COOKIE:
複製代碼 代碼如下:<?php
header('Content-Type:text/html; charset=utf-8');
if(emptyempty($_GET)){
exit('您還未登入');
}else{
foreach($_GET as $key=>$val){
setcookie($key,$val,0,'');
}
header("location:index.php");
}
?>
connect.php 用來檢測登入狀態的頁面,內嵌在頁面的iframe中:
複製代碼 代碼如下:<?php
header('Content-Type:text/html; charset=utf-8');
if(isset($_COOKIE['sign'])){
$callback = urldecode($_GET['callback']);unset($_GET['callback']);
$query = http_build_query($_COOKIE);
$callback = $callback."?{$query}";
}else{
exit;
}
?>
希望本文所述對大家的php程式設計有所協助。
http://www.bkjia.com/PHPjc/939404.htmlwww.bkjia.comtruehttp://www.bkjia.com/PHPjc/939404.htmlTechArticlephp的sso單點登入實現方法,phpsso單點登入 本文執行個體講述了php的sso單點登入實現方法。分享給大家供大家參考。具體分析如下: 這裡詳細講...