ladp3 获取属性_Ldap3库使用方法(四)

#!/usr/bin/env python

# -*- coding: utf-8 -*-

import json

from ldap3 import ALL_ATTRIBUTES

# 注意:ldap3库如果要使用tls(安全连接),需要ad服务先安装并配置好证书服务,才能通过tls连接,否则连接测试时会报LDAPSocketOpenError('unable to open socket'

# 如果是进行账号密码修改及账户激活时,会报错:“WILL_NOT_PERFORM”

from ldap3 import Connection, NTLM, Server

from ldap3 import MODIFY_REPLACE

server1 = Server("adtest.com", port=636, use_ssl=True, get_info=ALL, connect_timeout=5)

LDAP_SERVER_POOL = [server1]

SERVER_USER = 'adtest\\administrator'

SERVER_PASSWORD = "XXXXXXX"

class AD(object):

''' AD用户操作 '''

def __init__(self):

'''初始化'''

self.conn = Connection( #配置服务器连接参数

server=LDAP_SERVER_POOL,

auto_bind=True,

authentication=NTLM, #连接Windows AD需要配置此项

read_only=False, #禁止修改数据:True

user=SERVER_USER,#管理员账户

password=SERVER_PASSWORD,

)

self.leaved_base_dn = 'ou=Leaved,dc=adtest,dc=intra'#离职账户所在OU

self.active_base_dn = 'ou=测试部门,dc=adtest,dc=intra'#正式员工账户所在OU

self.search_filter = '(objectclass=user)'#只获取【用户】对象

self.ou_search_filter = '(objectclass=organizationalUnit)'#只获取【OU】对象

def update_obj(self, dn, attr):

'''更新员工 or 部门属性先比较每个属性值,是否和AD中的属性一致,不一样的记录,统一update注意:1. attr中dn属性写在最后2. 如果name属性不一样的话,需要先变更名字(实际是变更原始dn为新name的DN),后续继续操作update and move_objectUser 的 attr 照如下格式写:dn = "cn=test4,ou=IT组,dc=adtest,dc=com" #需要移动的User的原始路径{#updateUser需要更新的属性表"Sn": "李", # 姓"telephoneNumber": "12345678944","mobile": "12345678944","Displayname": "张三3","Manager":"CN=李四,OU=人事部,DC=adtest,DC=com",#需要使用用户的DN路径'DistinguishedName':"cn=张三,ou=IT组,dc=adtest,dc=com" #用户需要移动部门时,提供此属性,否则不提供}OU 的 attr 格式如下:dn = "ou=人事部,dc=adtest,dc=com" #更新前OU的原始路径attr = {'name':'人事部','managedBy':"CN=张三,OU=IT组,DC=adtest,DC=com",'DistinguishedName': "ou=人事部,dc=adtest,dc=com" # 更新后的部门完整路径}'''

changes_dic = {}

for k,v in attr.items():

if not self.conn.compare(dn=dn,attribute=k,value=v):

if k == "name":

res = self.__rename_obj(dn=dn,newname=attr['name']) # 改过名字后,DN就变了,这里调用重命名的方法

if res['description'] == "success":

if "CN" == dn[:2]:

dn = "cn=%s,%s" % (attr["name"], dn.split(",", 1)[1])

if "OU" == dn[:2]:

dn = "DN=%s,%s" % (attr["name"], dn.split(",", 1)[1])

if k == "DistinguishedName": # 如果属性里有“DistinguishedName”,表示需要移动User or OU

self.__move_object(dn=dn,new_dn=v) # 调用移动User or OU 的方法

changes_dic.update({k:[(MODIFY_REPLACE,[v])]})

self.conn.modify(dn=dn,changes=changes_dic)

return self.conn.result

def __rename_obj(self,dn,newname):

'''OU or User 重命名方法:param dn:需要修改的object的完整dn路径:param newname: 新的名字,User格式:"cn=新名字";OU格式:"OU=新名字":return:返回中有:'description': 'success', 表示操作成功{'result': 0, 'description': 'success', 'dn': '', 'message': '', 'referrals': None, 'type': 'modDNResponse'}'''

self.conn.modify_dn(dn,newname)

return self.conn.result

def compare_attr(self,dn,attr,value):

'''比较员工指定的某个属性'''

res = self.conn.compare(dn=dn,attribute=attr,value=value)

return res

def __move_object(self,dn,new_dn):

'''移动员工 or 部门到新部门'''

relative_dn,superou = new_dn.split(",",1)

res = self.conn.modify_dn(dn=dn,relative_dn=relative_dn,new_superior=superou)

return res

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/560931.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

两文本一图片android,Android富文本编辑器(二):图文混排以及图片上传处理

对于一个富文本编辑器来说,图文混排是最基本的功能。而从上一篇文章中我们知道图文混排需要使用ImageSpan。下面这段代码摘自我的RichEditText源码:/*** 添加图片* param filePath 图片文件路径*/public void addImage(String filePath) {SpannableStrin…

qt添加菜单纯代码_Qt Creator 插件开发(3):添加菜单项

本章我们将学习如何向 Qt Creator 的菜单栏添加内容。在上一章插件的基础之上,我们将尝试开发一个比较正式的插件——在菜单栏中可以看到,并且可以相应用户动作等。在我们开始之前,我们先来看看 Qt Creator 已有的菜单:Qt Creator…

android添加hidl,android hidl

1、定义.hal接口文件,如:在vendor/sprd/interface中新建目录hello,其中定义好hidl接口,如:1 package [email protected]1.0;23 interfaceIHello {45 helloWorld(string name) generates (stringresult);67 };2、利用hi…

震惊! Rightmost Digit 快速幂解决

题目 Given a positive integer N, you should output the most right digit of N^N. Input The input contains several test cases. The first line of the input is a single integer T which is the number of test cases. T test cases follow. Each test case conta…

rrpp协议如何修改_RRPP协议

产生背景在网络规划和实际组网应用中,大多采用环网来提供高可靠性。环网技术简单来说,就是将一些网络设备通过环的形状连接到一起,实现相互通信的一种技术。为了避免环网中产生广播风暴,最初采用了已被普遍应用的STP协议环路保护机…

android handler同步,android解决:使用多线程和Handler同步更新UI

如果运行时,可以看到滚动条由条慢慢变短,则说明程序成功了。截图如下,建议选择大点的文件做测试。main.xmlxmlns:android"http://schemas.android.com/apk/res/android"android:layout_height"wrap_content" android:id&…

hashmap hash冲突怎么解决_HashMap原理及冲突之简谈

了解HashMap原理对于日后的缓存机制多少有些认识。在网络中也有很多方面的帖子,但是很多都是轻描淡写,很少有把握的比较准确的信息,在这里试着不妨说解一二。对于HashMap主要以键值(key-value)的方式来体现,笼统的说就是采用key值…

html5把六张图片做成立方体,HTML5绘制在立方体上的几何曲线图形

CSS语言:CSSSCSS确定body {background: #222;width: 100vw;height: 100vh;overflow: hidden;-webkit-filter: blur(1px);filter: blur(1px);box-sizing: border-box;-webkit-perspective: 3000px;perspective: 3000px;}.cube {position: absolute;width: 250px;heig…

c语言中闰年 日期 天数 统计出在某个特定的年份中,出现了多少次既是13号又是星期五的情形

常识: 1、3、5、7、8、10、12月份,每个月31天。2月闰年有29天,非闰年28天其他月份,每月30天 闰年:一年有365天,闰年有366天,所谓闰年,即能被4整除且不能被100整除的年份&#xff0c…

java有啥区别 jsp_Java与JSP有什么区别

Java与JSP的区别有:1、Java是面向对象编程语言,而JSP是一个建立在Java基础上用于开发动态内容的web页面技术;2、Java负责逻辑业务处理,而JSP负责页面展现等等。【推荐课程:Java教程】JAVA是一种编程语言,可…

c++ stl 容器 迭代器 stl用法示例

1.基本概念 1.1容器概述 顺序容器 vector, deque,list关联容器 set, multiset, map, multimap容器适配器 stack, queue, priority_queue 1.1.1迭代器 用于指向顺序容器和关联容器中的元素迭代器用法和指针类似 有const 和非 const两种通过迭代器可以读取它指向的元素通过非…

python julian date_Python 的内嵌time模板翻译及说明

一、简介time模块提供各种操作时间的函数 说明:一般有两种表示时间的方式: 第一种是时间戳的方式(相对于1970.1.1 00:00:00以秒计算的偏移量),时间戳是惟一的 第二种以数组的形式表示即(struct_time),共有九个元素,分别表示,同一个时间戳的st…

html玫瑰花效果代码,html5渲染3D玫瑰花情人节礼物js特效代码

情人节马上就要到来了,这里给程序员前端设计师们献上一个,html5渲染而成的3D玫瑰花js效果,可以作为虚拟的情人节礼物送给自己的爱人。支持html5的浏览器查看。查看演示下载资源:16次 下载资源下载积分:20积分情人节玫瑰…

跳跃游戏(数组下标跳跃)

给定一个非负整数数组,假定你的初始位置为数组第一个下标。 数组中的每个元素代表你在那个位置能够跳跃的最大长度。 请确认你是否能够跳跃到数组的最后一个下标。 例如:A [2,3,1,1,4]A[2,3,1,1,4] 能够跳跃到最后一个下标,输出true&…

qc中的流程图怎么画_QC流程图参考

华北工控股份有限公司QC流程图样件试产量产文件编号:WI-MED-000FIC-G009版本:A0修改日期:客户:常规品机种:pcba适用工序:IQC/SMT/DIP/OQC/TEST/PACK审核:批准:检验方法检验频率记录担当负责人在制品完成品11确认型号、数量依送货单核对型号/数量仓库检查…

html 页面怎么加载富文本,UILabel加载html富文本

本文主要解决html标签之外文本属性设置当APP里面有搜索的需求的时候,产品可能会要求关键字显示特殊颜色或者字体。其中一种可能性是服务器返回的数据是带有html标签的字符串,那么该怎么解决?当标签之外的其他字体也需要设置不同格式&#xff…

python 打印皮卡丘_用python打印你的宠物小精灵吧

我们来通过一个有趣的例子开始编写我们的第一个python代码。本文涉及的python基础语法为:print输出函数,赋值,字符串print()print()是python的一个内置函数,用于打印输出,是最常见的一个函数之一。有些朋友可能对于打印…

最大子阵列

在一个数组中找出和最大的连续几个数。(至少包含一个数) 例如: 数组A[] [−2, 1, −3, 4, −1, 2, 1, −5, 4],则连续的子序列[4,−1,2,1]有最大的和6. 输入格式 第一行输入一个不超过1000的整数n。 第二行输入n个整数A[i]。…

html嵌入原始数据,如何用html和javascript显示原始图像数据?

我有一个ajax应用程序,PHP端将来自摄像头的未编码的原始图像数据发送到客户端javascript端.我想使用img或canvas标签通过html和javascript显示图像.图像数据是32 * 32无符号字符.我想做,无论达到我的目标(编码或其他所有),但我想在客户端做,因为我无法处理服务器端的任何其他操…

三值排序

排序是一种很频繁的计算任务。一个实际的例子是,当我们给某项竞赛的优胜者按金银铜牌排序的时候。在这个任务中可能的值只有三种1,2和3。我们用交换的方法把他排成升序的。 写一个程序计算出,计算出的一个包括1、2、3三种值的数字序列&#…