返回顶部
首页 > 资讯 > 数据库 >Powershell管理系列(四十)PowerShell查询
  • 297
分享到

Powershell管理系列(四十)PowerShell查询

2024-04-02 19:04:59 297人浏览 安东尼
摘要

-----提供AD\Exchange\Lync\Sharepoint\CRM\SC\O365等微软产品实施及外包,QQ:185426445.电话18666943750需求:根据要求对集团AD域及下属3个子域

-----提供AD\Exchange\Lync\Sharepoint\CRM\SC\O365等微软产品实施及外包,QQ:185426445.电话18666943750

需求:根据要求对集团AD域及下属3个子域的所有AD账号进行统计,查询所有定的账号,解锁,并每天早上发送邮件到指向邮箱。(之前三十九的基础上略作调整,只发一封邮件即可)

Remove-Item C:\get_locked_user\ -Recurse -Force
if(!(test-path C:\get_locked_user)) {New-Item C:\get_locked_user -type directory}
Import-Module activedirectory
$yuntcloud_Lockeduser=Search-ADAccount -LockedOut -SearcHBase "dc=yuntcloud,dc=com" -server dc01|select name,saMaccountname
$aaa_Lockeduser=Search-ADAccount -LockedOut -SearchBase "dc=aaa,dc=yuntcloud,dc=com" -server aaaDC1|select name,samaccountname
$bbb_Lockeduser=Search-ADAccount -LockedOut -SearchBase "dc=bbb,dc=yuntcloud,dc=com" -server bbbdc1|select name,samaccountname
$ccc_Lockeduser=Search-ADAccount -LockedOut -SearchBase "dc=ccc,dc=yuntcloud,dc=com" -server cccDC1|select name,samaccountname
#send email
$UserName = "test01@yuntcloud.com"      #定义管理员账户名称
$PassWord = ConvertTo-SecureString "Anvf20170708" -AsPlainText –Force
$cred = New-Object System.Management.Automation.PSCredential($UserName,$Password)
$nFrom="test01@yuntcloud.com"
$nTo="zhouping@yuntcloud.com"
$lockeduser=@()
#Unlock yuntcloud Locked user
if ([string]::IsNullOrEmpty($($yuntcloud_Lockeduser|%{$_.name})))
{
Write-Host "yuntcloud no locked user"
Start-Sleep 5
Set-Content C:\get_locked_user\locked.txt -Value "yuntcloud no locked user"
#Send-MailMessage -From $nFrom -To $nTo -Subject "yuntcloud no locked user" -Body "yuntcloud no locked user" -Credential $cred -SmtpServer "mail.yuntcloud.com" -Encoding ([System.Text.Encoding]::UTF8)
}
else
{
Write-Host "yuntcloud Locked user"
foreach($i in $yuntcloud_Lockeduser)
{
Write-Host $i.name
$lockeduser+=$i
}
Start-Sleep 5
Search-ADAccount -LockedOut -SearchBase "dc=yuntcloud,dc=com" -server dc01 |Unlock-ADAccount
Write-Host "yuntcloud all locked account were unlocked"
$lockeduser |Export-Csv -Path C:\get_locked_user\yuntcloud_lockeduser.csv -NoTypeInfORMation -Encoding utf8 
add-Content C:\get_locked_user\locked.txt -Value "yuntcloud Locked user"
add-Content C:\get_locked_user\locked.txt -Value $($yuntcloud_Lockeduser|%{$_.name})
#Send-MailMessage -From $nfrom -To $nto -Subject "yuntcloud locked user" -Body "yuntcloud locked user" -Attachments "C:\get_locked_user\yuntcloud_lockeduser.csv" -Credential $cred -SmtpServer mail.yuntcloud.com -Encoding ([System.Text.Encoding]::UTF8) 
Start-Sleep 3
}
#Unlock aaa.yuntcloud.com Locked user
$lockeduser=@()
if ([string]::IsNullOrEmpty($($aaa_Lockeduser|%{$_.name})))
{
Write-Host "aaa no locked user"
Start-Sleep 5
add-Content C:\get_locked_user\locked.txt -Value "aaa no locked user"
#Send-MailMessage -From $nfrom -To $nto -Subject "aaa no locked user" -Body "aaa no locked user" -Credential $cred -SmtpServer mail.yuntcloud.com -Encoding ([System.Text.Encoding]::UTF8)
}
else
{
Write-Host "aaa Locked user"
foreach($i in $aaa_Lockeduser)
{
Write-Host $i.name
$lockeduser+=$i
}
Start-Sleep 5
Search-ADAccount -LockedOut -SearchBase "dc=aaa,dc=yuntcloud,dc=com" -server aaaDC1 |Unlock-ADAccount
Write-Host "aaa all locked account were unlocked" 
$lockeduser |Export-Csv -Path C:\get_locked_user\aaa_lockeduser.csv -NoTypeInformation -Encoding utf8
add-Content C:\get_locked_user\locked.txt -Value "aaa Locked user"
add-Content C:\get_locked_user\locked.txt -Value $($aaa_Lockeduser|%{$_.name})
#Send-MailMessage -From $nfrom -To $nto -Subject "aaa locked user" -Body "aaa locked user" -Attachments "C:\get_locked_user\aaa_lockeduser.csv" -Credential $cred -SmtpServer mail.yuntcloud.com -Encoding ([System.Text.Encoding]::UTF8) 
Start-Sleep 3
}
#Unlock bbb.yuntcloud.com Locked user
$lockeduser=@()
if ([string]::IsNullOrEmpty($($bbb_Lockeduser|%{$_.name})))
{
Write-Host "bbb no locked user"
Start-Sleep 5
add-Content C:\get_locked_user\locked.txt -Value "bbb no locked user"
#Send-MailMessage -From $nfrom -To $nto -Subject "bbb no locked user" -Body "bbb no locked user" -Credential $cred -SmtpServer mail.yuntcloud.com -Encoding ([System.Text.Encoding]::UTF8)
}
else
{
Write-Host "bbb Locked user"
foreach($i in $bbb_Lockeduser)
{
Write-Host $i.name
$lockeduser+=$i
}
Start-Sleep 5
Search-ADAccount -LockedOut -SearchBase "dc=bbb,dc=yuntcloud,dc=com" -server bbbdc1 |Unlock-ADAccount
Write-Host "bbb all locked account were unlocked" 
$lockeduser |Export-Csv -Path C:\get_locked_user\bbb_lockeduser.csv -NoTypeInformation -Encoding utf8 
add-Content C:\get_locked_user\locked.txt -Value "bbb Locked user"
add-Content C:\get_locked_user\locked.txt -Value $($bbb_Lockeduser|%{$_.name})
#Send-MailMessage -From $nfrom -To $nto -Subject "bbb locked user" -Body "bbb locked user" -Attachments "C:\get_locked_user\bbb_lockeduser.csv" -Credential $cred -SmtpServer mail.yuntcloud.com -Encoding ([System.Text.Encoding]::UTF8) 
Start-Sleep 3
}
#Unlock ccc.yuntcloud.com Locked user
$lockeduser=@()
if ([string]::IsNullOrEmpty($($ccc_Lockeduser|%{$_.name})))
{
Write-Host "ccc no locked user"
Start-Sleep 5
add-Content C:\get_locked_user\locked.txt -Value "ccc no locked user"
#Send-MailMessage -From $nfrom -To $nto -Subject "ccc no locked user" -Body "ccc no locked user" -Credential $cred -SmtpServer mail.yuntcloud.com -Encoding ([System.Text.Encoding]::UTF8)
}
else
{
Write-Host "ccc Locked user"
foreach($i in $ccc_Lockeduser)
{
Write-Host $i.name
$lockeduser+=$i
}
Start-Sleep 5
Search-ADAccount -LockedOut -SearchBase "dc=ccc,dc=yuntcloud,dc=com" -server cccDC1 |Unlock-ADAccount
Write-Host "ccc all locked account were unlocked" 
$lockeduser |Export-Csv -Path C:\get_locked_user\ccc_lockeduser.csv -NoTypeInformation -Encoding utf8 
add-Content C:\get_locked_user\locked.txt -Value "ccc Locked user"
add-Content C:\get_locked_user\locked.txt -Value $($ccc_Lockeduser|%{$_.name})
#Send-MailMessage -From $nfrom -To $nto -Subject "ccc locked user" -Body "ccc locked user" -Attachments "C:\get_locked_user\ccc_lockeduser.csv" -Credential $cred -SmtpServer mail.yuntcloud.com -Encoding ([System.Text.Encoding]::UTF8) 
Start-Sleep 3
}
$body=get-Content C:\get_locked_user\locked.txt|Out-String
if (((Test-Path C:\get_locked_user\yuntcloud_lockeduser.csv) -eq $true) -and  ((Test-Path C:\get_locked_user\aaa_lockeduser.csv) -eq $false) -and ((Test-Path C:\get_locked_user\bbb_lockeduser.csv) -eq $false) -and ((Test-Path C:\get_locked_user\ccc_lockeduser.csv) -eq $false)) 
{
Send-MailMessage -From $nfrom -To $nto -Subject "yuntcloud 4 domains all locked user information total" -Body $body -Attachments "C:\get_locked_user\yuntcloud_lockeduser.csv" -Credential $cred -SmtpServer mail.yuntcloud.com -Encoding ([System.Text.Encoding]::UTF8) 
}
elseif (((Test-Path C:\get_locked_user\yuntcloud_lockeduser.csv) -eq $true) -and  ((Test-Path C:\get_locked_user\aaa_lockeduser.csv) -eq $true) -and ((Test-Path C:\get_locked_user\bbb_lockeduser.csv) -eq $false) -and ((Test-Path C:\get_locked_user\ccc_lockeduser.csv) -eq $false)) 
{
Send-MailMessage -From $nfrom -To $nto -Subject "yuntcloud 4 domains all locked user information total" -Body $body -Attachments "C:\get_locked_user\yuntcloud_lockeduser.csv","C:\get_locked_user\aaa_lockeduser.csv" -Credential $cred -SmtpServer mail.yuntcloud.com -Encoding ([System.Text.Encoding]::UTF8) 
}
elseif (((Test-Path C:\get_locked_user\yuntcloud_lockeduser.csv) -eq $true) -and  ((Test-Path C:\get_locked_user\aaa_lockeduser.csv) -eq $true) -and ((Test-Path C:\get_locked_user\bbb_lockeduser.csv) -eq $true) -and ((Test-Path C:\get_locked_user\ccc_lockeduser.csv) -eq $false)) 
{
Send-MailMessage -From $nfrom -To $nto -Subject "yuntcloud 4 domains all locked user information total" -Body $body -Attachments "C:\get_locked_user\yuntcloud_lockeduser.csv","C:\get_locked_user\aaa_lockeduser.csv","C:\get_locked_user\bbb_lockeduser.csv" -Credential $cred -SmtpServer mail.yuntcloud.com -Encoding ([System.Text.Encoding]::UTF8) 
}
elseif (((Test-Path C:\get_locked_user\yuntcloud_lockeduser.csv) -eq $true) -and  ((Test-Path C:\get_locked_user\aaa_lockeduser.csv) -eq $true) -and ((Test-Path C:\get_locked_user\bbb_lockeduser.csv) -eq $true) -and ((Test-Path C:\get_locked_user\ccc_lockeduser.csv) -eq $true)) 
{
Send-MailMessage -From $nfrom -To $nto -Subject "yuntcloud 4 domains all locked user information total" -Body $body -Attachments "C:\get_locked_user\yuntcloud_lockeduser.csv","C:\get_locked_user\aaa_lockeduser.csv","C:\get_locked_user\bbb_lockeduser.csv","C:\get_locked_user\ccc_lockeduser.csv" -Credential $cred -SmtpServer mail.yuntcloud.com -Encoding ([System.Text.Encoding]::UTF8) 
}
else
{
Send-MailMessage -From $nfrom -To $nto -Subject "yuntcloud 4 domains all locked user information total" -Body $body -Credential $cred -SmtpServer mail.yuntcloud.com -Encoding ([System.Text.Encoding]::UTF8) 
}



您可能感兴趣的文档:

--结束END--

本文标题: Powershell管理系列(四十)PowerShell查询

本文链接: https://lsjlt.com/news/41381.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作