snowy/README.md

262 lines
11 KiB
Markdown
Raw Normal View History

<div align="center">
<p align="center">
<img src="./_web/public/logo.png" height="150" alt="logo"/>
</p>
</div>
2020-12-01 15:26:53 +00:00
### 框架介绍
2021-04-13 03:04:23 +00:00
<div><h5>Snowy是小诺团队下基于SpringBoot+AntDesignVue开发的Java全新RBAC权限管理系统前后分离注释丰富代码简洁。在国策讲究自主可控的时候适配国产数据库金仓、达梦、主流数据库Mysql、Oracle、Mssql、Postgresql小诺的产品一致追求简洁干净一套代码搞定同时支持国产中间件部署、麒麟操作系统、Windows、Linux部署使用。</h5></div>
2021-04-13 03:09:31 +00:00
<div align="center"><h5 align="center">Snowy谐音“小诺”恰应小诺团队名称意思为”下雪的、纯洁的“寓意框架追求简洁至上大道至简。</h5></div>
2020-12-01 15:26:53 +00:00
2020-12-01 12:53:52 +00:00
<p align="center">
<p align="center">
2021-01-05 05:39:02 +00:00
<a href="https://www.antdv.com/docs/vue/introduce-cn/">
<img src="https://img.shields.io/badge/vue-2.x-blue.svg" alt="bootstrap">
</a>
2020-12-01 12:53:52 +00:00
<a href="https://www.antdv.com/docs/vue/introduce-cn/">
<img src="https://img.shields.io/badge/vue--ant--design-2.1.0-blue.svg" alt="bootstrap">
</a>
<a href="http://spring.io/projects/spring-boot">
<img src="https://img.shields.io/badge/spring--boot-2.3.1-green.svg" alt="spring-boot">
</a>
<a href="http://mp.baomidou.com">
<img src="https://img.shields.io/badge/mybatis--plus-3.3.2-blue.svg" alt="mybatis-plus">
</a>
<a href="./LICENSE">
<img src="https://img.shields.io/badge/license-Apache%202-red" alt="license Apache 2.0">
</a>
<a href="https://gitee.com/xiaonuobase/snowy">
2021-04-13 03:07:10 +00:00
<img src="https://gitee.com/xiaonuobase/snowy/badge/star.svg?theme=dark" alt="Gitee star">
</a>
<a href="https://gitee.com/xiaonuobase/snowy">
2021-04-13 03:07:10 +00:00
<img src="https://gitee.com/xiaonuobase/snowy/badge/fork.svg?theme=dark" alt="Gitee fork">
</a>
2020-12-01 12:53:52 +00:00
</p>
</p>
2020-12-02 12:04:56 +00:00
### 快速启动
2020-12-08 09:03:16 +00:00
您的开发电脑需要安装NodeJs最新版、npm或yarn最新版建议使用yarn、Mysql5.7、Jdk1.8、Maven3.6.3配置阿里仓库地址、开发工具推荐idea
2020-12-02 12:04:56 +00:00
* 启动前端打开_web文件夹进行依赖下载运行npm install或yarn命令再运行npm run serve或 yarn run serve
2021-04-13 09:29:23 +00:00
* 启动后端打开application-local中配置数据库信息运行SnowyApplication类即可启动
2020-12-02 12:04:56 +00:00
* 浏览器访问http://localhost:81 默认前端端口为81后端端口为82
### 其他版本
2020-12-01 12:53:52 +00:00
2021-04-13 09:29:23 +00:00
* layui单体版本https://gitee.com/xiaonuobase/snowy-layui
2021-04-13 03:09:31 +00:00
* vue前后分离版本https://gitee.com/xiaonuobase/snowy
2021-04-13 09:29:23 +00:00
* cloud微服务前后分离版本https://gitee.com/xiaonuobase/snowy-cloud
* 我们的其他产品线同样开源如需关注最新动态可加入QQ群聊探讨[732230670](https://wpa.qq.com/msgrd?v=3&uin=732230670&_blank)
* 如果我们的产品能满足您的需求,很期待您给我们右上角点个 star
2020-12-01 12:53:52 +00:00
### 在线演示
2020-12-01 15:26:53 +00:00
* 账号密码superAdmin/123456地址https://vue.xiaonuo.vip
2021-01-12 15:40:51 +00:00
### 在线文档
* https://doc.xiaonuo.vip
2020-12-01 15:26:53 +00:00
2021-04-22 17:59:52 +00:00
### 架构原理图
* 业务架构
![业务架构](./_images/snowy_biz.png)
* 应用架构
![应用架构](./_images/snowy_application.png)
* 数据架构
![数据架构](./_images/snowy_data.png)
* 技术架构
![技术架构](./_images/snowy_tech.png)
* 部署架构
![部署架构]( ./_images/snowy_deploy.png )
2021-04-22 17:59:52 +00:00
2021-04-25 07:29:57 +00:00
### 效果图
<table>
<tr>
<td><img src="https://images.gitee.com/uploads/images/2021/0413/111529_02708b11_1980003.png"/></td>
<td><img src="https://images.gitee.com/uploads/images/2021/0413/111909_5957b35a_1980003.png"/></td>
</tr>
<tr>
<td><img src="https://images.gitee.com/uploads/images/2021/0413/112254_5e8a3a0b_1980003.png"/></td>
<td><img src="https://images.gitee.com/uploads/images/2021/0413/112510_90191be8_1980003.png"/></td>
</tr>
<tr>
<td><img src="https://images.gitee.com/uploads/images/2021/0413/112640_73ea49e9_1980003.png"/></td>
<td><img src="https://images.gitee.com/uploads/images/2021/0413/112804_a21e5aef_1980003.png"/></td>
</tr>
</table>
### 框架亮点及优势
1. 模块化架构设计,层次清晰,业务层推荐写到单独模块,框架升级不影响业务。
```
模块树
2021-04-13 09:29:23 +00:00
├─snowy ->项目工程
│ ├─snowy-base ->框架基础模块
│ ├─snowy-core ->核心模块
│ ├─snowy-gen ->代码生成
│ ├─snowy-system ->基础业务
│ ├─snowy-main ->业务开始模块
2021-04-25 07:29:57 +00:00
│ ├─业务 ->您的业务
```
2、独创前端字典翻译
全部字典数据储存前端store后端接口数据统一过滤器翻译
下拉框多选框等取值只需1行代码'dictData'为过滤器名称,'sex'为字典类型code返回数组字典
```
this.$options.filters['dictData']('sex')
或直接给值
{{ code | dictData }}
```
列表数据中字典翻译:('code'为字典类型唯一code'value'为待翻译的值返回name
```
{{ code | dictType(value) }}
```
3、独创的数据权限范围机制
数据范围的分配也来自于给用户单独分配的数据范围,最终决定用户有几个公司的数据范围的是,用户拥有的角色的数据范围 + 用户直接分配的数据范围
若一个用户有多个角色,系统最终判定用户有哪些数据范围是以多个角色和用户数据范围的 并集 为准。
仅通过注解就可以获取当前用户的数据范围不强制联查sql可根据业务需求极其灵活的使用
```
@DataScope
```
param类继承baseparam使用param.getDadaScope即可获取到数据权限列表
```
@EqualsAndHashCode(callSuper = true)
@Data
public class SysUserParam extends BaseParam {
```
4、独创的文件预览系统
支持txt.doc.docx.ppt.pptx.xls.xlsx.pdf.png.jpg.jpeg.bmp.gif等
预览速度快,兼容性好,支持常见文本格式.只需在运行环境一键安装libreoffice即可运行简单操作方便。
```
#libreoffice文档在线预览配置
# CentOS 下安装 libreoffice
# 安装yum -y install libreoffice
# Linux 中文字体乱码解决:
# 1、上传 C:\Windows\Fonts 下的字体到 /usr/share/fonts/windows 目录
# 2、执行命令 chmod 644 /usr/share/fonts/windows/* && fc-cache -fv
jodconverter:
local:
#暂时关闭预览,启动时会有点慢
enabled: false
#设置libreoffice主目录 linux地址如/usr/lib64/libreoffice
office-home: C:\Program Files\LibreOffice
#开启多个libreoffice进程每个端口对应一个进程
port-numbers: 8100
#libreoffice进程重启前的最大进程数
max-tasks-per-process: 100
```
5、其他优势
前后端分离架构,分离开发,分离部署,前后端互不影响。
前端技术采用vue + antdvPro + axios。
后端采用spring boot + mybatis-plus + hutool等开源可靠。
基于spring security(jwt) + 用户UUID双重认证。
基于AOP实现的接口粒度的鉴权最细粒度过滤权限资源。
基于hibernate validator实现的校验框架支持自定义校验注解。
提供Request-No的响应header快速定位线上异常问题。
在线用户可查,可在线踢人,同账号登录可同时在线,可单独在线(通过系统参数配置)。
支持前端 + 后端在线代码生成。
文件,短信,缓存,邮件等,利用接口封装,方便拓展。
短信默认使用阿里云sms缓存默认使用内存缓存。
### 框架说明及后续补充
* 纯手研发搭建框架脚手架,在自己用的时候,也为各位小伙伴打下坚固的接私活利器。
* 后续我们会行发多个版本,将适配多个数据库环境,国产化环境,并且根据多年经验会出相关系统中用到的案例,提供给大家使用!
* 如需了解我们更多请移步官网https://xiaonuo.vip
* 当然有问题讨论的小伙伴还可以加入我们的QQ技术群[732230670](https://wpa.qq.com/msgrd?v=3&uin=732230670&_blank),一起学习讨论。
2020-12-01 15:26:53 +00:00
### 详细功能
2020-12-01 12:53:52 +00:00
2020-12-01 15:26:53 +00:00
1. 主控面板、控制台页面,可进行工作台,分析页,统计等功能的展示。
2. 用户管理、对企业用户和系统管理员用户的维护,可绑定用户职务,机构,角色,数据权限等。
3. 应用管理、通过应用来控制不同维度的菜单展示。
4. 机构管理、公司组织架构维护,支持多层级结构的树形结构。
5. 职位管理、用户职务管理,职务可作为用户的一个标签,职务目前没有和权限等其他功能挂钩。
6. 菜单管理、菜单目录,菜单,和按钮的维护是权限控制的基本单位。
7. 角色管理、角色绑定菜单后,可限制相关角色的人员登录系统的功能范围。角色也可以绑定数据授权范围。
8. 字典管理、系统内各种枚举类型的维护。
9. 访问日志、用户的登录和退出日志的查看和管理。
10. 操作日志、用户的操作业务的日志的查看和管理。
11. 服务监控、服务器的运行状态Java虚拟机信息jvm等数据的查看。
12. 在线用户、当前系统在线用户的查看。
13. 数据监控、druid控制台功能可查看sql的运行信息。
14. 公告管理、系统的公告的管理。
15. 文件管理、文件的上传下载查看等操作文件可使用本地存储阿里云oss腾讯cos接入支持拓展。
16. 定时任务、定时任务的维护通过cron表达式控制任务的执行频率。
17. 系统配置、系统运行的参数的维护,参数的配置与系统运行机制息息相关。
18. 邮件发送、发送邮件功能。
19. 短信发送、短信发送功能可使用阿里云sms腾讯云sms支持拓展。
2020-12-01 12:53:52 +00:00
2021-04-25 07:29:57 +00:00
### 官方公众号
##### 微信扫码关注公众号,免费加入微信交流群,公众号不定时分享一路走来的经验!
<table>
<tr>
<td>官方公众号</td>
<td><img src="https://pan.xiaonuo.vip/?explorer/share/file&hash=3841yKGwU0dOU5EARaYCHQAw6aFaB5JptCs-ACRfO_rQw7NdogWFXIQ&name=xiaonuobase.jpg" width="120"/></td>
</tr>
</table>
2020-12-30 09:44:37 +00:00
### 参与贡献
2020-12-30 09:42:39 +00:00
2021-04-13 09:29:23 +00:00
- 欢迎各路英雄好汉参与Snowy全系版本代码贡献期待您的加入
2020-12-30 09:42:39 +00:00
- 1. Fork 本仓库
- 2. 新建 Feat_xxx 分支
- 3. 提交代码
- 4. 新建 Pull Request
### 更新日志:
2021-04-25 07:29:57 +00:00
更新日志https://doc.xiaonuo.vip/snowy_vue/#%E6%9B%B4%E6%96%B0%E6%97%A5%E5%BF%97
2020-12-02 12:04:56 +00:00
### 版权说明
2021-04-13 09:29:23 +00:00
- Snowy生态技术框架全系版本采用 Apache License2.0协议
- 代码可用于个人项目等接私活或企业项目脚手架使用Snowy全系开源版完全免费
- 二次开发请不要删除和修改根目录下的LICENSE文件及代码头部作者声明。
2021-04-13 09:29:23 +00:00
- 请不要删除和修改Snowy源码头部的版权声明及出处。
2020-12-02 12:04:56 +00:00
### 小诺技术团队荣誉作品
2020-12-01 12:53:52 +00:00
| 成员组成 | 负责内容 |
| :---: | :---: |
| 俞宝山 | 全栈 |
| 徐玉祥 | 全栈 |
| 董夏雨 | 全栈 |