Skip to content
/ dt Public

利用 C# + XAML 进行快速业务开发的跨平台框架(搬运工)

Notifications You must be signed in to change notification settings

Daoting/dt

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

62 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

搬运工

利用 C# + XAML 进行快速业务开发的跨平台框架

GitHub Stars NuGet Downloads NuGet Downloads NuGet Downloads NuGet Downloads NuGet Downloads

概述

框架全名“数据的搬运工(Data Transfer)”,简称搬运工,缩写dt

涉及技术:.NET、UWP/WinUI、C# + Xaml、Uno Platform 、云原生。

搬运工由客户端和服务端两部分组成,是一套用于快速构建业务系统的基础技术实现和规范集,本身与具体业务无关。

  • 客户端部分通过Uno Platform支持在Windows、 浏览器(WebAssembly)、手机、Linux上跨平台运行,包括一系列可复用的前端控件和各种基础功能模块;

  • 服务端部分全面采用.NET云原生开发,提供多个通用的微服务,利用这些预定义的内容可直接快速的开发出符合常规要求的业务系统;

  • 同时,两部分都支持独立使用,也可根据规范在不同层面、不同粒度下扩展框架,从而满足特定的业务需求。

所有项目

客户端

客户端样例已在各主流应用商店中上架,请在应用商店搜索【搬运工样例】或使用以下链接进行安装:

客户端在界面布局上有个创新,内置两种界面模式:windows模式和phone模式,iOS和Android上是Phone模式;windows和wasm上支持两种模式的自动切换,当应用界面的实际宽度足够时按照windows模式显示,宽度较小时自动切换到Phone模式,两种模式的可视树根节点完全不同。

1-win_1.mp4

这样既能发挥windows上复杂布局时各区域之间的联动性

1-win.mp4

也能保证phone模式时的正确导航

1-win_2.mp4

服务端

全面采用基于 .NET 的云原生应用开发。

  • 所有服务既可以使用 Kubernetes 调度,也支持简单部署到IIS;
  • 既支持标准的微服务部署方式,也支持将所有服务合并成单体服务的部署方式。

系统未严格按照当前常见的某种具体的服务架构进行设计,而是根据自身整体架构的特点,借鉴常见架构的思想,比如DDD模式的领域事件、充血模式、数据仓库,CQRS架构的读写分离,六边形架构的微服务API设计等,结合客户端xaml的优势,使用MVVM(Model-View-ViewModel)模式开发客户端控件。实现客户端领域层和服务端领域层代码相同,既可以将业务放在客户端处理也可以稍加修改放在服务端处理,完美实现技术与业务解耦、业务逻辑解耦、业务封装复用等关键功能,为开发人员提供一种易懂易用的框架风格。总体框架图:

fm

目前提供3个通用的微服务:

  • 内核模型服务(cm),CM是Core Model的缩写,为平台提供基础的内核模型服务
  • 消息服务(msg),平台内置的基础消息服务,支持多副本部署,所有已注册的客户端在启动时调用服务端的Register方法,该Api采用基于http2协议的ServerStream模式,即:客户端发送一个请求,服务端返回数据流响应,相当于在服务端和客户端建立了长连接,服务端可以实时向客户端推送信息
  • 文件服务(fsm),统一管理应用范围内使用的文件,在k8s中支持多副本部署,支持分卷存储文件,可通过ConfigMap将数据卷Volume挂载到指定目录,该服务只负责文件的上传下载和文件管理功能,不涉及具体的业务问题,在功能和Api上较稳定。