Spring的应用

最近在做webapi项目中用到了Spring框架,个人理解就是用来映射接口和接口实现的,映射关系都写在一个xml文件中(SpringService.xml)

我们项目中是这样获取这个文件的,代码如下:(需要引用Spring.Context,Spring.Context.Support)

 public static class SpringService
    {
        static IApplicationContext context;
        static SpringService()
        {
            context = new XmlApplicationContext(AppDomain.CurrentDomain.BaseDirectory + @"SpringService.xml");
        }

        public static object GetObject(string objectName)
        {
            return context.GetObject(objectName);
        }
    }

接着,定义了一个interface IService,里面包含了各个业务逻辑的接口,类似如下图所示:

IService里面的业务接口命名要和Spring xml文件中的节点名称一致

创建一个ServiceFactory类将获取到的springservice转换为Iservice,代码如下:(我们这边有市场划分,不同市场调用不同的业务逻辑层)

public class ServiceFactory
    {
        public static IService GetService(string marketCode)
        {
            return SpringService.GetObject("MC_" + marketCode) as IService;
        }

        /// <summary>
        /// 当前用户MarkerCode对应的Service,        
        /// </summary>
        public static IService CurrentService
        {
            get
            {
                return GetService(GlobalServerConfig.MarketCode);
            }
        }
    }

这边再来看下springservice的xml文件是怎样的,如下图:

红框圈中的name则是对应了返回IService里面的业务模块接口命名“SecurityBLL”,ref引用的是xml下面BLL具体内容的节点名称"iSecurityBLLJP"。这个节点type中有两段内容,后面那段C2Global.Server.Business.Security.BusinessRule是这个业务接口模块所在的项目名称,前面那段C2Global.Server.Business.Security.BusinessRule.SecurityBLLBase是这个业务模块接口具体实现代码所在项目的.cs文件名。这样就完成了接口到接口实现类的一个映射,Controller中定义的Action可以取调用到这些业务模块。

Controller调用过程:

1.首先创建一个基础类APIServiceBase,这个借口继承ApiController,包含一个IService类型的对象CurrentService,所有的Controller继承这个基础类,可通过这个服务对象来调用BLL层方法,代码如下:

 public class APIServiceBase : ApiController
    {
        #region Logic
        /// <summary>
        /// 当前用户MarkerCode对应的Service        
        /// </summary>
        public IService CurrentService
        {
            get
            {
                return ServiceFactory.GetService(GlobalServerConfig.MarketCode);
            }
        }
        #endregion
    }

2.在SecurityBLL接口(接口名为ISecurityBLLOmni,IService包含这个类型的接口,命名为SecurityBLL)中定义一个接口,代码如下:

bool IsExistsMac(string CounterCode, string SequenceNum);

3.创建BLL层实现类SecurityBLLBase,继承上面的接口ISecurityBLLOmni,需定义好其包含接口的具体实现方法,代码如下:

        /// <summary>
        /// 验证MAC是否存在
        /// </summary>
        /// <param name="mac"></param>
        /// <returns></returns>
        public virtual bool IsExistsMacs(string mac, string deviceId)
        {
            return SecurityDAL.IsExistsMacs(mac, deviceId);
        }

4.创建一个SecurityController,定义一个Action方法,然后通过CurrentService来调用SecurityBLL中的接口,代码如下:

        /// <summary>
        /// 是否已经存在该计算机的信息
        /// </summary>
        /// <param name="CounterCode"></param>
        /// <param name="SequenceNum"></param>
        /// <returns></returns>
        [HttpGet]
        public bool IsExistsMac([FromUri]MacDto dto)
        {
            return CurrentService.SecurityBLL.IsExistsMac(dto.CounterCode, dto.PcNo);
        }

尽管只是调用接口,但是因为做了之前一系列的Spring映射,所以不需要去调用接口的实现方法,也可以知道接口应该如何执行,如何实现,Spring会去找到调用接口的实现类。

表述可能不太清晰,比较凌乱,是我自己个人的总结和理解,欢迎讨论。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值