欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時間:2020年11月28日 11:33:05   作者:-零  
這篇文章主要介紹了基于Django集成CAS實現流程詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下

前言

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

CAS概述

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

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

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

接入 CAS

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

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

CAS 服務端配置

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

創(chuàng)建 django-cas-server 項目:

django-admin startproject django-cas-server

安裝 django-mama-cas 依賴:

pip install django-mama-cas

在 INSTALLED_APPS 中添加 'mama_cas' 應用:

settings.py

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

使用

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 創(chuàng)建超級用戶,該用戶也就可以用于登錄 CAS :

CAS 客戶端

Python 有開源的 CAS 客戶端 python-cas ,由于我使用的 Django 開發(fā)后端,因此直接選用封裝好 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_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 登錄頁面(注意端口不同),登錄成功后將會跳轉回來。

總結

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

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

相關文章

  • Python+Flask實現自定義分頁的示例代碼

    Python+Flask實現自定義分頁的示例代碼

    分頁操作在web開發(fā)中幾乎是必不可少的,而flask不像django自帶封裝好的分頁操作。所以本文將自定義實現分頁效果,需要的可以參考一下
    2022-09-09
  • Python3+RIDE+RobotFramework自動化測試框架搭建過程詳解

    Python3+RIDE+RobotFramework自動化測試框架搭建過程詳解

    這篇文章主要介紹了Python3+RIDE+RobotFramework自動化測試框架搭建過程詳解,本文通過圖文并茂的形式給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-09-09
  • 簡單了解python模塊概念

    簡單了解python模塊概念

    這篇文章主要介紹了簡單了解python模塊概念,具有一定借鑒價值,需要的朋友可以參考下
    2018-01-01
  • Django 實現admin后臺顯示圖片縮略圖的例子

    Django 實現admin后臺顯示圖片縮略圖的例子

    今天小編就為大家分享一篇Django 實現admin后臺顯示圖片縮略圖的例子,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-07-07
  • 解決Django 在ForeignKey中出現 non-nullable field錯誤的問題

    解決Django 在ForeignKey中出現 non-nullable field錯誤的問題

    今天小編就為大家分享一篇解決Django 在ForeignKey中出現 non-nullable field錯誤的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-08-08
  • Selenium爬取b站主播頭像并以昵稱命名保存到本地

    Selenium爬取b站主播頭像并以昵稱命名保存到本地

    這篇文章主要介紹了使用Selenium自動化爬取b站主播頭像并以昵稱命名保存到本地的方法,代碼簡單完整,對于大家練習Selenium自動化有一定的幫助,需要的朋友可以參考下
    2021-04-04
  • Python批量生成字幕圖片的方法詳解

    Python批量生成字幕圖片的方法詳解

    這篇文章主要為大家詳細介紹了如何利用Python語言實現批量生成字幕圖片用于視頻剪輯,文中的示例代碼講解詳細,感興趣的小伙伴可以了解一下
    2022-05-05
  • Python實現服務端渲染SSR的示例代碼

    Python實現服務端渲染SSR的示例代碼

    服務端渲染是一種常見的技術策略,特別是在需要改善網站的搜索引擎優(yōu)化(SEO)和首屏加載時間的場景下,本文將介紹如何利用?Python?實現?SSR,感興趣的可以了解下
    2024-02-02
  • Python中glob庫實現文件名的匹配

    Python中glob庫實現文件名的匹配

    本文主要主要介紹了Python中glob庫實現文件名的匹配,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2021-06-06
  • pycharm安裝漢化包失敗的問題及解決

    pycharm安裝漢化包失敗的問題及解決

    這篇文章主要介紹了pycharm安裝漢化包失敗的問題及解決方案,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-11-11

最新評論