snowy/README.md

295 lines
13 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是一款基于国产密码算法后台权限管理系统其中采用了SM2、SM3、SM4及签名验签软件层面完全符合等保测评要求让更多的人认识密码使用密码。技术框架与密码结合让前后分离“密”不可分。</h5></div>
<div><h4>结合SpringBoot+AntDesignVue开发注释丰富代码简洁。适配国产数据库金仓、达梦、主流数据库Mysql、Oracle、Mssql、Postgresql小诺的产品一致追求简洁干净一套代码搞定同时支持国产中间件部署、麒麟操作系统、Windows、Linux部署使用。</h4></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">
<a href="https://gitee.com/xiaonuobase/snowy">
<img src="https://gitee.com/xiaonuobase/snowy/badge/star.svg?theme=dark" alt="Gitee star">
</a>
<a href="https://gitee.com/xiaonuobase/snowy">
<img src="https://gitee.com/xiaonuobase/snowy/badge/fork.svg?theme=dark" alt="Gitee fork">
</a>
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-1.5.6-blue.svg" alt="bootstrap">
2020-12-01 12:53:52 +00:00
</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>
2020-12-01 12:53:52 +00:00
</p>
</p>
2020-12-02 12:04:56 +00:00
### 快速启动
2021-10-14 09:34:54 +00:00
您的开发电脑需要安装NodeJs14.x、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
2021-06-15 16:14:12 +00:00
### 快速链接
* 演示地址(superAdmin/123456)https://snowy.xiaonuo.vip
* 在线文档https://doc.xiaonuo.vip
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
2021-10-27 17:43:57 +00:00
<img src="https://pan.xiaonuo.vip/?explorer/share/fileOut&shareID=7qwJHENw&path=%7BshareItemLink%3A7qwJHENw%7D%2F"/>
2020-12-01 12:53:52 +00:00
### 密码分步:fire:
| 功能 | 算法类型 |
| ---------------------- | ------------- |
| 登录 | SM2前端加密后端解密 |
| 登录登出日志 | SM2对登录登出日志做签名完整性保护存储 |
| 操作日志 | SM2对操作日志做签名完整性保护存储 |
| Token | SM4cbc模式加密Token不再曝光暴露 |
| 用户密码 | SM3完整性保护存储登录时做完整性校验 |
| 用户手机号 | SM4cbc模式加解密使用字段脱敏 |
2021-09-02 04:50:04 +00:00
### 视频教程:fire:
| 序号 | 链接地址 |
| ---------------------- | ------------- |
| 1 | [小诺开源技术团队及框架介绍](https://www.bilibili.com/video/BV1Yf4y1N7YU?from=search&seid=16730766915542181758) |
| 2 | [小诺框架Snowy基础环境介绍](https://www.bilibili.com/video/BV1yA411c7d3) |
| 3 | [Snowy代码下载及启动](https://www.bilibili.com/video/BV1SP4y1p7M8) |
| 4 | [Snowy生成一个完整的前后端模块](https://www.bilibili.com/video/BV1Ry4y1G7er) |
更新中。。。
2021-05-18 17:09:18 +00:00
### 升级计划:fire:
2021-10-14 09:34:54 +00:00
2.0版本正在全力打造中
2021-05-18 17:09:18 +00:00
2020-12-01 15:26:53 +00:00
2021-04-22 17:59:52 +00:00
### 架构原理图
* 业务架构
<p align="center">
<img src="https://pan.xiaonuo.vip/?explorer/share/fileOut&shareID=7qwKTmEw&path=%7BshareItemLink%3A7qwKTmEw%7D%2F"/>
</p>
2021-04-22 17:59:52 +00:00
* 应用架构
<p align="center">
<img src="https://pan.xiaonuo.vip/?explorer/share/fileOut&shareID=7qwKfxFw&path=%7BshareItemLink%3A7qwKfxFw%7D%2F"/>
</p>
2021-04-22 17:59:52 +00:00
* 数据架构
<p align="center">
<img src="https://pan.xiaonuo.vip/?explorer/share/fileOut&shareID=7qwKrjRw&path=%7BshareItemLink%3A7qwKrjRw%7D%2F"/>
</p>
2021-04-22 17:59:52 +00:00
* 技术架构
<p align="center">
<img src="https://pan.xiaonuo.vip/?explorer/share/fileOut&shareID=7qwK4RoA&path=%7BshareItemLink%3A7qwK4RoA%7D%2F"/>
</p>
2021-04-22 17:59:52 +00:00
* 部署架构
<p align="center">
<img src="https://pan.xiaonuo.vip/?explorer/share/fileOut&shareID=7qwLD35w&path=%7BshareItemLink%3A7qwLD35w%7D%2F"/>
</p>
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-05-24 09:05:29 +00:00
### 官方微信群
2021-04-25 07:29:57 +00:00
2022-01-25 16:34:34 +00:00
因群达到200人以上需加微信拉群
2021-04-25 07:29:57 +00:00
<table>
<tr>
2021-05-24 09:05:29 +00:00
<td>微信群</td>
<td><img src="https://pan.xiaonuo.vip/?explorer/share/fileOut&shareID=7qwFVcdA&path=%7BshareItemLink%3A7qwFVcdA%7D%2F" width="120"/></td>
2021-04-25 07:29:57 +00:00
</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
2022-01-25 16:34:34 +00:00
### 曾获荣誉:
<p align="center">
<img src="https://pan.xiaonuo.vip/?explorer/share/fileOut&shareID=7xtGQLOA&path=%7BshareItemLink%3A7xtGQLOA%7D%2F"/>
</p>
2020-12-02 12:04:56 +00:00
### 版权说明
2021-04-13 09:29:23 +00:00
- Snowy生态技术框架全系版本采用 Apache License2.0协议
- 代码可用于个人项目等接私活或企业项目脚手架使用Snowy全系开源版完全免费
2021-07-13 06:21:20 +00:00
- 二次开发如用于商业性质或开源竞品请先联系群主审核。
- 请不要删除和修改Snowy源码头部的版权与作者声明及出处。
2020-12-02 12:04:56 +00:00
### 小诺技术团队荣誉作品
2020-12-01 12:53:52 +00:00
| 成员组成 | 负责内容 |
| :---: | :---: |
| 俞宝山 | 全栈 |
| 徐玉祥 | 全栈 |
| 董夏雨 | 全栈 |