上一篇博文中,我们利用Excel的函数工具,很方便的一次性导入AD用户账户,现在我的AD中用户账户已存在,要为用户启用我们 的Exchange邮箱,该怎么做呢?上千用户挨个启用?其实可通过下面两种方法来批量启用用户邮箱,省时省力,下面就看看怎么做。。。。其实网上有很多 方法,这里只不过是进一步整理罢了。。。。

第一种

1、 获取OU Beijing(包含子OU)下所有的user类型账户

get-user –OrganizationalUnit Beijing | where-object{$_.RecipientType –eq “User”}

2、 获取OU Beijing(包含子OU)下所有的user类型账户然后启动他们的邮箱

get-user –OrganizationalUnit Beijing | where-object{$_.RecipientType –eq “User”} | Enable-Mailbox –Database “MailboxDatabase03” | get-mailbox | select name,windowsemailaddress,database

说明:“MailboxDatabase03” 是邮箱服务器上的数据库名称

注:红框中显示有乱码,原因是我们的AD账户显示名称为中文,后续处理乱码问题。

3、 为某一个OU单独启用邮箱

获取OU Beijing的子OU BD下所有的user类型账户,然后启动他们的邮箱

get-user –OrganizationalUnit BD | where-object{$_.RecipientType –eq “User” } | Enable-Mailbox –Database “MailboxDatabase03” | get-mailbox | select name,windowsemailaddress,database

 

 

4、 对于OU中为中文的用户,启用邮箱后,别名显示为乱码。

解决方法如下:

将下列内容copy到一个记事本中,并把这个文件存为alias.ps1文件

$list=Get-Mailbox

ForEach ($item in $list)

{

$user=Get-User $item

$sam=$user.SAMAccountName

Set-Mailbox $item –Alias "$sam"

}

注:$list=Get-Mailbox代表邮箱变量。

$item代表每个邮箱的属性变量。

$sam=$user.SAMAccountName代表每个用户的登录名变量

把alias.ps1文件保存到Exchange 2010 C盘目录下。然后打开输入:EMS

完成后乱码问题解决如下图:

可以看到所有用户邮箱的别名都改成了登录名。

据说这种方法处理乱码问题不太可靠,当在企业生产环境中使用这种方法处理超过6000用户邮箱时,不管执行多少次这个脚本文件都不起作用,用户邮箱的别名还是显示乱码。由于我处理的用户少于6000,所以没法验证真实性。不过遇到此问题时推荐使用第二种方法。

第二种方法

命令示例:

function NewMailUser

{

Enable-Mailbox -Identity ($_.split(","))[0] -Alias ($_.split(","))[1]

}

gc mb.csv | foreach {NewMailUser}

其中“function”为整个脚本定义函数,“NewMailUser”为定义的函数

大括号中的为启用邮箱Powershell 命令,“($_.split(","))[0]”代表调用CSV 文本文件内编号为0 的

的列,分隔符为逗号

其中“Gc mb.csv”代表被调用的CSV 文件(需要完整路径)

管道符后的“foreach ”为批量执行函数“NewMailUser”直到CSV 文件行尾

mb.csv的内容格式如下:

 

 

其中第一列为登录名,第二列为别名,两列可相同也可不同。

将命令内容copy到一个记事本中,并把这个文件存为enable-mailbox.ps1文件。把enable-mailbox.ps1文件保存到Exchange 2010 C盘目录下。然后打开输入:EMS

 

 

可以看到使用这种方法来批量启用用户邮箱都显示正常,并且用户邮箱会自动分配到Exchange 2010 邮箱服务器的Mailbox里面。

本文出自 “” 博客,请务必保留此出处