一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

腳本之家,腳本語言編程技術及教程分享平臺!
分類導航

Python|VBS|Ruby|Lua|perl|VBA|Golang|PowerShell|Erlang|autoit|Dos|bat|

服務器之家 - 腳本之家 - Python - 詳解Django-auth-ldap 配置方法

詳解Django-auth-ldap 配置方法

2021-04-27 00:18BigYoung Python

Django-auth-ldap是一個Django身份驗證后端,可以針對LDAP服務進行身份驗證。這篇文章主要介紹了詳解Django-auth-ldap 配置方法,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

使用場景

公司內部使用Django作為后端服務框架的Web服務,當需要使用公司內部搭建的Ldap 或者 Windows 的AD服務器作為Web登錄認證系統時,就需要這個Django-auth-ldap第三方插件

插件介紹

Django-auth-ldap是一個Django身份驗證后端,可以針對LDAP服務進行身份驗證。有許多豐富的配置選項可用于處理用戶,組和權限,便于對頁面和后臺的控制 插件介紹地址:Django-auth-ldap

安裝方法

注意:需先正確安裝python3環境、pip3 和 Django環境

前提: 需要先安裝python-ldap > = 3.0

第一步:安裝Django-auth-ldap

?
1
pip install django-auth-ldap

第二步:在setting.py中配置django-auth-ldap 模塊

要在Django項目中使用auth認證,請將django_auth_ldap.backend.LDAPBackend添加 到AUTHENTICATION_BACKENDS。不要向INSTALLED_APPS添加任何內容。 添加完效果如下:

?
1
2
3
4
5
AUTHENTICATION_BACKENDS = [
 
'django_auth_ldap.backend.LDAPBackend'
 
]

第三步:在django項目的settings.py中配置如下代碼:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
#Django-auth-ldap 配置部分
import ldap
from django_auth_ldap.config import LDAPSearch,GroupOfNamesType
 
#修改Django認證先走ldap,再走本地認證
AUTHENTICATION_BACKENDS = [
 'django_auth_ldap.backend.LDAPBackend',
 'django.contrib.auth.backends.ModelBackend',
]
 
#ldap的連接基礎配置
AUTH_LDAP_SERVER_URI = "ldap://xxx.xxx.xxx.xxx:389" # ldap or ad 服務器地址
AUTH_LDAP_BIND_DN = "CN=administrator,CN=Users,DC=test,DC=com" # 管理員的dn路徑
AUTH_LDAP_BIND_PASSWORD = 'testpassword' # 管理員密碼
 
#允許認證用戶的路徑
AUTH_LDAP_USER_SEARCH = LDAPSearch("OU=test,DC=test,DC=intra",
     ldap.SCOPE_SUBTREE, "(sAMAccountName=%(user)s)")
 
#通過組進行權限控制
AUTH_LDAP_GROUP_SEARCH = LDAPSearch("ou=groups,ou=test,dc=test,dc=intra",
 ldap.SCOPE_SUBTREE, "(objectClass=groupOfNames)"
)
 
AUTH_LDAP_GROUP_TYPE = GroupOfNamesType()
 
#is_staff:這個組里的成員可以登錄;is_superuser:組成員是django admin的超級管理員;is_active:組成員可以登錄django admin后臺,但是無權限查看后臺內容
AUTH_LDAP_USER_FLAGS_BY_GROUP = {
 "is_staff": "cn=test_users,ou=groups,OU=test,DC=test,DC=com",
 "is_superuser": "cn=test_users,ou=groups,OU=tset,DC=test,DC=com",
}
#通過組進行權限控制end
 
#如果ldap服務器是Windows的AD,需要配置上如下選項
AUTH_LDAP_CONNECTION_OPTIONS = {
 ldap.OPT_DEBUG_LEVEL: 1,
 ldap.OPT_REFERRALS: 0,
}
 
#當ldap用戶登錄時,從ldap的用戶屬性對應寫到django的user數據庫,鍵為django的屬性,值為ldap用戶的屬性
AUTH_LDAP_USER_ATTR_MAP = {
 "first_name": "givenName",
 "last_name": "sn",
 "email": "mail"
}
 
#如果為True,每次組成員都從ldap重新獲取,保證組成員的實時性;反之會對組成員進行緩存,提升性能,但是降低實時性
# AUTH_LDAP_FIND_GROUP_PERMS = True

以上配置完畢后,登錄服務器后臺地址:http://serverurl:8080/admin 使用ldap or ad中指定的group里的用戶進行登錄認證。希望對大家的學習有所幫助,也希望大家多多支持服務器之家。

原文鏈接:http://www.bigyoung.cn/1017.html

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 99精品视频在线观看 | 女女同性做爰xxoo亲吻 | 久久国产精品免费网站 | 日本指交 | 日本高清在线观看天码888 | 国产精品激情综合久久 | 亚洲 欧美 国产 视频二区 | 美女机机对机机的视频(免费) | 国产精品人人视频 | 九九久久国产精品免费热6 九九精品视频一区二区三区 | 亚洲欧美精品一区二区 | 日本在线观看免费观看完整版 | 欧美精品一区二区三区久久 | 国产精品露脸国语对白手机视频 | 闺蜜的样子小说安沁在线阅读 | 99国产精品热久久久久久夜夜嗨 | 亚洲天堂中文 | 青草娱乐极品免费视频 | 欧美第一视频 | 免费十几分视频 | 亚洲不卡视频在线观看 | 亚洲欧美国产精品久久久 | 亚洲欧洲日产国码 最新 | 性欧美video| 午夜在线观看免费完整直播网 | 亚洲欧美日韩一区成人 | 99re热| 四虎综合九九色九九综合色 | 国产播放啪视频免费视频 | 2020精品极品国产色在线观看 | 狠狠色婷婷 | 香蕉精品视频 | 爱情岛论坛亚洲一号路线 | 久久久久夜 | 国产尤物视频 | 波多野结衣178部中文字幕 | 女人全身裸露无遮挡免费观看 | 国产精品成人扳一级aa毛片 | 日本又黄又裸一级大黄裸片 | 日本视频一区在线观看免费 | 四虎最新免费观看网址 |