• ATK-DataPortal 设计框架(三)


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

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

    框架设计了两个数据门户,一是支持本地访问,二是支持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

     

     

     

     

     

     

  • 相关阅读:
    第22章 Makefile基础
    第 36 章 TCP/IP协议基础
    socket通信
    移植zlib
    GNU Autotool介绍
    移植sqlite
    关于wireshark的使用
    关于UDP通信的参考目录
    线程问题
    大数据核心知识点:Hbase、Spark、Hive、MapReduce概念理解,特点及机制
  • 原文地址:https://www.cnblogs.com/athinker/p/9692729.html
Copyright © 2020-2023  润新知