Demo客户端相关规范 v1.0
目录
更新日志
更新时间 | 更新日志 | 更新人员 |
---|---|---|
2019/08/09 | 完成v1.0版本文档 | CraigTaylor |
开发环境
开发工具
组件名 | 描述 | 可选版本 | 推荐版本 |
---|---|---|---|
Visual Studio Community | 社区免费版 | For Visual Studio 2017 | For Visual Studio 2019 |
Visual Studio Professional | 专家收费版 | For Visual Studio 2017 | For Visual Studio 2019 |
Visual Studio Enterprise | 企业收费版 | For Visual Studio 2017 | For Visual Studio 2019 |
Visual Studio Preview | 预览免费版 | For Visual Studio Community | For Visual Studio Enterprise |
Visual Studio Code | 推荐编辑器 | For Visual Studio Code Insider | For Visual Studio Code Stable |
Visual Studio Installer Projects | 打包扩展插件 | For Visual Studio 2017 | For Visual Studio 2019 |
.NET Core Runtime | 运行时依赖 | For .NET Core 3.0 | For .NET Core 2.2 |
.NET Core SDK | 集成包依赖 | For .NET Core 3.0 | For .NET Core 2.2 |
Runtime & Hosting Bundle | 可选(IIS用) | For .NET Core 3.0 | For .NET Core 2.2 |
代码管理
项目代码
项目名称 | 项目简介 | 代码位置 |
---|---|---|
Demo.Client | 标准版项目 | Github For Demo.Client |
分支管理
分支名称 | 分支简介 | 备注 |
---|---|---|
Develop | 起到了Master分支的作用,作为最终上线代码 | 发起并入需要审核 |
CustomBranch | 私人分支,基于最新代码新建,修改后合并进入Develop |
名称管理
分支名称建议采用"用户名
-版本标记
-发布模式
-创建年月日
"格式
例如:
- Taylor-CN-Develop-20190701
- Taylor-US-Develop-20190901
Tag名称建议采用"版本标记
-发布模式
-创建年月日
-版本号
"格式
例如:
- CN-Release-20191001-v1.0.0.0
- US-Release-20191001-v1.0.0.0
打包管理
存储路径
项目名 | 测试版 | 正式版 |
---|---|---|
标准版 | \共享存储\Demo\Demo.Client\测试版 |
\共享存储\Demo\Demo.Client\正式版 |
存储结构
测试包
文件名 | 文件描述 | 文件举例 |
---|---|---|
发布模式 -版本号 -版本名称 .zip |
解压即用的程序集(必须) | Test-v1.0.0.0-标准版.zip |
发布模式 -版本号 -版本名称 -更新日志 .docx |
指定版本的更新日志(建议) | Test-v1.0.0.0-标准版-更新日志.docx |
正式包
文件名 | 文件描述 | 文件举例 |
---|---|---|
Demo -版本号 .msi |
全新安装的安装包 | Demo1.0.0.0.msi |
发布模式 -版本号 .zip |
升级更新的升级包 | Release-v1.0.0.0.zip |
名称管理
压缩包名建议采用"发布模式
-版本号
-版本名称
.zip
"格式
例如:
- Develop-v1.0.0.0-标准版.zip
- Test-v1.0.0.0-标准版.zip
- Preview-v1.0.0.0-标准版.zip
- Release-v1.0.0.0-标准版.zip
更新日志建议采用"发布模式
-版本号
-版本名称
-更新日志
.docx
"格式
例如:
- Develop-v1.0.0.0-标准版-更新日志.docx
- Test-v1.0.0.0-标准版-更新日志.docx
- Preview-v1.0.0.0-标准版-更新日志.docx
- Release-v1.0.0.0-标准版-更新日志.docx
依赖组件
内部组件
组件名 | 描述 | 推荐版本 |
---|---|---|
Demo.Core | 内部代码框架 | 1.0.0.0 |
外部组件
组件名 | 描述 | 推荐版本 |
---|---|---|
Autofac | 自动注册框架 | 4.8.1 |
AutoMapper | 自动映射框架 | 8.0.0 |
MvvmLight | MVVM绑定框架 | 5.4.1.1 |
MvvmLightLibs | MVVM绑定框架 | 5.4.1.1 |
Newtonsoft.Json | JSON解析框架 | 12.0.1 |
Google.Protobuf | Google二进制协议 | 3.7.0 |
log4net | 本地日志记录 | 2.0.8 |
WPFLocalizeExtension | 多语言扩展 | 3.3.1 |
解决方案结构
解决方案命名
标准版项目 |
---|
Demo.Client |
解决方案文件夹
描述 | 标准版 |
---|---|
基础层 | 0.Demo.Client.Infrastructure |
领域层 | 1.Demo.Client.Domain |
应用层 | 2.Demo.Client.Application |
测试集 | DemoTestProject |
主要程序 | Demo |
升级程序 | DemoAutoUpdater |
打包项目 | Setup1 |
项目文件夹
0.Demo.Client.Infrastructure
项目名称 | 项目描述 |
---|---|
Demo.Client.DataBaseAccess | 操作本地数据库 |
Demo.Client.DataContract | 接口涉及的数据模型 |
Demo.Client.Domain.Query | 领域查询 |
Demo.Client.Infrastructure.IQuery | 基础框架之接口定义 |
Demo.Client.Infrastructure.Utility | 基础框架之全局帮助类 |
1.Demo.Client.Domain
项目名称 | 项目描述 |
---|---|
Demo.Client.DomainModel | 领域模型 |
2.Demo.Client.Application
项目名称 | 项目描述 |
---|---|
Demo.Client.Application.Imp | 接口实现层 - 应用服务(包括第三方) |
Demo.Client.IApplication | 接口定义层 - 应用服务 |
Demo.Client.IRemotingService | 接口定义层 - 第三方 |
DemoTestProject
项目名称 | 项目描述 |
---|---|
Infrastructure.ConsoleTest | N/A |
命名规范
文件目录
目录 | 描述 |
---|---|
\Demo\Views \ |
存放界面 |
\Demo\Views \UserControls \ |
存放自定义控件 |
\Demo\ViewModels \ |
存放绑定 |
\Demo\TemplateSettings \ |
存放打印模板 |
\Demo\Styles \ |
存放样式文件 |
\Demo\Models \ |
存放主程序用的模型 |
\Demo\Languages \ |
存放多语言字典 |
\Demo\Converter \ |
存放界面转换器 |
\Demo\Controls \ |
存放基础控件 |
\Demo\Common \ |
存放主程序非业务帮助类 |
\Demo\BusinessCommon \ |
存放主程序业务帮助类 |
\Demo\ClientEnum \ |
存放主程序枚举 |
\Demo\Update \ |
存放主程序升级检查 |
文件命名
文件 | 描述 | 举例 |
---|---|---|
业务名称 .cs |
领域模型(数据库用) | LearnCore.cs |
业务名称 Item.cs |
领域模型(列表子项) | LearnCoreItem.cs |
业务名称 Dto.cs |
数据模型(接口服务用) | LearnCoreDto.cs |
业务名称 DtoFor分组名称 .cs |
数据模型(分组拆分) | LearnCoreDtoForPrice.cs |
业务名称 ItemDto.cs |
数据模型(列表子项) | LearnCoreItemDto.cs |
业务名称 ViewDto.cs |
绑定模型(界面绑定) | LearnCoreViewDto.cs |
业务名称 ViewDtoFor分组名称 .cs |
绑定模型(分组拆分) | LearnCoreViewDtoForPrice.cs |
业务名称 Page.xaml |
界面定义 | MainPage.xaml |
业务名称 Control.xaml |
控件定义 | MainControl.xaml |
业务名称 ViewModel.cs |
绑定定义(数据绑定) | MainViewModel.cs |
业务名称 ViewModelFor分组名称 .cs |
绑定定义(分组拆分) | MainViewModelForLearnCore.cs |
代码命名
业务 | 描述 | 举例 |
---|---|---|
I 业务名 RemotingService |
接口定义 - 学习API服务 | ILearnCoreRemotingService |
业务名 RemotingService |
接口实现 - 学习API服务 | LearnCoreRemotingService |
I 业务名 Service |
接口定义 - 学习服务 | ILearnCoreService |
业务名 Service |
接口实现 - 学习服务 | LearnCoreService |
I 数据表名 QueryService |
接口定义 - 学习查询数据 | ILearnCoreQueryService |
数据表名 QueryService |
接口实现 - 学习查询数据 | LearnCoreQueryService |
辅助调试
附加自动策略
添加位置
\App_Data\LocalConfigs\PublishMode.json
配置说明
PublishMode
描述发布模式
枚举名 | 含义 | 数值 |
---|---|---|
Release | 正式上线-正式环境 | 1 |
Preview | 发布预览-正式环境 | 2 |
Test | 测试使用-测试环境 | 3 |
Develop | 开发自用-测试环境 | 4 |
AutomaticType
描述自动操作
枚举名 | 含义 | 数值 |
---|---|---|
AutoLogin | 自动登录 | 1 |
MainFullScreen | 主界面全屏 | 2 |
ViceSizeScreen | 自定义副屏尺寸 | 3 |
配置举例
{
"PublishMode": 4,
"PublishName": "开发自用-测试环境",
"AutomaticConfigs":[
{
"AutomaticType": 1,
"AutomaticName": "自动登录,XXX家的账号",
"AutomaticValues":[ "username","@userSuffix","password"]
},
{
"AutomaticType": 2,
"AutomaticName": "主界面全屏",
"AutomaticValues":[ false ]
},
{
"AutomaticType": 3,
"AutomaticName": "缩小副屏",
"AutomaticValues":[ 1024,600]
}
]
}
{
"PublishMode": 3,
"PublishName": "测试使用-测试环境",
"AutomaticConfigs":[
{
"AutomaticType": 1,
"AutomaticName": "自动登录,XXX家的账号",
"AutomaticValues":[ "username","@userSuffix","password"]
},
{
"AutomaticType": 2,
"AutomaticName": "主界面全屏",
"AutomaticValues":[ false ]
},
{
"AutomaticType": 3,
"AutomaticName": "缩小副屏",
"AutomaticValues":[ 1024,600]
}
]
}
公共资源
.Net Core
- .Net Core 2.2:https://dotnet.microsoft.com/download
- .Net Core 3.0:https://dotnet.microsoft.com/download/dotnet-core/3.0
Demo客户端相关规范 v1.0的更多相关文章
- Linux系统部署规范v1.0
Linux系统部署规范v1.0 目的: 1.尽可能减少线上操作: 2.尽可能实现自动化部署: 3.尽可能减少安装服务和启动的服务: 4.尽可能使用安全协议提供服务: 5.尽可能让业务系统单一: 6.尽 ...
- arcconf工具相关命令V1.0
arcconf工具相关命令V1.0 清除当前所有raid配置 Arcconf delete 1 array all #删除所有逻辑盘 Arcconf uninit 1 all ...
- Python代码项目目录规范v1.0
程序目录规范:bin # 存放可执行程序 xxxx.py # 程序主程序(入口文件)config # 存放配置信息 settings.py # 全局配置文件(可能暂时未应用)db # 存放数据文件 c ...
- 【iCore4 双核心板】DEMO V1.0 测试程序发布
iCore4 Demo V1.0程序说明 一.概要 本资料包含5个文件夹: 1.“arm”里是iCore4上arm的程序包,开发环境为KEIL5.17: 2.“fpga”里是iCore4上FPGA的程 ...
- 【iCore1S 双核心板】DEMO V1.0 测试程序发布
iCore1S Demo V1.0程序说明 一.概要 本资料包含5个文件夹: 1.“ARM”里是iCore1S上ARM的程序包,开发环境为KEIL5.17: 2.“FPGA”里是iCore1S上FPG ...
- 安卓开发开发规范手册V1.0
安卓开发开发规范手册V1.0 之前发布过一份Web安全开发规范手册V1.0,看到收藏文章的读者挺多,发现整理这些文档还挺有意义. 最近周末抽了些时间把之前收集关于安卓安全开发的资料也整理了一下,整理出 ...
- [iOS UI进阶 - 2.0] 彩票Demo v1.0
A.需求 1.模仿“网易彩票”做出有5个导航页面和相应功能的Demo 2.v1.0 版本搭建基本框架 code source:https://github.com/hellovoidworld/H ...
- MingQQ v1.0高仿版开源了,使用WebQQ协议实现了QQ客户端基本的聊天功能...
MingQQ v1.0高仿版开源了,使用WebQQ协议实现了QQ客户端基本的聊天功能... MingQQ目前支持的功能如下:1.支持普通方式登录.验证码方式登录.注销.保持在线.改变在线状态.2.支持 ...
- Rookey.Frame v1.0快速开发平台-用户登录
上一次介绍的了Rookey.Frame v1.0快速开发平台的整体功能,接下来会对各个功能点进行解析说明,今天给大家介绍下系统登录功能. 用户登录 系统中基本上所有功能页面都是从后台代码拼接后返回的, ...
随机推荐
- AtCoder Beginner Contest 143 F - Distinct Numbers
题意 给出一个长度为NNN的序列,求对于所有k∈[1,N]k\in[1,N]k∈[1,N],每次从序列中选出kkk个互不相同的数,最多能取多少次. N≤3e5N\le3e5N≤3e5 题解 我们首先把 ...
- js的使用及语法
通常,通过 JavaScript,您需要操作 HTML 元素. 1.通过 id 找到 HTML 元素 2.通过标签名找到 HTML 元素 3.通过类名找到 HTML 元素 提示:通过类名查找 HTML ...
- python 装饰器之应用示例
import time import hashlib import pickle import threading #装饰函数缓存应用 cache ={} def is_obsolete(entry, ...
- 【中国剩余定理-入门】-C++
中国剩余定理也称孙子定理,是中国古代求解一次同余式组(见同余)的方法.是数论中一个重要定理. 这玩意在luogu居然有模板题: [TJOI2009]猜数字 先来看一个问题: 在<孙子算经> ...
- 百度UEditor编辑器从word粘贴公式
官网地址http://ueditor.baidu.com Git 地址 https://github.com/fex-team/ueditor 参考博客地址 http://blog.ncmem.com ...
- exam8.29
咕了好几篇后... 我终于开始重新写了 T1: 不会,没思路,暴搜还可能会(一开始我以为暴搜时间复杂度为$\Theta (mn ^ k)$) 于是码出了暴搜... 跑一遍$(4,4,5)$,然后... ...
- 决策单调性优化DP学习笔记
用途 废话,当然是在DP式子满足某些性质的时候来优化复杂度-- 定义 对于\(j\)往大于\(j\)的\(i\)转移,可以表示成一个关于\(i\)的函数\(f_j(i)\),也就是\(dp_i=\ma ...
- JDBC_MySQL8.0.13_连接测试
前言 手贱把MySQL升级到了8.0.13,在IntelliJ IDEA中测试连接不上.因此记录一下,供个人以后参考. 系统环境 win10x64 jkd11 IDEA MySQL 8.10.13 C ...
- Python基础之给函数增加元信息
1. 参数注解 当写好一个函数以后,想为这个函数的参数添加一些额外的信息,这样的话,其他的使用者就可以清楚的知道这个函数应该怎么使用,这个时候可以使用函数参数注解. 函数参数注解能提示程序员应该怎样正 ...
- selenium鼠标下滑操作
# coding = utf-8 import time from selenium import webdriver from selenium.webdriver.common.by import ...