[原创]django+ldap+memcache实现单点登录+统一认证

前言

由于公司内部的系统越来越多,为了方便用户使用,通过django进行了单点登录和统一认证的尝试,目前实现了django项目的单点登录和非django项目的统一认证,中间波折挺多,涉及的技术包括django\memcache\ldap等,如果有时间的话,后边会逐步更新博客分开介绍实现过程。
sso的实现相对复杂,期间也调研了如cas+ldap,最后采取了一种学习成本较低的方式,即通过mc共享session方式实现单点登录。有兴趣并且懂java的同学可以自行了解cas。应该是一种更成熟的sso解决方案
此外,目前单点登录只支持django项目,其他系统只能完成到统一认证,后续还需提供一套http接口以便其他语言的项目可以接入

实现过程

请参考以下这一堆博客
ldap部署相关,ldap双机\LAM配置管理\ldap备份还原
[原创]django+ldap实现统一认证部分一(django-auth-ldap实践)
[原创]django+ldap实现统一认证部分二(python-ldap实践)
[原创]django+ldap实现单点登录(装饰器和缓存)

逻辑图示意

807193-20161121002910529-1546954656.png

效果展示

807193-20161121004056013-1827612233.png
登录首页:可以实现用户的注册、登录、重置密码,实际通过python-ldap模块来操作ldap集群
ldap集群的搭建请参考后边博客
807193-20161121004423763-78242823.png
登录后的用户首页,如接入完成的下游系统,可以根据下游系统的权限自动进行登录,退出后全部系统退出
登录判定成功后,会刷新下游系统的账户信息,以避免出现下游系统与统一认证系统信息不一致现象
807193-20161121004840904-173457662.png
使用了开源的基于php开发的ldap管理工具ldap account manager(简称lam),用于更方便的从ldap查询或管理用户,包括sso系统自带admin权限、和用户是否具有登录权限,均可通过此平台统一控制
807193-20161122234309721-635135323.png
也可以使用ldap经典的树形结构展示,我通过划分成3个group(管理员、员工、黑名单),对权限进行基础控制

结语

目前已经开发完毕并投入生产,期间还有个稍复杂的地方,就是一些下游系统已经运行一段时间,拥有了一些账户,这个导入工作可以通过lam进行,但lam不支持中文,还需要进行一个utf-8的转换。
后续会更新多篇博客对完整实现方式进行介绍,希望可以给需要的人带来一些帮助。

转载于:https://www.cnblogs.com/caseast/p/6084124.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,我可以为您提供一些关于 Django + layui + 原生 SQL 语句实现登录的详细信息。 首先,Django 是一个基于 Python 的 Web 应用程序框架,它可以帮助您快速地构建 Web 应用程序。Layui 是一个流行的前端 UI 框架,它提供了许多易于使用的 UI 组件和样式。原生 SQL 语句是一种直接与数据库进行交互的方式,它可以让您更加灵活地操作数据。 下面是一些实现登录的步骤: 1. 创建 Django 项目并安装必要的包,包括 Django、pymysql 等。 2. 定义数据库模型,可以使用 Django 自带的 ORM,也可以使用原生 SQL 语句。例如,可以创建一个名为 User 的模型,其中包含用户名和密码: ```python class User(models.Model): username = models.CharField(max_length=50) password = models.CharField(max_length=50) ``` 3. 创建登录页面,并使用 Layui 的表单组件和 AJAX 技术提交表单数据。 4. 在后端编写登录验证逻辑,可以使用原生 SQL 语句查询数据库中是否存在对应的用户名和密码。 ```python def login(request): if request.method == 'POST': username = request.POST.get('username') password = request.POST.get('password') user = User.objects.raw('SELECT * FROM user WHERE username=%s AND password=%s', [username, password]) if user: # 登录成功 return JsonResponse({'code': 0, 'msg': '登录成功'}) else: # 登录失败 return JsonResponse({'code': 1, 'msg': '用户名或密码错误'}) ``` 5. 在前端根据后端返回的结果进行相应的处理,例如跳转到首页或者显示错误提示信息。 希望这些信息能对您有所帮助,如有任何问题或需要进一步了解,请随时告诉我。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值