基于Django集成CAS实现流程详解


Posted in Python onNovember 28, 2020

前言

单点登录(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.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 创建超级用户,该用户也就可以用于登录 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_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 相关文章推荐
小结Python用fork来创建子进程注意事项
Jul 03 Python
跟老齐学Python之不要红头文件(1)
Sep 28 Python
python实现二维码扫码自动登录淘宝
Dec 27 Python
Python实现简单的获取图片爬虫功能示例
Jul 12 Python
利用pandas将numpy数组导出生成excel的实例
Jun 14 Python
pyqt 实现在Widgets中显示图片和文字的方法
Jun 13 Python
Pyqt QImage 与 np array 转换方法
Jun 27 Python
使用Django搭建网站实现商品分页功能
May 22 Python
使用TensorBoard进行超参数优化的实现
Jul 06 Python
python实现梯度下降算法的实例详解
Aug 17 Python
python 邮件检测工具mmpi的使用
Jan 04 Python
使用qt quick-ListView仿微信好友列表和聊天列表的示例代码
Jun 13 Python
Django haystack实现全文搜索代码示例
Nov 28 #Python
windows下python 3.9 Numpy scipy和matlabplot的安装教程详解
Nov 28 #Python
关于Python 解决Python3.9 pandas.read_excel(‘xxx.xlsx‘)报错的问题
Nov 28 #Python
Python self用法详解
Nov 28 #Python
Python3.9最新版下载与安装图文教程详解(Windows系统为例)
Nov 28 #Python
python安装sklearn模块的方法详解
Nov 28 #Python
Django-silk性能测试工具安装及使用解析
Nov 28 #Python
You might like
在WIN98下以apache模块方式安装php
2006/10/09 PHP
简单PHP上传图片、删除图片实现代码
2010/05/12 PHP
php学习之运算符相关概念
2011/06/09 PHP
javascript demo 基本技巧
2009/12/18 Javascript
关于JavaScript中name的意义冲突示例介绍
2014/05/29 Javascript
javascript 闭包详解
2015/02/15 Javascript
javascript实现无缝上下滚动特效
2015/12/16 Javascript
js中flexible.js实现淘宝弹性布局方案
2020/06/23 Javascript
js HTML5多图片上传及预览实例解析(不含前端的文件分割)
2016/08/26 Javascript
nodejs 图片预览和上传的示例代码
2017/09/30 NodeJs
JS解决position:sticky的兼容性问题的方法
2017/10/17 Javascript
vue.js  父向子组件传参的实例代码
2017/10/29 Javascript
如何开发出更好的JavaScript模块
2017/12/22 Javascript
[原创]jquery判断元素内容是否为空的方法
2018/05/04 jQuery
javascript实现手动点赞效果
2019/04/09 Javascript
js对象简介与基本用法示例
2020/03/13 Javascript
浅谈Vue使用Cascader级联选择器数据回显中的坑
2020/10/31 Javascript
[38:42]完美世界DOTA2联赛循环赛 Matador vs Forest BO2第二场 11.05
2020/11/05 DOTA
Python将xml和xsl转换为html的方法
2015/03/10 Python
Python实现图片拼接的代码
2018/07/02 Python
python生成lmdb格式的文件实例
2018/11/08 Python
Windows10下Tensorflow2.0 安装及环境配置教程(图文)
2019/11/21 Python
Python 面向对象静态方法、类方法、属性方法知识点小结
2020/03/09 Python
python shell命令行中import多层目录下的模块操作
2020/03/09 Python
一款利用纯css3实现的win8加载动画的实例分析
2014/12/11 HTML / CSS
CSS3简单实现照片墙
2014/12/12 HTML / CSS
html5中canvas图表实现柱状图的示例
2017/11/13 HTML / CSS
BrandAlley英国:法国折扣奢侈品网上零售商
2017/07/03 全球购物
为数据库创建索引都需要注意些什么
2012/07/17 面试题
预备党员党校学习自我评价分享
2013/11/12 职场文书
国贸专业的职业规划范文
2014/01/23 职场文书
2014年大学生四年规划书范文
2014/04/03 职场文书
爱心募捐感谢信
2015/01/22 职场文书
教师年度个人总结
2015/02/11 职场文书
2015年销售助理工作总结
2015/05/11 职场文书
建国70周年的心得体会(2篇)
2019/09/20 职场文书