Django集成CAS單點(diǎn)登錄的方法示例
CAS 全稱集中式認(rèn)證服務(wù)(Central Authentication Service),是實(shí)現(xiàn)單點(diǎn)登錄(SSO)的一中手段。
CAS 的通訊流程圖如下(圖片來自Google圖庫):

對于本文用戶可感知的層面,認(rèn)證過程如下:
- 前端訪問后端登錄接口
- 后端返回重定向到 CAS 服務(wù)器的登錄頁面,并攜帶當(dāng)前用戶訪問的網(wǎng)頁鏈接
- 用戶登錄,瀏覽器發(fā)送請求到 CAS 服務(wù)器進(jìn)行認(rèn)證
- CAS 認(rèn)證通過,將本次登錄保存到會話,返回回調(diào)地址給后端
- 后端返回重定向請求給前端
- 前端重定向到跳轉(zhuǎn)登錄前的頁面
中間涉及到的 TGT 處理邏輯已經(jīng)由開源 CAS Client(python-cas) 實(shí)現(xiàn)。
要注意,CAS 服務(wù)器本身有一些過濾條件,例如域名白名單等,因此接入的時候需要將新系統(tǒng)的域名或 IP 加入 CAS 服務(wù)端配置中。
出于安全考慮,CAS 一般不支持跨域,因此前后端分離開發(fā)時可能比較麻煩。(似乎有解決方案,但是未嘗試過)
接入 CAS
因?yàn)槭堑谝淮谓佑| CAS ,為了方便調(diào)試,我在本地直接啟動一個 CAS 服務(wù)端用于調(diào)試。
CAS 客戶端也就是集成于我們實(shí)際開發(fā)的Django代碼中。
CAS 服務(wù)端
GitHub 中有很多 CAS 項(xiàng)目,我選了一個基于 Django 的 django-mama-cas 應(yīng)用。
配置
創(chuàng)建 django-cas-server 項(xiàng)目:
django-admin startproject django-cas-server
安裝 django-mama-cas 依賴:
pip install django-mama-cas
在 INSTALLED_APPS 中添加 'mama_cas' 應(yīng)用:
settings.py
INSTALLED_APPS = [ ... 'mama_cas', ]
添加 mama_cas 應(yīng)用中的路由:
urls.py
urlpatterns += [url(r'', include('mama_cas.urls'))]
配置 CAS 信息:
MAMA_CAS_SERVICES = [
{
# 必填項(xiàng),此項(xiàng)為**Client** IP:Port,相當(dāng)于白名單
'SERVICE': 'http://127.0.0.1:8000',
# 回調(diào)模式,具體參考官方文檔
'CALLBACKS': [
'mama_cas.callbacks.user_model_attributes',
],
},
]
使用
# 使用任意端口都可,此處我使用 30000 python manage.py runserver 0.0.0.0:30000
服務(wù)啟動后,可以訪問 http://0.0.0.0:30000/login 到達(dá) CAS 登錄頁面。
問題來了,用戶名密碼是什么呢?
我著實(shí)花了點(diǎn)時間才解決這個問題———— django-mama-cas 默認(rèn)使用的是 django.auth 模塊 User ,使用 django-admin 創(chuàng)建超級用戶,該用戶也就可以用于登錄 CAS :
python manage.py createsuperuser
輸入用戶密碼即完成超級用戶創(chuàng)建,接著使用這個用戶登錄即可。
CAS 客戶端
Python 有開源的 CAS 客戶端 python-cas ,由于我使用的 Django 開發(fā)后端,因此直接選用封裝好 python-cas 的 Django 應(yīng)用 django-cas-ng 。
配置
同樣需要先安裝依賴:
pip install django-cas-ng
在 settings.py 中的 INSTALLED_APPS 和 AUTHENTICATION_BACKENDS 兩處添加 django-cas-ng 的配置:
settings.py
INSTALLED_APPS = ( # ... other installed apps 'django_cas_ng', ) AUTHENTICATION_BACKENDS = ( 'django.contrib.auth.backends.ModelBackend', 'django_cas_ng.backends.CASBackend', )
同時參考準(zhǔn)備接入的 CAS 地址和版本,添加幾個對應(yīng)的配置:
# CAS 的地址 CAS_SERVER_URL = 'http://127.0.0.1:30000' # CAS 版本 CAS_VERSION = '3' # 存入所有 CAS 服務(wù)端返回的 User 數(shù)據(jù)。 CAS_APPLY_ATTRIBUTES_TO_USER = True
添加登入登出的路由(這兩部分邏輯已由 django-cas-ng 完成,可以直接使用。如果需要擴(kuò)展,可以參照源碼自己實(shí)現(xiàn)即可):
urls.py
import django_cas_ng.views as cas_views
urlpatterns = [
...
path('login/', django_cas_ng.views.LoginView.as_view(), name='cas_ng_login'),
path('logout/', django_cas_ng.views.LogoutView.as_view(), name='cas_ng_logout'),
]
調(diào)試
啟動當(dāng)前服務(wù):
python manage.py runserver
訪問 http://127.0.0.1:8000/login ,網(wǎng)頁將會跳轉(zhuǎn)到 http://127.0.0.1:30000/login?service=http://127.0.0.1:8000 CAS 登錄頁面(注意端口不同),登錄成功后將會跳轉(zhuǎn)回來。
總結(jié)
CAS 本身邏輯需要理解,但是畢竟是成熟的單點(diǎn)登錄架構(gòu),一般都存在開源的客戶端實(shí)現(xiàn),代碼量不多,多調(diào)試多參考文檔配置即可。
參考
https://github.com/jbittel/django-mama-cas
https://django-mama-cas.readthedocs.io/en/latest/
https://github.com/mingchen/django-cas-ng
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
python讀取.mat文件的數(shù)據(jù)及實(shí)例代碼
這篇文章主要介紹了python讀取.mat文件的數(shù)據(jù)的方法,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價值 ,需要的朋友可以參考下2019-07-07
python 獲取毫秒數(shù),計算調(diào)用時長的方法
今天小編就為大家分享一篇python 獲取毫秒數(shù),計算調(diào)用時長的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-02-02
合并百度影音的離線數(shù)據(jù)( with python 2.3)
這篇文章主要介紹了合并百度影音的離線數(shù)據(jù)( with python 2.3)的相關(guān)資料2015-08-08
python之線程池map()方法傳遞多參數(shù)list
這篇文章主要介紹了python之線程池map()方法傳遞多參數(shù)list問題,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-03-03
Pandas DataFrame中的tuple元素遍歷的實(shí)現(xiàn)
這篇文章主要介紹了Pandas DataFrame中的tuple元素遍歷的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-10-10
python中使用ctypes調(diào)用so傳參設(shè)置遇到的問題及解決方法
這篇文章主要介紹了python中使用ctypes調(diào)用so傳參設(shè)置,本文較詳細(xì)的給大家介紹了遇到問題及解決方案,需要的朋友可以參考下2019-06-06

