前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >Django项目如何接入公司LDAP帐号认证

Django项目如何接入公司LDAP帐号认证

作者头像
测试开发技术
发布于 2020-01-17 09:01:03
发布于 2020-01-17 09:01:03
3.3K00
代码可运行
举报
文章被收录于专栏:测试开发技术测试开发技术
运行总次数:0
代码可运行

点击上方“公众号”可以订阅哦!

一、前言

Django项目开发过程中,为了保证安全性,通常都会接入用户帐号认证权限功能,而标题中LDAP是什么呢?当然这个不是本文介绍的重点,简单来说,LDAP是一种目录管理协议,通常公司用于存储员工的计算机登录帐号密码信息用的,而如果Django项目接入LDAP后,相当于登录Django站点时,可以不用再额外为使用该站点的用户去重新注册添加用户,使用者可以直接用各自的计算机登录帐号、密码登录即可。 如果想接入LDAP,前提是你们公司有LDAP服务器,当然我相信一般公司都会有,好了,闲话不说了,直接进入主题。

二、环境准备

1、安装python-ldap、django-auth-ldap

模块版本及下载地址,博主亲测有效! python-ldap 2.4.12 https://pypi.python.org/pypi/python-ldap/2.4.12 django-auth-ldap 1.1.4 https://pypi.python.org/pypi/django-auth-ldap/1.1.4

或直接在线安装

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
pip install python-ldap -i https://pypi.douban.com/simple
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
pip install  install django-auth-ldap -i http://pypi.douban.com/simple

三、 配置

1、setting.py配置

安装完成后,打开django项目中settings.py文件,增加ldap配置如下:

##ldap认证接入

AUTH_LDAP_SERVER_URI = 'ldap://ip:port' #ldap服务地址、端口

# AUTH_LDAP_BIND_DN = 'uid=username,ou=xx1,dc=xx2,dc=com'

# AUTH_LDAP_BIND_PASSWORD = "

AUTH_LDAP_USER_SEARCH = LDAPSearch("ou=xx1,dc=xx2,dc=com", ldap.SCOPE_SUBTREE, "(uid=%(user)s)")

AUTH_LDAP_ALWAYS_UPDATE_USER = True

AUTH_LDAP_USER_ATTR_MAP = {

"first_name": "givenName",

"last_name": "sn",

"email": "mail"

}

AUTH_USER_MODEL = 'UserManage.Account'

AUTHENTICATION_BACKENDS = (

'django_auth_ldap.backend.LDAPBackend', # ldap认证

'UserManage.auth.UsernamePasswordAuth', ## 本地自定义model的认证方式

)

注意事项:

1、实际接入ldap中,最关键的几个参数,ldap服务器地址、端口号、ou、dc等几个值,可从公司运维部获取得知。 2、实际接入ldap中,AUTH_LDAP_BIND_DN、 AUTH_LDAP_BIND_PASSWORD 可不用配置。 3、上述配置中,博主将ou、dc替换成xx1、xx2,实际使用更改成对应值即中。

四、简要流程

登录时,在默认的django数据库帐号验证之前,会先到LDAP服务器上去验证。 输入的登录帐号到LDAP服务器验证之前,会先用配置文件中的绑定DN、密码去验证,验证通过才能继续用输入的帐号密码去LDAP服务器验证。 若LDAP验证通过,会检查django数据库中是否已存在该帐号,若不存在,则会根据LDAP验证通过后获取的用户信息,来创建django数据库的用户账号。帐号名和输入的一样,密码则会设为一个无效的密码(看了下源码是”!”,无法合法哈希编码),因为该帐号密码验证是从LDAP上进行,所以django中的密码不会被使用到。除了默认的用户姓名、邮件等信息,若要把Group信息也同步过来的话需要进行相应的配置。 若LDAP验证失败,则会使用Django数据库的默认登录验证。

欢迎关注订阅

每日一篇!

公众号:mikezhou_talk

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2019-05-10,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 测试开发技术 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
重磅发布!腾讯云 ASW 工作流,可视化编排云服务
业界的云服务编排需要开发者编写代码,实际业务场景面对的常常是复杂的逻辑结构,开发人员要花大量时间处理组件间的逻辑和代码,学习成本高,难度大。
腾讯云工作流
2021/04/27
3.1K0
可视化编排云服务,工作流 ASW 开始公测!
ASW 简介 应用与服务编排工作流(Application Services Workflow,ASW)是对腾讯云服务进行可视化编排,组合成工作流模板的应用程序集成类产品。可以更简单、更直观、更快速地构建和更新应用。 ASW 可以用拖拽组件的方式来编排分布式任务和服务,工作流会按照设定好的顺序可靠地协调执行,并在必要时支持执行用户定义的重试逻辑,确保任务和服务按照模板定义的步骤顺利完成。 同时,您将无需编写代码,只需用可视化编排的方式快速构建自动化工作流模板,并实例化为任务去执行,或发布为服务接口提供对外
腾讯云serverless团队
2021/01/22
3.3K0
使用 ASW 工作流创建您的第一个函数编排
应用与服务编排工作流(Application Services Workflow,ASW)是一个用来协调分布式任务执行的编排产品,根据腾讯云状态语言定义来编排分布式任务和服务,工作流会按照设定好的顺序可靠地协调执行,将云函数与多个腾讯云服务按步骤进行调度,通过低代码配置,就可以完成开发和运行业务流程所需要的任务协调、状态管理以及错误处理等繁琐工作,让研发团队能更简单、更高效的构建与更新应用。 01. ASW 工作流与传统工作流的对比 特性 ASW 工作流传统工作流易用性已完成云服务集成, 方便调用云上资源
腾讯云serverless团队
2021/04/29
2.1K0
ASW 工作流最佳实践(四):并行多任务处理
在数据处理、多媒体文件处理、商品审核、容器运维管理等系统架构中,往往需要并行多路任务处理的场景 。 例如电商商品审核系统,商家每天对商品进行管理更新后,商品数据需要通过商品中台进行一系列的审核操作:如 图片审核、死链检测、商品打标、文本审核、统一类目 等环节。海量更新的商品数据会先投递到 Ckafka,商品中台需要一个能快速处理大量数据,高并发、高吞吐量的数据处理流水线。 利用 ASW 低代码、灵活便捷的特性,通过 ASW + 云函数作为微服务的粘合剂,可快速搭建一个高效可用、易扩展性的微服务架构应用。A
腾讯云serverless团队
2021/06/03
1.2K0
技术架构解密 - 应用与服务编排工作流 ASW
腾讯云应用与服务编排工作流 ASW(Application Service Workflow)是新一代计算架构体系下的服务编排解决方案,用来协调分布式任务执行的编排产品。在应用与服务编排工作流中设定好任务执行步骤,可以将多个腾讯云服务按步骤进行调度,完成各种业务应用场景。能简化开发和运行业务流程所需要的任务协调、状态管理以及错误处理等繁琐工作,更简单、更高效的构建应用。像胶水一样粘合云上各种产品和服务,提供面向用户场景的端到端解决方案。 01. 应用与服务编排工作流 ASW 背景介绍 随着云计算
腾讯云serverless团队
2021/07/14
2.1K0
ASW 工作流最佳实践(二):使用 ASW 并发调用函数
在音视频转码、ETL 作业处理、基因数据处理等诸多场景中,我们都可以通过工作流并行调用云函数,将任务进行并行处理,大大提高任务处理的吞吐量,满足应用场景的高实时性、高并发能力。 在《使用 ASW 工作流创建您的第一个函数编排》文章中,我们分享了如何使用 ASW 编排一个 Sum 云函数进行求和计算。本期文章主要分享如何使用 ASW 的 Map 节点能力进行并发的数据求和计算。 01. 创建函数 1. 登录「云函数控制台」,创建一个函数名称为 Sum,运行环境为 Python 3.6 的云函数。 云函数控
腾讯云serverless团队
2021/05/18
7790
可视化编排云服务,工作流 ASW 开始公测!
应用与服务编排工作流 (Application Services Workflow,ASW) 是对腾讯云服务进行可视化编排,组合成工作流模板的应用程序集成类产品。可以更简单、更直观、更快速地构建和更新应用。
腾讯云工作流
2021/03/10
3.1K0
发布更新|腾讯云 Serverless 产品动态 20210120
一、ASW 工作流公测发布 公测时间: 2021-01-22 产品背景: 应用与服务编排工作流(Application Services Workflow,以下简称:ASW)是按照业务场景对腾讯云服务进行可视化编排,组合成工作流模板的应用程序集成类产品,可以更简单、更直观、更快速地构建和更新应用。 产品功能: 支持云函数、视频处理 MPS、语音识别 ASR、自然语言处理 NLP、通用文字识别 General OCR 服务的编排能力 产品介绍: https://cloud.tencent.com/produ
腾讯云serverless团队
2021/01/21
1.1K0
简单三步,通过工作流(ASW)快速完成订单数据处理
本文介绍如何通过工作流 ASW 编排云函数,快速完成订单数据的处理。 工作原理 工作流调用函数获取一定时间段内的订单数据,对数据进行预处理。 将预处理的数据交给 Map 迭代任务处理:每个订单进行数据处理后,分别写到不同的数据库表中,或者绘制成图表展示。 操作步骤 创建工作流程需要首先创建一个状态机,通过编排状态机的不同元件,改变状态机结构,从而实现用户自定义的功能集合。 简单三步即可完成:创建云函数 → 创建工作流 → 运行状态机 Step 1:创建云函数 a. 创建 GetOrder 函数 登录
腾讯云serverless团队
2021/02/02
8290
如何快速搭建一个高可用的数据处理流水线?
ASW 应用与服务编排工作流是腾讯云服务的编排工具,用户可以将多个云服务编排到业务场景相关的应用程序中,可以通过 ASW 工作流编排分布式任务,管理执行任务的顺序、错误处理、重试逻辑和状态,从而显著减轻团队的研发负担。 通过 ASW Map 并发能力编排调用云函数,完成批量数据的处理,并将结果写回存储,提供开箱即用、灵活便捷、高弹性高可用的数据处理系统模型。尤其适合证券交易数据统计,电商系统商品订单数据分析,微博热点分析等大数据分析场景。本文为您介绍如何使用 ASW 编排云函数,快速搭建一个高可用的数据
腾讯云serverless团队
2021/05/28
1.3K0
如何快速搭建一个 AI 识别处理的流水线?
本文为您介绍如何使用 ASW 编排云函数与 AI 产品服务,快速搭建一个 AI 智能识别的处理流水线。通过 ASW 编排调用腾讯云 AI 能力,完成 活体检测、语音识别、关键字采样、自动审核 等一系列自动化识别认证流程,提供开箱即用、灵活便捷、高弹性高可用的 AI 智能识别处理场景。 尤其适合社区人脸识别,金融交易人脸支付,智能线上开户等 AI 人工智能场景。 01. ASW 工作流 - 「AI 识别」系统架构 在「智能线上开户」的场景中,用户在应用客户端登录,客户端将用户视频采集后上传到 COS,通过
腾讯云serverless团队
2021/06/21
1.3K0
腾讯云李啸川:Serverless 化云原生释放云计算效率红利
 以下内容来自「2021 全区分布式云大会:《Serverless 化云原生释放云计算效率红利》主题分享」,深度好文,预计阅读需 22 分钟。 分享嘉宾 李啸川,腾讯云 Serverless 技术产品专家,目前负责腾讯云 Serverless 产品及企业解决方案的设计工作,致力于推动云原生技术架构演进及落地,为技术工作者提供高效的云服务产品。十余年技术研发经验,曾就职于 Oracle、IBM,从事于企业级商业套件及云服务引擎研发工作,后切换到消费互联网,孵化小米 MIOT、创立小米有品电商等业务,加入腾讯
腾讯云serverless团队
2021/04/28
2.2K0
COS 数据工作流 + Serverless云函数自定义处理能力发布!
在工业 4.0 的浪潮下,智能和数据与物理世界结合越加紧密,多元化、灵活、高效的数据处理能力成为各行各业的热点需求。虽然对象存储 COS 已经预置电商、文创、教育、社交、安防等行业需要的基础数据处理能力,但在特殊流程和定制化需求方面公有云依然难以做到全方位满足客户需求。 01. 数据工作流全新能力出炉: 支持自定义云函数 COS 数据工作流是一套完整的端到云到端的数据存储、处理、发布等「一站式」云上智能解决方案。 COS 数据工作流最新增加了自定义函数的处理能力,开发者可添加 Serverless 云函数
腾讯云serverless团队
2021/08/06
1.2K0
COS 数据工作流 + 云函数最佳实践 - 自定义音视频转码
音视频作为信息传播中流量占比最大的部分在各行业的业务中都弥足重要,而不同的业务场景中对音视频的处理逻辑可能具备行业的特殊性。公有云虽然提供大量的视频处理服务供用户选择,但依然不能做到全面覆盖用户的特殊流程及定制化需求。 使用 COS 工作流处理结合云函数 SCF 定制逻辑此时就是一个绝佳选择,帮助用户 快速创建满足需求的各种音视频处理服务。 01. 「COS 数据工作流 + 云函数」应用场景 1. 快速接入用户自建转码集群,兼容用户原有业务; 2. 支持行业特殊格式与处理逻辑,接入电影、安防等特殊行业
腾讯云serverless团队
2021/08/10
1.4K0
中台整合零售:腾讯电商业务中台的 Serverless 架构升级
零售领域变革不是一个新话题,从电商到 O2O ,从无人售货柜到机器人导购,腾讯云的尝试一直未曾止步。对于传统零售企业来说,通过数据中台可以让顾客与需求更好地匹配,同时实现平台上多触点获取流量。而技术中台,则可以帮助零售企业提升整体运营效率,在提高安全性的基础上,还能享受 AI 时代带来的智能化红利。 谈及腾讯电商业务中台,腾讯云应用与服务编排工作流 ASW 的项目负责人王子一认为,“以消费者为中心,实现上下游的产业协同,赋能商家,商家一次接入后,可应用于如下全部业务场景:检索业务、广告业务、智能广告投放、
腾讯云serverless团队
2022/01/25
2.4K0
Serverless 在线教育解决方案——豌豆思维落地实践
在线教育蓬勃发展 技术保障面临新挑战 2020年的互联网市场中,受疫情影响,在线教育用户增长幅度大幅领先于其它互联网应用,行业增长趋势明显。在教育部“停课不停学“的指导下,原来线下教育培训机构也在逐渐从线下向线上蔓延。与此同时,已经在运营的在线教育小班由于用户数量的增加,也逐渐从小班教学向大班扩展。在线教育行业涌入大量用户,给技术团队带来了新的挑战。 在大多数在线教育机构,基本都是在自建的机房里基于服务器和 NFS 来实现音视频课程的存储和转码逻辑。但是如果遇到流量突增,例如暑假期间或者突发疫情等情况,I
腾讯云serverless团队
2021/04/02
7680
Serverless 在数据处理场景下的最佳应用
我们知道传统的数据处理无外乎涉及 Kafka、Logstash、File Beats、Spark、Flink、CLS、COS 等组件。这些海量服务器组件承担着从数据源取数据,数据聚合过滤等处理,再到数据流转的任务,不管是开发成本、运维成本以及价格方面都有所欠佳。下面将为大家详细介绍:云函数 SCF 是如何降低传统海量服务器组件的开发和运维成本的。 01.  腾讯云云函数 SCF 腾讯云云函数(Serverless Cloud Function,SCF)是腾讯云为企业和开发者们提供的无服务器执行环境,在无需
腾讯云serverless团队
2021/04/15
7900
直播预告:国内首发!负载均衡搭载 Serverless 云函数,云原生极致体验
腾讯云 Serverless 云函数 SCF 现已全面支持负载均衡触发方式,深度对接 Serverless 云函数公网访问服务,提供更易理解、更低成本、更易操作的公网服务及 Web 访问体验。适用于企业服务节点较多,有历史服务在 CVM、容器、自建机房,且服务较重、访问量较多的场景,帮助企业平滑迁移传统架构至 Serverless,一键部署,弹性无限。 5 月 7 日晚 7 点,由腾讯云高级产品经理易欣欣,为大家深入解读 「负载均衡+云函数」服务特性,以及在不同典型场景中的最佳实践,扫码或点击「阅读原文
腾讯云serverless团队
2021/04/26
6620
典型的 Serverless 无服务器应用架构
本文由 Serverless.com 产品经理 Oliver 翻译修改自 Xavier Lefèvre 所写的 ‘What a typical 100% Serverless Architecture looks like in AWS!' 要讨论无服务器架构的话,并不能仅仅局限于 FaaS 上,比如腾讯云 SCF,或 AWS Lambda。函数计算最吸引人的两个原因是:弹性伸缩(扩缩容)和按量计费,与此同时开发者还可以大幅减少甚至免去运维的工作和困扰,进而专心在软件功能开发和代码可靠性提高上。 以下是一
腾讯云serverless团队
2021/11/23
2.2K0
【玩转 WordPress】— 史上最快速搭建 WordPress 教程
以下内容来自「玩转腾讯云」用户原创文章,已获得授权。 01. 什么是 Serverless? 在《Serverless Architectures》中对 Serverless 是这样子定义的: Serverless was first used to describe applications that significantly or fully incorporate third-party, cloud-hosted applications and services, to manage serv
腾讯云serverless团队
2021/07/06
1K0
推荐阅读
相关推荐
重磅发布!腾讯云 ASW 工作流,可视化编排云服务
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
本文部分代码块支持一键运行,欢迎体验
本文部分代码块支持一键运行,欢迎体验