Problem
在asp.net web form或者asp.net mvc在從開發環境發布到測試、生產環境時,其數據庫環境、動態配置會有很大差別,特別是數據庫鏈接字符串。我們需要每次發布都去修改web.config嗎?
以數據庫連接為例,本地開發時的連接字符串為:
<connectionStrings> <add name="AvastinDP" connectionString="Data Source=.\SQLEXPRESS;Initial Catalog=AvastinDP;Integrated Security=True" providerName="System.Data.SqlClient" /> </connectionStrings>
測試服務器的數據庫連接為:
<connectionStrings> <add name="AvastinDP" connectionString="Data Source=devdbtest03\SQLEXPRESS;Initial Catalog=AvastinDP;Persist Security Info=True;User ID=[username];Password=[password]" providerName="System.Data.SqlClient" /> </connectionStrings>
生產環境的數據庫連接為:
<connectionStrings> <add name="AvastinDP" connectionString="Data Source=dbserversh001\SQL2008R2;Initial Catalog=AvastinDP;Persist Security Info=True;User ID=[username];;Password=[password]" providerName="System.Data.SqlClient" /> </connectionStrings>
Solution
在Visual Studio 2010的項目中,展開Web.Config我們會發現,還有Web.Debug.Config和Web.Release.Config,通過在其中添加相應的配置信息,可以在發布時,替換相應的Web.Config中的信息。
Discussion
在Web.Debug.Config中,有如下字符串
<!-- ... <connectionStrings> <add name="MyDB" connectionString="Data Source=ReleaseSQLServer;Initial Catalog=MyReleaseDB;Integrated Security=True" xdt:Transform="SetAttributes" xdt:Locator="Match(name)"/> </connectionStrings> -->
注意,Match(name)指在替換時匹配Name相同的字符串進行替換。於是我們將Web.Debug.Config修改為:
<connectionStrings> <add name="AvastinDP" connectionString="Data Source=.\SQLEXPRESS;Initial Catalog=AvastinDP;Integrated Security=True" providerName="System.Data.SqlClient" xdt:Transform="SetAttributes" xdt:Locator="Match(name)"/> </connectionStrings>
將Web.Release.Config修改為
<connectionStrings> <add name="AvastinDP" connectionString="Data Source=dbserversh001\SQL2008R2;Initial Catalog=AvastinDP;Persist Security Info=True;User ID=[username];;Password=[password]" providerName="System.Data.SqlClient" xdt:Transform="SetAttributes" xdt:Locator="Match(name)"/> </connectionStrings>
在發布時選擇Debug/Release。
See Also
1. 增加更多的發布環境及配置文件
當我們有多個發布環境時,還可以通過Configuration Manager進行添加。
通過Add Config Transforms來增加相應的配置文件
2. 替換其他配置信息
<appSettings> <add key="ClientValidationEnabled" value="false" xdt:Locator="Match(key)" xdt:Transform="Replace" /> </appSettings>
相關文檔: