中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

怎么在Django中利用CAS實現一個單點登錄功能

發布時間:2021-04-06 17:50:23 來源:億速云 閱讀:488 作者:Leah 欄目:開發技術

這期內容當中小編將會給大家帶來有關怎么在Django中利用CAS實現一個單點登錄功能,文章內容豐富且以專業的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。

CAS 全稱集中式認證服務(Central Authentication Service),是實現單點登錄(SSO)的一中手段。

CAS 的通訊流程圖如下(圖片來自Google圖庫):

怎么在Django中利用CAS實現一個單點登錄功能

對于本文用戶可感知的層面,認證過程如下:

  1. 前端訪問后端登錄接口

  2. 后端返回重定向到 CAS 服務器的登錄頁面,并攜帶當前用戶訪問的網頁鏈接

  3. 用戶登錄,瀏覽器發送請求到 CAS 服務器進行認證

  4. CAS 認證通過,將本次登錄保存到會話,返回回調地址給后端

  5. 后端返回重定向請求給前端

  6. 前端重定向到跳轉登錄前的頁面

中間涉及到的 TGT 處理邏輯已經由開源 CAS Client(python-cas) 實現。

要注意,CAS 服務器本身有一些過濾條件,例如域名白名單等,因此接入的時候需要將新系統的域名或 IP 加入 CAS 服務端配置中。

出于安全考慮,CAS 一般不支持跨域,因此前后端分離開發時可能比較麻煩。(似乎有解決方案,但是未嘗試過)

接入 CAS

因為是第一次接觸 CAS ,為了方便調試,我在本地直接啟動一個 CAS 服務端用于調試。

CAS 客戶端也就是集成于我們實際開發的Django代碼中。

CAS 服務端

GitHub 中有很多 CAS 項目,我選了一個基于 Django 的 django-mama-cas 應用。

配置

創建 django-cas-server 項目:

django-admin startproject django-cas-server

安裝 django-mama-cas 依賴:

pip install django-mama-cas

INSTALLED_APPS 中添加 'mama_cas' 應用:

settings.py

INSTALLED_APPS = [
  ...
  'mama_cas',
]

添加 mama_cas 應用中的路由:

urls.py

urlpatterns += [url(r'', include('mama_cas.urls'))]

配置 CAS 信息:

MAMA_CAS_SERVICES = [
  {
    # 必填項,此項為**Client** IP:Port,相當于白名單
    'SERVICE': 'http://127.0.0.1:8000',
    # 回調模式,具體參考官方文檔
    'CALLBACKS': [
      'mama_cas.callbacks.user_model_attributes',
    ],
  },
]

使用

# 使用任意端口都可,此處我使用 30000
python manage.py runserver 0.0.0.0:30000

服務啟動后,可以訪問 http://0.0.0.0:30000/login 到達 CAS 登錄頁面。

問題來了,用戶名密碼是什么呢?

我著實花了點時間才解決這個問題———— django-mama-cas 默認使用的是 django.auth 模塊 User ,使用 django-admin 創建超級用戶,該用戶也就可以用于登錄 CAS :

python manage.py createsuperuser

輸入用戶密碼即完成超級用戶創建,接著使用這個用戶登錄即可。

CAS 客戶端

Python 有開源的 CAS 客戶端 python-cas ,由于我使用的 Django 開發后端,因此直接選用封裝好 python-cas 的 Django 應用 django-cas-ng

配置

同樣需要先安裝依賴:

pip install django-cas-ng

settings.py 中的 INSTALLED_APPSAUTHENTICATION_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',
)

同時參考準備接入的 CAS 地址和版本,添加幾個對應的配置:

# CAS 的地址
CAS_SERVER_URL = 'http://127.0.0.1:30000'
# CAS 版本
CAS_VERSION = '3'
# 存入所有 CAS 服務端返回的 User 數據。
CAS_APPLY_ATTRIBUTES_TO_USER = True

添加登入登出的路由(這兩部分邏輯已由 django-cas-ng 完成,可以直接使用。如果需要擴展,可以參照源碼自己實現即可):

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'),
]

調試

啟動當前服務:

python manage.py runserver

訪問 http://127.0.0.1:8000/login ,網頁將會跳轉到 http://127.0.0.1:30000/login?service=http://127.0.0.1:8000 CAS 登錄頁面(注意端口不同),登錄成功后將會跳轉回來。

上述就是小編為大家分享的怎么在Django中利用CAS實現一個單點登錄功能了,如果剛好有類似的疑惑,不妨參照上述分析進行理解。如果想知道更多相關知識,歡迎關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

延庆县| 鸡东县| 松江区| 茶陵县| 重庆市| 东安县| 忻州市| 西乡县| 瑞安市| 华蓥市| 马边| 安徽省| 来宾市| 元朗区| 兰溪市| 茂名市| 台南县| 微博| 彭水| 潞城市| 阳泉市| 西贡区| 收藏| 东乡族自治县| 根河市| 石柱| 衡南县| 荆州市| 广灵县| 错那县| 通渭县| 雅江县| 新巴尔虎左旗| 当涂县| 印江| 婺源县| 同心县| 犍为县| 新闻| 宝丰县| 彭山县|