我目前正在为SharePoint 2010开发新功能。除了部署我的功能外,我还想在SharePoint应用程序web.config中的<appSettings/>
部分添加一些设置。
我在MSDN上找到了有关在部署期间添加补充.config文件的一些信息,但我无法使其工作。这种方法对我来说似乎是最干净的,因为我可以将所有更改放在一个文件中,并将其与我的应用程序的其余部分一起部署。
我已根据文档中的建议创建了一个webconfig.MyApp.xml
文件,并将其部署到<SharePoint 14 hive>\Config
文件夹,但我的更改未传播到我的应用程序web.config。
以下是我的补充配置文件中的示例代码段。
<?xml version="1.0" encoding="utf-8" ?>
<actions>
<add path="configuration/appSettings">
<add key="MyFeatureKey" value="MyFeatureValue" />
</add>
</actions>
我希望避免手动编辑web.config,因为在SharePoint维护期间这些更改很容易丢失等。
如果您对部署web.config更改的备用可维护方法有任何想法,我的耳朵是开放的。
更新
到目前为止给出的答案很棒,我相信它们会奏效。但是我正在寻找一种可以在我的单WSP
内打包并且无需任何额外步骤即可部署的解决方案。
答案 0 :(得分:5)
正如Russ和breischl所建议的那样,您可以使用SPWebApplication对象的WebConfigModifications属性。要将其与您的功能一起部署,请将您的代码放入功能接收器中。这样,您可以在安装该功能时自动进行web.config修改。
在功能接收器中,不要忘记在SPWebApplication对象上调用ApplyWebConfigModifications()属性。
您可以将功能和功能接收器组件打包在一个wsp包中。
答案 1 :(得分:3)
创建补充配置文件时,web.config修改不会自动合并,直到您拨打stsadm -o copyappbincontent
为止。
您也可以强制此命令通过FeatureReceiver
运行。
在探索反射器中的stsadm
工具后,我发现copyappbincontent
操作会调用SPWebApplication.WebService.ApplyApplicationContentToLocalServer()
'
public override void FeatureActivated(SPFeatureReceiverProperties properties)
{
var webApp = (SPWebApplication)properties.Feature.Parent;
webApp.WebService.ApplyApplicationContentToLocalServer();
}
支持 @Jason Weber 解决这个问题,但不幸的是,他将答案放在评论而不是问题中。
答案 2 :(得分:3)
关于未应用于web.config的补充文件:来自MSDN:“您可以通过运行copyappbincontent Stsadm命令行操作,追溯将更改应用于服务器的web.config文件。您必须运行部署中每个前端Web服务器上的操作。“
答案 3 :(得分:1)
将其放入名为AddWebConfigMods.ps1
的文件中Param ($weburl, $WebConfigModifications )
$url = New-Object System.Uri($webUrl)
[System.Reflection.Assembly]::LoadWithPartialName("Microsoft.SharePoint") | Out-Null
$webApp = [Microsoft.SharePoint.Administration.SPWebApplication]::Lookup($url)
#delete mods by the owners being added
$ownerstodelete = $WebConfigModifications | Group-Object owner | Select-Object Name
foreach($owner in $ownerstodelete)
{
$modstodelete = @()
foreach($mod in $webApp.WebConfigModifications)
{
if($mod.Owner -eq $owner.Name)
{
$modstodelete += $mod
}
}
Write-Host ("Deleting " + $modstodelete.Count + " mods for owner: " + $owner)
foreach($delmod in $modstodelete)
{
Write-Host (" + Deleting " + $delmod.Value)
$webApp.WebConfigModifications.Remove($delmod) | Out-Null
}
}
#this is where we start to add mods
$i = 0;
Write-Host ("Adding " + $WebConfigModifications.Count + " webconfig modifications to " + $weburl)
foreach($modEntry in $WebConfigModifications)
{
Write-Host (" + Adding " + $modEntry.Value)
$mod = New-Object Microsoft.SharePoint.Administration.SPWebConfigModification
$mod.Path = $modEntry.Path
$mod.Name = $modEntry.Name
$mod.Sequence = $i++
$mod.Owner = $modEntry.Owner
$mod.Type = $modEntry.Type
$mod.Value = $modEntry.Value
$webApp.WebConfigModifications.Add($mod)
}
$webApp.Update()
$webApp.WebService.ApplyWebConfigModifications()
然后使用你的配置创建一个csv文件
Name,Path,Owner,Type,Value
system.serviceModel,configuration,alinean-common,EnsureSection,<system.serviceModel/>
connectionStrings,configuration,alinean-common,EnsureSection,<connectionStrings />
appSettings,configuration,alinean-common,EnsureSection,<appSettings />
serviceHostingEnvironment,configuration/system.serviceModel,alinean-common,EnsureChildNode,<serviceHostingEnvironment aspNetCompatibilityEnabled='true'/>
然后在另一个ps1脚本中,理想情况下是用于部署解决方案的脚本,导入csv配置选项并调用在第一个代码块中创建的函数:
#read config mods from CSVs
$mods = Import-CSV .\config\admin-common.webconfigmods.csv
Write-Host "Applying configuration modifications"
#add web config mods to sharepoint using powershell script
&.\AddWebConfigMods "[sharepoint site url]" $mods
&stsadm -o execadmsvcjobs
答案 4 :(得分:0)
我相信this会帮助你。使用WebConfigModifications会被SharePoint记住,并自动写入物理web.config文件,因此可以轻松地跨多个部署的站点进行维护。
答案 5 :(得分:0)
Russ是正确的,您需要使用WebConfigModifications。 Here是另一种只使用普通代码的资源。