国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術文章
文章詳情頁

基于Django集成CAS實現流程詳解

瀏覽:24日期:2024-09-16 17:26:43

前言

單點登錄(Single Sign On,SSO)是指在多個應用系統中,用戶只需要登錄一次就可以訪問所有相互信任的應用系統。有多種開源的單點登錄方案,其中,CAS(Central Authentication Service)是Yale University開發的、應用比較廣泛的一種實現。

CAS概述

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

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

前端訪問后端登錄接口 后端返回重定向到 CAS 服務器的登錄頁面,并攜帶當前用戶訪問的網頁鏈接 用戶登錄,瀏覽器發送請求到 CAS 服務器進行認證 CAS 認證通過,將本次登錄保存到會話,返回回調地址給后端 后端返回重定向請求給前端 前端重定向到跳轉登錄前的頁面 中間涉及到的 TGT 處理邏輯已經由開源 CAS Client(python-cas) 實現。 要注意,CAS 服務器本身有一些過濾條件,例如域名白名單等,因此接入的時候需要將新系統的域名或 IP 加入 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

settings.pyINSTALLED_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’, ], },]

使用

python manage.py runserver 0.0.0.0:9000

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

django-mama-cas 默認使用的是 django.auth 模塊 User ,使用 django-admin 創建超級用戶,該用戶也就可以用于登錄 CAS :

CAS 客戶端

Python 有開源的 CAS 客戶端 python-cas ,由于我使用的 Django 開發后端,因此直接選用封裝好 python-cas 的 Django 應用 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’,)

同時參考準備接入的 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_viewsurlpatterns = [ ... 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 登錄頁面(注意端口不同),登錄成功后將會跳轉回來。

總結

CAS 本身邏輯需要理解,但是畢竟是成熟的單點登錄架構,一般都存在開源的客戶端實現,代碼量不多,多調試多參考文檔配置即可。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。

標簽: Django
相關文章:
主站蜘蛛池模板: 成人午夜私人影院入口 | 中文字幕一区二区三区视频在线 | 亚洲精品第一区二区在线 | 性欧美视频a毛片在线播放 性欧美一级 | a级国产乱理伦片在线观看 a级国产乱理伦片在线观看99 | 欧美激情免费a视频 | 日韩在线观看不卡 | 精品国产a | 国产精品久久久久久久久久久搜索 | 国产成人高清视频在线观看免费97 | 欧美黄网站免费观看 | 韩国一级淫片视频免费播放 | 一级待一黄aaa大片在线还看 | 国内精品久久久久久久影视麻豆 | 免费观看毛片视频 | 九九九九在线精品免费视频 | 午夜精| 久草国产在线播放 | 性欧美17一18sex性高清播放 | 国产亚洲精品午夜一区 | 久久草在线免费 | 亚洲精品国产啊女成拍色拍 | 国产福利一区二区在线精品 | 亚洲视频中文字幕 | 欧美人拘一级毛片 | 国产欧美一区二区三区免费看 | 台湾50部三级 | 国产a毛片 | 无国产精品白浆是免费 | 免费鲁丝片一级观看 | 欧美久草视频 | 狠狠色狠狠色综合日日32 | 国产a级午夜毛片 | 97se狠狠狠狠狠亚洲综合网 | 免费观看a级网站 | 亚洲人成网7777777国产 | 99久久亚洲综合精品网站 | 一级做a爰片久久毛片鸭王 一级做a爰全过程免费视频毛片 | 国产三级一区二区 | 男人使劲躁女人视频小v | 亚洲国产成a人v在线 |