Не удалось найти объект «пользователь» в «Контроллере домена» - PullRequest
3 голосов
/ 06 марта 2020

Я создал сценарий PowerShell для сбора всех сведений о почтовых ящиках пользователей, таких как «PrimarySmtpAddress, Identity, displayname» в локальных серверах Exchange. Я пытаюсь запустить эту команду из powershell:

$UserNameInSmtpFormat = Get-Mailbox -Identity $User -ErrorAction Stop | Select PrimarySmtpAddress, Identity, displayname

Эта команда работает нормально (powershell.exe "c:\pstest\readUsers.ps1" 'Administrator@domain.com' 'Password' 'users.txt' 'http://Exchange/PowerShell/'), которая сохраняется как 'testok.cmd'

В этой команде я получаю ошибка: - (powershell.exe "c:\pstest\readUsers.ps1" 'User@domain.com' 'Password' 'users.txt' 'http://Exchange/PowerShell/') Это сохраняется как 'testproblem.cmd'

Я получаю приведенную ниже ошибку

Ошибка: - Когда я даю администратору тогда учетные данные учетной записи работают нормально, но когда я пытаюсь собрать то же самое с помощью обычных учетных данных «пользователя», я получаю ошибку ниже;

Операция не может быть выполнена, потому что объект 'user@domain.com' не найден в 'd c .Domain.com' .. Exception.Message

Ниже приведен сценарий

( #Constant Variables 
$Office365AdminUsername = $args[0]
$Office365AdminPassword = $args[1]
$UserNamesFile = $args[2]
$connectionUri = $args[3]   
#Main
Function Main {
#Remove all existing Powershell sessions
    Get-PSSession | Remove-PSSession
#Encrypt password for transmission to Office365
    $SecureOffice365Password = ConvertTo-SecureString -AsPlainText $Office365AdminPassword -Force
#Build credentials object
    $Office365Credentials  = New-Object System.Management.Automation.PSCredential $Office365AdminUsername, $SecureOffice365Password 
Write-Host  "Credentials object created"
#Create remote Powershell session
    $Session = New-PSSession -ConfigurationName Microsoft.Exchange -ConnectionUri $connectionUri -Credential $Office365credentials -Authentication Kerberos –AllowRedirection  
Write-Host  "Remote session established"
#Check for errors
if ($Session -eq $null){
    Write-Host  "Invalid creditials"
}else{
    Write-Host  "Login success"
    #Import the session
        Import-PSSession $Session
}
try {
    Write-Host  "SMTPADDRESS"

        Foreach($User in (get-content $UserNamesFile))
        { 
            Write-Host  "mailboxIdentity : $User"
            $UserNameInSmtpFormat =Get-Mailbox -Identity $User -ErrorAction Stop | Select PrimarySmtpAddress, Identity, displayname     

            $UserNameInSmtpFormat        
    }
    Write-Host  "ENDSMTPADDRESS"
} 
catch {
   write-host "EXCEPTION"
   write-host "`r`n $_.Exception.Message"
                                }
finally {
    Exit-PSSession
    Remove-PSSession $Session
                                }
}
# Start script
. Main  
)

1 Ответ

3 голосов
/ 11 марта 2020

Решением было «Права на роль», и оно решается путем предоставления того же самого пользователя, от которого я пытался получить данные почтового ящика. Я назначил пользователю роль «Получатель почты» на вкладке «Разрешения» в ECP.

Спасибо.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...