PowerShell 替換 Office365 用戶主郵件地址

最近公司一個部門改組,所有人的主郵件都需要改成新的後綴。我們使用的是Office365,用戶信息都是通過DirSync同步本地的AD到雲上,因此不能直接使用Exchange的命令修改,而需要在本地的AD上改完之後,再同步到Azure AD上。


基本思路,修改用戶和組的proxyaddresses參數,這個就是一大串字符串;大寫的SMTP表示主地址,小寫的代表別名。 修改之後同步的O365就行了。

wKiom1cr2fOyorjPAABZMSh53cU958.png


這些用戶的新的郵件地址我之前已經通過以下的方式添加爲別名了,因此只需要在指定時間和現在的主地址交換一下就行了。 這些改動都可以通過 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



發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章