1200字范文,内容丰富有趣,写作的好帮手!
1200字范文 > PowerShell 批量禁用AD账号并记录

PowerShell 批量禁用AD账号并记录

时间:2018-12-31 17:27:26

相关推荐

PowerShell 批量禁用AD账号并记录

因原始版本包含AD组织信息,以下为删改版本,仅做个人备忘

较好判断禁用账号是否重名,避免禁错用户 记录对用户操作的日志,删除组,移动OU,修改备注等

Write-Host @"## name.csv 存放要禁用的账户 中文名# # log.txt 详细记录了针对用户执行的每一个执行操作(改Description, 删除每一个组, 移动等等)## 请认真阅读黄色警告,对其中忽略处理的用户,进行手动处理#"@pause# 调试过程设置该参数不实际执行,只提示# 要使用,请设置注释掉该行并新增一行# $needWhatIf = "-WhatIf"$needWhatIf = ""# 每执行一个操作都提示确认# 要取消,请设置注释掉该行并新增一行# $needConfirm = ""$needConfirm = "-Confirm"$suffix = "{0} {1}" -f $needWhatIf, $needConfirm$baseDN = "DC=test,DC=com"$resigningOU = "OU=yourResigningOU,DC=test,DC=com"# $cmd 传入要执行的命令字符串# 执行命令并记录命令日志和错误日志function logAndExe($cmd) {$cmd | Tee-Object log.txt -AppendInvoke-Expression $cmdif( -not $?){$Error[0] | Tee-Object log.txt -Append}}# $sam 传入用户的SamAccountName# 搜索用户所属的组,并剔除掉‘Domain Users’# 返回 组 的字符串列表 [group1, group2, .....]function search_user_group($sam){$groups = Get-ADPrincipalGroupMembership -Identity $sam$group_list = New-Object System.Collections.ArrayListforeach($g in $groups){if($g.name -ne 'Domain Users'){$group_list.Add($g) | Out-Null}}return $group_list}# 开始执行主逻辑Start-Process -Wait notepad -ArgumentList .\name.csv$userList = Import-Csv 'name.csv' -Encoding Default$samList = New-Object System.Collections.ArrayList$d = Get-Date"`r`n$d:开始导入用户:`r`n" | Tee-Object -Append "log.txt" | Write-Hostforeach($u in $userList){# $block_str = "(Name -eq '{0}') -and (Mobile -eq '{1}')" -f $u.Name, $u.Mobile$u.Name = $u.Name.TrimEnd()# 用户可能有重名后缀,完全限定加上’+‘,比如张三,张三01,则张三+完全限定if($u.Name.EndsWith("+")){$u.Name = $u.Name.TrimEnd("+")$block_str = "Name -eq ""{0}""" -f $u.Name}else{$block_str = "Name -like ""{0}*""" -f $u.Name}$block = [scriptblock]::Create($block_str) $tmp = Get-ADUser -Filter $block -SearchBase $baseDNif($tmp -eq $null){"在""$baseDN""下找不到用户: $($u.Name) ,因此忽略,请确认" | Tee-Object -Append "log.txt" | Write-Warningcontinue}# 如果用户姓名有类似,进一步筛选# 如: 张三 # 张三01将会给出警告,张三三不会给出警告# 假定 给出的是 张三01, 不会搜索到重复elseif($tmp.GetType().Name -eq "Object[]"){$tmp2 = $tmp | Where-Object {($_.Name -eq $u.Name ) -or $_.Name.Contains($u.Name+“0”)}if($tmp2.GetType().Name -eq "Object[]"){# 两个以上才会是Object[], 结果至少有一个,因为 $_.Name -eq $u.Name"该用户账号: $($u.Name) 存在重名,因此忽略,请确认后填写完整名,如:张三01!`r`n如果用户为张三,而还有其他用户张三01等,完全限定张三请填写 ""张三+""" | Tee-Object -Append "log.txt" | Write-Warning"-----------------------------" | Tee-Object -Append "log.txt" | Write-Warningforeach($t in $tmp2){$t.Name | Tee-Object -Append "log.txt" | Write-Warning}"-----------------------------" | Tee-Object -Append "log.txt" | Write-Warning# 警告后,跳过添加,继续处理下一个用户continue}else{# 筛选后只有一个,则继续加入到待处理列表if($tmp2.Name -ne $u.Name){"在""$baseDN""下找到用户: {0} 与name.csv中的用户: {1} 不完全匹配,,因此忽略" -f $tmp2.Name, $u.Name | Tee-Object -Append "log.txt" | Write-Warningcontinue}$tmp = $tmp2}}elseif($tmp.Name -ne $u.Name){"在""$baseDN""下找不到用户: $($u.Name) ,因此忽略,请确认" | Tee-Object -Append "log.txt" | Write-Warningcontinue}$samList.Add($tmp) | Out-Null}# 对列表中用户执行移动,剔除组,改名操作foreach($u in $samList){$d = Get-Date"$d:开始处理用户:$($u.Name)`r`n" | Tee-Object -Append "log.txt" | Write-Warning# 如果不同部门人员离职需要放到不同OU,可增加函数detect_ou判断# $ou = detect_ou($u.DistinguishedName)# 根据上面函数查找OU,没找到目标OU将不予处理,并记录下日志$ou = $resigningOUif($ou -ne $false){# 步骤1: 先改用户描述$_desc = Get-ADUser -Identity $u.SamAccountName -Properties Description$desc = $_desc.Description$cmd = @"Set-ADUser -Identity {0} -Description {1} {2}"@ -f $u.SamAccountName, ("`"Disabled {0} {1}`"" -f $d.ToString("yyyy/M/dd"), $desc), $suffixlogAndExe($cmd)# 步骤2: 剔除用户所属的组foreach($g in search_user_group($u.SamAccountName)){$cmd = @"Remove-ADGroupMember -Identity "{0}" -Members "{1}" {2}"@ -f $g, $u.SamAccountName, $suffixlogAndExe($cmd)}# 步骤3: 禁用该用户$cmd = @"Disable-ADAccount -Identity {0} {1}"@ -f $u.SamAccountName, $suffixlogAndExe($cmd)# 步骤4: 移动该用户到对应的OU$cmd = @"Move-ADObject -Identity "{0}" -TargetPath "{1}" {2}"@ -f $u.DistinguishedName, $ou, $suffixlogAndExe($cmd)}}Pause

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。