黄聪:Microsoft Enterprise Library 5.0 系列教程(十) Configuration Application Block
原文:黄聪:Microsoft Enterprise Library 5.0 系列教程(十) Configuration Application Block
到目前为止,我们使用的模块都是在同一个配置文件中,这显然是不灵活的,我们希望每个功能模块能独立的在一个配置文件中体现,这样不仅易于管理,易于扩展,也易于阅读和分类.企业库当然考虑到了这个问题并且提供了解决方案,本章就是讲解如何使用Configuration Application Block来将各个模块分割到独立的配置文件中的.
和以前一样,我们先提需求,再用实例做讲解,这样比较形象生动些:
1) 创建一个工程,里面用到企业库的Data 数据访问模块和Log日志处理模块
2) 2个模块的配置分别保存在不同的配置文件中(Data.config和Log.config中)
3) 在程序中调用这2个模块
1. 用VS 2008新建一个控制台应用程序.接着运行EntLibConfig.exe, 选择Blocks菜单 ,单击Add Data Settings .并设置Connection String属性,可以随意设置一个连接字符串,在此只做测试使用,配置好后保存成Data.config,保存到你的控制台程序目录下:
2. 再打开一个EntLibConfig.exe. 选择Blocks菜单 ,单击Add Logging Settings .设置如下所示,日志模块的详细介绍请参考我之前的文章.配置好之后保存成Log.config,并保存到你的控制台程序目录下.
3. 再打开一个EntLibConfig.exe. 选择Blocks菜单 ,单击Add Configuration Settings . 点击Sources面板右上角的加号按钮—Add Sources—Add File-based Configuration Source.设置创建好的File-based Configuration Source的Name属性为Data ConfigurationSource.接着将File Path属性设置为前面创建好的Data.config文件:
4. 点击Redirected Sections面板右上角的加号按钮—Add Redirected Sections.设置Configuration Source的属性为Data Configuration Source:
5. 同3,4步一样,我们再设置Log模块的配置,最后设置如下图所示:
6. 好了,保存该配置文件为App.config,同样保存到前面建立好的控制台程序目录下,这时候你的程序目录下应该有如下3个文件啦:
7. 创建一个新的控制台应用程序,将App.config添加到程序内,并加入需要的Dll文件:
添加引用:
using System.Configuration;using Microsoft.Practices.EnterpriseLibrary.Common.Configuration;using Microsoft.Practices.EnterpriseLibrary.Data;using Microsoft.Practices.EnterpriseLibrary.Common.Configuration.Manageability;using Microsoft.Practices.EnterpriseLibrary.Data.Configuration;using Microsoft.Practices.EnterpriseLibrary.Logging;
8. 测试:
using System;using System.Collections.Generic;using System.Linq;using System.Text;using System.Configuration;using Microsoft.Practices.EnterpriseLibrary.Common.Configuration;using Microsoft.Practices.EnterpriseLibrary.Data;using Microsoft.Practices.EnterpriseLibrary.Common.Configuration.Manageability;using Microsoft.Practices.EnterpriseLibrary.Data.Configuration;using Microsoft.Practices.EnterpriseLibrary.Logging;namespace test{ class Program { staticvoid Main(string[] args) { //从Data.config配置文件获取设置 DatabaseProviderFactory dbFactory = new DatabaseProviderFactory(GetFileConfigurationSource("Data Configuration Source")); Database db = dbFactory.Create("Connection String"); Console.WriteLine(db.ConnectionString); //从Log.config的配置文件获取设置 LogWriter lw =new LogWriterFactory(GetFileConfigurationSource("Log Configuration Source")).Create(); lw.Write(""); } privatestatic FileConfigurationSource GetFileConfigurationSource(string SourceName) { //获取App.config Configuration config = ConfigurationManager.OpenExeConfiguration(ConfigurationUserLevel.None); //获取资源节点集合 ConfigurationSourceSection section = (ConfigurationSourceSection)config.GetSection(ConfigurationSourceSection.SectionName); //获取重定向配置文件资源配置节点 FileConfigurationSourceElement elem = (FileConfigurationSourceElement)section.Sources.Get(SourceName); //获取重定向配置文件资源 FileConfigurationSource fileSource =new FileConfigurationSource(elem.FilePath); return fileSource; } }}
9. 运行结果:
打开rolling.log可以看见如下内容:
至此,我们就解决了前面提出的所有需求啦,我们将数据库模块和日志模块的配置分别创建在Data.config和Log.config文件中,并用App.config作为字典来查询各个模块和配置文件的从属关系,这样使得各个模块间的耦合度大大降低,简化了管理.好了,Microsoft Enterprise Library的系列教程到此算是告一段落了.6,7月份要准备期考啦,考完试我再做其他的系列教程吧,请大家届时关注,哈哈
黄聪:Microsoft Enterprise Library 5.0 系列教程(十) Configuration Application Block的更多相关文章
- 黄聪:Microsoft Enterprise Library 5.0 系列教程(六) Security Application Block
原文:黄聪:Microsoft Enterprise Library 5.0 系列教程(六) Security Application Block 开发人员经常编写需要安全功能的应用程序.这些应用程序 ...
- 黄聪:Microsoft Enterprise Library 5.0 系列教程(四) Logging Application Block
原文:黄聪:Microsoft Enterprise Library 5.0 系列教程(四) Logging Application Block 企业库日志应用程序模块工作原理图: 从上图我们可以 ...
- 黄聪:Microsoft Enterprise Library 5.0 系列教程(三) Validation Application Block (高级)
原文:黄聪:Microsoft Enterprise Library 5.0 系列教程(三) Validation Application Block (高级) 企业库验证应用程序模块之配置文件模式: ...
- 黄聪:Microsoft Enterprise Library 5.0 系列教程(三) Validation Application Block (初级)
原文:黄聪:Microsoft Enterprise Library 5.0 系列教程(三) Validation Application Block (初级) 企业库提供了一个很强大的验证应用程序模 ...
- 黄聪:Microsoft Enterprise Library 5.0 系列教程(二) Cryptography Application Block (高级)
原文:黄聪:Microsoft Enterprise Library 5.0 系列教程(二) Cryptography Application Block (高级) 本章介绍的是企业库加密应用程序模块 ...
- 黄聪:Microsoft Enterprise Library 5.0 系列教程(二) Cryptography Application Block (初级)
原文:黄聪:Microsoft Enterprise Library 5.0 系列教程(二) Cryptography Application Block (初级) 企业库加密应用程序模块提供了2种方 ...
- 黄聪:Microsoft Enterprise Library 5.0 系列教程(一) Caching Application Block (高级)
原文:黄聪:Microsoft Enterprise Library 5.0 系列教程(一) Caching Application Block (高级) Caching Application Bl ...
- 黄聪:Microsoft Enterprise Library 5.0 系列教程(一) : Caching Application Block (初级)
原文:黄聪:Microsoft Enterprise Library 5.0 系列教程(一) : Caching Application Block (初级) 本篇文章具体官方解释请参照以下链接: h ...
- Microsoft Enterprise Library 5.0 系列教程(四) Logging Application Block
Download dll: http://www.microsoft.com/en-us/download/confirmation.aspx?id=15104 http://www.cnblogs. ...
随机推荐
- open sql 更新数据
insert语句: 1.插入单行数据有两种方法:wa是一个工作区 insert into dbtab values wa. insert into dbtab from wa. 该语句也可以将数据行插 ...
- 深入理解 JBoss 7/WildFly Standalone 模式启动过程
概述 JBoss 7/WildFly Standalone 模式启动过程大致例如以下: 启动脚本 standalone.sh 启动 JBoss Modules,JBoss Modules 启动 JBo ...
- R语言与数据分析之六:时间序列简介
今年在某服装企业蹲点了4个多月,之间非常长一段时间在探索其现货和期货预測.时间序列也是做销售预測的首选,今天和小伙伴分享下时间序列的基本性质和怎样用R来挖据时间序列的相关属性. 首先读入一个时间序列: ...
- Swift - 网页控件(UIWebView)加载本地数据,文件
使用UIWebView加载本地数据或资源有如下三种方式: 1,使用loadHTMLString方法加载HTML内容 2,使用loadRequest方法加载本地资源(也可用于加载服务器资源) 3,先将内 ...
- php获取server端mac和clientmac的地址
获取servermac <?php /** 获取网卡的MAC地址原码:眼下支持WIN/LINUX系统 获取机器网卡的物理(MAC)地址 **/ class GetmacAddr{ var $re ...
- [SVN]常见问题的解决方案
Date:2014-1-3 Summary: SVN使用的一些常见问题解决方案记录,来源Internet,本人亲测 Contents: 1.回滚自己的分支到某一个版本 $svn merge -r rH ...
- 明晚8点,捷微团队QQ群公开课,解说jeewx2.0版本号maven环境的搭建入门!
2014-08-13号晚8点,捷微团队QQ群公开课,解说jeewx2.0版本号maven环境的搭建入门! 讲师:刘强(团队成员) QQ群:287090836 (JAVA版本号微信开源项目) http: ...
- Nagios的客户端的安装
一.Linux服务器的nagios客户端的安装 步骤: 1. 创建目录,上传文件到该目录 mkdir /data nagios-plugins-2.1.1.tar.gz nrpe-2.12.tar. ...
- Juniper srx防火墙NAT配置
一.基础操作说明: 1. 设备恢复出厂化 root# load factory-default root# set system root-authentication plain-text-pas ...
- [置顶] think in java interview-高级开发人员面试宝典(七)
上两周研发任务太紧了,所以担搁了一下,我们继续我们的面试之旅. 下面是一个基于图书系统的15道SQL问答,供大家参考 问题描述:本题用到下面三个关系表:CARD 借书卡. CNO 卡号,N ...