ATK-DataPortal 设计框架(三)

20 篇文章 0 订阅
12 篇文章 0 订阅

边界清晰、服务自治、契约共享、基于策略的兼容性,是面向对向设计时四个基本原则,我们的应用可能分布在不同的环境之中,应用可能在同一服务器中,也可能在不同的网络环境中,保证框架的基类能在不同环境中仍然可用,也就是在分布式环境中仍然可用,是框架设计的一个目标。

为保证业务逻辑和数据访问能正确分离,框架设计了数据门户,以使在必要时,保证数据层和业务层分布在不同的逻辑环境中时业务访问仍然可用。

框架设计了两个数据门户,一是支持本地访问,二是支持WCF服务访问

数据门户的通过IDataPortal接口的类DataPortal<E>来实现的

一、IDataPortal接口

 

 public interface IDataPortal<E>  where E : BusinessBase, IBusinessBaseContext

    {

        OperateState Insert(E obj);

 

        OperateState Delete(E obj);

 

        OperateState Update(E obj);

 

        E Fetch(E obj);

 

        OperateState Execute(E obj);

}

 

实现了增删改查的基本数据方法,同时也定义了支持执行类型的数据操作Execute(E obj);方法。

 

二、DataPortal<E>类,是门户类的实现

    public class DataPortal<E> : IDataPortal<E> where E : BusinessBase, IBusinessBaseContext

    {

}

DataPortal<E>类简单的实现的IDataPortal接口所定义的方法,其实际的操作在两个代理类

 

三、LocalProxy<T>本地代理

本地代理主要是为当前前端和服务器端布署在应用服务中,此时,前端可直接访问到数据层,不需要复杂的操作。

四、WcfProxy<T> WCF代理

WCF代理类处理业务层和数据层不能直接访问,数据层中的业务是通过WCF服务向其他应用公开的,WcfProxy<T> 提供了一个一至的服务访问,所有基于ATK-DataPortal的基类实现的类,都可通过WcfProxy<T> 提供的方法正确访问。

 

 

----

ATK

1、一个完整支持分布式服务框架;

2、代码生成工具,可快速生成基于服务框架的应用;

3、其他支持库

4、完整代码可在GitHub的https://github.com/azthinker ;开源中国 https://gitee.com/azthinker

目标:使应用开发,低代码、高效率、快迭代

有兴趣的请在QQ群中参与讨论、联系作者  QQ群名称:ATK高效开发 ,QQ群号:747049962

也可发邮件至:azthinker@sina.com

Demo中的数据库、编译好的代码工具链接:https://pan.baidu.com/s/1B9RQm7_-SFyhLb_HLIGs0w 密码:85q6

ATK Demo使用的数据库 : https://download.csdn.net/download/xftyyyyb/10675497

ATK自动代码工具 :https://download.csdn.net/download/xftyyyyb/10675490

 

 

 

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值