您的位置:首页 > 其它

Castle IOC容器构建配置详解(一)

2009-04-17 16:22 309 查看
摘要:知道如何简单使用Castle IOC,也听完了Castle IOC的内幕故事,从本文开始讲会详细讲解Castle IOC的一些使用。先从构建配置信息开始吧,在Castle IOC中并不像Spring.net那样贯穿着一个思想就是一切皆为配置,对于对象之间的依赖关系,Castle IOC会自动去连接,因此相比之下它的配置文件要比Spring.net简单的多。

主要内容
1.配置什么
2.几种配置方式
3.Include 介绍
4.Properties介绍
5.条件状态

一.配置什么
Castle IOC中并不像Spring.net那样贯穿着一个思想就是一切皆为配置,对于对象之间的依赖关系,Castle IOC会自动去连接,因此相比之下它的配置文件要比Spring.net简单的多。我们主要配置的就是Component和Facility,所有的组件配置都放在Components节点中,每一个组件以<Component>开始,以</Component>结束,其中组件ID必须指定,组件的参数用< parameters >节点来指定:


<!--出处:http://terrylee.cnblogs.com-->




<?xml version="1.0" encoding="utf-8" ?>




<configuration>




<components>




<component id="comp1">




<parameters>




<para>component1 para</para>




</parameters>




</component>




<component id="comp2">




<parameters>




<para>component2 para</para>




</parameters>




</component>




</components>




</configuration>
所有的扩展单元配置都在Facilities节点中,每一个扩展单元以一个<Facility>开始,以</Facility>结束:


<!--出处:http://terrylee.cnblogs.com-->




<?xml version="1.0" encoding="utf-8" ?>




<configuration>




<facilities>




<facility id="nhibernate" type="Full Type Name, AssemblyName"></facility>




<facility id="transaction" type="Full Type Name, AssemblyName"></facility>




</facilities>




</configuration>
二.几种配置方式
在Castle IOC中,支持三种方式的配置
l XML方式的配置
l 应用程序配置文件
l 实现接口IconfigurationStore自定义配置
1.XML方式的配置
指定一个自定义的XML作为配置文件,在实例化容器的时候用XmlInterpreter,简单的配置文件如下


<!--出处:http://terrylee.cnblogs.com-->




<?xml version="1.0" encoding="utf-8" ?>




<configuration>




<components>




<component id="txtLog">




<parameters>




<target>log.txt</target>




</parameters>




</component>




</components>




</configuration>
初始化容器时的代码


IWindsorContainer container = new WindsorContainer( new XmlInterpreter("BasicUsage.xml") );
2.使用应用程序配置文件
用Web.config或者App.config作为配置文件,这种方式的配置在实例化时不需要指定配置文件,容器会自动去检查应用程序的配置文件中的Castle IOC配置区


<!--出处:http://terrylee.cnblogs.com-->




<?xml version="1.0" encoding="utf-8" ?>




<configuration>




<configSections>




<section name="castle" type="Castle.Windsor.Configuration.AppDomain.CastleSectionHandler,Castle.Windsor" />




</configSections>




<castle>




<components>




<component id="txtLog">




<parameters>




<target>log.txt</target>




</parameters>




</component>




</components>




</castle>




</configuration>
初始化容器时直接采用默认初始化


IWindsorContainer container = new WindsorContainer(new XmlInterpreter() );
三.Include介绍
有时系统比较复杂,组件会非常的多。如果把这么多的组件放在了同一个配置文件里面去配置,配置文件将变得很大,而且不易阅读。使用Include可以把配置文件分开在很多个不同的配置文件中,最后统一在一个XML中或者应用程序配置文件指定这些分开配置文件的URI。如下面所示,我们有这样三个配置文件:
properties.config


<!--出处:http://terrylee.cnblogs.com-->




<?xml version="1.0" encoding="utf-8" ?>




<configuration>




<properties>




<StrConn>MyConnectionString</StrConn>




</properties>




<properties>




<TimeOut>500</TimeOut>




</properties>




</configuration>
facilities.config


<!--出处:http://terrylee.cnblogs.com-->




<?xml version="1.0" encoding="utf-8" ?>




<configuration>




<facilities>




<facility id="nhibernate" type="Full Type Name, AssemblyName"></facility>




</facilities>




</configuration>
services.config


<!--出处:http://terrylee.cnblogs.com-->




<?xml version="1.0" encoding="utf-8" ?>




<configuration>




<components>




<component id="ILog"




type="CastleDemo.DatabaseLog, CastleDemo" />




</components>




</configuration>
则在Web.config或者App.config中就可以这样去写了:


<!--出处:http://terrylee.cnblogs.com-->




<?xml version="1.0" encoding="utf-8" ?>




<configuration>




<configSections>




<section name="castle" type="Castle.Windsor.Configuration.AppDomain.CastleSectionHandler, Castle.Windsor" />




</configSections>




<castle>




<include uri="file://properties.config" />




<include uri="file://facilities.config" />




<include uri="file://services.config" />




</castle>




</configuration>
四.Properties介绍
配置文件中,经常我们会遇到一个相同的值在多个地方使用,如数据库连接中的字符串,我们要是在每一个用到的地方都配置一遍,如果服务器变了,那所有的这些地方都得改动,这时可以使用Properties节点来配置,在容器使用配置信息之前,它将会被配置文件中的另一个Properties来替换,需要替换的地方我们使用#{}来标识。如


<!--出处:http://terrylee.cnblogs.com-->




<?xml version="1.0" encoding="utf-8" ?>




<configuration>




<properties>




<connectionString>server=local;uid=sa;pwd=sa;database=test</connectionString>




</properties>




<components>




<component id="connectionfactory" service="Company.Project.IConnectionFactory, Company.Project"




type="Company.Project.DefaultConnectionFactory, Company.Project">




<properties>




<connString>#{connectionString}</connString>




</properties>




</component>




</components>




</configuration>
五.条件状态

配置文件有时候会非常的复杂,Castle IOC支持我们在配置文件中使用条件选择或者判断,这有点像C#预处理指令(如#if,如果你没有使用过,可以参考MSDN),
可以使用以下的节点:

名称
示例
define
<define flag="DEBUG" />
undef
<undef flag="DEBUG" />
if
<if defined="DEBUG">
<interceptors>
<interceptor>${logging.interceptor}</interceptor>
</interceptors>
</if>
choose
<choose>
<when defined="DEBUG">
<component id="BasicUsageDebug" />
</when>
……
</choose>
when
与choose结合使用
otherwise
与choose结合使用
一个完整的配置示例如下:


<!--出处:http://terrylee.cnblogs.com-->




<?xml version="1.0" encoding="utf-8" ?>




<configuration>




<define flag="DEBUG" />




<components>




<component id="BasicUsageDemo">




<if defined="DEBUG">




<interceptors>




<interceptor>${logging.interceptor}</interceptor>




</interceptors>




</if>




</component>




<undef flag="DEBUG" />




<choose>




<when defined="DEBUG">




<component id="BasicUsageDebug" />




</when>




<when defined="Complex">




<component id="ComplexDeme" />




</when>




<when defined="Prod">




<component id="ProdDemo" />




</when>




<otherwise>




<component id="Default" />




</otherwise>




</choose>




</components>




</configuration>

Castle IOC容器的基本配置就到这儿了,在下一篇中会介绍一些复杂类型的配置及类型转换。

参考资料

Castle的官方网站http://www.castleproject.org
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: