### 一、序言
`UCode Cms`是面向企业级应用软件开发的脚手架。希望构造一个合起来是一个系统,拆分出来是独立的组件,供其它项目复用。
本项目与其它项目的显著区别是拒绝摊大饼式功能集成,核心追求是代码和功能复用。
##### 当前版本
```xml
<version>1.5.2.1</version>
```
### 二、项目基本情况
#### (一)项目特点
##### 1、源码开源
源码开源并且使用MIT开源许可协议,个人或者企业用户免费放心使用,项目源码地址:
```bash
git clone https://gitee.com/decsa/ucode-cms-vue.git
```
##### 2、快速上手
新建空项目,引入相关依赖,初始化数据库,启动项目,一个项目脚手架便搭建完成,更加便捷的操作是克隆[demo项目],修改数据库连接并启动项目。
```xml
<!--ucode-cms核心依赖-->
<dependency>
<groupId>xin.altitude.cms</groupId>
<artifactId>ucode-cms-spring-boot-starter</artifactId>
<version>1.5.2.1</version>
</dependency>
```
#### (二)项目的内在逻辑
市面上各种管理系统做的非常好,作者无意重复造轮子,简要本项目的初衷。
大部分管理系统属于大杂烩性质的,说的难听点是堆砌功能,其实很多时候仅仅是想用其做个项目初始环境脚手架而已,并不想用过多的功能,齐全的功能此时却是累赘。
第一个特点:`积木式结构`。积木式结构允许使用者在核心依赖的基础上自由选择功能模块,体现的思想是功能复用,减少无意义的功能开发。
第二个特点:`暴露配置`。隐藏源码,暴露配置意味着使用者既能通过配置文件修改系统行为,又能较少的与不相干源码打交道。
第三个特点:`标准化代码`。鼓励使用者按照项目的框架提炼公共代码,按照类似插件性质予以封装,为本项目添砖加瓦。
##### 1、标准化
标准化是UCodeCms项目的核心内涵,即将通用性的功能浓缩成不可修改的互相独立的Maven依赖,用户使用时可`按需配置`。
##### 2、高内聚低耦合
广泛使用高内聚低耦合设计原则,将用户很少修改的源码进行封装,同时对外提供可供修改配置的开关,降低使用成本。
##### 3、积木式项目结构
核心依赖仅需要引入`ucode-cms-spring-boot-starter`便可初始化项目,starter内置其余核心依赖。
### 三、项目细节
#### (一)项目结构
UCode Cms源码项目结构如下
```text
├── cms-ui // 系统UI部分源码
├── sql // 系统数据库SQL脚本
├── ucode-cms-admin // 测试demo项目(非必选)
├── ucode-cms-code // 代码生成器源码
├── ucode-cms-code-spring-boot-starter // 代码生成器starter
├── ucode-cms-common // 通用代码部分(核心依赖、可跨项目使用)
├── ucode-cms-excel // Excel处理模块源码
├── ucode-cms-framework // 核心依赖
├── ucode-cms-job // 任务调度源码
├── ucode-cms-monitor // 系统监控源码
├── ucode-cms-spring-boot-starter // 核心starter
├── ucode-cms-system // 系统部分源码
└── ucode-cms-ui // 系统UI部分依赖
```
#### (二)项目依赖
`UCode Cms`使用的是热门主流框架依赖。
| 依赖 | 版本 |
| ---------------- | ---------- |
| JDK | 1.8 |
| Spring Framework | 5 |
| Spring Boot | 2.6.3 |
| Mybatis Plus | 3.5.0 |
| hutool | 5.7.19 |
| Guava | 31.0.1-jre |
### 四、对外复用依赖
本系统基于Spring生态,除了满足自身需求外,还能够以Maven依赖的方式对外提供功能和代码的复用。
##### 1、公共代码
公共代码依赖广泛应用于本项目中,同时也能以工具类的方式对外提供服务。
```xml
<dependency>
<groupId>xin.altitude.cms</groupId>
<artifactId>ucode-cms-common</artifactId>
<version>1.5.2.1</version>
</dependency>
```
##### 2、代码生成器
作者很懒,对于重复性代码连复制粘贴的欲望也没有,于是跨项目版的代码生成器应运而生。支持单表代码生成、多表连接代码生成。
```xml
<dependency>
<groupId>xin.altitude.cms</groupId>
<artifactId>ucode-cms-code-spring-boot-starter</artifactId>
<version>1.5.2.1</version>
</dependency>
```
##### 3、分布式BitMap
支持编码和注解两种方式实现分布式BitMap
```xml
<dependency>
<groupId>xin.altitude.cms</groupId>
<artifactId>ucode-cms-bitmap</artifactId>
<version>1.5.2.1</version>
</dependency>
```
##### 4、分布式限流
使用注解,基于IP或者用户的方式对接口限流,支持分布式系统。
```xml
<dependency>
<groupId>xin.altitude.cms</groupId>
<artifactId>ucode-cms-limiter</artifactId>
<version>1.5.2.1</version>
</dependency>
```
##### 5、防重复提交
对于一些增加数据的场合,由于非幂等性的原因,网络不稳定容易产生脏数据,这时可使用防重复提交功能。
```xml
<dependency>
<groupId>xin.altitude.cms</groupId>
<artifactId>ucode-cms-repeat</artifactId>
<version>1.5.2.1</version>
</dependency>
```
##### 6、分布式日志收集
基于Redis pub/sub订阅特性实现的日志收集,用消息队列的方式收集日志,然后从另外系统消费日志(数据落库)。实现了跨系统日志收集复用。
```xml
<dependency>
<groupId>xin.altitude.cms</groupId>
<artifactId>ucode-cms-log</artifactId>
<version>1.5.2.1</version>
</dependency>
```
##### 7、统计API接口响应时间
基于AOP的方式封装统计API接口响应时间,按需引入。
```xml
<dependency>
<groupId>xin.altitude.cms</groupId>
<artifactId>ucode-cms-take-time</artifactId>
<version>1.5.2.1</version>
</dependency>
```
---
> 喜欢本文点个♥️赞♥️支持一下,如有需要,可通过微信`dream4s`与我联系。相关源码在[GitHub](https://gitee.com/decsa),视频讲解在[B站](https://space.bilibili.com/1936685014),本文收藏在[博客天地](http://www.altitude.xin)。
---