使用XDT提高开发效率
使用XDT提高开发效率
XDT介绍
XDT(XML Document Transformation)技术是一种用于对XML文档进行转换的技术。它通常用于在部署或配置过程中,根据不同的环境或条件自动修改XML文件的内容,以便适应特定的环境或配置需求。
XDT技术主要应用于Web.config、App.config等配置文件的转换。在Web开发中,通常有多个环境(如开发环境、测试环境、生产环境等),这些环境可能需要不同的配置,例如数据库连接字符串、API地址等。使用XDT技术可以根据不同的部署环境自动修改配置文件,避免手动修改或维护多个不同版本的配置文件。
XDT技术使用基于XML的转换语法,通常使用的是Web.Release.config、Web.Debug.config等命名规则的配置文件。这些文件包含了在发布或调试不同环境时需要应用的变更。当进行部署或调试时,系统会根据当前环境选择相应的配置文件,并将其中的转换规则应用到原始的XML文件中,从而生成最终的配置文件。
常见的XDT转换规则包括插入、替换、删除、设置属性等操作。使用这些规则,可以根据需要轻松地修改配置文件,以满足不同环境的需求。
总的来说,XDT技术是一种方便的XML文档转换技术,可以在部署和配置过程中帮助开发人员自动地对XML文件进行转换,以适应不同的环境和配置需求。这有助于简化配置管理和提高部署的灵活性。
语法简介
| 特性 | 语法 | 描述 | 示例 |
|---|---|---|---|
| Locator 特性语法 | Condition | 指定一个 XPath 表达式,该表达式会追加到当前元素的 XPath 表达式。 选择了与组合 XPath 表达式匹配的元素。 | Locator="Condition(XPath Expression)" |
| ^ | Match | 选择针对指定的一个或多个特性具有匹配值的一个或多个元素。 如果指定了多个特性名称,则将仅选择与所有指定特性匹配的元素。 | Locator="Match(comma-Delimited List Of One Or More Attribute Names)" |
| ^ | XPath | 指定应用于开发 Web.config 文件的绝对 XPath 表达式。 (与 Condition 不同,所指定的表达式不追加到与当前元素对应的隐式 XPath 表达式。) | Locator="XPath(XPath Expression)" |
| Transform 特性语法 | Replace | 将所选的元素替换为在转换文件中指定的元素。 如果选择多个元素,则只替换所选的第一个元素。 有关如何使用 Replace 关键字的示例,请参见 Locator 特性的示例。 | Transform="Replace" |
| ^ | Insert | 将转换文件中定义的元素作为所选的一个或多个元素的同级进行添加。 该新元素被添加到任何集合的末尾。 | Transform="Insert" |
| ^ | InsertBefore | 将转换 XML 中定义的元素直接插入到由指定 XPath 表达式选择的元素之前。 该 XPath 表达式必须是一个绝对表达式,因为它作为一个整体应用于开发 Web.config 文件,而不只是追加到当前元素的隐式 XPath 表达式中。 | Transform="InsertBefore(XPath Expression)" |
| ^ | InsertAfter | 将转换 XML 中定义的元素直接插入到由指定 XPath 表达式选择的元素之后。 该 XPath 表达式必须是一个绝对表达式,因为它作为一个整体应用于开发 Web.config 文件,而不是追加到当前元素的隐式 XPath 表达式中。 | Transform="InsertAfter(XPath Expression)" |
| ^ | Remove | 移除选定元素。 如果选择了多个元素,则移除第一个元素。 | Transform="Remove" |
| ^ | RemoveAll | 移除选定的一个或多个元素。 | Transform="RemoveAll" |
| ^ | RemoveAttributes | 从所选元素移除指定的特性。 | Transform="RemoveAttributes(comma-Delimited List Of One Or More Attribute Names)" |
| ^ | SetAttributes | SetAttributes 变换影响所有选定的元素。 此行为与 Replace 不同转换特性,仅影响第一个选定的元素,如果选择了多个元素 | Transform="SetAttributes(comma-Delimited List Of One Or More Attribute Names)" |
使用方法
针对XDT文件和XML文件的转换,可以使用SlowCheetah插件来实现。SlowCheetah是一个Visual Studio扩展,可以在Visual Studio中使用XDT技术来转换XML文件。
选择你的Visual Studio版本下载对应的插件,安装后重启Visual Studio即可。
Visual Studio 2022: SlowCheetah VS 2022 Extension (version 4.x)
Visual Studio 2015-2019: SlowCheetah VS 2015-2019 Extension (version 3.x)
App.config内容如下,维护了环境变量environment,我们需要根据不同的环境变量来修改App.config中的内容。
<?xml version="1.0" encoding="utf-8" ?>
<configuration>
<appSettings>
<add key="environment" value="Dev" />
</appSettings>
<startup>
<supportedRuntime version="v4.0" sku=".NETFramework,Version=v4.5" />
</startup>
</configuration>
选中我们要转换的App.config文件,右键选择Add Transform,会自动生成两个个config文件,如下图所示:

他会在我们的packages.config中添加一个nuget引用
<?xml version="1.0" encoding="utf-8"?>
<packages>
<package id="Microsoft.VisualStudio.SlowCheetah" version="4.0.50" targetFramework="net45" developmentDependency="true" />
</packages>
同时他会修改我们的项目.csproj文件增加如下内容,增加了App.Debug.config、App.Release.config两个文件。也增加了Microsoft.VisualStudio.SlowCheetah.targets文件的引用,用于生成事件调用。
<ItemGroup>
<None Include="App.config">
<SubType>Designer</SubType>
<TransformOnBuild>true</TransformOnBuild>
</None>
<None Include="App.Debug.config">
<DependentUpon>App.config</DependentUpon>
<IsTransformFile>true</IsTransformFile>
</None>
<None Include="App.Release.config">
<DependentUpon>App.config</DependentUpon>
<IsTransformFile>true</IsTransformFile>
</None>
<None Include="packages.config" />
</ItemGroup>
<Import Project="..\..\..\packages\Microsoft.VisualStudio.SlowCheetah.4.0.50\build\Microsoft.VisualStudio.SlowCheetah.targets" Condition="Exists('..\..\..\packages\Microsoft.VisualStudio.SlowCheetah.4.0.50\build\Microsoft.VisualStudio.SlowCheetah.targets')" />
<Target Name="EnsureNuGetPackageBuildImports" BeforeTargets="PrepareForBuild">
<PropertyGroup>
<ErrorText>这台计算机上缺少此项目引用的 NuGet 程序包。使用“NuGet 程序包还原”可下载这些程序包。有关更多信息,请参见 http://go.microsoft.com/fwlink/?LinkID=322105。缺少的文件是 {0}。</ErrorText>
</PropertyGroup>
<Error Condition="!Exists('..\..\..\packages\Microsoft.VisualStudio.SlowCheetah.4.0.50\build\Microsoft.VisualStudio.SlowCheetah.targets')" Text="$([System.String]::Format('$(ErrorText)', '..\..\..\packages\Microsoft.VisualStudio.SlowCheetah.4.0.50\build\Microsoft.VisualStudio.SlowCheetah.targets'))" />
</Target>
但是我们不需要App.Debug.config和App.Release.config两个配置文件,我们预期在Debug模式下想要调试开发环境(Dev),在Testing模式想要调试测试环境(Testing)。所以我们需要修改App.Debug.config改为App.Testing.config文件。
有需要可以新增更多类型配置文件,如App.Production.config文件。

同时修改.csproj文件,删除App.Release.config文件的引用。并去文件资源管理器中物理删除App.Release.config。
<None Include="App.config">
<TransformOnBuild>true</TransformOnBuild>
</None>
<None Include="App.Testing.config">
<DependentUpon>App.config</DependentUpon>
<IsTransformFile>true</IsTransformFile>
</None>
新增的App.Testing.config配置文件如下,可以看到environment使用了Replace替换,Locator使用了Match(key)匹配key值,这样就可以根据key值来替换value值为Testing。
<?xml version="1.0" encoding="utf-8"?>
<!--For more information on using transformations see the web.config examples at http://go.microsoft.com/fwlink/?LinkId=214134. -->
<configuration xmlns:xdt="http://schemas.microsoft.com/XML-Document-Transform">
<appSettings>
<add key="environment" value="Testing" xdt:Transform="Replace" xdt:Locator="Match(key)" />
</appSettings>
</configuration>
右键App.Testing.config文件,选择Preview Transform,可以看到environment的value值已经被替换为Testing了。

但是我们默认情况下只有Debug和Release调试模式,我们需要增加Testing调试模式,所以我们需要修改.csproj文件,增加Condition条件,如下所示,增加了Condition=" '$(Configuration)|$(Platform)' == 'Testing|AnyCPU' "条件,这样就可以在Testing环境下使用App.Testing.config配置文件了。
csproj的文件改动如下
<PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Debug|AnyCPU' ">
<DebugSymbols>true</DebugSymbols>
<DebugType>full</DebugType>
<Optimize>false</Optimize>
<OutputPath>bin\Debug\</OutputPath>
<DefineConstants>DEBUG;TRACE</DefineConstants>
<ErrorReport>prompt</ErrorReport>
<WarningLevel>4</WarningLevel>
</PropertyGroup>
<PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Release|AnyCPU' ">
<DebugType>pdbonly</DebugType>
<Optimize>true</Optimize>
<OutputPath>bin\Release\</OutputPath>
<DefineConstants>TRACE</DefineConstants>
<ErrorReport>prompt</ErrorReport>
<WarningLevel>4</WarningLevel>
</PropertyGroup>
<PropertyGroup Condition="'$(Configuration)|$(Platform)' == 'Testing|AnyCPU'">
<DebugSymbols>true</DebugSymbols>
<OutputPath>bin\Testing\</OutputPath>
<DefineConstants>DEBUG;TRACE</DefineConstants>
<DebugType>full</DebugType>
<PlatformTarget>AnyCPU</PlatformTarget>
<LangVersion>7.3</LangVersion>
<ErrorReport>prompt</ErrorReport>
</PropertyGroup>
也可以在菜单栏选择生成=》配置管理器项,新建Testing环境。

解决方案配置默认为自带的Debug或者Release。我们选择工具栏解决方案配置下拉框我们新建的Testing环境,设置启动项为当前项目F5运行程序,可以看到environment的value值已经被替换为Testing了。
internal class Program
{
private static void Main(string[] args)
{
string env = System.Configuration.ConfigurationManager.AppSettings["environment"];
System.Console.WriteLine($"EnvironmentName:{env}");
// print: EnvironmentName:Testing
System.Console.ReadKey();
}
}
本示例简单展示如何使用XDT来提高开发效率,实际开发中会有更多复杂情况。具体语法可以参考MSDN。
参考
- dotnet/xdt
- Xdt transform samples
- XDT web.config transforms
- Web.config Transformation Syntax for Web Project Deployment Using Visual Studio
使用XDT提高开发效率的更多相关文章
- 如何利用 Visual Studio 自带工具提高开发效率
Visual Stuido 是一款强大的Windows 平台集成开发工具,你是否好好地利用了它呢? 显示行号 有些时候(比如错误定位)的时候,显示行号将有利于我们进行快速定位. 如何显示 1. 工具 ...
- 成吨提高开发效率:Intellij Shortcuts精简子集与思维模式
在线精简cheatsheet备查表:intellij.linesh.twGithub项目:intellij-mac-frequent-keymap Intellij的快捷键多而繁杂,从官方推荐的key ...
- 善用VS中的Code Snippet来提高开发效率
http://www.cnblogs.com/anderslly/archive/2009/02/16/vs2008-code-snippets.html http://www.cnblogs.com ...
- 实用手册:130+ 提高开发效率的 vim 常用命令
Vim 是从 vi 发展出来的一个文本编辑器.代码补完.编译及错误跳转等方便编程的功能特别丰富,在程序员中被广泛使用.和 Emacs 并列成为类 Unix 系统用户最喜欢的编辑器.这里收录了130+程 ...
- 提高开发效率的 Eclipse 实用操作
工欲善其事,必先利其器.对于程序员来说,Eclipse便是其中的一个“器”.本文会从Eclipse快捷键和实用技巧这两个篇章展开介绍.Eclipse快捷键用熟后,不用鼠标,便可进行编程开发,避免鼠标分 ...
- 10 款提高开发效率的 jQuery/CSS3 组件
前端开发是一项十分繁琐而又耗体力的工作,如何更有效率的开发我们的应用,很多人会选择适当地使用一些jQuery插件.今天就要给大家分享10款可以提高开发效率的jQuery/CSS3组件.部分插件可以下载 ...
- 能够提高开发效率的Eclipse实用操作
工欲善其事,必先利其器.对于程序员来说,Eclipse便是其中的一个“器”.本文会从Eclipse快捷键和实用技巧这两个篇章展开介绍.Eclipse快捷键用熟后,不用鼠标,便可进行编程开发,避免鼠标分 ...
- tomcat免重启随意更改java代码 提高开发效率
转载:http://developer.51cto.com/art/201012/241243.htm 做为了一个java开发人员,总是为因为要增加一个类,或是增加删除一个方法,甚至修改一个小处代码而 ...
- 能够提高开发效率的 Eclipse 实用操作
工欲善其事,必先利其器.对于程序员来说,Eclipse便是其中的一个“器”.本文会从Eclipse快捷键和实用技巧这两个篇章展开介绍.Eclipse快捷键用熟后,不用鼠标,便可进行编程开发,避免鼠标分 ...
- 善用VS中的Code Snippet来提高开发效率 分类: C# 2015-01-22 11:06 69人阅读 评论(0) 收藏
前言 在谈谈VS中的模板中,我介绍了如何创建项目/项模板,这种方式可以在创建项目时省却不少重复性的工作,从而提高开发效率.在创建好了项目和文件后,就得开始具体的编码了,这时又有了新的重复性工作,就是 ...
随机推荐
- C51单片机开发
C51单片机开发笔记 定时器 C51中的定时器和计数器是同一个硬件电路支持的,通过寄存器配置不同,就可以将他当做定时器 或者计数器使用. 确切的说,定时器和计数器区别是致使他们背后的计数存储器加1的信 ...
- React跨路由组件动画
我们是袋鼠云数栈 UED 团队,致力于打造优秀的一站式数据中台产品.我们始终保持工匠精神,探索前端道路,为社区积累并传播经验价值. 本文作者:佳岚 回顾传统React动画 对于普通的 React 动画 ...
- 为.NET打开新大门:OpenVINO.NET开源项目全新发布
为.NET打开新大门:OpenVINO.NET开源项目全新发布 在AI的应用越来越广泛的今天,优化深度学习模型并进行推理部署已经成为了一门必要的技术.Intel开发的OpenVINO工具包(Open ...
- .NET高性能开发-位图索引(一)
首先来假设这样一个业务场景,大家对于飞机票应该不陌生,大家在购买机票时,首先是选择您期望的起抵城市和时间,然后选择舱等(公务舱.经济舱),点击查询以后就会出现航班列表,随意的点击一个航班,可以发现有非 ...
- Redis的速度不够用?为什么你应该考虑使用 KeyDB,一个更快、更强大、更灵活的开源数据库
你是否正在使用 Redis 作为您的数据结构存储,享受它的高性能.高可用的特性?如果是这样,那么你可能会对 KeyDB 感兴趣. 什么是 KeyDB? KeyDB 一个由 Snap 提供支持.专为扩展 ...
- Linux内存管理 | 一、内存管理的由来及思想
1.前言 <中庸>有:"九层之台,起于垒土" 之说,那么对于我们搞技术的人,同样如此! 对于Linux内存管理,你可以说没有留意过,但是它存在于我们日常开发的方方面面, ...
- 从零开始编写一个 Python 异步 ASGI WEB 框架
从零开始编写一个 Python 异步 ASGI WEB 框架 前言 本着 「路漫漫其修远兮,吾将上下而求索」 的精神,这次要和朋友们分享的内容是<从零开始编写一个 Python 异步 ASGI ...
- P8816 [CSP-J 2022] 上升点列
Problem 考察算法:\(DP\). 题目简述 给你 \(n\) 个点,每个点有一个坐标 \((x_i,y_i)\),还可以添加 \(k\) 个点. 添加之后,求:最长的上升点列的长度. 上升点列 ...
- svn的常规使用
svn的常规使用 svn的常规使用 1 客户端 2 svn server 3 qt使用svn 4 svn项目迁移 Ubuntu上使用svn 1 安装 2 使用 svn的常规使用 1 客户端 下载地址: ...
- 随着Web3.0的到来,IPFS能否成为未来?
IPFS能否成为未来互联网存储市场的霸主? 首先在说IPFS之前,我们有必要先聊一聊HTTP,因为目前我们从互联网上看到的,用的,基本上都是HTTP,自从1991年发明了HTTP,到现在已经多了30多 ...