在.NET/SQLServer应用程序中管理调试和释放连接字符串的好方法是什么?
我有两个SQL Server,一个生产服务器和一个生成/调试服务器,当我部署ASP.NET应用程序时,我需要一种在两者之间切换的方法。
目前,我只是将它们存储在web.config中,然后将其中一个注释掉,但这在部署时容易出错。
最佳答案
创建Web.config文件的调试和发布版本,例如Web.debug.config和Web.release.config。然后添加一个预编译条件,该条件将根据当前目标将相关版本复制到web.config中。
编辑:要添加预编译条件,请在项目上单击鼠标右键,然后选择“属性”,然后转到“构建事件”选项卡,然后将以下代码添加到预编译条件。显然,您将不得不根据需要修改代码,请参见下图。
@echo off
echo Configuring web.config pre-build event ...
if exist "$(ProjectDir)web.config" del /F / Q "$(ProjectDir)web.config"
if "$(ConfigurationName)" == "Debug Test" goto test
if "$(ConfigurationName)" == "Debug M" goto M
if "$(ConfigurationName)" == "Debug BA" goto BA
if "$(ConfigurationName)" == "Release Test" goto test
if "$(ConfigurationName)" == "Release M" goto M
if "$(ConfigurationName)" == "Release BA" goto BA
echo No web.config found for configuration $(ConfigurationName). Abort batch.
exit -1
goto :end
:test
copy /Y "$(ProjectDir)web.config.test" "$(ProjectDir)web.config"
GOTO end
:BA
copy /Y "$(ProjectDir)web.config.BA" "$(ProjectDir)web.config"
GOTO end
:M
copy /Y "$(ProjectDir)web.config.M" "$(ProjectDir)web.config"
GOTO end
:end
echo Pre-build event finished
Project Properties http://img442.imageshack.us/img442/1843/propsa.jpg
关于c# - 管理调试和发布连接字符串,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/2382826/