亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Django集成CAS單點(diǎn)登錄的方法示例

 更新時(shí)間:2019年06月10日 08:27:14   作者:嚴(yán)北  
這篇文章主要介紹了Django集成CAS單點(diǎn)登錄的方法示例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧

CAS 全稱集中式認(rèn)證服務(wù)(Central Authentication Service),是實(shí)現(xiàn)單點(diǎn)登錄(SSO)的一中手段。

CAS 的通訊流程圖如下(圖片來(lái)自Google圖庫(kù)):

對(duì)于本文用戶可感知的層面,認(rèn)證過(guò)程如下:

  1. 前端訪問(wèn)后端登錄接口
  2. 后端返回重定向到 CAS 服務(wù)器的登錄頁(yè)面,并攜帶當(dāng)前用戶訪問(wèn)的網(wǎng)頁(yè)鏈接
  3. 用戶登錄,瀏覽器發(fā)送請(qǐng)求到 CAS 服務(wù)器進(jìn)行認(rèn)證
  4. CAS 認(rèn)證通過(guò),將本次登錄保存到會(huì)話,返回回調(diào)地址給后端
  5. 后端返回重定向請(qǐng)求給前端
  6. 前端重定向到跳轉(zhuǎn)登錄前的頁(yè)面

中間涉及到的 TGT 處理邏輯已經(jīng)由開(kāi)源 CAS Client(python-cas) 實(shí)現(xiàn)。

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

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

接入 CAS

因?yàn)槭堑谝淮谓佑| CAS ,為了方便調(diào)試,我在本地直接啟動(dòng)一個(gè) CAS 服務(wù)端用于調(diào)試。

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

CAS 服務(wù)端

GitHub 中有很多 CAS 項(xiàng)目,我選了一個(gè)基于 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ù)啟動(dòng)后,可以訪問(wèn) http://0.0.0.0:30000/login 到達(dá) CAS 登錄頁(yè)面。

問(wèn)題來(lái)了,用戶名密碼是什么呢?

我著實(shí)花了點(diǎn)時(shí)間才解決這個(gè)問(wèn)題———— django-mama-cas 默認(rèn)使用的是 django.auth 模塊 User ,使用 django-admin 創(chuàng)建超級(jí)用戶,該用戶也就可以用于登錄 CAS :

python manage.py createsuperuser

輸入用戶密碼即完成超級(jí)用戶創(chuàng)建,接著使用這個(gè)用戶登錄即可。

CAS 客戶端

Python 有開(kāi)源的 CAS 客戶端 python-cas ,由于我使用的 Django 開(kāi)發(fā)后端,因此直接選用封裝好 python-cas 的 Django 應(yīng)用 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',
)

同時(shí)參考準(zhǔn)備接入的 CAS 地址和版本,添加幾個(gè)對(duì)應(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)當(dāng)前服務(wù):

python manage.py runserver

訪問(wèn) http://127.0.0.1:8000/login ,網(wǎng)頁(yè)將會(huì)跳轉(zhuǎn)到 http://127.0.0.1:30000/login?service=http://127.0.0.1:8000 CAS 登錄頁(yè)面(注意端口不同),登錄成功后將會(huì)跳轉(zhuǎn)回來(lái)。

總結(jié)

CAS 本身邏輯需要理解,但是畢竟是成熟的單點(diǎn)登錄架構(gòu),一般都存在開(kāi)源的客戶端實(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

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • 關(guān)于pytorch中網(wǎng)絡(luò)loss傳播和參數(shù)更新的理解

    關(guān)于pytorch中網(wǎng)絡(luò)loss傳播和參數(shù)更新的理解

    今天小編就為大家分享一篇關(guān)于pytorch中網(wǎng)絡(luò)loss傳播和參數(shù)更新的理解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2019-08-08
  • 基于Python3制作一個(gè)帶GUI界面的小說(shuō)爬蟲(chóng)工具

    基于Python3制作一個(gè)帶GUI界面的小說(shuō)爬蟲(chóng)工具

    這篇文章主要為大家介紹了一個(gè)通過(guò)Python3制作的帶GUI界面的小說(shuō)爬蟲(chóng)工具,用來(lái)從筆趣閣爬取小說(shuō)。感興趣的小伙伴可以跟隨小編一起動(dòng)手嘗試一下
    2022-02-02
  • python中pandas.read_csv()函數(shù)的深入講解

    python中pandas.read_csv()函數(shù)的深入講解

    這篇文章主要給大家介紹了關(guān)于python中pandas.read_csv()函數(shù)的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2021-03-03
  • 從PySpark中的字符串獲取列表方法講解

    從PySpark中的字符串獲取列表方法講解

    在本篇內(nèi)容里小編給大家分享的是一篇關(guān)于從PySpark中的字符串獲取列表方法講解及相關(guān)實(shí)例,有需要的朋友們跟著學(xué)習(xí)下。
    2021-12-12
  • 解決python3爬蟲(chóng)無(wú)法顯示中文的問(wèn)題

    解決python3爬蟲(chóng)無(wú)法顯示中文的問(wèn)題

    下面小編就為大家分享一篇解決python3爬蟲(chóng)無(wú)法顯示中文的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2018-04-04
  • Python調(diào)用實(shí)現(xiàn)最小二乘法的方法詳解

    Python調(diào)用實(shí)現(xiàn)最小二乘法的方法詳解

    所謂線性最小二乘法,可以理解為是解方程的延續(xù),區(qū)別在于,當(dāng)未知量遠(yuǎn)小于方程數(shù)的時(shí)候,將得到一個(gè)無(wú)解的問(wèn)題。本文主要和大家分享Python調(diào)用實(shí)現(xiàn)最小二乘法的方法,需要的可以參考一下
    2023-04-04
  • Python中Numpy mat的使用詳解

    Python中Numpy mat的使用詳解

    這篇文章主要介紹了Python中Numpy mat的使用詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-05-05
  • Python通過(guò)paramiko庫(kù)實(shí)現(xiàn)遠(yuǎn)程執(zhí)行l(wèi)inux命令的方法

    Python通過(guò)paramiko庫(kù)實(shí)現(xiàn)遠(yuǎn)程執(zhí)行l(wèi)inux命令的方法

    這篇文章主要介紹了Python通過(guò)paramiko庫(kù)實(shí)現(xiàn)遠(yuǎn)程執(zhí)行l(wèi)inux命令,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2023-03-03
  • Python讀取Word(.docx)正文信息的方法

    Python讀取Word(.docx)正文信息的方法

    這篇文章主要為大家詳細(xì)介紹了Python讀取Word(.docx)正文信息的方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-03-03
  • Python實(shí)現(xiàn)RabbitMQ6種消息模型的示例代碼

    Python實(shí)現(xiàn)RabbitMQ6種消息模型的示例代碼

    這篇文章主要介紹了Python實(shí)現(xiàn)RabbitMQ6種消息模型的示例代碼,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-03-03

最新評(píng)論