一种Webconfig自动化升级方法
1、方法功能
使用本方法,可以将开发环境最新版本的web.config结构与生产环境环境的config融合,而不用考虑两个config的版本差异值是多少。使用一种标记的方式,在开发环境webconfig上标记哪些节点的哪些属性需要保留为生产环境对应的值,而这种标记不影响开发环境web.config的使用。
2、适用范围
1、将开发环境的webconfig更新到生产环境,不再需要手动改配置值;
2、在多个生产环境中,使用同一份开发环境的webconfig,可转换得到适合本生产环境的最终config;
3、设计依赖
本方法有两个依赖:灵活的xml处理指令标记与逻辑固定的指令解释器,扩展在于指令标记而不是解释器。
3.1灵活的xml处理指令标记
开发环境的webconfig中,在希望保存原有配置值的元素之上写上处理指令,目标为"merge"。对于集合下相同名称的的元素,使用by来指示唯一标识的属性名称是什么,像appSettings下的元素,by="key";使用attr来指示需要保留原有配置值的属性名称,缺省为全部属性,可以写单个,多个中间半角逗号分隔。以下红色部分就是merge指令,它的存在不会影响到开发环境中webconfig本身的正确性。
<appSettings>
<add key="useLocalIPAdress" value="false"/> <!--通过节点的key属性来合并value-->
<?merge by="key" attr="value"?>
<add key="localIPAdress" value="192.168.1.99" /> <!--通过节点的key属性来合并所有属性-->
<?merge by="key"?>
<add key="useProxy" value="true" />
</appSettings>
<!--通过节点名称来合并account,password,sex,age-->
<?merge attr="account,password,sex,age" ?>
<admin account="admin" password="123456" sex="男" age="18" enable="true" />
3.2固定的指令解释器
解释器的功能是将带有指令的config当作xml解析,遍历所有元素,如果元素之上存在"merge"指令,则解析指令的数据内容,通过by的值或自身的节点名称,从旧的config中读取相配的节点,按照attr描述,进行将旧config的值复制过来,最终得到一份融合后的xml数据,转存为web.config文件即可。由于功能单一与逻辑固定,解释器本身不需要进行更新,合并xml大体方法如下:
/// <summary>
/// 将valueXml的值与markXml的结构合并
/// 返回得到的新的xml
/// </summary>
/// <param name="valueXml">带有值的xml</param>
/// <param name="markXml">带有标记的xml</param>
/// <returns></returns>
public static string MergeXml(string valueXml, string markXml)
{
var valueDoc = XDocument.Parse(valueXml);
var markDoc = XDocument.Parse(markXml);
var markElements = markDoc.Descendants().ToArray(); foreach (var markElement in markElements)
{
var mergeMark = markElement.GetMergeMark();
if (mergeMark == null)
{
continue;
} if (string.IsNullOrEmpty(mergeMark.By) == false)
{
var byAttr = markElement.Attribute(mergeMark.By);
var xPath = markElement.GetAbsoluteXPath(byAttr);
valueDoc.XPathSelectElement(xPath).CopyAttrValuesTo(markElement, mergeMark.Attr);
}
else
{
var xPath = markElement.GetAbsoluteXPath();
valueDoc.XPathSelectElement(xPath).CopyAttrValuesTo(markElement, mergeMark.Attr);
}
}
return markDoc.ToString();
}
为了简单,我做了一下文件右键菜单关联,人工更新web.config更方便:

4、项目与下载
https://github.com/xljiulang/ConfigMerge
一种Webconfig自动化升级方法的更多相关文章
- MySQL 升级方法指南大全
原文:MySQL 升级方法指南大全 通常,从一个发布版本升级到另一个版本时,我们建议按照顺序来升级版本.例如,想要升级 MySQL 3.23 时,先升级到 MySQL 4.0,而不是直接升级到 MyS ...
- Java中8种常见的排序方法
排序方法的演示1)插入排序(直接插入排序.希尔排序)2)交换排序(冒泡排序.快速排序)3)选择排序(直接选择排序.堆排序)4)归并排序5)分配排序(基数排序)所需辅助空间最多:归并排序所需辅助空间最少 ...
- C#与Ranorex自动化公用方法
原创 - C#与Ranorex自动化公用方法 利用c#在Ranorex上写自动化已经有很长的一段时间了,总结发现常用的方法不外乎如下几种: 1.打开浏览器:或者app public static vo ...
- javascript四种类型识别的方法
× 目录 [1]typeof [2]instanceof [3]constructor[4]toString 前面的话 javascript有复杂的类型系统,类型识别则是基本的功能.javascrip ...
- oracle 11g RAC 补丁升级方法
一.自动升级方法 使用auto方式在两节点分别进行PSU的安装,安装PSU前注意更新opatch工具至PSU所要求版本,p22191577补丁包括GI和DB,分别执行即可. 两节点分别grid用户执行 ...
- iOS 三种收起键盘的方法
- (void)viewDidLoad { [super viewDidLoad]; // Do any additional setup after loading the view, typica ...
- 干货:结合Scikit-learn介绍几种常用的特征选择方法
原文 http://dataunion.org/14072.html 主题 特征选择 scikit-learn 作者: Edwin Jarvis 特征选择(排序)对于数据科学家.机器学习从业者来说非 ...
- 【读书笔记】iOS-开发技巧-三种收起键盘的方法
- (void)viewDidLoad { [super viewDidLoad]; // Do any additional setup after loading the view, typica ...
- 结合Scikit-learn介绍几种常用的特征选择方法
特征选择(排序)对于数据科学家.机器学习从业者来说非常重要.好的特征选择能够提升模型的性能,更能帮助我们理解数据的特点.底层结构,这对进一步改善模型.算法都有着重要作用. 特征选择主要有两个功能: 减 ...
随机推荐
- 在 Docker 中使用 flannel - 每天5分钟玩转 Docker 容器技术(60)
上一节我们安装和配置了 flannel,本节在 Docker 中使用 flannel. 配置 Docker 连接 flannel 编辑 host1 的 Docker 配置文件 /etc/systemd ...
- 阿里云服务器(Windows)如何下载文件
背景:公司只有我一个技术,在我之前还有一个老技术,属于兼职状态,为了尽快熟悉公司网站及app项目情况,我联系了老技术,请他尽快将代码发给我,他说代码文件过大,问我能不能连上服务器下载.百度了很多,都不 ...
- Unix硬链接和符号链接(转)
首先要弄清楚,在Linux系统中,内核为每一个新创建的文件分配一个Inode(索引结点),每个文件都有一个惟一的inode号.文件属性保存在索引结点里,在访问文件时,索引结点被复制到内存在,从而实现文 ...
- 优化关键渲染路径CRP
什么是关键渲染路径? 从收到 HTML.CSS 和 JavaScript 字节到对其进行必需的处理,从而将它们转变成渲染的像素这一过程中有一些中间步骤 浏览器渲染页面前需要先构建 DOM 和 CSSO ...
- hdu 6199 沈阳网络赛---gems gems gems(DP)
题目链接 Problem Description Now there are n gems, each of which has its own value. Alice and Bob play a ...
- 01-TypeScript概述
本篇文章向大家介绍新的TypeScript客户端脚本语言,主要涉及两个方面,一是传统JavaScript语言的弱点,二是TypeScript语言的优势. 一.JavaScript的弱点 1.弱类型,缺 ...
- 201521123084 《Java程序设计》第11周学习总结
1. 本周学习总结 1.1 以你喜欢的方式(思维导图或其他)归纳总结多线程相关内容. 2. 书面作业 本次PTA作业题集多线程 1. 互斥访问与同步访问 完成题集4-4(互斥访问)与4-5(同步访问) ...
- bootstrap导航条+模态对话框+分页样式
<!DOCTYPE html> <html> <head> <meta http-equiv="Content-Type" content ...
- LaTeX排版指南
V0.0.1 工具链 CTeX:http://www.ctex.org/HomePage ,CTeX是一个中文套装,但也同时发布一个独立的ctex宏包 TeXLive:https://tug.org/ ...
- 团队作业4——第一次项目冲刺(Alpha版本)6th day
一.Daily Scrum Meeting照片 二.燃尽图 三.项目进展 24点的游戏输入是点击我们给的图片然后会输入相应的数字,之前的所做的出 现了一点问题,在把数字删掉重新输入就不行,这个问题仍然 ...