我正在编写一个程序来创建一个 AD 帐户并启用一个 Exchange 邮箱,我从中得到了一些奇怪的行为。
首先,虽然成功创建了AD用户,但是邮箱无法启用,因为“找不到MyPath/Mr. Example”。我认为这是因为 AD 服务器和 Exchange 服务器之间存在时间差(代码在 Exchange 服务器上运行)。虽然插入睡眠时间似乎可以解决这个问题,但还有其他可能我可能会丢失吗?
其次,我在 Powershell 使用的“红色错误文本”中收到此错误消息。似乎我的 try/catch 语句让错误溜走,这导致我的脚本错误地通知我任务已成功完成。如何强制在脚本中捕获错误而不是显示在控制台上?(我在测试期间以点源方式运行它,这就是我注意到这一点的方式。)
我已经在下面包含了相关部分。任何帮助表示赞赏!谢谢 =)
Import-Module ActiveDirectory
Add-PSSnapin Microsoft.Exchange.Management.Powershell.Admin
$errorLog = @()
$masterLog = @()
$time = Get-Date
New-ADUser -SamAccountName "example" -Name "Mr. Example" -Path "DC=MyPath" -Enabled 1 -Server ADServer
try{
Enable-Mailbox -Identity "MyPath/Mr. Example" -Alias "example" -Database "DatabaseName"
}
catch{
$myError = $Error[0]
$errorLog = $errorLog + "[$time] Error enabling mailbox for $fullName`: $myError"
}
if($errorLog.length -eq 0){
echo "An Active Directory account and Exchange mailbox for Mr. Example has been successfully created!"
}
else{
foreach($event in $errorLog){
$masterLog = $masterLog + $event
}
}