Ich möchte PowerShell als Teil unseres automatisierten Build-Prozesses verwenden, um eine App.config-Datei während der Bereitstellung in unserer Testumgebung zu aktualisieren. Wie kann ich das machen?Wie lese/schreibe ich App.config-Einstellungen mit PowerShell?
Antwort
Angesichts dieser Probe App.config: C: \ Sample \ App.config:
<?xml version="1.0" encoding="utf-8" ?>
<configuration>
<connectionStrings>
<add name="dbConnectionString"
connectionString="Data Source=(local);Initial Catalog=Northwind;Integrated Security=True"/>
</connectionStrings>
</configuration>
Das folgende Skript, C: \ Sample \ Script.ps1, wird gelesen und eine Einstellung schreiben:
# get the directory of this script file
$currentDirectory = [IO.Path]::GetDirectoryName($MyInvocation.MyCommand.Path)
# get the full path and file name of the App.config file in the same directory as this script
$appConfigFile = [IO.Path]::Combine($currentDirectory, 'App.config')
# initialize the xml object
$appConfig = New-Object XML
# load the config file as an xml object
$appConfig.Load($appConfigFile)
# iterate over the settings
foreach($connectionString in $appConfig.configuration.connectionStrings.add)
{
# write the name to the console
'name: ' + $connectionString.name
# write the connection string to the console
'connectionString: ' + $connectionString.connectionString
# change the connection string
$connectionString.connectionString = 'Data Source=(local);Initial Catalog=MyDB;Integrated Security=True'
}
# save the updated config file
$appConfig.Save($appConfigFile)
Führen Sie das Skript:
PS C:\Sample> .\Script.ps1
Ausgang:
name: dbConnectionString
connectionString: Data Source=(local);Initial Catalog=Northwind;Integrated Security=True
Aktualisiert C: \ Sample \ App.config:
<?xml version="1.0" encoding="utf-8"?>
<configuration>
<connectionStrings>
<add name="dbConnectionString"
connectionString="Data Source=(local);Initial Catalog=MyDB;Integrated Security=True" />
</connectionStrings>
</configuration>
Der Code kann viel kürzer sein (basierend auf Robins app.config):
$appConfig = [xml](cat D:\temp\App.config)
$appConfig.configuration.connectionStrings.add | foreach {
$_.connectionString = "your connection string"
}
$appConfig.Save("D:\temp\App.config")
Cool, danke für den Tipp. Ich wusste nicht, dass ich diese Syntax verwenden könnte. – Robin
Wenn wir nach kurzen streben, sollte foreach als% geschrieben werden. –
Sehr nützliche Antwort danke @ Robin – 101V