最近公司一個部門改組,所有人的主郵件都需要改成新的後綴。我們使用的是Office365,用戶信息都是通過DirSync同步本地的AD到雲上,因此不能直接使用Exchange的命令修改,而需要在本地的AD上改完之後,再同步到Azure AD上。
基本思路,修改用戶和組的proxyaddresses參數,這個就是一大串字符串;大寫的SMTP表示主地址,小寫的代表別名。 修改之後同步的O365就行了。
這些用戶的新的郵件地址我之前已經通過以下的方式添加爲別名了,因此只需要在指定時間和現在的主地址交換一下就行了。 這些改動都可以通過 ADSI Edit的界面來查看屬性。
set-aduser user -add @{proxyaddresses="smtp:XXXXXX"}
交換的代碼如下
#首先我得獲取一個名單,這個名單一部分是現有AD裏面的,還有一部分是通過Excel發給我的 $result=@() $users=get-aduser -Filter {proxyaddresses -like "*old.com.au*"} -Properties proxyaddresses -SearchBase "ou=old,ou=melbourne,dc=test,dc=com,dc=au" foreach( $user in $users){ foreach ($address in $user.proxyAddresses) { if($address -like "*@old.com.au*"){ $rappaddress=$address.Substring(5) break; } } $temp=[pscustomobject]@{"Full Name"=$user.Name;"Current Email"=$rappaddress} $result+=$temp } #$result $a=import-csv C:\temp\newuserList.csv | select "Full Name", "Current Email" $oo=$result+$a #獲取名單以後,對於名單當前的用戶 我希望獲取他們的主郵件地址,於是寫了個function function Get-PrimarySMTP(){ [CmdletBinding()] Param ( # Param1 help description [Parameter(Mandatory=$true, ValueFromPipelineByPropertyName=$true, Position=0)] [string[]] $users ) $pp=$null $pp=@{'name'=$null;'primarysmtp'=$null} $obj=New-Object -TypeName psobject -Property $pp $result=@() foreach($user in $users){ $info=get-aduser -Filter {name -eq $user} -Properties proxyaddresses $primarySMTPAddress = "" foreach ($address in $info.proxyAddresses) { if (($address.Length -gt 5) -and ($address.SubString(0,5) -ceq 'SMTP:') ) { $primarySMTPAddress = $address.SubString(5) break } } $objtemp=$obj | select * $objtemp.name=$info.Name $objtemp.primarysmtp=$primarySMTPAddress $result+=$objtemp } $result } #執行看看 當前用戶的主SMTP地址 Get-PrimarySMTP -users $users #對於每一個用戶的每一個地址進行循環,如果是大寫的那就變成小寫,如果小寫的剛好是我需要的那個,那就改成大寫 $users=$oo | sort "full Name"|select -ExpandProperty "Full Name" foreach($user in $users){ $info=get-aduser -Filter {name -eq $user} -Properties proxyaddresses $filter="smtp:"+$info.GivenName+"."+$info.Surname+"@new.com" $new=@() foreach($address in $info.proxyaddresses){ $temp=$address if($address -clike "SMTP*"){ $temp=$address.ToLower() } if($address -like $filter){ $temp=$address.Substring(0,4).toupper()+$address.Substring(4).tolower() } $new+=$temp } write-host "---------------------------" -ForegroundColor Cyan $new set-aduser $info.SamAccountName -Replace @{proxyaddresses=$new} -confirm } #然後同步一下DC repadmin /syncall syddc01 dc=omnicom,dc=com,dc=au /d /e /a #再看看新的的SMTP主地址 Get-PrimarySMTP -users $users #同步到O365 import-module dirsync Start-OnlineCoexistenceSync #通過Azure AD 模塊查詢O365的郵箱看看是否已經更新了 $users | get-mailbox | select name, primarysmtpaddress