这几个月一直在帮客户改需求,部署。我已经心力憔悴,经过一段时间的摸索,我对用PowerShell实现自动化部署也有了一些心得,比如说利用PowerShell导出导入AD中的User。在基于SharePoint平台开发时,利用AD来进行人员的管理,一般会建组织单元(OrganizationalUnit)来对用户进行管理。当最终部署到客户的服务器上时,怎样把本地AD中的用户数据同步到服务器上呢,要知道如果手动输入人员是一件麻烦的事。幸运的事,PowerShell可以帮我们解决这个麻烦的问题。
<#
.Description
从AD中的组织单元里以csv格式导出人员数据
.Example
.\userInfoExport.ps1 -ou "Sources" -dc "xcgov" -path "c:\temp\xxx.csv"
#>
param([string]$ou,[string]$dc,[string]$path)
if(!(Get-PSSnapin| Where-Object{$_.Name -eq "Microsoft.SharePoint.PowerShell"})){
Add-PSSnapin "Microsoft.SharePoint.PowerShell"
}
$searchBase='OU='+$ou+',Dc='+$dc+',Dc=com'
Get-ADUser -LDAPFilter '(name=*)' -SearchBase $searchBase |Select GivenName,SurName,Name,SamAccountName|Export-Csv $path -NoTypeInformation -Encoding UTF8
<#
.Description
从指定的csv格式中导入人员信息
.Example
.\importUserInfo.ps1 -ou "Hello" -dc "Kingdom" -sourcePath "C:\temp\xxx.csv"
#>
param([string]$ou,[string]$dc,[string]$sourcePath)
if(!(Get-PSSnapin|Where-Object{$_.Name -eq "Microsoft.SharePoint.PowerShell"})){
Add-PSSnapin "Microsoft.SharePoint.PowerShell"
}
#创建组织单元#
[string]$path='OU='+$ou+',Dc='+$dc+',Dc=Com'
if(![adsi]::Exists("LDAP://$path")){
$domainObj=[adsi]("LDAP://Dc="+$dc+",Dc=com")
$domainOU=$domainObj.Create("OrganizationalUnit","OU="+$ou)
$domainOU.SetInfo()
}
$users=Import-Csv -Path $sourcePath
foreach($user in $users){
$givenName=$user.GivenName
$surName=$user.SurName
$name=$user.Name
$samAccountName=$user.SamAccountName
$userPrincipalName=$samAccountName+'@'+$dc+'.com'
$password=$user.Password
#创建AD User#
New-ADUser -Name $name -SamAccountName $samAccountName -UserPrincipalName $userPrincipalName -DisplayName $name -GivenName $givenName -Surname $surName -AccountPassword (ConvertTo-SecureString $password -AsPlainText -Force) -PasswordNeverExpires $true -Enabled $true -Path $path
}
Write-Host "导入成功"
导入成功后,如下所示:
这篇博客对PowerShell自动化部署SharePoint开了个头,下一篇随笔打算写写利用SPSD进行自动化部署SharePoint,包括利用PowerShell创建权限组,分配权限,设置母版页等。