Castle.Net 基本应用

什么是Castle

Castle是针对.NET平台的一个开源项目,从数据访问框架ORM到IOC容器,再到WEB层的MVC框架、AOP,基本包括了整个开发过程中的所有东西,为我们快速的构建企业级的应用程序提供了很好的服务。

官方网站:http://www.castleproject.org/

提到Castle就不得不说说IOC容器.

IOC容器

IOC(Inversion of Control,反转控制)是一种面向对象设计原则, 是面向对象领域新兴的编程思想 。其原理是组件本身并不与其他组件建立直接的依赖关系,依赖关系将在组件之外的某个地方建立。这样做主要是为了解耦类之间的关系,使得类更加容易测试、重 用,系统更加容易组装和配置。这些先进技术极大促进了软件开发的发展。

还有一种解释:控制反转意味着在系统开发过程中,设计的类将交由容器去控制,而不是在类的内部去控制,类与类之间的关系将交由容器处理,一个类在需 要调用另一个类时,只要调用另一个类在容器中注册的名字就可以得到这个类的实例,与传统的编程方式有了很大的不同,”不用你找,我来提供给你”,这就是控 制反转的含义.

其实说明白了, 反转控制就是依赖注入,两者概念一样.最终目标是都是为了降低系统的耦合关系.

Castle.Net简单应用

说是简单应用,就不对一些特殊操作做出解释啦,具体的系列文章可以看看TerryLee  的Castle.net系列文章.不过就是版本旧了点.

我下载的是Castle.Windsor.2.5.3.可以到官网上去下载.

此例来做一个发送消息的简单例子.来学习Castle.

首先建立两个接口,一个发送消息接口ISend,一个信息内容格式接口IMessage,这里可以形象的把接口当成服务来看.

namespace CastleNetDem2.Container
{
    public interface ISend
    {
        void Send(string Sendform, string SendTo, string Message);
    }
}
namespace CastleNetDem2.Container
{
    public interface IMessage
    {
        string FormMessage(string message);
    }
}

然后建立实现了这俩个服务的组件,即实现类.

namespace CastleNetDem2.Components
{
   public class MessagePro : IMessage
    {
       
        public string FormMessage(string message)
        {
            return "[" + message + "]";
        }
 
    }
}
 
 
namespace CastleNetDem2.Components
{
    public class SendPro : ISend
    {
        public SendPro() { }
 
        private IMessage _msgObj;
        public SendPro(IMessage msg) 
        {
            this._msgObj = msg;
        }
 
        public void Send(string Sendform, string SendTo, string Message)
        {
            Console.WriteLine("{0}发送给{1}消息:{2}", Sendform, SendTo, _msgObj.FormMessage(Message));
        }
    }
}

下面最重要的就是编写配置文件,

<configSections>
    <section name="castle" type="Castle.Windsor.Configuration.AppDomain.CastleSectionHandler, Castle.Windsor"/>
  </configSections>
  <castle>
    <components>
      <component id="Container.SendPro" service="CastleNetDem2.Container.ISend, CastleNetDem2"
                 type="CastleNetDem2.Components.SendPro, CastleNetDem2">
        <parameters>
          <msg>${Message}</msg>
        </parameters>
      </component>
 
      <component id="Message" service="CastleNetDem2.Container.IMessage, CastleNetDem2"
                 type="CastleNetDem2.Components.MessagePro, CastleNetDem2"/>
    </components>
  </castle>

这里需要注意SendPro的构造注入需要传入一个Message对象.用${}来引入.

测试:

static void Main(string[] args)
        {
            //容器
            IWindsorContainer container = new WindsorContainer(new XmlInterpreter());
 
            ISend send = container.GetService<ISend>();
 
            send.Send("MisYan", "MisJia", "我到家了.");
 
            Console.ReadKey();
        }

运行结果:

补充

component节点的parameters类型说明:

更具体的说明请访问:http://www.cnblogs.com/Terrylee/archive/2006/04/24/383196.html

Castle.Windsor.2.5.3 需要引入的 DLL文件Castle.Core.dll,Castle.Windsor.dll

总结

其实注入就是不用去手动的实例化你的对象,而由容器帮你完成这一系列的操作.用IBatis.Net结合Castle使用,想必会非常强大..

时间: 2024-10-24 08:38:03

Castle.Net 基本应用的相关文章

再论IBatisNet + Castle进行项目的开发

随着项目的进展,Castle和IBatisNet给我的惊喜更多.Com+很重,不需要分布式的中小项目慎用,NHibernate虽好,NHibernate的2005-9-20发布了最新版本1.0-rc1,缺少高水平的OO设计师,项目组程序员水平参次不齐 ,应用Castle + IBatisnet大家不会再把精力浪费到数据访问,事务处理,主键生成等地方了,可以集中精力进行业务组件的编写.项目的进展很顺利.    从架构上讲,Castle作为轻量级Ioc容器无疑要位于高位,所以iBatisNet现在只

升级个人网站框架组件IBatisNet+Castle

<sqlMap namespace="Sequence" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"  xsi:noNamespaceSchemaLocation="SqlMap.xsd"> -- </sqlMap> 更改为 <?xml version="1.0" encoding="UTF-8" ?> &l

应用IBatisNet+Castle进行项目的开发

最近在做一个项目,项目的需求不够明确,这是做项目的大忌,但是没有办法.项目的架构采用Dotnet平台使用C#进行开发,为了加快项目的开发进度,采用代码生成工具之MyGeneration 生成业务基本代码,数据持久层采用IBatisNet,事务处理采用Castle的事务处理代码块,整体采用Castle IOC容器进行组装.       IBatisNet的SQL语句放在XML文件中,SQL语句同代码的分离,带来的好处很多,修改数据库的结构,只需要使用代码生成器生成XML文件和数据库表对应的业务实体

在asp.net页面上得到Castle容器的实例

在项目中使用Castle IOC容器,Asp.net程序中如何得到Castle容器内. 可以如下实现: 1.Gloabal实现接口IContainerAccessor public class Global : System.Web.HttpApplication, IContainerAccessor      { /// <summary>         /// 必需的设计器变量.         /// </summary>          private System.

对Castle Windsor的Resolve方法的解析时new对象的探讨

依赖注入框架Castle Windsor从容器里解析一个实例时(也就是调用Resolve方法),是通过调用待解析对象的构造函数new一个对象并返回,那么问题是:它是调用哪个构造函数呢? 无参的构造函数 带参但参数不是靠依赖注入的构造函数 带参且参数是靠依赖注入的构造函数 有多个带参且参数是靠依赖注入的构造函数 带着这个问题,我写了一段测试代码. 测试1: 只有一个无参构造函数: CtorTest类(在控制台程序里用Windsor解析这个类) public class CtorTest { pub

NET Core 整合Autofac和Castle

NET Core 整合Autofac和Castle 阅读目录 前言: 1.ASP.NET Core中的Autofac 2.整合Castle的DynamicProxy 3.注意事项 回到目录 前言: 除了ASP.NETCore自带的IOC容器外,我们还可以使用其他成熟的DI框架,如Autofac,StructureMap等(笔者只用过Unity,Ninject和Castle). 回到目录 1.ASP.NET Core中的Autofac 首先在Project.json的Dependency节点为中添

洛谷P1457 城堡 The Castle

P1457 城堡 The Castle 137通过 279提交 题目提供者该用户不存在 标签USACO 难度提高+/省选- 提交  讨论  题解 最新讨论 暂时没有讨论 题目描述 我们憨厚的USACO主人公农夫约翰(Farmer John)以无法想象的运气,在他生日那天收到了一份特别的礼物:一张“幸运爱尔兰”(一种彩票).结果这张彩票让他获得了这次比赛唯一的奖品——坐落于爱尔兰郊外的一座梦幻般的城堡! 喜欢吹嘘的农夫约翰立刻回到有着吹嘘传统的威斯康辛老家开始吹嘘了, 农夫约翰想要告诉他的奶牛们关

Autofac 之 基于 Castle DynamicProxy2 的 Interceptor 功能

Autofac 结合 Castle DynamicProxy2 功能 Autofac 不仅作为轻量级高效的 IoC 容器,而且还能很好的与 Castle.DynamicProxy2 结合起来,实现 AOP 功能. 首先,我们需要定义拦截器,简单的定义可实现 Castle.DynamicProxy.IInterceptor 接口即可. 添加拦截器   定义好了拦截器后,如何应用到相关对象呢?有两种方式: 1)使用 Autofac.Extras.DynamicProxy2.InterceptAttr

Castle Core 4.0.0 alpha001发布

时隔一年多以后Castle 项目又开始活跃,最近刚发布了Castle Core 4.0.0 的alpha版本,主要包括的内容是DynamicProxy 和 DictionaryAdapter,日志集成工作正在开发中,这个版本主要针对的是.NET Core版本的更新. Castle.DynamicProxy可以实现动态代理的功能,这个也是很多框架的基础.也就是说它是众多开源项目向.NET Core兼容的重要基础组件.在IBatis.Net中就是使用了Castle.DynamicProxy来实现数据

分享一个简单程序(webApi+castle+Automapper+Ef+angular)

前段时间在周末给朋友做了一个小程序,用来记录他们单位的一些调度信息(免费,无版权问题).把代码分享出来.整个程序没有做任何架构.但是麻雀虽小,用到的技术也没少.WebApi+Castle+AutoMapper+Ef+angular,日志记录Log4net.初学者可以学习借鉴,虽然做的比较仓促,但是自我感觉代码写的还是比较规范. git地址:https://git.oschina.net/richieyangs/TaskRecord.git 只需修改web.config中的连接字符串,Ctrl+F