国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > Python > 正文

詳解Django-auth-ldap 配置方法

2020-01-04 13:53:17
字體:
供稿:網(wǎng)友

使用場(chǎng)景

公司內(nèi)部使用Django作為后端服務(wù)框架的Web服務(wù),當(dāng)需要使用公司內(nèi)部搭建的Ldap 或者 Windows 的AD服務(wù)器作為Web登錄認(rèn)證系統(tǒng)時(shí),就需要這個(gè)Django-auth-ldap第三方插件

插件介紹

Django-auth-ldap是一個(gè)Django身份驗(yàn)證后端,可以針對(duì)LDAP服務(wù)進(jìn)行身份驗(yàn)證。有許多豐富的配置選項(xiàng)可用于處理用戶,組和權(quán)限,便于對(duì)頁面和后臺(tái)的控制 插件介紹地址:Django-auth-ldap

安裝方法

注意:需先正確安裝python3環(huán)境、pip3 和 Django環(huán)境

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

第一步:安裝Django-auth-ldap

pip install django-auth-ldap

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

要在Django項(xiàng)目中使用auth認(rèn)證,請(qǐng)將django_auth_ldap.backend.LDAPBackend添加 到AUTHENTICATION_BACKENDS。不要向INSTALLED_APPS添加任何內(nèi)容。 添加完效果如下:

AUTHENTICATION_BACKENDS = ['django_auth_ldap.backend.LDAPBackend' ,]

第三步:在django項(xiàng)目的settings.py中配置如下代碼:

#Django-auth-ldap 配置部分import ldapfrom django_auth_ldap.config import LDAPSearch,GroupOfNamesType #修改Django認(rèn)證先走ldap,再走本地認(rèn)證AUTHENTICATION_BACKENDS = [ 'django_auth_ldap.backend.LDAPBackend', 'django.contrib.auth.backends.ModelBackend',] #ldap的連接基礎(chǔ)配置AUTH_LDAP_SERVER_URI = "ldap://xxx.xxx.xxx.xxx:389" # ldap or ad 服務(wù)器地址AUTH_LDAP_BIND_DN = "CN=administrator,CN=Users,DC=test,DC=com" # 管理員的dn路徑AUTH_LDAP_BIND_PASSWORD = 'testpassword' # 管理員密碼 #允許認(rèn)證用戶的路徑AUTH_LDAP_USER_SEARCH = LDAPSearch("OU=test,DC=test,DC=intra",     ldap.SCOPE_SUBTREE, "(sAMAccountName=%(user)s)") #通過組進(jìn)行權(quán)限控制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:這個(gè)組里的成員可以登錄;is_superuser:組成員是django admin的超級(jí)管理員;is_active:組成員可以登錄django admin后臺(tái),但是無權(quán)限查看后臺(tái)內(nèi)容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",}#通過組進(jìn)行權(quán)限控制end #如果ldap服務(wù)器是Windows的AD,需要配置上如下選項(xiàng)AUTH_LDAP_CONNECTION_OPTIONS = { ldap.OPT_DEBUG_LEVEL: 1, ldap.OPT_REFERRALS: 0,} #當(dāng)ldap用戶登錄時(shí),從ldap的用戶屬性對(duì)應(yīng)寫到django的user數(shù)據(jù)庫,鍵為django的屬性,值為ldap用戶的屬性AUTH_LDAP_USER_ATTR_MAP = { "first_name": "givenName", "last_name": "sn", "email": "mail"} #如果為True,每次組成員都從ldap重新獲取,保證組成員的實(shí)時(shí)性;反之會(huì)對(duì)組成員進(jìn)行緩存,提升性能,但是降低實(shí)時(shí)性# AUTH_LDAP_FIND_GROUP_PERMS = True

以上配置完畢后,登錄服務(wù)器后臺(tái)地址:http://serverurl:8080/admin 使用ldap or ad中指定的group里的用戶進(jìn)行登錄認(rèn)證。希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持VEVB武林網(wǎng)。


注:相關(guān)教程知識(shí)閱讀請(qǐng)移步到python教程頻道。
發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 西林县| 望奎县| 隆昌县| 温泉县| 平阴县| 喜德县| 霸州市| 长海县| 蒙城县| 安远县| 双城市| 陇南市| 方正县| 兴国县| 林口县| 江口县| 溧水县| 怀仁县| 普陀区| 雅江县| 元朗区| 天祝| 淮滨县| 深圳市| 长治市| 陇川县| 赤水市| 苍梧县| 诏安县| 迁西县| 衡阳县| 石狮市| 富锦市| 进贤县| 南丹县| 五台县| 明水县| 福海县| 定西市| 家居| 同江市|