ホームページ >バックエンド開発 >PHPチュートリアル >PHPはチケットを一律発行することでシングルサインインSSO機能を実現
PHP は、チケットを一律に発行することでシングル サインオン SSO 機能を実装します。
サイト a、サイト b、およびサイト c は、それぞれ、サイト a およびサイト c のログイン要求として機能します。サイト b とサイト c に転送されます。統合ログイン、登録センター (サードパーティ ID 認証センターとも呼ばれます) として使用され、ユーザーはログイン検証を完了した後、サードパーティ認証センターにログインします。ユーザーのログイン情報を含む暗号化キーが生成され、暗号化キーを含むブート ページを使用して複数の異なるサブアプリケーションが生成されるため、ユーザーはサブアプリケーションのブート ページに入るか、サブページの認証を完了するかを自由に選択できます。そのため、サブアプリケーションのログイン入り口に個別にログインする必要はありません。効果を確認してください:
サイト a からログインします。ログインに成功したら、サードパーティのログイン ガイダンス インターフェイスに入ります:
ボタンを押して、ステーション A ガイダンス センターに入ります。
<?phpfunction chksecret($secret){ $key=decode($secret); $arr = explode(",",$key); if(isset($arr[3]) && $arr[3]=="verifyok"){ $_SESSION['username']=$arr[1]; $_SESSION['login']=$arr[3]; }else{ $url=gethost(); echo "<script>alert('登陆失败!');window.location.href='".$url."';</script>"; }}function gethost(){ return "http://".$_SERVER['HTTP_HOST'];}function chklogin(){ if(isset($_SESSION['login']) && $_SESSION['login']=='verifyok'){ }else{ $host=gethost(); header("location:$host"); }}function decode($string = '', $skey = 'lmj951753') { $strArr = str_split(str_replace(array('O0O0O', 'o000o', 'oo00o'), array('=', '+', '/'), $string), 2); $strCount = count($strArr); foreach (str_split($skey) as $key => $value) $key <= $strCount && $strArr[$key][1] === $value && $strArr[$key] = $strArr[$key][0]; return base64_decode(join('', $strArr));}function encode($string = '', $skey = 'lmj951753') { $strArr = str_split(base64_encode($string)); $strCount = count($strArr); foreach (str_split($skey) as $key => $value) $key < $strCount && $strArr[$key].=$value; return str_replace(array('=', '+', '/'), array('O0O0O', 'o000o', 'oo00o'), join('', $strArr));}?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"><html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en"><head> <meta http-equiv="Content-Type" content="text/html;charset=UTF-8"> <title>a站点</title></head><body> <h1>这是a站</h1> <div> <form action="http://www.b.com/ssologin.php" method="post"> <p>用户名:<input type="text" name="username" /></p> <p>密 码:<input type="text" name="password" /></p> <p><input type="submit" name='btn' value="登陆"/></p> </form> </div></body></html>
<?phprequire_once('function.php');session_start();$secret=isset($_GET['key'])?trim($_GET['key']):'';if($secret){ chksecret($secret);}else{ chklogin();}?><!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"><html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en"><head> <meta http-equiv="Content-Type" content="text/html;charset=UTF-8"> <title>登陆引导中心</title></head><body> <p>欢迎回来!这里是A站点<?php echo $_SESSION['username'] ?></p> <p><a href='http://www.a.com/admin.php'>管理中心 </a> <a href='http://www.a.com/logout.php'>退出</a> </p></body></html>sso ログインセンター:
<?phpheader("Content-type:text/html;charset=utf-8");$refer=$_SERVER['HTTP_REFERER'];$username=isset($_POST['username'])?trim($_POST['username']):'';$password=isset($_POST['password'])?trim($_POST['password']):'';if(empty($username) || empty($password)){ goback($refer);}$application=array(//根据子站点需要,添加应用列表 array('name'=>'进入A应用','url'=>'http://www.a.com/'), array('name'=>'进入C应用','url'=>'http://www.c.com/'));if($username=="admin" && $password=="123456"){ $str=time().','.$username.",".$password.",verifyok,".$refer; $key=encode($str); echo "登陆成功!".$username.'<br/>'; foreach ($application as $k => $v) { if($refer==$v['url']){ echo "<a target='_blank' style='color:red;font-weight:bold' href='".$v['url']."home.php?key=$key'>".$v['name']."</a> "; }else{ echo "<a target='_blank' href='".$v['url']."home.php?key=$key'>".$v['name']."</a> "; } }}else{ echo "<script>alert('登陆失败!');history.go(-1);</script>"; exit();}function goback($refer){ header("Location:$refer"); exit();}function decode($string = '', $skey = 'lmj951753') { $strArr = str_split(str_replace(array('O0O0O', 'o000o', 'oo00o'), array('=', '+', '/'), $string), 2); $strCount = count($strArr); foreach (str_split($skey) as $key => $value) $key <= $strCount && $strArr[$key][1] === $value && $strArr[$key] = $strArr[$key][0]; return base64_decode(join('', $strArr));}function encode($string = '', $skey = 'lmj951753') { $strArr = str_split(base64_encode($string)); $strCount = count($strArr); foreach (str_split($skey) as $key => $value) $key < $strCount && $strArr[$key].=$value; return str_replace(array('=', '+', '/'), array('O0O0O', 'o000o', 'oo00o'), join('', $strArr));}?>