首頁 後端開發 php教程 如何实现SSO单点登陆?

如何实现SSO单点登陆?

Jun 06, 2016 pm 08:14 PM
sso

可以使用跨域Cookie实现单点登录。步骤:1、未登录用户访问子站a.com进行登录,自动跳转到统一登录页;2、用户在统一登录页进行登录,成功后显示登录跳转页,然后自动跳转回a.com,单点登录完成;4、用户在访问b.com时无需再次登录。

如何实现SSO单点登陆?

单点登录

单点登录(SSO - Single Sign On):对于同一个客户端(例如 Chrome 浏览器),只要登录了一个子站(例如 a.com),则所有子站(b.com、c.com)都认为已经登录。

比如用户在登录淘宝后,跳转到天猫时就已经登录了。

如何实现SSO单点登陆?

方法:使用跨域Cookie实现单点登录

用例步骤

● 未登录用户访问子站 a.com 进行登录,自动跳转到账户中心的统一登录页 account.com/login

● 用户在统一登录页进行登录,登录成功后显示登录跳转页

● 显示登录跳转页后自动跳转回 a.com,单点登录完成

● 用户在访问 b.com 时无需再次登录

实现原理

登录

● 统一登录页登录请求完成后响应为登录跳转页

● 登录跳转页中通知各子站进行登录

<script src='b.com/login?uid=xxxx&token=xxxxx'></script>
<script src='c.com/login?uid=xxxx&token=xxxxx'></script>
登入後複製

● 子站收到登录请求后验证 token 是否有效,有效的话在响应中设置 cookie(user_token=xxxx)

token 验证

● 账户中心使用私钥加密 user id,生成 token

● 子站使用公钥解密 token,将得到的 user id 和参数 uid 对比,如果一样就是校验通过

登出

● 用户在某个子站主动登出时跳转到账户中心统一登出页 account.com/logout?uid=xxxx&token=xxxx

● 账户中心验证 token 后进行登出,在登出跳转页中通知各子站进行登出(设置 cookie),类似登录通知

● 子站收到登出请求后验证 token 是否有效,有效的话在响应中设置 cookie(删除 user_token)

关键点

● 浏览器渲染登录跳转页时将执行上面用 <script> 发送的登录通知请求,执行完后(或者超时)才跳转回前面登录的子站

● 登录通知请求是跨域的(当前域是账户中心 account.com),所以在响应中设置 cookie 时 IE 某些版本需要设置 P3P 头

● 在验证 token 时可以考虑使用账户中心提供高性能的验证接口,子站进行调用

更多相关知识,请访问 PHP中文网!!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱門文章

兩個點博物館:邦格荒地地點指南
4 週前 By 尊渡假赌尊渡假赌尊渡假赌
倉庫:如何復興隊友
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒險:如何獲得巨型種子
3 週前 By 尊渡假赌尊渡假赌尊渡假赌

熱門文章

兩個點博物館:邦格荒地地點指南
4 週前 By 尊渡假赌尊渡假赌尊渡假赌
倉庫:如何復興隊友
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒險:如何獲得巨型種子
3 週前 By 尊渡假赌尊渡假赌尊渡假赌

熱門文章標籤

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

如何使用PHP實現高效穩定的SSO單一登錄 如何使用PHP實現高效穩定的SSO單一登錄 Oct 15, 2023 pm 02:49 PM

如何使用PHP實現高效穩定的SSO單一登錄

PHP中的OAuth:建構一個多平台SSO解決方案 PHP中的OAuth:建構一個多平台SSO解決方案 Jul 28, 2023 pm 09:38 PM

PHP中的OAuth:建構一個多平台SSO解決方案

探討PHP SSO單一登入的安全性與漏洞防範 探討PHP SSO單一登入的安全性與漏洞防範 Oct 15, 2023 pm 02:36 PM

探討PHP SSO單一登入的安全性與漏洞防範

聊聊基於Node實作單一登入(SSO)的方法 聊聊基於Node實作單一登入(SSO)的方法 Dec 06, 2022 pm 07:49 PM

聊聊基於Node實作單一登入(SSO)的方法

Java JAAS 的最新最佳實踐 Java JAAS 的最新最佳實踐 Feb 23, 2024 pm 10:52 PM

Java JAAS 的最新最佳實踐

基於Swoole的SSO單一登入系統設計實踐 基於Swoole的SSO單一登入系統設計實踐 Jun 14, 2023 pm 04:08 PM

基於Swoole的SSO單一登入系統設計實踐

PHP SSO單一登入在多系統整合中的實際應用案例 PHP SSO單一登入在多系統整合中的實際應用案例 Oct 15, 2023 am 11:45 AM

PHP SSO單一登入在多系統整合中的實際應用案例

深入理解PHP SSO單一登入的工作原理與技術機制 深入理解PHP SSO單一登入的工作原理與技術機制 Oct 15, 2023 am 09:19 AM

深入理解PHP SSO單一登入的工作原理與技術機制

See all articles