以前,我们只需将web.config从我们的项目中删除,让每个人都可以在自己的机器上保留自己的本地版本的web.config。我们移动到VS2010,现在迫使我将web.config添加到我的项目中,以便运行调试模式。因为我们的项目链接到TFS,它会自动将web.config添加到源代码控制,并尝试以这种方式进行维护。
解决方法
>所有web配置文件现在都是“DependentOn”的“web.config”
>每个开发者或团队都需要自己的“[User / Team] .Debug.config”
应该转换配置文件,无论我们是否在发布模式下都“发布”。
这是如何做的:
>右键单击要执行此操作的Web项目,然后选择“卸载项目”(而不是“删除项目”)。
>再次右键单击同一个Web项目(现在应该变灰),然后选择“编辑… csproj”。这将在Xml编辑器中打开项目。
>向下滚动,直到找到具有所有“Web.config”列表的部分。现在,注释掉Xml中的所有“Dependent Upon”元素。
关闭Xml编辑器并保存更改。接下来,再次右键单击您的项目,然后选择“重新加载”。当项目重新加载时,您将注意到Web.config不再“堆栈”在“Web.config”下。这是必要的,以“欺骗”TFS。
>现在,复制“Web.config”文件,将其粘贴到同一个项目中,并将其重命名为“Web.base.config”。这将被用于每次重新生成Web.config(下一个覆盖)。
>现在,选择Web.config文件,然后转到“文件 – >源代码控制 – >从源代码控制中排除Web.config”。此外,打开源代码管理资源管理器(TFS资源管理器视图),并找到您的Web.config的位置,并将其从TFS中删除。这是因为Web.config将在每次构建项目时重新生成(我将在下面介绍)。
>现在,我们将创建一个新的Build文件,这将帮助我们为任何Built Type重新生成Web.config,即使是Debug(即Web.config Transformed缺少开始)。在项目中创建一个新的Xml文件,并将其重命名为“[YourProjectName] .wpp.targets”。重要的是要将这个项目命名为什么,包括所有点,破折号等(例如My.Project.wpp.targets)。
>现在,在新文件中输入以下Xml。如果开始强调语法错误,请放心:
<?xml version="1.0" encoding="utf-8"?> <Project ToolsVersion="4.0" xmlns="http://schemas.microsoft.com/developer/msbuild/2003"> <UsingTask TaskName="TransformXml" AssemblyFile="$(MSBuildExtensionsPath)\Microsoft\VisualStudio\v10.0\Web\Microsoft.Web.Publishing.Tasks.dll"/> <!-- Make sure web.config will be there even for package/publish --> <Target Name="CopyWebConfig" BeforeTargets="Build;Rebuild"> <Copy SourceFiles="Web.base.config" DestinationFiles="Web.config" OverwriteReadOnlyFiles="true" SkipUnchangedFiles="false" /> </Target> <Target Name="CustomTarget" BeforeTargets="BeforeBuild"> <Message Text="Transforming: Web.$(Configuration).config" Importance="high" /> <TransformXml Source="Web.base.config" Transform="Web.$(Configuration).config" Destination="Web.config" /> </Target> </Project>
>现在,从这一点上,你永远不会编辑Web.config,每次应用程序编译时都会被覆盖。您只编辑“Web.base.config”。
>现在,让我们来看看这个项目。再次右键单击项目,然后“卸载”它。现在,再次右键单击并编辑它。现在,返回并取消评论我们在步骤#3中评论的所有元素。此外,您应该在“Web.base.config”元素下添加“DependentOn”元素,以便它也将显示在“Web.config”下。关闭并保存,然后重新加载您的项目。您应该注意到,所有配置现在都在“Web.config”下。
>此时,您可以根据需要将多个配置添加到您的项目/解决方案中。例如,我添加了一个名为“Tim(Debug)”的Build Config,但是Project config被称为“Tim.Debug”。当我右键单击“Web.config”并选择“添加配置转换”,它现在添加我的“Web.Tim.Debug.config”文件。您还可以为每个环境或每个团队添加配置。
值得注意的是,您的个人配置文件只是“Web.base.config”的一个子集,并且在任何构建过程中都将被“转换”。要切换在调试期间将要构建的Transform,只需转到解决方案的顶端,并选择所需的Build Config。只要您有一个该Build Config的web.config,它将转换。如果没有,您将获得“Web.base.config”。
注意:这也应该使用标准的Windows / WPF应用程序使用“app.config”代替。