0

我在 Powershell 中的脚本有问题...

我想将用户从 OU(父 OU:例如“IT”)转移到“子 OU”=>“用户”。(“IT”>“用户”)。

问题

$name = "CN=Michael Allen,OU=IT,DC=Adatum,DC=com" 
Move-ADObject "CN=Michael Allen,OU=IT,DC=Adatum,DC=com" -TargetPath "OU=IT,OU=Users,DC=Adatum,DC=com"
Move-ADObject : The operation could not be performed because the object's parent is either 
uninstantiated or deleted
At line:5 char:1
+ Move-ADObject "CN=Michael Allen,OU=IT,DC=Adatum,DC=com" -TargetPath "OU=IT,OU=Us ...
+ ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
    + CategoryInfo          : NotSpecified: (CN=Michael Allen,OU=IT,DC=Adatum,DC=com:ADObject) [Move-AD 
   Object], ADException
    + FullyQualifiedErrorId : ActiveDirectoryServer:8329,Microsoft.ActiveDirectory.Management.Commands. 
   MoveADObject

我的代码

$root = [ADSI]"LDAP://RootDSE"
$DOMAIN = $root.Get("rootDomainNamingContext")

#Informations serveur & domaine (Ex. : SERVER='LON-DC' / DOMAIN='DC=Adatum,DC=com')"
$SERVER = (Get-WmiObject Win32_ComputerSystem).Name
$root = [ADSI]"LDAP://RootDSE"
$DOMAIN = $root.Get("rootDomainNamingContext")

#Sous OU des OU parentes
$CHILD_OU1 = "Users"
$CHILD_OU2 = "Computers"
$CHILD_OU3 = "Groups"

#Pour chaque sous-OUs "Users", on récupère les utilisateurs des OU parent du fichier texte défini et on les transferts
foreach ($PARENT_OU in $OU_FILE) {
    #Récupération de la liste des utilisateurs de l'OU parente
    $users = Get-ADUser -Filter * -SearchBase "OU=$PARENT_OU,$DOMAIN"
    #Write-Host "Liste d'utilisateurs pour : $PARENT_OU : [$users]"

    #Pour chaque utilisateurs de la liste dans l'OU parente, on le transfert dans l'OU enfante "Users"
    foreach ($user in $users) {
    Write-Host "Utilisateur pour le transfert : $user"
    Write-Host "OU parente : $PARENT_OU"
    Write-Host "OU enfante : $CHILD_OU1"
    Move-ADObject -Identity "$user" -Server $SERVER -TargetPath "OU=$PARENT_OU,OU=$CHILD_OU1,$DOMAIN"
    }

}

我是法国人,我尝试了很多时间来编写这个脚本,但我无法理解... somone 可以帮助我吗?

谢谢。

4

2 回答 2

0

通常,当无法验证目标 OU 路径时会出现此错误,“用户”OU 是否已经存在于“IT”OU 中?另一种调试方法是在您的目标 OU 中创建一个临时用户,并将其 OU 位置与您的目标进行比较,以确保它们完全匹配。

于 2020-01-22T22:21:28.787 回答
0

谢谢大家的回答!但我发现了谁是“真的很愚蠢”的问题......

My Move-AdObject was :
Move-ADObject -Identity "$user" -Server $SERVER -TargetPath "OU=$PARENT_OU,OU=$CHILD_OU1,$DOMAIN"

它是:

我的 Move-AdObject 是:Move-ADObject -Identity "$user" -Server $SERVER -TargetPath " OU=$CHILD_OU1,OU=$PARENT_OU ,$DOMAIN"。

感谢您的回答,我注意到所有细节,这将对我有所帮助。

良好的延续:)

于 2020-01-23T10:21:56.097 回答