liuchen864
9 months ago
commit
e1255a3332
340 changed files with 38147 additions and 0 deletions
@ -0,0 +1,53 @@ |
|||
# Build Tools |
|||
.gradle |
|||
build/ |
|||
target/ |
|||
*.zip |
|||
*.rar |
|||
|
|||
!gradle/wrapper/gradle-wrapper.jar |
|||
!.mvn/wrapper/maven-wrapper.jar |
|||
|
|||
# IDE |
|||
|
|||
### STS,Eclipse ### |
|||
.apt_generated |
|||
.classpath |
|||
.factorypath |
|||
.project |
|||
.settings |
|||
.springBeans |
|||
.gitee |
|||
.github |
|||
|
|||
### IntelliJ IDEA ### |
|||
.idea |
|||
*.iws |
|||
*.iml |
|||
*.ipr |
|||
|
|||
### JRebel ### |
|||
rebel.xml |
|||
|
|||
### NetBeans ### |
|||
/nbproject/private/ |
|||
/nbbuild/ |
|||
/dist/ |
|||
/nbdist/ |
|||
/.nb-gradle/ |
|||
!**/src/main/**/build/ |
|||
!**/src/test/**/build/ |
|||
|
|||
### VS Code ### |
|||
.vscode/ |
|||
|
|||
# Others |
|||
HELP.md |
|||
*.log |
|||
*.xml.versionsBackup |
|||
*.swp |
|||
.mvn |
|||
|
|||
#MAC |
|||
.DS_Store |
|||
win-system/src/main/resources/~$userInfo.xlsx |
@ -0,0 +1,20 @@ |
|||
The MIT License (MIT) |
|||
|
|||
Copyright (c) 2018 Win-in |
|||
|
|||
Permission is hereby granted, free of charge, to any person obtaining a copy of |
|||
this software and associated documentation files (the "Software"), to deal in |
|||
the Software without restriction, including without limitation the rights to |
|||
use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of |
|||
the Software, and to permit persons to whom the Software is furnished to do so, |
|||
subject to the following conditions: |
|||
|
|||
The above copyright notice and this permission notice shall be included in all |
|||
copies or substantial portions of the Software. |
|||
|
|||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR |
|||
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS |
|||
FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR |
|||
COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER |
|||
IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN |
|||
CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. |
@ -0,0 +1,95 @@ |
|||
<p align="center"> |
|||
<img alt="logo" src="https://oscimg.oschina.net/oscnet/up-d3d0a9303e11d522a06cd263f3079027715.png"> |
|||
</p> |
|||
<h1 align="center" style="margin: 30px 0 30px; font-weight: bold;">RuoYi v3.8.4</h1> |
|||
<h4 align="center">基于SpringBoot+Vue前后端分离的Java快速开发框架</h4> |
|||
<p align="center"> |
|||
<a href="https://gitee.com/y_project/RuoYi-Vue/stargazers"><img src="https://gitee.com/y_project/RuoYi-Vue/badge/star.svg?theme=dark"></a> |
|||
<a href="https://gitee.com/y_project/RuoYi-Vue"><img src="https://img.shields.io/badge/RuoYi-v3.8.4-brightgreen.svg"></a> |
|||
<a href="https://gitee.com/y_project/RuoYi-Vue/blob/master/LICENSE"><img src="https://img.shields.io/github/license/mashape/apistatus.svg"></a> |
|||
</p> |
|||
|
|||
## 平台简介 |
|||
|
|||
[若依](https://gitee.com/zhangmrit/RuoYi-Vue) 是一套全部开源的快速开发平台,毫无保留给个人及企业免费使用。 |
|||
|
|||
* 前端采用Vue、Element UI。 |
|||
* 后端采用Spring Boot、Spring Security、Redis & Jwt。 |
|||
* 权限认证使用Jwt,支持多终端认证系统。 |
|||
* 支持加载动态权限菜单,多方式轻松权限控制。 |
|||
* 高效率开发,使用代码生成器可以一键生成前后端代码。 |
|||
* 在原有基础上添加了 lombok mybatis-plus hutool guava |
|||
* 代码生成添加了markdown api文档 |
|||
* nested 嵌套路由分支 |
|||
* shardingsphere shardingsphere分支 |
|||
|
|||
## 内置功能 |
|||
|
|||
1. 用户管理:用户是系统操作者,该功能主要完成系统用户配置。 |
|||
2. 部门管理:配置系统组织机构(公司、部门、小组),树结构展现支持数据权限。 |
|||
3. 岗位管理:配置系统用户所属担任职务。 |
|||
4. 菜单管理:配置系统菜单,操作权限,按钮权限标识等。 |
|||
5. 角色管理:角色菜单权限分配、设置角色按机构进行数据范围权限划分。 |
|||
6. 字典管理:对系统中经常使用的一些较为固定的数据进行维护。 |
|||
7. 参数管理:对系统动态配置常用参数。 |
|||
8. 通知公告:系统通知公告信息发布维护。 |
|||
9. 操作日志:系统正常操作日志记录和查询;系统异常信息日志记录和查询。 |
|||
10. 登录日志:系统登录日志记录查询包含登录异常。 |
|||
11. 在线用户:当前系统中活跃用户状态监控。 |
|||
12. 定时任务:在线(添加、修改、删除)任务调度包含执行结果日志。 |
|||
13. 代码生成:前后端代码的生成(java、html、xml、sql)支持CRUD下载 。 |
|||
14. 系统接口:根据业务代码自动生成相关的api接口文档。 |
|||
15. 服务监控:监视当前系统CPU、内存、磁盘、堆栈等相关信息。 |
|||
16. 缓存监控:对系统的缓存信息查询,命令统计等。 |
|||
17. 在线构建器:拖动表单元素生成相应的HTML代码。 |
|||
18. 连接池监视:监视当前系统数据库连接池状态,可进行分析SQL找出系统性能瓶颈。 |
|||
|
|||
## 在线体验 |
|||
|
|||
- admin/admin123 |
|||
- 陆陆续续收到一些打赏,为了更好的体验已用于演示服务器升级。谢谢各位小伙伴。 |
|||
|
|||
演示地址:http://vue.ruoyi.vip |
|||
文档地址:http://doc.ruoyi.vip |
|||
|
|||
## 演示图 |
|||
|
|||
<table> |
|||
<tr> |
|||
<td><img src="https://oscimg.oschina.net/oscnet/cd1f90be5f2684f4560c9519c0f2a232ee8.jpg"/></td> |
|||
<td><img src="https://oscimg.oschina.net/oscnet/1cbcf0e6f257c7d3a063c0e3f2ff989e4b3.jpg"/></td> |
|||
</tr> |
|||
<tr> |
|||
<td><img src="https://oscimg.oschina.net/oscnet/up-8074972883b5ba0622e13246738ebba237a.png"/></td> |
|||
<td><img src="https://oscimg.oschina.net/oscnet/up-9f88719cdfca9af2e58b352a20e23d43b12.png"/></td> |
|||
</tr> |
|||
<tr> |
|||
<td><img src="https://oscimg.oschina.net/oscnet/up-39bf2584ec3a529b0d5a3b70d15c9b37646.png"/></td> |
|||
<td><img src="https://oscimg.oschina.net/oscnet/up-936ec82d1f4872e1bc980927654b6007307.png"/></td> |
|||
</tr> |
|||
<tr> |
|||
<td><img src="https://oscimg.oschina.net/oscnet/up-b2d62ceb95d2dd9b3fbe157bb70d26001e9.png"/></td> |
|||
<td><img src="https://oscimg.oschina.net/oscnet/up-d67451d308b7a79ad6819723396f7c3d77a.png"/></td> |
|||
</tr> |
|||
<tr> |
|||
<td><img src="https://oscimg.oschina.net/oscnet/5e8c387724954459291aafd5eb52b456f53.jpg"/></td> |
|||
<td><img src="https://oscimg.oschina.net/oscnet/644e78da53c2e92a95dfda4f76e6d117c4b.jpg"/></td> |
|||
</tr> |
|||
<tr> |
|||
<td><img src="https://oscimg.oschina.net/oscnet/up-8370a0d02977eebf6dbf854c8450293c937.png"/></td> |
|||
<td><img src="https://oscimg.oschina.net/oscnet/up-49003ed83f60f633e7153609a53a2b644f7.png"/></td> |
|||
</tr> |
|||
<tr> |
|||
<td><img src="https://oscimg.oschina.net/oscnet/up-d4fe726319ece268d4746602c39cffc0621.png"/></td> |
|||
<td><img src="https://oscimg.oschina.net/oscnet/up-c195234bbcd30be6927f037a6755e6ab69c.png"/></td> |
|||
</tr> |
|||
<tr> |
|||
<td><img src="https://oscimg.oschina.net/oscnet/b6115bc8c31de52951982e509930b20684a.jpg"/></td> |
|||
<td><img src="https://oscimg.oschina.net/oscnet/up-5e4daac0bb59612c5038448acbcef235e3a.png"/></td> |
|||
</tr> |
|||
</table> |
|||
|
|||
|
|||
## 若依前后端分离交流群 |
|||
|
|||
QQ群: [![加入QQ群](https://img.shields.io/badge/已满-937441-blue.svg)](https://jq.qq.com/?_wv=1027&k=5bVB1og) [![加入QQ群](https://img.shields.io/badge/已满-887144332-blue.svg)](https://jq.qq.com/?_wv=1027&k=5eiA4DH) [![加入QQ群](https://img.shields.io/badge/已满-180251782-blue.svg)](https://jq.qq.com/?_wv=1027&k=5AxMKlC) [![加入QQ群](https://img.shields.io/badge/已满-104180207-blue.svg)](https://jq.qq.com/?_wv=1027&k=51G72yr) [![加入QQ群](https://img.shields.io/badge/已满-186866453-blue.svg)](https://jq.qq.com/?_wv=1027&k=VvjN2nvu) [![加入QQ群](https://img.shields.io/badge/已满-201396349-blue.svg)](https://jq.qq.com/?_wv=1027&k=5vYAqA05) [![加入QQ群](https://img.shields.io/badge/已满-101456076-blue.svg)](https://jq.qq.com/?_wv=1027&k=kOIINEb5) [![加入QQ群](https://img.shields.io/badge/已满-101539465-blue.svg)](https://jq.qq.com/?_wv=1027&k=UKtX5jhs) [![加入QQ群](https://img.shields.io/badge/已满-264312783-blue.svg)](https://jq.qq.com/?_wv=1027&k=EI9an8lJ) [![加入QQ群](https://img.shields.io/badge/已满-167385320-blue.svg)](https://jq.qq.com/?_wv=1027&k=SWCtLnMz) [![加入QQ群](https://img.shields.io/badge/已满-104748341-blue.svg)](https://jq.qq.com/?_wv=1027&k=96Dkdq0k) [![加入QQ群](https://img.shields.io/badge/160110482-blue.svg)](https://jq.qq.com/?_wv=1027&k=0fsNiYZt) 点击按钮入群。 |
@ -0,0 +1,12 @@ |
|||
@echo off |
|||
echo. |
|||
echo [信息] 清理工程target生成路径。 |
|||
echo. |
|||
|
|||
%~d0 |
|||
cd %~dp0 |
|||
|
|||
cd .. |
|||
call mvn clean |
|||
|
|||
pause |
@ -0,0 +1,12 @@ |
|||
@echo off |
|||
echo. |
|||
echo [信息] 打包Web工程,生成war/jar包文件。 |
|||
echo. |
|||
|
|||
%~d0 |
|||
cd %~dp0 |
|||
|
|||
cd .. |
|||
call mvn clean package -Dmaven.test.skip=true |
|||
|
|||
pause |
@ -0,0 +1,14 @@ |
|||
@echo off |
|||
echo. |
|||
echo [��Ϣ] ʹ��Jar��������Web���̡� |
|||
echo. |
|||
|
|||
cd %~dp0 |
|||
cd ../win-admin/target |
|||
|
|||
set JAVA_OPTS=-Xms256m -Xmx1024m -XX:MetaspaceSize=128m -XX:MaxMetaspaceSize=512m |
|||
|
|||
java -jar %JAVA_OPTS% win-admin.jar |
|||
|
|||
cd bin |
|||
pause |
Binary file not shown.
@ -0,0 +1,47 @@ |
|||
# mybatis-plus mate替代方案 |
|||
|
|||
[TOC] |
|||
|
|||
## 前请说明 |
|||
不是说mp-mate不好,首先这个是企业级收费框架,日常能用到的功能不多,即使买了授权也是没有源码的,对于学习没什么帮助,下面收录的文字可以帮你大概的了解这些过程是怎么实现的 |
|||
|
|||
## 数据敏感词过滤 |
|||
主要是一些文章的敏感词检测,这不应该封装到数据库来 |
|||
需要检测的地方调用方法就行了 |
|||
|
|||
|
|||
## 数据范围(数据权限) |
|||
若依自己的 @datascope |
|||
|
|||
|
|||
## 表结构自动维护 |
|||
|
|||
个人感觉用不上 |
|||
|
|||
## 字段数据绑定(字典回写) |
|||
[mybatis自定义插件处理数据字典](https://blog.csdn.net/qq_25863973/article/details/106183181) |
|||
|
|||
个人想法也不应该是mybatis层处理的东西 |
|||
|
|||
|
|||
## 字段加密解密 |
|||
[使用mybatis的BaseTypeHandler来给敏感字段进行AES加密](https://www.cnblogs.com/java-spring/p/14676670.html) |
|||
|
|||
[动态代理Mybatis Mapper类](https://blog.csdn.net/why_still_confused/article/details/113060605) |
|||
|
|||
[Spring Boot Mybatis 优雅解决敏感信息加解密问题](https://ld246.com/article/1587991687126) |
|||
|
|||
## 字段脱敏 |
|||
|
|||
[interceptor方式](https://blog.csdn.net/lemon_csdn/article/details/121627878) |
|||
|
|||
[Mybatis拦截器实现数据脱敏](https://blog.csdn.net/chengbinbbs/article/details/105879611) |
|||
|
|||
[mybatis-cipher](https://gitee.com/Jerry.hu/mybatis-cipher) |
|||
|
|||
[敏感数据加解密以及数据脱敏mybatis插件](https://github.com/chenhaiyangs/mybatis-encrypt-plugin) |
|||
|
|||
提供一些思路,跟加密其实很像 |
|||
|
|||
## 多数据源分库分表(读写分离) |
|||
[shardingsphere](https://gitee.com/zhangmrit/RuoYi-Vue/tree/shardingsphere/) |
@ -0,0 +1,290 @@ |
|||
<?xml version="1.0" encoding="UTF-8"?> |
|||
<project xmlns="http://maven.apache.org/POM/4.0.0" |
|||
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" |
|||
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> |
|||
<modelVersion>4.0.0</modelVersion> |
|||
|
|||
<artifactId>win</artifactId> |
|||
<groupId>com.win</groupId> |
|||
<version>1.0.0</version> |
|||
|
|||
<name>win-in</name> |
|||
<url>http://www.ccwin-in.com/</url> |
|||
<description>闻音管理系统</description> |
|||
|
|||
<properties> |
|||
<win.version>1.0.0</win.version> |
|||
<spring-boot.version>2.5.14</spring-boot.version> |
|||
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding> |
|||
<project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding> |
|||
<java.version>1.8</java.version> |
|||
<maven-jar-plugin.version>3.1.1</maven-jar-plugin.version> |
|||
<druid.version>1.2.16</druid.version> |
|||
<bitwalker.version>1.21</bitwalker.version> |
|||
<kaptcha.version>2.3.3</kaptcha.version> |
|||
<pagehelper.boot.version>1.4.6</pagehelper.boot.version> |
|||
<fastjson.version>2.0.34</fastjson.version> |
|||
<oshi.version>6.4.3</oshi.version> |
|||
<commons.io.version>2.11.0</commons.io.version> |
|||
<commons.fileupload.version>1.4</commons.fileupload.version> |
|||
<commons.collections.version>3.2.2</commons.collections.version> |
|||
<poi.version>4.1.0</poi.version> |
|||
<velocity.version>2.3</velocity.version> |
|||
<jwt.version>0.9.1</jwt.version> |
|||
<mybatis-plus.version>3.5.3</mybatis-plus.version> |
|||
<shardingsphere.version>5.1.1</shardingsphere.version> |
|||
<dynamic-datasource.version>3.3.2</dynamic-datasource.version> |
|||
<knife4j.version>3.0.3</knife4j.version> |
|||
</properties> |
|||
|
|||
<!-- 依赖声明 --> |
|||
<dependencyManagement> |
|||
<dependencies> |
|||
|
|||
<!-- SpringBoot的依赖配置--> |
|||
<dependency> |
|||
<groupId>org.springframework.boot</groupId> |
|||
<artifactId>spring-boot-dependencies</artifactId> |
|||
<version>${spring-boot.version}</version> |
|||
<type>pom</type> |
|||
<scope>import</scope> |
|||
</dependency> |
|||
|
|||
<!-- 阿里数据库连接池 --> |
|||
<dependency> |
|||
<groupId>com.alibaba</groupId> |
|||
<artifactId>druid-spring-boot-starter</artifactId> |
|||
<version>${druid.version}</version> |
|||
</dependency> |
|||
|
|||
<!-- 解析客户端操作系统、浏览器等 --> |
|||
<dependency> |
|||
<groupId>eu.bitwalker</groupId> |
|||
<artifactId>UserAgentUtils</artifactId> |
|||
<version>${bitwalker.version}</version> |
|||
</dependency> |
|||
|
|||
<!-- pagehelper 分页插件 --> |
|||
<dependency> |
|||
<groupId>com.github.pagehelper</groupId> |
|||
<artifactId>pagehelper-spring-boot-starter</artifactId> |
|||
<version>${pagehelper.boot.version}</version> |
|||
</dependency> |
|||
|
|||
<!-- 获取系统信息 --> |
|||
<dependency> |
|||
<groupId>com.github.oshi</groupId> |
|||
<artifactId>oshi-core</artifactId> |
|||
<version>${oshi.version}</version> |
|||
</dependency> |
|||
|
|||
<!-- io常用工具类 --> |
|||
<dependency> |
|||
<groupId>commons-io</groupId> |
|||
<artifactId>commons-io</artifactId> |
|||
<version>${commons.io.version}</version> |
|||
</dependency> |
|||
|
|||
<!-- 文件上传工具类 --> |
|||
<dependency> |
|||
<groupId>commons-fileupload</groupId> |
|||
<artifactId>commons-fileupload</artifactId> |
|||
<version>${commons.fileupload.version}</version> |
|||
</dependency> |
|||
|
|||
<!-- excel工具 --> |
|||
<dependency> |
|||
<groupId>org.apache.poi</groupId> |
|||
<artifactId>poi-ooxml</artifactId> |
|||
<version>${poi.version}</version> |
|||
</dependency> |
|||
<dependency> |
|||
<groupId>org.apache.poi</groupId> |
|||
<artifactId>poi</artifactId> |
|||
<version>${poi.version}</version> |
|||
</dependency> |
|||
<dependency> |
|||
<groupId>org.apache.poi</groupId> |
|||
<artifactId>poi-ooxml-schemas</artifactId> |
|||
<version>${poi.version}</version> |
|||
</dependency> |
|||
<dependency> |
|||
<groupId>org.apache.poi</groupId> |
|||
<artifactId>poi-scratchpad</artifactId> |
|||
<version>${poi.version}</version> |
|||
</dependency> |
|||
<dependency> |
|||
<groupId>org.apache.poi</groupId> |
|||
<artifactId>ooxml-schemas</artifactId> |
|||
<version>1.4</version> |
|||
</dependency> |
|||
|
|||
<!-- velocity代码生成使用模板 --> |
|||
<dependency> |
|||
<groupId>org.apache.velocity</groupId> |
|||
<artifactId>velocity-engine-core</artifactId> |
|||
<version>${velocity.version}</version> |
|||
</dependency> |
|||
|
|||
<!-- collections工具类 --> |
|||
<dependency> |
|||
<groupId>commons-collections</groupId> |
|||
<artifactId>commons-collections</artifactId> |
|||
<version>${commons.collections.version}</version> |
|||
</dependency> |
|||
|
|||
<!-- 阿里JSON解析器 --> |
|||
<dependency> |
|||
<groupId>com.alibaba.fastjson2</groupId> |
|||
<artifactId>fastjson2</artifactId> |
|||
<version>${fastjson.version}</version> |
|||
</dependency> |
|||
|
|||
<!-- Token生成与解析--> |
|||
<dependency> |
|||
<groupId>io.jsonwebtoken</groupId> |
|||
<artifactId>jjwt</artifactId> |
|||
<version>${jwt.version}</version> |
|||
</dependency> |
|||
|
|||
<!-- 验证码 --> |
|||
<dependency> |
|||
<groupId>pro.fessional</groupId> |
|||
<artifactId>kaptcha</artifactId> |
|||
<version>${kaptcha.version}</version> |
|||
</dependency> |
|||
|
|||
<dependency> |
|||
<groupId>com.baomidou</groupId> |
|||
<artifactId>mybatis-plus-boot-starter</artifactId> |
|||
<version>${mybatis-plus.version}</version> |
|||
</dependency> |
|||
|
|||
<dependency> |
|||
<groupId>com.baomidou</groupId> |
|||
<artifactId>mybatis-plus-extension</artifactId> |
|||
<version>${mybatis-plus.version}</version> |
|||
</dependency> |
|||
|
|||
<!-- 动态数据源 --> |
|||
<dependency> |
|||
<groupId>com.baomidou</groupId> |
|||
<artifactId>dynamic-datasource-spring-boot-starter</artifactId> |
|||
<version>${dynamic-datasource.version}</version> |
|||
</dependency> |
|||
|
|||
<dependency> |
|||
<groupId>com.github.xiaoymin</groupId> |
|||
<artifactId>knife4j-spring-boot-starter</artifactId> |
|||
<version>${knife4j.version}</version> |
|||
</dependency> |
|||
|
|||
<dependency> |
|||
<groupId>org.apache.commons</groupId> |
|||
<artifactId>commons-exec</artifactId> |
|||
<version>1.3</version> |
|||
</dependency> |
|||
|
|||
<dependency> |
|||
<groupId>com.jcraft</groupId> |
|||
<artifactId>jsch</artifactId> |
|||
<version>0.1.55</version> |
|||
</dependency> |
|||
|
|||
<!-- 定时任务--> |
|||
<dependency> |
|||
<groupId>com.win</groupId> |
|||
<artifactId>win-quartz</artifactId> |
|||
<version>${win.version}</version> |
|||
</dependency> |
|||
|
|||
<!-- 代码生成--> |
|||
<dependency> |
|||
<groupId>com.win</groupId> |
|||
<artifactId>win-generator</artifactId> |
|||
<version>${win.version}</version> |
|||
</dependency> |
|||
|
|||
<!-- 核心模块--> |
|||
<dependency> |
|||
<groupId>com.win</groupId> |
|||
<artifactId>win-framework</artifactId> |
|||
<version>${win.version}</version> |
|||
</dependency> |
|||
|
|||
<!-- 系统模块--> |
|||
<dependency> |
|||
<groupId>com.win</groupId> |
|||
<artifactId>win-system</artifactId> |
|||
<version>${win.version}</version> |
|||
</dependency> |
|||
|
|||
<!-- 通用工具--> |
|||
<dependency> |
|||
<groupId>com.win</groupId> |
|||
<artifactId>win-common</artifactId> |
|||
<version>${win.version}</version> |
|||
</dependency> |
|||
|
|||
</dependencies> |
|||
</dependencyManagement> |
|||
|
|||
<modules> |
|||
<module>win-admin</module> |
|||
<module>win-framework</module> |
|||
<module>win-system</module> |
|||
<module>win-quartz</module> |
|||
<module>win-generator</module> |
|||
<module>win-common</module> |
|||
</modules> |
|||
<packaging>pom</packaging> |
|||
|
|||
<dependencies> |
|||
<dependency> |
|||
<groupId>org.projectlombok</groupId> |
|||
<artifactId>lombok</artifactId> |
|||
<scope>provided</scope> |
|||
</dependency> |
|||
</dependencies> |
|||
|
|||
<build> |
|||
<plugins> |
|||
<plugin> |
|||
<groupId>org.apache.maven.plugins</groupId> |
|||
<artifactId>maven-compiler-plugin</artifactId> |
|||
<version>3.1</version> |
|||
<configuration> |
|||
<source>${java.version}</source> |
|||
<target>${java.version}</target> |
|||
<encoding>${project.build.sourceEncoding}</encoding> |
|||
</configuration> |
|||
</plugin> |
|||
</plugins> |
|||
</build> |
|||
|
|||
<repositories> |
|||
<repository> |
|||
<id>public</id> |
|||
<name>aliyun nexus</name> |
|||
<url>https://maven.aliyun.com/repository/public</url> |
|||
<releases> |
|||
<enabled>true</enabled> |
|||
</releases> |
|||
</repository> |
|||
</repositories> |
|||
|
|||
<pluginRepositories> |
|||
<pluginRepository> |
|||
<id>public</id> |
|||
<name>aliyun nexus</name> |
|||
<url>https://maven.aliyun.com/repository/public</url> |
|||
<releases> |
|||
<enabled>true</enabled> |
|||
</releases> |
|||
<snapshots> |
|||
<enabled>false</enabled> |
|||
</snapshots> |
|||
</pluginRepository> |
|||
</pluginRepositories> |
|||
|
|||
</project> |
@ -0,0 +1,174 @@ |
|||
DROP TABLE IF EXISTS qrtz_fired_triggers; |
|||
DROP TABLE IF EXISTS qrtz_paused_trigger_grps; |
|||
DROP TABLE IF EXISTS qrtz_scheduler_state; |
|||
DROP TABLE IF EXISTS qrtz_locks; |
|||
DROP TABLE IF EXISTS qrtz_simple_triggers; |
|||
DROP TABLE IF EXISTS qrtz_simprop_triggers; |
|||
DROP TABLE IF EXISTS qrtz_cron_triggers; |
|||
DROP TABLE IF EXISTS qrtz_blob_triggers; |
|||
DROP TABLE IF EXISTS qrtz_triggers; |
|||
DROP TABLE IF EXISTS qrtz_job_details; |
|||
DROP TABLE IF EXISTS qrtz_calendars; |
|||
|
|||
-- ---------------------------- |
|||
-- 1、存储每一个已配置的 jobDetail 的详细信息 |
|||
-- ---------------------------- |
|||
create table qrtz_job_details ( |
|||
sched_name varchar(120) not null comment '调度名称', |
|||
job_name varchar(200) not null comment '任务名称', |
|||
job_group varchar(200) not null comment '任务组名', |
|||
description varchar(250) null comment '相关介绍', |
|||
job_class_name varchar(250) not null comment '执行任务类名称', |
|||
is_durable varchar(1) not null comment '是否持久化', |
|||
is_nonconcurrent varchar(1) not null comment '是否并发', |
|||
is_update_data varchar(1) not null comment '是否更新数据', |
|||
requests_recovery varchar(1) not null comment '是否接受恢复执行', |
|||
job_data blob null comment '存放持久化job对象', |
|||
primary key (sched_name, job_name, job_group) |
|||
) engine=innodb comment = '任务详细信息表'; |
|||
|
|||
-- ---------------------------- |
|||
-- 2、 存储已配置的 Trigger 的信息 |
|||
-- ---------------------------- |
|||
create table qrtz_triggers ( |
|||
sched_name varchar(120) not null comment '调度名称', |
|||
trigger_name varchar(200) not null comment '触发器的名字', |
|||
trigger_group varchar(200) not null comment '触发器所属组的名字', |
|||
job_name varchar(200) not null comment 'qrtz_job_details表job_name的外键', |
|||
job_group varchar(200) not null comment 'qrtz_job_details表job_group的外键', |
|||
description varchar(250) null comment '相关介绍', |
|||
next_fire_time bigint(13) null comment '上一次触发时间(毫秒)', |
|||
prev_fire_time bigint(13) null comment '下一次触发时间(默认为-1表示不触发)', |
|||
priority integer null comment '优先级', |
|||
trigger_state varchar(16) not null comment '触发器状态', |
|||
trigger_type varchar(8) not null comment '触发器的类型', |
|||
start_time bigint(13) not null comment '开始时间', |
|||
end_time bigint(13) null comment '结束时间', |
|||
calendar_name varchar(200) null comment '日程表名称', |
|||
misfire_instr smallint(2) null comment '补偿执行的策略', |
|||
job_data blob null comment '存放持久化job对象', |
|||
primary key (sched_name, trigger_name, trigger_group), |
|||
foreign key (sched_name, job_name, job_group) references qrtz_job_details(sched_name, job_name, job_group) |
|||
) engine=innodb comment = '触发器详细信息表'; |
|||
|
|||
-- ---------------------------- |
|||
-- 3、 存储简单的 Trigger,包括重复次数,间隔,以及已触发的次数 |
|||
-- ---------------------------- |
|||
create table qrtz_simple_triggers ( |
|||
sched_name varchar(120) not null comment '调度名称', |
|||
trigger_name varchar(200) not null comment 'qrtz_triggers表trigger_name的外键', |
|||
trigger_group varchar(200) not null comment 'qrtz_triggers表trigger_group的外键', |
|||
repeat_count bigint(7) not null comment '重复的次数统计', |
|||
repeat_interval bigint(12) not null comment '重复的间隔时间', |
|||
times_triggered bigint(10) not null comment '已经触发的次数', |
|||
primary key (sched_name, trigger_name, trigger_group), |
|||
foreign key (sched_name, trigger_name, trigger_group) references qrtz_triggers(sched_name, trigger_name, trigger_group) |
|||
) engine=innodb comment = '简单触发器的信息表'; |
|||
|
|||
-- ---------------------------- |
|||
-- 4、 存储 Cron Trigger,包括 Cron 表达式和时区信息 |
|||
-- ---------------------------- |
|||
create table qrtz_cron_triggers ( |
|||
sched_name varchar(120) not null comment '调度名称', |
|||
trigger_name varchar(200) not null comment 'qrtz_triggers表trigger_name的外键', |
|||
trigger_group varchar(200) not null comment 'qrtz_triggers表trigger_group的外键', |
|||
cron_expression varchar(200) not null comment 'cron表达式', |
|||
time_zone_id varchar(80) comment '时区', |
|||
primary key (sched_name, trigger_name, trigger_group), |
|||
foreign key (sched_name, trigger_name, trigger_group) references qrtz_triggers(sched_name, trigger_name, trigger_group) |
|||
) engine=innodb comment = 'Cron类型的触发器表'; |
|||
|
|||
-- ---------------------------- |
|||
-- 5、 Trigger 作为 Blob 类型存储(用于 Quartz 用户用 JDBC 创建他们自己定制的 Trigger 类型,JobStore 并不知道如何存储实例的时候) |
|||
-- ---------------------------- |
|||
create table qrtz_blob_triggers ( |
|||
sched_name varchar(120) not null comment '调度名称', |
|||
trigger_name varchar(200) not null comment 'qrtz_triggers表trigger_name的外键', |
|||
trigger_group varchar(200) not null comment 'qrtz_triggers表trigger_group的外键', |
|||
blob_data blob null comment '存放持久化Trigger对象', |
|||
primary key (sched_name, trigger_name, trigger_group), |
|||
foreign key (sched_name, trigger_name, trigger_group) references qrtz_triggers(sched_name, trigger_name, trigger_group) |
|||
) engine=innodb comment = 'Blob类型的触发器表'; |
|||
|
|||
-- ---------------------------- |
|||
-- 6、 以 Blob 类型存储存放日历信息, quartz可配置一个日历来指定一个时间范围 |
|||
-- ---------------------------- |
|||
create table qrtz_calendars ( |
|||
sched_name varchar(120) not null comment '调度名称', |
|||
calendar_name varchar(200) not null comment '日历名称', |
|||
calendar blob not null comment '存放持久化calendar对象', |
|||
primary key (sched_name, calendar_name) |
|||
) engine=innodb comment = '日历信息表'; |
|||
|
|||
-- ---------------------------- |
|||
-- 7、 存储已暂停的 Trigger 组的信息 |
|||
-- ---------------------------- |
|||
create table qrtz_paused_trigger_grps ( |
|||
sched_name varchar(120) not null comment '调度名称', |
|||
trigger_group varchar(200) not null comment 'qrtz_triggers表trigger_group的外键', |
|||
primary key (sched_name, trigger_group) |
|||
) engine=innodb comment = '暂停的触发器表'; |
|||
|
|||
-- ---------------------------- |
|||
-- 8、 存储与已触发的 Trigger 相关的状态信息,以及相联 Job 的执行信息 |
|||
-- ---------------------------- |
|||
create table qrtz_fired_triggers ( |
|||
sched_name varchar(120) not null comment '调度名称', |
|||
entry_id varchar(95) not null comment '调度器实例id', |
|||
trigger_name varchar(200) not null comment 'qrtz_triggers表trigger_name的外键', |
|||
trigger_group varchar(200) not null comment 'qrtz_triggers表trigger_group的外键', |
|||
instance_name varchar(200) not null comment '调度器实例名', |
|||
fired_time bigint(13) not null comment '触发的时间', |
|||
sched_time bigint(13) not null comment '定时器制定的时间', |
|||
priority integer not null comment '优先级', |
|||
state varchar(16) not null comment '状态', |
|||
job_name varchar(200) null comment '任务名称', |
|||
job_group varchar(200) null comment '任务组名', |
|||
is_nonconcurrent varchar(1) null comment '是否并发', |
|||
requests_recovery varchar(1) null comment '是否接受恢复执行', |
|||
primary key (sched_name, entry_id) |
|||
) engine=innodb comment = '已触发的触发器表'; |
|||
|
|||
-- ---------------------------- |
|||
-- 9、 存储少量的有关 Scheduler 的状态信息,假如是用于集群中,可以看到其他的 Scheduler 实例 |
|||
-- ---------------------------- |
|||
create table qrtz_scheduler_state ( |
|||
sched_name varchar(120) not null comment '调度名称', |
|||
instance_name varchar(200) not null comment '实例名称', |
|||
last_checkin_time bigint(13) not null comment '上次检查时间', |
|||
checkin_interval bigint(13) not null comment '检查间隔时间', |
|||
primary key (sched_name, instance_name) |
|||
) engine=innodb comment = '调度器状态表'; |
|||
|
|||
-- ---------------------------- |
|||
-- 10、 存储程序的悲观锁的信息(假如使用了悲观锁) |
|||
-- ---------------------------- |
|||
create table qrtz_locks ( |
|||
sched_name varchar(120) not null comment '调度名称', |
|||
lock_name varchar(40) not null comment '悲观锁名称', |
|||
primary key (sched_name, lock_name) |
|||
) engine=innodb comment = '存储的悲观锁信息表'; |
|||
|
|||
-- ---------------------------- |
|||
-- 11、 Quartz集群实现同步机制的行锁表 |
|||
-- ---------------------------- |
|||
create table qrtz_simprop_triggers ( |
|||
sched_name varchar(120) not null comment '调度名称', |
|||
trigger_name varchar(200) not null comment 'qrtz_triggers表trigger_name的外键', |
|||
trigger_group varchar(200) not null comment 'qrtz_triggers表trigger_group的外键', |
|||
str_prop_1 varchar(512) null comment 'String类型的trigger的第一个参数', |
|||
str_prop_2 varchar(512) null comment 'String类型的trigger的第二个参数', |
|||
str_prop_3 varchar(512) null comment 'String类型的trigger的第三个参数', |
|||
int_prop_1 int null comment 'int类型的trigger的第一个参数', |
|||
int_prop_2 int null comment 'int类型的trigger的第二个参数', |
|||
long_prop_1 bigint null comment 'long类型的trigger的第一个参数', |
|||
long_prop_2 bigint null comment 'long类型的trigger的第二个参数', |
|||
dec_prop_1 numeric(13,4) null comment 'decimal类型的trigger的第一个参数', |
|||
dec_prop_2 numeric(13,4) null comment 'decimal类型的trigger的第二个参数', |
|||
bool_prop_1 varchar(1) null comment 'Boolean类型的trigger的第一个参数', |
|||
bool_prop_2 varchar(1) null comment 'Boolean类型的trigger的第二个参数', |
|||
primary key (sched_name, trigger_name, trigger_group), |
|||
foreign key (sched_name, trigger_name, trigger_group) references qrtz_triggers(sched_name, trigger_name, trigger_group) |
|||
) engine=innodb comment = '同步机制的行锁表'; |
|||
|
|||
commit; |
@ -0,0 +1,692 @@ |
|||
-- ---------------------------- |
|||
-- 1、部门表 |
|||
-- ---------------------------- |
|||
drop table if exists sys_dept; |
|||
create table sys_dept ( |
|||
dept_id bigint(20) not null auto_increment comment '部门id', |
|||
parent_id bigint(20) default 0 comment '父部门id', |
|||
ancestors varchar(50) default '' comment '祖级列表', |
|||
dept_name varchar(30) default '' comment '部门名称', |
|||
order_num int(4) default 0 comment '显示顺序', |
|||
leader varchar(20) default null comment '负责人', |
|||
phone varchar(11) default null comment '联系电话', |
|||
email varchar(50) default null comment '邮箱', |
|||
status char(1) default '0' comment '部门状态(0正常 1停用)', |
|||
del_flag char(1) default '0' comment '删除标志(0代表存在 2代表删除)', |
|||
create_by varchar(64) default '' comment '创建者', |
|||
create_time datetime comment '创建时间', |
|||
update_by varchar(64) default '' comment '更新者', |
|||
update_time datetime comment '更新时间', |
|||
primary key (dept_id) |
|||
) engine=innodb auto_increment=200 comment = '部门表'; |
|||
|
|||
-- ---------------------------- |
|||
-- 初始化-部门表数据 |
|||
-- ---------------------------- |
|||
insert into sys_dept values(100, 0, '0', '闻音科技', 0, '闻音', '15888888888', 'ry@qq.com', '0', '0', 'admin', sysdate(), '', null); |
|||
insert into sys_dept values(101, 100, '0,100', '深圳总公司', 1, '闻音', '15888888888', 'ry@qq.com', '0', '0', 'admin', sysdate(), '', null); |
|||
insert into sys_dept values(102, 100, '0,100', '长沙分公司', 2, '闻音', '15888888888', 'ry@qq.com', '0', '0', 'admin', sysdate(), '', null); |
|||
insert into sys_dept values(103, 101, '0,100,101', '研发部门', 1, '闻音', '15888888888', 'ry@qq.com', '0', '0', 'admin', sysdate(), '', null); |
|||
insert into sys_dept values(104, 101, '0,100,101', '市场部门', 2, '闻音', '15888888888', 'ry@qq.com', '0', '0', 'admin', sysdate(), '', null); |
|||
insert into sys_dept values(105, 101, '0,100,101', '测试部门', 3, '闻音', '15888888888', 'ry@qq.com', '0', '0', 'admin', sysdate(), '', null); |
|||
insert into sys_dept values(106, 101, '0,100,101', '财务部门', 4, '闻音', '15888888888', 'ry@qq.com', '0', '0', 'admin', sysdate(), '', null); |
|||
insert into sys_dept values(107, 101, '0,100,101', '运维部门', 5, '闻音', '15888888888', 'ry@qq.com', '0', '0', 'admin', sysdate(), '', null); |
|||
insert into sys_dept values(108, 102, '0,100,102', '市场部门', 1, '闻音', '15888888888', 'ry@qq.com', '0', '0', 'admin', sysdate(), '', null); |
|||
insert into sys_dept values(109, 102, '0,100,102', '财务部门', 2, '闻音', '15888888888', 'ry@qq.com', '0', '0', 'admin', sysdate(), '', null); |
|||
|
|||
|
|||
-- ---------------------------- |
|||
-- 2、用户信息表 |
|||
-- ---------------------------- |
|||
drop table if exists sys_user; |
|||
create table sys_user ( |
|||
user_id bigint(20) not null auto_increment comment '用户ID', |
|||
dept_id bigint(20) default null comment '部门ID', |
|||
user_name varchar(30) not null comment '用户账号', |
|||
nick_name varchar(30) not null comment '用户昵称', |
|||
user_type varchar(2) default '00' comment '用户类型(00系统用户)', |
|||
email varchar(50) default '' comment '用户邮箱', |
|||
phonenumber varchar(11) default '' comment '手机号码', |
|||
sex char(1) default '0' comment '用户性别(0男 1女 2未知)', |
|||
avatar varchar(100) default '' comment '头像地址', |
|||
password varchar(100) default '' comment '密码', |
|||
status char(1) default '0' comment '帐号状态(0正常 1停用)', |
|||
del_flag char(1) default '0' comment '删除标志(0代表存在 2代表删除)', |
|||
login_ip varchar(128) default '' comment '最后登录IP', |
|||
login_date datetime comment '最后登录时间', |
|||
create_by varchar(64) default '' comment '创建者', |
|||
create_time datetime comment '创建时间', |
|||
update_by varchar(64) default '' comment '更新者', |
|||
update_time datetime comment '更新时间', |
|||
remark varchar(500) default null comment '备注', |
|||
primary key (user_id) |
|||
) engine=innodb auto_increment=100 comment = '用户信息表'; |
|||
|
|||
-- ---------------------------- |
|||
-- 初始化-用户信息表数据 |
|||
-- ---------------------------- |
|||
insert into sys_user values(1, 103, 'admin', '闻音', '00', 'win@163.com', '15888888888', '1', '', '$2a$10$7JB720yubVSZvUI0rEqK/.VqGOZTH.ulu33dHOiBE8ByOhJIrdAu2', '0', '0', '127.0.0.1', sysdate(), 'admin', sysdate(), '', null, '管理员'); |
|||
insert into sys_user values(2, 105, 'win', '闻音', '00', 'win@qq.com', '15666666666', '1', '', '$2a$10$7JB720yubVSZvUI0rEqK/.VqGOZTH.ulu33dHOiBE8ByOhJIrdAu2', '0', '0', '127.0.0.1', sysdate(), 'admin', sysdate(), '', null, '测试员'); |
|||
|
|||
|
|||
-- ---------------------------- |
|||
-- 3、岗位信息表 |
|||
-- ---------------------------- |
|||
drop table if exists sys_post; |
|||
create table sys_post |
|||
( |
|||
post_id bigint(20) not null auto_increment comment '岗位ID', |
|||
post_code varchar(64) not null comment '岗位编码', |
|||
post_name varchar(50) not null comment '岗位名称', |
|||
post_sort int(4) not null comment '显示顺序', |
|||
status char(1) not null comment '状态(0正常 1停用)', |
|||
create_by varchar(64) default '' comment '创建者', |
|||
create_time datetime comment '创建时间', |
|||
update_by varchar(64) default '' comment '更新者', |
|||
update_time datetime comment '更新时间', |
|||
remark varchar(500) default null comment '备注', |
|||
primary key (post_id) |
|||
) engine=innodb comment = '岗位信息表'; |
|||
|
|||
-- ---------------------------- |
|||
-- 初始化-岗位信息表数据 |
|||
-- ---------------------------- |
|||
insert into sys_post values(1, 'ceo', '董事长', 1, '0', 'admin', sysdate(), '', null, ''); |
|||
insert into sys_post values(2, 'se', '项目经理', 2, '0', 'admin', sysdate(), '', null, ''); |
|||
insert into sys_post values(3, 'hr', '人力资源', 3, '0', 'admin', sysdate(), '', null, ''); |
|||
insert into sys_post values(4, 'user', '普通员工', 4, '0', 'admin', sysdate(), '', null, ''); |
|||
|
|||
|
|||
-- ---------------------------- |
|||
-- 4、角色信息表 |
|||
-- ---------------------------- |
|||
drop table if exists sys_role; |
|||
create table sys_role ( |
|||
role_id bigint(20) not null auto_increment comment '角色ID', |
|||
role_name varchar(30) not null comment '角色名称', |
|||
role_key varchar(100) not null comment '角色权限字符串', |
|||
role_sort int(4) not null comment '显示顺序', |
|||
data_scope char(1) default '1' comment '数据范围(1:全部数据权限 2:自定数据权限 3:本部门数据权限 4:本部门及以下数据权限)', |
|||
menu_check_strictly tinyint(1) default 1 comment '菜单树选择项是否关联显示', |
|||
dept_check_strictly tinyint(1) default 1 comment '部门树选择项是否关联显示', |
|||
status char(1) not null comment '角色状态(0正常 1停用)', |
|||
del_flag char(1) default '0' comment '删除标志(0代表存在 2代表删除)', |
|||
create_by varchar(64) default '' comment '创建者', |
|||
create_time datetime comment '创建时间', |
|||
update_by varchar(64) default '' comment '更新者', |
|||
update_time datetime comment '更新时间', |
|||
remark varchar(500) default null comment '备注', |
|||
primary key (role_id) |
|||
) engine=innodb auto_increment=100 comment = '角色信息表'; |
|||
|
|||
-- ---------------------------- |
|||
-- 初始化-角色信息表数据 |
|||
-- ---------------------------- |
|||
insert into sys_role values('1', '超级管理员', 'admin', 1, 1, 1, 1, '0', '0', 'admin', sysdate(), '', null, '超级管理员'); |
|||
insert into sys_role values('2', '普通角色', 'common', 2, 2, 1, 1, '0', '0', 'admin', sysdate(), '', null, '普通角色'); |
|||
|
|||
|
|||
-- ---------------------------- |
|||
-- 5、菜单权限表 |
|||
-- ---------------------------- |
|||
drop table if exists sys_menu; |
|||
create table sys_menu ( |
|||
menu_id bigint(20) not null auto_increment comment '菜单ID', |
|||
menu_name varchar(50) not null comment '菜单名称', |
|||
parent_id bigint(20) default 0 comment '父菜单ID', |
|||
order_num int(4) default 0 comment '显示顺序', |
|||
path varchar(200) default '' comment '路由地址', |
|||
component varchar(255) default null comment '组件路径', |
|||
query varchar(255) default null comment '路由参数', |
|||
is_frame int(1) default 1 comment '是否为外链(0是 1否)', |
|||
is_cache int(1) default 0 comment '是否缓存(0缓存 1不缓存)', |
|||
menu_type char(1) default '' comment '菜单类型(M目录 C菜单 F按钮)', |
|||
visible char(1) default 0 comment '菜单状态(0显示 1隐藏)', |
|||
status char(1) default 0 comment '菜单状态(0正常 1停用)', |
|||
perms varchar(100) default null comment '权限标识', |
|||
icon varchar(100) default '#' comment '菜单图标', |
|||
create_by varchar(64) default '' comment '创建者', |
|||
create_time datetime comment '创建时间', |
|||
update_by varchar(64) default '' comment '更新者', |
|||
update_time datetime comment '更新时间', |
|||
remark varchar(500) default '' comment '备注', |
|||
primary key (menu_id) |
|||
) engine=innodb auto_increment=2000 comment = '菜单权限表'; |
|||
|
|||
-- ---------------------------- |
|||
-- 初始化-菜单信息表数据 |
|||
-- ---------------------------- |
|||
-- 一级菜单 |
|||
insert into sys_menu values('1', '系统管理', '0', '1', 'system', null, '', 1, 0, 'M', '0', '0', '', 'system', 'admin', sysdate(), '', null, '系统管理目录'); |
|||
insert into sys_menu values('2', '系统监控', '0', '2', 'monitor', null, '', 1, 0, 'M', '0', '0', '', 'monitor', 'admin', sysdate(), '', null, '系统监控目录'); |
|||
insert into sys_menu values('3', '系统工具', '0', '3', 'tool', null, '', 1, 0, 'M', '0', '0', '', 'tool', 'admin', sysdate(), '', null, '系统工具目录'); |
|||
insert into sys_menu values('4', '闻音官网', '0', '4', 'http://www.ccwin-in.com/', null, '', 0, 0, 'M', '0', '0', '', 'guide', 'admin', sysdate(), '', null, '闻音官网地址'); |
|||
-- 二级菜单 |
|||
insert into sys_menu values('100', '用户管理', '1', '1', 'user', 'system/user/index', '', 1, 0, 'C', '0', '0', 'system:user:list', 'user', 'admin', sysdate(), '', null, '用户管理菜单'); |
|||
insert into sys_menu values('101', '角色管理', '1', '2', 'role', 'system/role/index', '', 1, 0, 'C', '0', '0', 'system:role:list', 'peoples', 'admin', sysdate(), '', null, '角色管理菜单'); |
|||
insert into sys_menu values('102', '菜单管理', '1', '3', 'menu', 'system/menu/index', '', 1, 0, 'C', '0', '0', 'system:menu:list', 'tree-table', 'admin', sysdate(), '', null, '菜单管理菜单'); |
|||
insert into sys_menu values('103', '部门管理', '1', '4', 'dept', 'system/dept/index', '', 1, 0, 'C', '0', '0', 'system:dept:list', 'tree', 'admin', sysdate(), '', null, '部门管理菜单'); |
|||
insert into sys_menu values('104', '岗位管理', '1', '5', 'post', 'system/post/index', '', 1, 0, 'C', '0', '0', 'system:post:list', 'post', 'admin', sysdate(), '', null, '岗位管理菜单'); |
|||
insert into sys_menu values('105', '字典管理', '1', '6', 'dict', 'system/dict/index', '', 1, 0, 'C', '0', '0', 'system:dict:list', 'dict', 'admin', sysdate(), '', null, '字典管理菜单'); |
|||
insert into sys_menu values('106', '参数设置', '1', '7', 'config', 'system/config/index', '', 1, 0, 'C', '0', '0', 'system:config:list', 'edit', 'admin', sysdate(), '', null, '参数设置菜单'); |
|||
insert into sys_menu values('107', '通知公告', '1', '8', 'notice', 'system/notice/index', '', 1, 0, 'C', '0', '0', 'system:notice:list', 'message', 'admin', sysdate(), '', null, '通知公告菜单'); |
|||
insert into sys_menu values('108', '日志管理', '1', '9', 'log', '', '', 1, 0, 'M', '0', '0', '', 'log', 'admin', sysdate(), '', null, '日志管理菜单'); |
|||
insert into sys_menu values('109', '在线用户', '2', '1', 'online', 'monitor/online/index', '', 1, 0, 'C', '0', '0', 'monitor:online:list', 'online', 'admin', sysdate(), '', null, '在线用户菜单'); |
|||
insert into sys_menu values('110', '定时任务', '2', '2', 'job', 'monitor/job/index', '', 1, 0, 'C', '0', '0', 'monitor:job:list', 'job', 'admin', sysdate(), '', null, '定时任务菜单'); |
|||
insert into sys_menu values('111', '数据监控', '2', '3', 'druid', 'monitor/druid/index', '', 1, 0, 'C', '0', '0', 'monitor:druid:list', 'druid', 'admin', sysdate(), '', null, '数据监控菜单'); |
|||
insert into sys_menu values('112', '服务监控', '2', '4', 'server', 'monitor/server/index', '', 1, 0, 'C', '0', '0', 'monitor:server:list', 'server', 'admin', sysdate(), '', null, '服务监控菜单'); |
|||
insert into sys_menu values('113', '缓存监控', '2', '5', 'cache', 'monitor/cache/index', '', 1, 0, 'C', '0', '0', 'monitor:cache:list', 'redis', 'admin', sysdate(), '', null, '缓存监控菜单'); |
|||
insert into sys_menu values('114', '缓存列表', '2', '6', 'cacheList', 'monitor/cache/list', '', 1, 0, 'C', '0', '0', 'monitor:cache:list', 'redis-list', 'admin', sysdate(), '', null, '缓存列表菜单'); |
|||
insert into sys_menu values('115', '表单构建', '3', '1', 'build', 'tool/build/index', '', 1, 0, 'C', '0', '0', 'tool:build:list', 'build', 'admin', sysdate(), '', null, '表单构建菜单'); |
|||
insert into sys_menu values('116', '代码生成', '3', '2', 'gen', 'tool/gen/index', '', 1, 0, 'C', '0', '0', 'tool:gen:list', 'code', 'admin', sysdate(), '', null, '代码生成菜单'); |
|||
insert into sys_menu values('117', '系统接口', '3', '3', 'swagger', 'tool/swagger/index', '', 1, 0, 'C', '0', '0', 'tool:swagger:list', 'swagger', 'admin', sysdate(), '', null, '系统接口菜单'); |
|||
-- 三级菜单 |
|||
insert into sys_menu values('500', '操作日志', '108', '1', 'operlog', 'monitor/operlog/index', '', 1, 0, 'C', '0', '0', 'monitor:operlog:list', 'form', 'admin', sysdate(), '', null, '操作日志菜单'); |
|||
insert into sys_menu values('501', '登录日志', '108', '2', 'logininfor', 'monitor/logininfor/index', '', 1, 0, 'C', '0', '0', 'monitor:logininfor:list', 'logininfor', 'admin', sysdate(), '', null, '登录日志菜单'); |
|||
-- 用户管理按钮 |
|||
insert into sys_menu values('1000', '用户查询', '100', '1', '', '', '', 1, 0, 'F', '0', '0', 'system:user:query', '#', 'admin', sysdate(), '', null, ''); |
|||
insert into sys_menu values('1001', '用户新增', '100', '2', '', '', '', 1, 0, 'F', '0', '0', 'system:user:add', '#', 'admin', sysdate(), '', null, ''); |
|||
insert into sys_menu values('1002', '用户修改', '100', '3', '', '', '', 1, 0, 'F', '0', '0', 'system:user:edit', '#', 'admin', sysdate(), '', null, ''); |
|||
insert into sys_menu values('1003', '用户删除', '100', '4', '', '', '', 1, 0, 'F', '0', '0', 'system:user:remove', '#', 'admin', sysdate(), '', null, ''); |
|||
insert into sys_menu values('1004', '用户导出', '100', '5', '', '', '', 1, 0, 'F', '0', '0', 'system:user:export', '#', 'admin', sysdate(), '', null, ''); |
|||
insert into sys_menu values('1005', '用户导入', '100', '6', '', '', '', 1, 0, 'F', '0', '0', 'system:user:import', '#', 'admin', sysdate(), '', null, ''); |
|||
insert into sys_menu values('1006', '重置密码', '100', '7', '', '', '', 1, 0, 'F', '0', '0', 'system:user:resetPwd', '#', 'admin', sysdate(), '', null, ''); |
|||
-- 角色管理按钮 |
|||
insert into sys_menu values('1007', '角色查询', '101', '1', '', '', '', 1, 0, 'F', '0', '0', 'system:role:query', '#', 'admin', sysdate(), '', null, ''); |
|||
insert into sys_menu values('1008', '角色新增', '101', '2', '', '', '', 1, 0, 'F', '0', '0', 'system:role:add', '#', 'admin', sysdate(), '', null, ''); |
|||
insert into sys_menu values('1009', '角色修改', '101', '3', '', '', '', 1, 0, 'F', '0', '0', 'system:role:edit', '#', 'admin', sysdate(), '', null, ''); |
|||
insert into sys_menu values('1010', '角色删除', '101', '4', '', '', '', 1, 0, 'F', '0', '0', 'system:role:remove', '#', 'admin', sysdate(), '', null, ''); |
|||
insert into sys_menu values('1011', '角色导出', '101', '5', '', '', '', 1, 0, 'F', '0', '0', 'system:role:export', '#', 'admin', sysdate(), '', null, ''); |
|||
-- 菜单管理按钮 |
|||
insert into sys_menu values('1012', '菜单查询', '102', '1', '', '', '', 1, 0, 'F', '0', '0', 'system:menu:query', '#', 'admin', sysdate(), '', null, ''); |
|||
insert into sys_menu values('1013', '菜单新增', '102', '2', '', '', '', 1, 0, 'F', '0', '0', 'system:menu:add', '#', 'admin', sysdate(), '', null, ''); |
|||
insert into sys_menu values('1014', '菜单修改', '102', '3', '', '', '', 1, 0, 'F', '0', '0', 'system:menu:edit', '#', 'admin', sysdate(), '', null, ''); |
|||
insert into sys_menu values('1015', '菜单删除', '102', '4', '', '', '', 1, 0, 'F', '0', '0', 'system:menu:remove', '#', 'admin', sysdate(), '', null, ''); |
|||
-- 部门管理按钮 |
|||
insert into sys_menu values('1016', '部门查询', '103', '1', '', '', '', 1, 0, 'F', '0', '0', 'system:dept:query', '#', 'admin', sysdate(), '', null, ''); |
|||
insert into sys_menu values('1017', '部门新增', '103', '2', '', '', '', 1, 0, 'F', '0', '0', 'system:dept:add', '#', 'admin', sysdate(), '', null, ''); |
|||
insert into sys_menu values('1018', '部门修改', '103', '3', '', '', '', 1, 0, 'F', '0', '0', 'system:dept:edit', '#', 'admin', sysdate(), '', null, ''); |
|||
insert into sys_menu values('1019', '部门删除', '103', '4', '', '', '', 1, 0, 'F', '0', '0', 'system:dept:remove', '#', 'admin', sysdate(), '', null, ''); |
|||
-- 岗位管理按钮 |
|||
insert into sys_menu values('1020', '岗位查询', '104', '1', '', '', '', 1, 0, 'F', '0', '0', 'system:post:query', '#', 'admin', sysdate(), '', null, ''); |
|||
insert into sys_menu values('1021', '岗位新增', '104', '2', '', '', '', 1, 0, 'F', '0', '0', 'system:post:add', '#', 'admin', sysdate(), '', null, ''); |
|||
insert into sys_menu values('1022', '岗位修改', '104', '3', '', '', '', 1, 0, 'F', '0', '0', 'system:post:edit', '#', 'admin', sysdate(), '', null, ''); |
|||
insert into sys_menu values('1023', '岗位删除', '104', '4', '', '', '', 1, 0, 'F', '0', '0', 'system:post:remove', '#', 'admin', sysdate(), '', null, ''); |
|||
insert into sys_menu values('1024', '岗位导出', '104', '5', '', '', '', 1, 0, 'F', '0', '0', 'system:post:export', '#', 'admin', sysdate(), '', null, ''); |
|||
-- 字典管理按钮 |
|||
insert into sys_menu values('1025', '字典查询', '105', '1', '#', '', '', 1, 0, 'F', '0', '0', 'system:dict:query', '#', 'admin', sysdate(), '', null, ''); |
|||
insert into sys_menu values('1026', '字典新增', '105', '2', '#', '', '', 1, 0, 'F', '0', '0', 'system:dict:add', '#', 'admin', sysdate(), '', null, ''); |
|||
insert into sys_menu values('1027', '字典修改', '105', '3', '#', '', '', 1, 0, 'F', '0', '0', 'system:dict:edit', '#', 'admin', sysdate(), '', null, ''); |
|||
insert into sys_menu values('1028', '字典删除', '105', '4', '#', '', '', 1, 0, 'F', '0', '0', 'system:dict:remove', '#', 'admin', sysdate(), '', null, ''); |
|||
insert into sys_menu values('1029', '字典导出', '105', '5', '#', '', '', 1, 0, 'F', '0', '0', 'system:dict:export', '#', 'admin', sysdate(), '', null, ''); |
|||
-- 参数设置按钮 |
|||
insert into sys_menu values('1030', '参数查询', '106', '1', '#', '', '', 1, 0, 'F', '0', '0', 'system:config:query', '#', 'admin', sysdate(), '', null, ''); |
|||
insert into sys_menu values('1031', '参数新增', '106', '2', '#', '', '', 1, 0, 'F', '0', '0', 'system:config:add', '#', 'admin', sysdate(), '', null, ''); |
|||
insert into sys_menu values('1032', '参数修改', '106', '3', '#', '', '', 1, 0, 'F', '0', '0', 'system:config:edit', '#', 'admin', sysdate(), '', null, ''); |
|||
insert into sys_menu values('1033', '参数删除', '106', '4', '#', '', '', 1, 0, 'F', '0', '0', 'system:config:remove', '#', 'admin', sysdate(), '', null, ''); |
|||
insert into sys_menu values('1034', '参数导出', '106', '5', '#', '', '', 1, 0, 'F', '0', '0', 'system:config:export', '#', 'admin', sysdate(), '', null, ''); |
|||
-- 通知公告按钮 |
|||
insert into sys_menu values('1035', '公告查询', '107', '1', '#', '', '', 1, 0, 'F', '0', '0', 'system:notice:query', '#', 'admin', sysdate(), '', null, ''); |
|||
insert into sys_menu values('1036', '公告新增', '107', '2', '#', '', '', 1, 0, 'F', '0', '0', 'system:notice:add', '#', 'admin', sysdate(), '', null, ''); |
|||
insert into sys_menu values('1037', '公告修改', '107', '3', '#', '', '', 1, 0, 'F', '0', '0', 'system:notice:edit', '#', 'admin', sysdate(), '', null, ''); |
|||
insert into sys_menu values('1038', '公告删除', '107', '4', '#', '', '', 1, 0, 'F', '0', '0', 'system:notice:remove', '#', 'admin', sysdate(), '', null, ''); |
|||
-- 操作日志按钮 |
|||
insert into sys_menu values('1039', '操作查询', '500', '1', '#', '', '', 1, 0, 'F', '0', '0', 'monitor:operlog:query', '#', 'admin', sysdate(), '', null, ''); |
|||
insert into sys_menu values('1040', '操作删除', '500', '2', '#', '', '', 1, 0, 'F', '0', '0', 'monitor:operlog:remove', '#', 'admin', sysdate(), '', null, ''); |
|||
insert into sys_menu values('1041', '日志导出', '500', '3', '#', '', '', 1, 0, 'F', '0', '0', 'monitor:operlog:export', '#', 'admin', sysdate(), '', null, ''); |
|||
-- 登录日志按钮 |
|||
insert into sys_menu values('1042', '登录查询', '501', '1', '#', '', '', 1, 0, 'F', '0', '0', 'monitor:logininfor:query', '#', 'admin', sysdate(), '', null, ''); |
|||
insert into sys_menu values('1043', '登录删除', '501', '2', '#', '', '', 1, 0, 'F', '0', '0', 'monitor:logininfor:remove', '#', 'admin', sysdate(), '', null, ''); |
|||
insert into sys_menu values('1044', '日志导出', '501', '3', '#', '', '', 1, 0, 'F', '0', '0', 'monitor:logininfor:export', '#', 'admin', sysdate(), '', null, ''); |
|||
insert into sys_menu values('1045', '账户解锁', '501', '4', '#', '', '', 1, 0, 'F', '0', '0', 'monitor:logininfor:unlock', '#', 'admin', sysdate(), '', null, ''); |
|||
-- 在线用户按钮 |
|||
insert into sys_menu values('1046', '在线查询', '109', '1', '#', '', '', 1, 0, 'F', '0', '0', 'monitor:online:query', '#', 'admin', sysdate(), '', null, ''); |
|||
insert into sys_menu values('1047', '批量强退', '109', '2', '#', '', '', 1, 0, 'F', '0', '0', 'monitor:online:batchLogout', '#', 'admin', sysdate(), '', null, ''); |
|||
insert into sys_menu values('1048', '单条强退', '109', '3', '#', '', '', 1, 0, 'F', '0', '0', 'monitor:online:forceLogout', '#', 'admin', sysdate(), '', null, ''); |
|||
-- 定时任务按钮 |
|||
insert into sys_menu values('1049', '任务查询', '110', '1', '#', '', '', 1, 0, 'F', '0', '0', 'monitor:job:query', '#', 'admin', sysdate(), '', null, ''); |
|||
insert into sys_menu values('1050', '任务新增', '110', '2', '#', '', '', 1, 0, 'F', '0', '0', 'monitor:job:add', '#', 'admin', sysdate(), '', null, ''); |
|||
insert into sys_menu values('1051', '任务修改', '110', '3', '#', '', '', 1, 0, 'F', '0', '0', 'monitor:job:edit', '#', 'admin', sysdate(), '', null, ''); |
|||
insert into sys_menu values('1052', '任务删除', '110', '4', '#', '', '', 1, 0, 'F', '0', '0', 'monitor:job:remove', '#', 'admin', sysdate(), '', null, ''); |
|||
insert into sys_menu values('1053', '状态修改', '110', '5', '#', '', '', 1, 0, 'F', '0', '0', 'monitor:job:changeStatus', '#', 'admin', sysdate(), '', null, ''); |
|||
insert into sys_menu values('1054', '任务导出', '110', '6', '#', '', '', 1, 0, 'F', '0', '0', 'monitor:job:export', '#', 'admin', sysdate(), '', null, ''); |
|||
-- 代码生成按钮 |
|||
insert into sys_menu values('1055', '生成查询', '116', '1', '#', '', '', 1, 0, 'F', '0', '0', 'tool:gen:query', '#', 'admin', sysdate(), '', null, ''); |
|||
insert into sys_menu values('1056', '生成修改', '116', '2', '#', '', '', 1, 0, 'F', '0', '0', 'tool:gen:edit', '#', 'admin', sysdate(), '', null, ''); |
|||
insert into sys_menu values('1057', '生成删除', '116', '3', '#', '', '', 1, 0, 'F', '0', '0', 'tool:gen:remove', '#', 'admin', sysdate(), '', null, ''); |
|||
insert into sys_menu values('1058', '导入代码', '116', '4', '#', '', '', 1, 0, 'F', '0', '0', 'tool:gen:import', '#', 'admin', sysdate(), '', null, ''); |
|||
insert into sys_menu values('1059', '预览代码', '116', '5', '#', '', '', 1, 0, 'F', '0', '0', 'tool:gen:preview', '#', 'admin', sysdate(), '', null, ''); |
|||
insert into sys_menu values('1060', '生成代码', '116', '6', '#', '', '', 1, 0, 'F', '0', '0', 'tool:gen:code', '#', 'admin', sysdate(), '', null, ''); |
|||
|
|||
|
|||
-- ---------------------------- |
|||
-- 6、用户和角色关联表 用户N-1角色 |
|||
-- ---------------------------- |
|||
drop table if exists sys_user_role; |
|||
create table sys_user_role ( |
|||
user_id bigint(20) not null comment '用户ID', |
|||
role_id bigint(20) not null comment '角色ID', |
|||
primary key(user_id, role_id) |
|||
) engine=innodb comment = '用户和角色关联表'; |
|||
|
|||
-- ---------------------------- |
|||
-- 初始化-用户和角色关联表数据 |
|||
-- ---------------------------- |
|||
insert into sys_user_role values ('1', '1'); |
|||
insert into sys_user_role values ('2', '2'); |
|||
|
|||
|
|||
-- ---------------------------- |
|||
-- 7、角色和菜单关联表 角色1-N菜单 |
|||
-- ---------------------------- |
|||
drop table if exists sys_role_menu; |
|||
create table sys_role_menu ( |
|||
role_id bigint(20) not null comment '角色ID', |
|||
menu_id bigint(20) not null comment '菜单ID', |
|||
primary key(role_id, menu_id) |
|||
) engine=innodb comment = '角色和菜单关联表'; |
|||
|
|||
-- ---------------------------- |
|||
-- 初始化-角色和菜单关联表数据 |
|||
-- ---------------------------- |
|||
insert into sys_role_menu values ('2', '1'); |
|||
insert into sys_role_menu values ('2', '2'); |
|||
insert into sys_role_menu values ('2', '3'); |
|||
insert into sys_role_menu values ('2', '4'); |
|||
insert into sys_role_menu values ('2', '100'); |
|||
insert into sys_role_menu values ('2', '101'); |
|||
insert into sys_role_menu values ('2', '102'); |
|||
insert into sys_role_menu values ('2', '103'); |
|||
insert into sys_role_menu values ('2', '104'); |
|||
insert into sys_role_menu values ('2', '105'); |
|||
insert into sys_role_menu values ('2', '106'); |
|||
insert into sys_role_menu values ('2', '107'); |
|||
insert into sys_role_menu values ('2', '108'); |
|||
insert into sys_role_menu values ('2', '109'); |
|||
insert into sys_role_menu values ('2', '110'); |
|||
insert into sys_role_menu values ('2', '111'); |
|||
insert into sys_role_menu values ('2', '112'); |
|||
insert into sys_role_menu values ('2', '113'); |
|||
insert into sys_role_menu values ('2', '114'); |
|||
insert into sys_role_menu values ('2', '115'); |
|||
insert into sys_role_menu values ('2', '116'); |
|||
insert into sys_role_menu values ('2', '117'); |
|||
insert into sys_role_menu values ('2', '500'); |
|||
insert into sys_role_menu values ('2', '501'); |
|||
insert into sys_role_menu values ('2', '1000'); |
|||
insert into sys_role_menu values ('2', '1001'); |
|||
insert into sys_role_menu values ('2', '1002'); |
|||
insert into sys_role_menu values ('2', '1003'); |
|||
insert into sys_role_menu values ('2', '1004'); |
|||
insert into sys_role_menu values ('2', '1005'); |
|||
insert into sys_role_menu values ('2', '1006'); |
|||
insert into sys_role_menu values ('2', '1007'); |
|||
insert into sys_role_menu values ('2', '1008'); |
|||
insert into sys_role_menu values ('2', '1009'); |
|||
insert into sys_role_menu values ('2', '1010'); |
|||
insert into sys_role_menu values ('2', '1011'); |
|||
insert into sys_role_menu values ('2', '1012'); |
|||
insert into sys_role_menu values ('2', '1013'); |
|||
insert into sys_role_menu values ('2', '1014'); |
|||
insert into sys_role_menu values ('2', '1015'); |
|||
insert into sys_role_menu values ('2', '1016'); |
|||
insert into sys_role_menu values ('2', '1017'); |
|||
insert into sys_role_menu values ('2', '1018'); |
|||
insert into sys_role_menu values ('2', '1019'); |
|||
insert into sys_role_menu values ('2', '1020'); |
|||
insert into sys_role_menu values ('2', '1021'); |
|||
insert into sys_role_menu values ('2', '1022'); |
|||
insert into sys_role_menu values ('2', '1023'); |
|||
insert into sys_role_menu values ('2', '1024'); |
|||
insert into sys_role_menu values ('2', '1025'); |
|||
insert into sys_role_menu values ('2', '1026'); |
|||
insert into sys_role_menu values ('2', '1027'); |
|||
insert into sys_role_menu values ('2', '1028'); |
|||
insert into sys_role_menu values ('2', '1029'); |
|||
insert into sys_role_menu values ('2', '1030'); |
|||
insert into sys_role_menu values ('2', '1031'); |
|||
insert into sys_role_menu values ('2', '1032'); |
|||
insert into sys_role_menu values ('2', '1033'); |
|||
insert into sys_role_menu values ('2', '1034'); |
|||
insert into sys_role_menu values ('2', '1035'); |
|||
insert into sys_role_menu values ('2', '1036'); |
|||
insert into sys_role_menu values ('2', '1037'); |
|||
insert into sys_role_menu values ('2', '1038'); |
|||
insert into sys_role_menu values ('2', '1039'); |
|||
insert into sys_role_menu values ('2', '1040'); |
|||
insert into sys_role_menu values ('2', '1041'); |
|||
insert into sys_role_menu values ('2', '1042'); |
|||
insert into sys_role_menu values ('2', '1043'); |
|||
insert into sys_role_menu values ('2', '1044'); |
|||
insert into sys_role_menu values ('2', '1045'); |
|||
insert into sys_role_menu values ('2', '1046'); |
|||
insert into sys_role_menu values ('2', '1047'); |
|||
insert into sys_role_menu values ('2', '1048'); |
|||
insert into sys_role_menu values ('2', '1049'); |
|||
insert into sys_role_menu values ('2', '1050'); |
|||
insert into sys_role_menu values ('2', '1051'); |
|||
insert into sys_role_menu values ('2', '1052'); |
|||
insert into sys_role_menu values ('2', '1053'); |
|||
insert into sys_role_menu values ('2', '1054'); |
|||
insert into sys_role_menu values ('2', '1055'); |
|||
insert into sys_role_menu values ('2', '1056'); |
|||
insert into sys_role_menu values ('2', '1057'); |
|||
insert into sys_role_menu values ('2', '1058'); |
|||
insert into sys_role_menu values ('2', '1059'); |
|||
insert into sys_role_menu values ('2', '1060'); |
|||
|
|||
-- ---------------------------- |
|||
-- 8、角色和部门关联表 角色1-N部门 |
|||
-- ---------------------------- |
|||
drop table if exists sys_role_dept; |
|||
create table sys_role_dept ( |
|||
role_id bigint(20) not null comment '角色ID', |
|||
dept_id bigint(20) not null comment '部门ID', |
|||
primary key(role_id, dept_id) |
|||
) engine=innodb comment = '角色和部门关联表'; |
|||
|
|||
-- ---------------------------- |
|||
-- 初始化-角色和部门关联表数据 |
|||
-- ---------------------------- |
|||
insert into sys_role_dept values ('2', '100'); |
|||
insert into sys_role_dept values ('2', '101'); |
|||
insert into sys_role_dept values ('2', '105'); |
|||
|
|||
|
|||
-- ---------------------------- |
|||
-- 9、用户与岗位关联表 用户1-N岗位 |
|||
-- ---------------------------- |
|||
drop table if exists sys_user_post; |
|||
create table sys_user_post |
|||
( |
|||
user_id bigint(20) not null comment '用户ID', |
|||
post_id bigint(20) not null comment '岗位ID', |
|||
primary key (user_id, post_id) |
|||
) engine=innodb comment = '用户与岗位关联表'; |
|||
|
|||
-- ---------------------------- |
|||
-- 初始化-用户与岗位关联表数据 |
|||
-- ---------------------------- |
|||
insert into sys_user_post values ('1', '1'); |
|||
insert into sys_user_post values ('2', '2'); |
|||
|
|||
|
|||
-- ---------------------------- |
|||
-- 10、操作日志记录 |
|||
-- ---------------------------- |
|||
drop table if exists sys_oper_log; |
|||
create table sys_oper_log ( |
|||
oper_id bigint(20) not null auto_increment comment '日志主键', |
|||
title varchar(50) default '' comment '模块标题', |
|||
business_type int(2) default 0 comment '业务类型(0其它 1新增 2修改 3删除)', |
|||
method varchar(100) default '' comment '方法名称', |
|||
request_method varchar(10) default '' comment '请求方式', |
|||
operator_type int(1) default 0 comment '操作类别(0其它 1后台用户 2手机端用户)', |
|||
oper_name varchar(50) default '' comment '操作人员', |
|||
dept_name varchar(50) default '' comment '部门名称', |
|||
oper_url varchar(255) default '' comment '请求URL', |
|||
oper_ip varchar(128) default '' comment '主机地址', |
|||
oper_location varchar(255) default '' comment '操作地点', |
|||
oper_param varchar(2000) default '' comment '请求参数', |
|||
json_result varchar(2000) default '' comment '返回参数', |
|||
status int(1) default 0 comment '操作状态(0正常 1异常)', |
|||
error_msg varchar(2000) default '' comment '错误消息', |
|||
oper_time datetime comment '操作时间', |
|||
primary key (oper_id) |
|||
) engine=innodb auto_increment=100 comment = '操作日志记录'; |
|||
|
|||
|
|||
-- ---------------------------- |
|||
-- 11、字典类型表 |
|||
-- ---------------------------- |
|||
drop table if exists sys_dict_type; |
|||
create table sys_dict_type |
|||
( |
|||
dict_id bigint(20) not null auto_increment comment '字典主键', |
|||
dict_name varchar(100) default '' comment '字典名称', |
|||
dict_type varchar(100) default '' comment '字典类型', |
|||
status char(1) default '0' comment '状态(0正常 1停用)', |
|||
create_by varchar(64) default '' comment '创建者', |
|||
create_time datetime comment '创建时间', |
|||
update_by varchar(64) default '' comment '更新者', |
|||
update_time datetime comment '更新时间', |
|||
remark varchar(500) default null comment '备注', |
|||
primary key (dict_id), |
|||
unique (dict_type) |
|||
) engine=innodb auto_increment=100 comment = '字典类型表'; |
|||
|
|||
insert into sys_dict_type values(1, '用户性别', 'sys_user_sex', '0', 'admin', sysdate(), '', null, '用户性别列表'); |
|||
insert into sys_dict_type values(2, '菜单状态', 'sys_show_hide', '0', 'admin', sysdate(), '', null, '菜单状态列表'); |
|||
insert into sys_dict_type values(3, '系统开关', 'sys_normal_disable', '0', 'admin', sysdate(), '', null, '系统开关列表'); |
|||
insert into sys_dict_type values(4, '任务状态', 'sys_job_status', '0', 'admin', sysdate(), '', null, '任务状态列表'); |
|||
insert into sys_dict_type values(5, '任务分组', 'sys_job_group', '0', 'admin', sysdate(), '', null, '任务分组列表'); |
|||
insert into sys_dict_type values(6, '系统是否', 'sys_yes_no', '0', 'admin', sysdate(), '', null, '系统是否列表'); |
|||
insert into sys_dict_type values(7, '通知类型', 'sys_notice_type', '0', 'admin', sysdate(), '', null, '通知类型列表'); |
|||
insert into sys_dict_type values(8, '通知状态', 'sys_notice_status', '0', 'admin', sysdate(), '', null, '通知状态列表'); |
|||
insert into sys_dict_type values(9, '操作类型', 'sys_oper_type', '0', 'admin', sysdate(), '', null, '操作类型列表'); |
|||
insert into sys_dict_type values(10, '系统状态', 'sys_common_status', '0', 'admin', sysdate(), '', null, '登录状态列表'); |
|||
|
|||
|
|||
-- ---------------------------- |
|||
-- 12、字典数据表 |
|||
-- ---------------------------- |
|||
drop table if exists sys_dict_data; |
|||
create table sys_dict_data |
|||
( |
|||
dict_code bigint(20) not null auto_increment comment '字典编码', |
|||
dict_sort int(4) default 0 comment '字典排序', |
|||
dict_label varchar(100) default '' comment '字典标签', |
|||
dict_value varchar(100) default '' comment '字典键值', |
|||
dict_type varchar(100) default '' comment '字典类型', |
|||
css_class varchar(100) default null comment '样式属性(其他样式扩展)', |
|||
list_class varchar(100) default null comment '表格回显样式', |
|||
is_default char(1) default 'N' comment '是否默认(Y是 N否)', |
|||
status char(1) default '0' comment '状态(0正常 1停用)', |
|||
create_by varchar(64) default '' comment '创建者', |
|||
create_time datetime comment '创建时间', |
|||
update_by varchar(64) default '' comment '更新者', |
|||
update_time datetime comment '更新时间', |
|||
remark varchar(500) default null comment '备注', |
|||
primary key (dict_code) |
|||
) engine=innodb auto_increment=100 comment = '字典数据表'; |
|||
|
|||
insert into sys_dict_data values(1, 1, '男', '0', 'sys_user_sex', '', '', 'Y', '0', 'admin', sysdate(), '', null, '性别男'); |
|||
insert into sys_dict_data values(2, 2, '女', '1', 'sys_user_sex', '', '', 'N', '0', 'admin', sysdate(), '', null, '性别女'); |
|||
insert into sys_dict_data values(3, 3, '未知', '2', 'sys_user_sex', '', '', 'N', '0', 'admin', sysdate(), '', null, '性别未知'); |
|||
insert into sys_dict_data values(4, 1, '显示', '0', 'sys_show_hide', '', 'primary', 'Y', '0', 'admin', sysdate(), '', null, '显示菜单'); |
|||
insert into sys_dict_data values(5, 2, '隐藏', '1', 'sys_show_hide', '', 'danger', 'N', '0', 'admin', sysdate(), '', null, '隐藏菜单'); |
|||
insert into sys_dict_data values(6, 1, '正常', '0', 'sys_normal_disable', '', 'primary', 'Y', '0', 'admin', sysdate(), '', null, '正常状态'); |
|||
insert into sys_dict_data values(7, 2, '停用', '1', 'sys_normal_disable', '', 'danger', 'N', '0', 'admin', sysdate(), '', null, '停用状态'); |
|||
insert into sys_dict_data values(8, 1, '正常', '0', 'sys_job_status', '', 'primary', 'Y', '0', 'admin', sysdate(), '', null, '正常状态'); |
|||
insert into sys_dict_data values(9, 2, '暂停', '1', 'sys_job_status', '', 'danger', 'N', '0', 'admin', sysdate(), '', null, '停用状态'); |
|||
insert into sys_dict_data values(10, 1, '默认', 'DEFAULT', 'sys_job_group', '', '', 'Y', '0', 'admin', sysdate(), '', null, '默认分组'); |
|||
insert into sys_dict_data values(11, 2, '系统', 'SYSTEM', 'sys_job_group', '', '', 'N', '0', 'admin', sysdate(), '', null, '系统分组'); |
|||
insert into sys_dict_data values(12, 1, '是', 'Y', 'sys_yes_no', '', 'primary', 'Y', '0', 'admin', sysdate(), '', null, '系统默认是'); |
|||
insert into sys_dict_data values(13, 2, '否', 'N', 'sys_yes_no', '', 'danger', 'N', '0', 'admin', sysdate(), '', null, '系统默认否'); |
|||
insert into sys_dict_data values(14, 1, '通知', '1', 'sys_notice_type', '', 'warning', 'Y', '0', 'admin', sysdate(), '', null, '通知'); |
|||
insert into sys_dict_data values(15, 2, '公告', '2', 'sys_notice_type', '', 'success', 'N', '0', 'admin', sysdate(), '', null, '公告'); |
|||
insert into sys_dict_data values(16, 1, '正常', '0', 'sys_notice_status', '', 'primary', 'Y', '0', 'admin', sysdate(), '', null, '正常状态'); |
|||
insert into sys_dict_data values(17, 2, '关闭', '1', 'sys_notice_status', '', 'danger', 'N', '0', 'admin', sysdate(), '', null, '关闭状态'); |
|||
insert into sys_dict_data values(18, 99, '其他', '0', 'sys_oper_type', '', 'info', 'N', '0', 'admin', sysdate(), '', null, '其他操作'); |
|||
insert into sys_dict_data values(19, 1, '新增', '1', 'sys_oper_type', '', 'info', 'N', '0', 'admin', sysdate(), '', null, '新增操作'); |
|||
insert into sys_dict_data values(20, 2, '修改', '2', 'sys_oper_type', '', 'info', 'N', '0', 'admin', sysdate(), '', null, '修改操作'); |
|||
insert into sys_dict_data values(21, 3, '删除', '3', 'sys_oper_type', '', 'danger', 'N', '0', 'admin', sysdate(), '', null, '删除操作'); |
|||
insert into sys_dict_data values(22, 4, '授权', '4', 'sys_oper_type', '', 'primary', 'N', '0', 'admin', sysdate(), '', null, '授权操作'); |
|||
insert into sys_dict_data values(23, 5, '导出', '5', 'sys_oper_type', '', 'warning', 'N', '0', 'admin', sysdate(), '', null, '导出操作'); |
|||
insert into sys_dict_data values(24, 6, '导入', '6', 'sys_oper_type', '', 'warning', 'N', '0', 'admin', sysdate(), '', null, '导入操作'); |
|||
insert into sys_dict_data values(25, 7, '强退', '7', 'sys_oper_type', '', 'danger', 'N', '0', 'admin', sysdate(), '', null, '强退操作'); |
|||
insert into sys_dict_data values(26, 8, '生成代码', '8', 'sys_oper_type', '', 'warning', 'N', '0', 'admin', sysdate(), '', null, '生成操作'); |
|||
insert into sys_dict_data values(27, 9, '清空数据', '9', 'sys_oper_type', '', 'danger', 'N', '0', 'admin', sysdate(), '', null, '清空操作'); |
|||
insert into sys_dict_data values(28, 1, '成功', '0', 'sys_common_status', '', 'primary', 'N', '0', 'admin', sysdate(), '', null, '正常状态'); |
|||
insert into sys_dict_data values(29, 2, '失败', '1', 'sys_common_status', '', 'danger', 'N', '0', 'admin', sysdate(), '', null, '停用状态'); |
|||
|
|||
|
|||
-- ---------------------------- |
|||
-- 13、参数配置表 |
|||
-- ---------------------------- |
|||
drop table if exists sys_config; |
|||
create table sys_config ( |
|||
config_id int(5) not null auto_increment comment '参数主键', |
|||
config_name varchar(100) default '' comment '参数名称', |
|||
config_key varchar(100) default '' comment '参数键名', |
|||
config_value varchar(500) default '' comment '参数键值', |
|||
config_type char(1) default 'N' comment '系统内置(Y是 N否)', |
|||
create_by varchar(64) default '' comment '创建者', |
|||
create_time datetime comment '创建时间', |
|||
update_by varchar(64) default '' comment '更新者', |
|||
update_time datetime comment '更新时间', |
|||
remark varchar(500) default null comment '备注', |
|||
primary key (config_id) |
|||
) engine=innodb auto_increment=100 comment = '参数配置表'; |
|||
|
|||
insert into sys_config values(1, '主框架页-默认皮肤样式名称', 'sys.index.skinName', 'skin-blue', 'Y', 'admin', sysdate(), '', null, '蓝色 skin-blue、绿色 skin-green、紫色 skin-purple、红色 skin-red、黄色 skin-yellow' ); |
|||
insert into sys_config values(2, '用户管理-账号初始密码', 'sys.user.initPassword', '123456', 'Y', 'admin', sysdate(), '', null, '初始化密码 123456' ); |
|||
insert into sys_config values(3, '主框架页-侧边栏主题', 'sys.index.sideTheme', 'theme-dark', 'Y', 'admin', sysdate(), '', null, '深色主题theme-dark,浅色主题theme-light' ); |
|||
insert into sys_config values(4, '账号自助-验证码开关', 'sys.account.captchaEnabled', 'true', 'Y', 'admin', sysdate(), '', null, '是否开启验证码功能(true开启,false关闭)'); |
|||
insert into sys_config values(5, '账号自助-是否开启用户注册功能', 'sys.account.registerUser', 'false', 'Y', 'admin', sysdate(), '', null, '是否开启注册用户功能(true开启,false关闭)'); |
|||
|
|||
|
|||
-- ---------------------------- |
|||
-- 14、系统访问记录 |
|||
-- ---------------------------- |
|||
drop table if exists sys_logininfor; |
|||
create table sys_logininfor ( |
|||
info_id bigint(20) not null auto_increment comment '访问ID', |
|||
user_name varchar(50) default '' comment '用户账号', |
|||
ipaddr varchar(128) default '' comment '登录IP地址', |
|||
login_location varchar(255) default '' comment '登录地点', |
|||
browser varchar(50) default '' comment '浏览器类型', |
|||
os varchar(50) default '' comment '操作系统', |
|||
status char(1) default '0' comment '登录状态(0成功 1失败)', |
|||
msg varchar(255) default '' comment '提示消息', |
|||
login_time datetime comment '访问时间', |
|||
primary key (info_id) |
|||
) engine=innodb auto_increment=100 comment = '系统访问记录'; |
|||
|
|||
|
|||
-- ---------------------------- |
|||
-- 15、定时任务调度表 |
|||
-- ---------------------------- |
|||
drop table if exists sys_job; |
|||
create table sys_job ( |
|||
job_id bigint(20) not null auto_increment comment '任务ID', |
|||
job_name varchar(64) default '' comment '任务名称', |
|||
job_group varchar(64) default 'DEFAULT' comment '任务组名', |
|||
invoke_target varchar(500) not null comment '调用目标字符串', |
|||
cron_expression varchar(255) default '' comment 'cron执行表达式', |
|||
misfire_policy varchar(20) default '3' comment '计划执行错误策略(1立即执行 2执行一次 3放弃执行)', |
|||
concurrent char(1) default '1' comment '是否并发执行(0允许 1禁止)', |
|||
status char(1) default '0' comment '状态(0正常 1暂停)', |
|||
create_by varchar(64) default '' comment '创建者', |
|||
create_time datetime comment '创建时间', |
|||
update_by varchar(64) default '' comment '更新者', |
|||
update_time datetime comment '更新时间', |
|||
remark varchar(500) default '' comment '备注信息', |
|||
primary key (job_id, job_name, job_group) |
|||
) engine=innodb auto_increment=100 comment = '定时任务调度表'; |
|||
|
|||
insert into sys_job values(1, '系统默认(无参)', 'DEFAULT', 'ryTask.ryNoParams', '0/10 * * * * ?', '3', '1', '1', 'admin', sysdate(), '', null, ''); |
|||
insert into sys_job values(2, '系统默认(有参)', 'DEFAULT', 'ryTask.ryParams(\'ry\')', '0/15 * * * * ?', '3', '1', '1', 'admin', sysdate(), '', null, ''); |
|||
insert into sys_job values(3, '系统默认(多参)', 'DEFAULT', 'ryTask.ryMultipleParams(\'ry\', true, 2000L, 316.50D, 100)', '0/20 * * * * ?', '3', '1', '1', 'admin', sysdate(), '', null, ''); |
|||
|
|||
|
|||
-- ---------------------------- |
|||
-- 16、定时任务调度日志表 |
|||
-- ---------------------------- |
|||
drop table if exists sys_job_log; |
|||
create table sys_job_log ( |
|||
job_log_id bigint(20) not null auto_increment comment '任务日志ID', |
|||
job_name varchar(64) not null comment '任务名称', |
|||
job_group varchar(64) not null comment '任务组名', |
|||
invoke_target varchar(500) not null comment '调用目标字符串', |
|||
job_message varchar(500) comment '日志信息', |
|||
status char(1) default '0' comment '执行状态(0正常 1失败)', |
|||
exception_info varchar(2000) default '' comment '异常信息', |
|||
create_time datetime comment '创建时间', |
|||
primary key (job_log_id) |
|||
) engine=innodb comment = '定时任务调度日志表'; |
|||
|
|||
|
|||
-- ---------------------------- |
|||
-- 17、通知公告表 |
|||
-- ---------------------------- |
|||
drop table if exists sys_notice; |
|||
create table sys_notice ( |
|||
notice_id int(4) not null auto_increment comment '公告ID', |
|||
notice_title varchar(50) not null comment '公告标题', |
|||
notice_type char(1) not null comment '公告类型(1通知 2公告)', |
|||
notice_content longblob default null comment '公告内容', |
|||
status char(1) default '0' comment '公告状态(0正常 1关闭)', |
|||
create_by varchar(64) default '' comment '创建者', |
|||
create_time datetime comment '创建时间', |
|||
update_by varchar(64) default '' comment '更新者', |
|||
update_time datetime comment '更新时间', |
|||
remark varchar(255) default null comment '备注', |
|||
primary key (notice_id) |
|||
) engine=innodb auto_increment=10 comment = '通知公告表'; |
|||
|
|||
-- ---------------------------- |
|||
-- 初始化-公告信息表数据 |
|||
-- ---------------------------- |
|||
insert into sys_notice values('1', '温馨提醒:2018-07-01 闻音新版本发布啦', '2', '新版本内容', '0', 'admin', sysdate(), '', null, '管理员'); |
|||
insert into sys_notice values('2', '维护通知:2018-07-01 闻音系统凌晨维护', '1', '维护内容', '0', 'admin', sysdate(), '', null, '管理员'); |
|||
|
|||
|
|||
-- ---------------------------- |
|||
-- 18、代码生成业务表 |
|||
-- ---------------------------- |
|||
drop table if exists gen_table; |
|||
create table gen_table ( |
|||
table_id bigint(20) not null auto_increment comment '编号', |
|||
table_name varchar(200) default '' comment '表名称', |
|||
table_comment varchar(500) default '' comment '表描述', |
|||
sub_table_name varchar(64) default null comment '关联子表的表名', |
|||
sub_table_fk_name varchar(64) default null comment '子表关联的外键名', |
|||
class_name varchar(100) default '' comment '实体类名称', |
|||
tpl_category varchar(200) default 'crud' comment '使用的模板(crud单表操作 tree树表操作)', |
|||
package_name varchar(100) comment '生成包路径', |
|||
module_name varchar(30) comment '生成模块名', |
|||
business_name varchar(30) comment '生成业务名', |
|||
function_name varchar(50) comment '生成功能名', |
|||
function_author varchar(50) comment '生成功能作者', |
|||
gen_type char(1) default '0' comment '生成代码方式(0zip压缩包 1自定义路径)', |
|||
gen_path varchar(200) default '/' comment '生成路径(不填默认项目路径)', |
|||
options varchar(1000) comment '其它生成选项', |
|||
create_by varchar(64) default '' comment '创建者', |
|||
create_time datetime comment '创建时间', |
|||
update_by varchar(64) default '' comment '更新者', |
|||
update_time datetime comment '更新时间', |
|||
remark varchar(500) default null comment '备注', |
|||
primary key (table_id) |
|||
) engine=innodb auto_increment=1 comment = '代码生成业务表'; |
|||
|
|||
|
|||
-- ---------------------------- |
|||
-- 19、代码生成业务表字段 |
|||
-- ---------------------------- |
|||
drop table if exists gen_table_column; |
|||
create table gen_table_column ( |
|||
column_id bigint(20) not null auto_increment comment '编号', |
|||
table_id varchar(64) comment '归属表编号', |
|||
column_name varchar(200) comment '列名称', |
|||
column_comment varchar(500) comment '列描述', |
|||
column_type varchar(100) comment '列类型', |
|||
java_type varchar(500) comment 'JAVA类型', |
|||
java_field varchar(200) comment 'JAVA字段名', |
|||
is_pk char(1) comment '是否主键(1是)', |
|||
is_increment char(1) comment '是否自增(1是)', |
|||
is_required char(1) comment '是否必填(1是)', |
|||
is_insert char(1) comment '是否为插入字段(1是)', |
|||
is_edit char(1) comment '是否编辑字段(1是)', |
|||
is_list char(1) comment '是否列表字段(1是)', |
|||
is_query char(1) comment '是否查询字段(1是)', |
|||
query_type varchar(200) default 'EQ' comment '查询方式(等于、不等于、大于、小于、范围)', |
|||
html_type varchar(200) comment '显示类型(文本框、文本域、下拉框、复选框、单选框、日期控件)', |
|||
dict_type varchar(200) default '' comment '字典类型', |
|||
sort int comment '排序', |
|||
create_by varchar(64) default '' comment '创建者', |
|||
create_time datetime comment '创建时间', |
|||
update_by varchar(64) default '' comment '更新者', |
|||
update_time datetime comment '更新时间', |
|||
primary key (column_id) |
|||
) engine=innodb auto_increment=1 comment = '代码生成业务表字段'; |
@ -0,0 +1,83 @@ |
|||
<?xml version="1.0" encoding="UTF-8"?> |
|||
<project xmlns="http://maven.apache.org/POM/4.0.0" |
|||
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" |
|||
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> |
|||
<parent> |
|||
<artifactId>win</artifactId> |
|||
<groupId>com.win</groupId> |
|||
<version>1.0.0</version> |
|||
</parent> |
|||
<modelVersion>4.0.0</modelVersion> |
|||
<packaging>jar</packaging> |
|||
<artifactId>win-admin</artifactId> |
|||
|
|||
<description> |
|||
web服务入口 |
|||
</description> |
|||
|
|||
<dependencies> |
|||
|
|||
<!-- spring-boot-devtools --> |
|||
<dependency> |
|||
<groupId>org.springframework.boot</groupId> |
|||
<artifactId>spring-boot-devtools</artifactId> |
|||
<optional>true</optional> <!-- 表示依赖不会传递 --> |
|||
</dependency> |
|||
|
|||
<!-- Mysql驱动包 --> |
|||
<dependency> |
|||
<groupId>mysql</groupId> |
|||
<artifactId>mysql-connector-java</artifactId> |
|||
</dependency> |
|||
|
|||
<!-- 核心模块--> |
|||
<dependency> |
|||
<groupId>com.win</groupId> |
|||
<artifactId>win-framework</artifactId> |
|||
</dependency> |
|||
|
|||
<!-- 定时任务--> |
|||
<dependency> |
|||
<groupId>com.win</groupId> |
|||
<artifactId>win-quartz</artifactId> |
|||
</dependency> |
|||
|
|||
<!-- 代码生成--> |
|||
<dependency> |
|||
<groupId>com.win</groupId> |
|||
<artifactId>win-generator</artifactId> |
|||
</dependency> |
|||
|
|||
</dependencies> |
|||
|
|||
<build> |
|||
<plugins> |
|||
<plugin> |
|||
<groupId>org.springframework.boot</groupId> |
|||
<artifactId>spring-boot-maven-plugin</artifactId> |
|||
<version>2.1.1.RELEASE</version> |
|||
<configuration> |
|||
<fork>true</fork> <!-- 如果没有该配置,devtools不会生效 --> |
|||
</configuration> |
|||
<executions> |
|||
<execution> |
|||
<goals> |
|||
<goal>repackage</goal> |
|||
</goals> |
|||
</execution> |
|||
</executions> |
|||
</plugin> |
|||
<plugin> |
|||
<groupId>org.apache.maven.plugins</groupId> |
|||
<artifactId>maven-war-plugin</artifactId> |
|||
<version>3.1.0</version> |
|||
<configuration> |
|||
<failOnMissingWebXml>false</failOnMissingWebXml> |
|||
<warName>${project.artifactId}</warName> |
|||
</configuration> |
|||
</plugin> |
|||
</plugins> |
|||
<finalName>${project.artifactId}</finalName> |
|||
</build> |
|||
|
|||
</project> |
@ -0,0 +1,26 @@ |
|||
package com.win.web; |
|||
|
|||
import com.alibaba.druid.spring.boot.autoconfigure.DruidDataSourceAutoConfigure; |
|||
import com.github.xiaoymin.knife4j.spring.annotations.EnableKnife4j; |
|||
import org.springframework.boot.SpringApplication; |
|||
import org.springframework.boot.autoconfigure.SpringBootApplication; |
|||
import org.springframework.boot.autoconfigure.jdbc.DataSourceAutoConfiguration; |
|||
|
|||
/** |
|||
* 启动程序 |
|||
* |
|||
* @author win |
|||
*/ |
|||
@EnableKnife4j |
|||
@SpringBootApplication( |
|||
scanBasePackages = {"com.win.common", "com.win.system", "com.win.framework", "com.win.generator", "com.win.quartz", "com.win.flowable", "com.win.web"}, |
|||
exclude = {DataSourceAutoConfiguration.class, DruidDataSourceAutoConfigure.class}) |
|||
public class WinApplication { |
|||
|
|||
public static void main(String[] args) { |
|||
// System.setProperty("spring.devtools.restart.enabled", "false");
|
|||
SpringApplication.run(WinApplication.class, args); |
|||
System.out.println("闻音启动成功"); |
|||
} |
|||
|
|||
} |
@ -0,0 +1,16 @@ |
|||
package com.win.web; |
|||
|
|||
import org.springframework.boot.builder.SpringApplicationBuilder; |
|||
import org.springframework.boot.web.servlet.support.SpringBootServletInitializer; |
|||
|
|||
/** |
|||
* web容器中进行部署 |
|||
* |
|||
* @author win |
|||
*/ |
|||
public class WinServletInitializer extends SpringBootServletInitializer { |
|||
@Override |
|||
protected SpringApplicationBuilder configure(SpringApplicationBuilder application) { |
|||
return application.sources(WinApplication.class); |
|||
} |
|||
} |
@ -0,0 +1,31 @@ |
|||
package com.win.web.config; |
|||
|
|||
import org.springframework.context.annotation.Bean; |
|||
import org.springframework.context.annotation.Configuration; |
|||
import org.springframework.http.client.ClientHttpRequestFactory; |
|||
import org.springframework.http.client.SimpleClientHttpRequestFactory; |
|||
import org.springframework.http.converter.StringHttpMessageConverter; |
|||
import org.springframework.web.client.RestTemplate; |
|||
|
|||
import java.nio.charset.StandardCharsets; |
|||
|
|||
@Configuration |
|||
public class RestTemplateConfig { |
|||
|
|||
@Bean |
|||
public RestTemplate restTemplate(ClientHttpRequestFactory factory) { |
|||
RestTemplate restTemplate = new RestTemplate(factory); |
|||
// 支持中文编码
|
|||
restTemplate.getMessageConverters().set(1, new StringHttpMessageConverter(StandardCharsets.UTF_8)); |
|||
return restTemplate; |
|||
} |
|||
|
|||
@Bean |
|||
public ClientHttpRequestFactory simpleClientHttpRequestFactory() { |
|||
SimpleClientHttpRequestFactory factory = new SimpleClientHttpRequestFactory(); |
|||
factory.setReadTimeout(5000);//单位为ms
|
|||
factory.setConnectTimeout(5000);//单位为ms
|
|||
return factory; |
|||
} |
|||
|
|||
} |
@ -0,0 +1,17 @@ |
|||
package com.win.web.config; |
|||
|
|||
import com.win.common.utils.shell.ShellVo; |
|||
import lombok.Data; |
|||
import org.springframework.boot.context.properties.ConfigurationProperties; |
|||
import org.springframework.stereotype.Component; |
|||
|
|||
@Data |
|||
@Component |
|||
@ConfigurationProperties(prefix = "shell") |
|||
public class ShellConfig { |
|||
|
|||
//linux配置信息
|
|||
private ShellVo jlht; |
|||
private ShellVo jlht2; |
|||
|
|||
} |
@ -0,0 +1,34 @@ |
|||
package com.win.web.config; |
|||
|
|||
|
|||
import lombok.Data; |
|||
import org.springframework.boot.context.properties.ConfigurationProperties; |
|||
import org.springframework.context.annotation.Configuration; |
|||
|
|||
@Data |
|||
@Configuration |
|||
@ConfigurationProperties(prefix = "sfms") |
|||
public class SmfsConfigure { |
|||
|
|||
/** |
|||
* 用户名 |
|||
*/ |
|||
private String username; |
|||
/** |
|||
* 密码 |
|||
*/ |
|||
private String password; |
|||
/** |
|||
* 采购订单请求地址 |
|||
*/ |
|||
private String purchaseOrder; |
|||
/** |
|||
* 访问token |
|||
*/ |
|||
private String accessToken; |
|||
/** |
|||
* 刷新token |
|||
*/ |
|||
private String refreshToken; |
|||
|
|||
} |
@ -0,0 +1,121 @@ |
|||
package com.win.web.config; |
|||
|
|||
import com.win.common.config.WinConfig; |
|||
import io.swagger.annotations.ApiOperation; |
|||
import io.swagger.models.auth.In; |
|||
import org.springframework.beans.factory.annotation.Autowired; |
|||
import org.springframework.beans.factory.annotation.Value; |
|||
import org.springframework.context.annotation.Bean; |
|||
import org.springframework.context.annotation.Configuration; |
|||
import springfox.documentation.builders.ApiInfoBuilder; |
|||
import springfox.documentation.builders.PathSelectors; |
|||
import springfox.documentation.builders.RequestHandlerSelectors; |
|||
import springfox.documentation.service.*; |
|||
import springfox.documentation.spi.DocumentationType; |
|||
import springfox.documentation.spi.service.contexts.SecurityContext; |
|||
import springfox.documentation.spring.web.plugins.Docket; |
|||
|
|||
import java.util.ArrayList; |
|||
import java.util.List; |
|||
|
|||
/** |
|||
* Swagger2的接口配置 |
|||
* |
|||
* @author win |
|||
*/ |
|||
@Configuration |
|||
public class SwaggerConfig |
|||
{ |
|||
/** 系统基础配置 */ |
|||
@Autowired |
|||
private WinConfig winConfig; |
|||
|
|||
/** 是否开启swagger */ |
|||
@Value("${swagger.enabled}") |
|||
private boolean enabled; |
|||
|
|||
/** 设置请求的统一前缀 */ |
|||
@Value("${swagger.pathMapping}") |
|||
private String pathMapping; |
|||
|
|||
/** |
|||
* 创建API |
|||
*/ |
|||
@Bean |
|||
public Docket createRestApi() |
|||
{ |
|||
return new Docket(DocumentationType.OAS_30) |
|||
// 是否启用Swagger
|
|||
.enable(enabled) |
|||
// 用来创建该API的基本信息,展示在文档的页面中(自定义展示的信息)
|
|||
.apiInfo(apiInfo()) |
|||
// 设置哪些接口暴露给Swagger展示
|
|||
.select() |
|||
// 扫描所有有注解的api,用这种方式更灵活
|
|||
.apis(RequestHandlerSelectors.withMethodAnnotation(ApiOperation.class)) |
|||
// 扫描指定包中的swagger注解
|
|||
// .apis(RequestHandlerSelectors.basePackage("com.win.project.tool.swagger"))
|
|||
// 扫描所有 .apis(RequestHandlerSelectors.any())
|
|||
.paths(PathSelectors.any()) |
|||
.build() |
|||
/* 设置安全模式,swagger可以设置访问token */ |
|||
.securitySchemes(securitySchemes()) |
|||
.securityContexts(securityContexts()) |
|||
.pathMapping(pathMapping); |
|||
} |
|||
|
|||
/** |
|||
* 安全模式,这里指定token通过Authorization头请求头传递 |
|||
*/ |
|||
private List<SecurityScheme> securitySchemes() |
|||
{ |
|||
List<SecurityScheme> apiKeyList = new ArrayList<SecurityScheme>(); |
|||
apiKeyList.add(new ApiKey("Authorization", "Authorization", In.HEADER.toValue())); |
|||
return apiKeyList; |
|||
} |
|||
|
|||
/** |
|||
* 安全上下文 |
|||
*/ |
|||
private List<SecurityContext> securityContexts() |
|||
{ |
|||
List<SecurityContext> securityContexts = new ArrayList<>(); |
|||
securityContexts.add( |
|||
SecurityContext.builder() |
|||
.securityReferences(defaultAuth()) |
|||
.operationSelector(o -> o.requestMappingPattern().matches("/.*")) |
|||
.build()); |
|||
return securityContexts; |
|||
} |
|||
|
|||
/** |
|||
* 默认的安全上引用 |
|||
*/ |
|||
private List<SecurityReference> defaultAuth() |
|||
{ |
|||
AuthorizationScope authorizationScope = new AuthorizationScope("global", "accessEverything"); |
|||
AuthorizationScope[] authorizationScopes = new AuthorizationScope[1]; |
|||
authorizationScopes[0] = authorizationScope; |
|||
List<SecurityReference> securityReferences = new ArrayList<>(); |
|||
securityReferences.add(new SecurityReference("Authorization", authorizationScopes)); |
|||
return securityReferences; |
|||
} |
|||
|
|||
/** |
|||
* 添加摘要信息 |
|||
*/ |
|||
private ApiInfo apiInfo() |
|||
{ |
|||
// 用ApiInfoBuilder进行定制
|
|||
return new ApiInfoBuilder() |
|||
// 设置标题
|
|||
.title("标题:闻音管理系统_接口文档") |
|||
// 描述
|
|||
.description("描述:用于管理集团旗下公司的人员信息,具体包括XXX,XXX模块...") |
|||
// 作者信息
|
|||
.contact(new Contact(winConfig.getName(), null, null)) |
|||
// 版本
|
|||
.version("版本号:" + winConfig.getVersion()) |
|||
.build(); |
|||
} |
|||
} |
@ -0,0 +1,133 @@ |
|||
package com.win.web.controller.base; |
|||
|
|||
import com.alibaba.fastjson2.JSONObject; |
|||
import com.win.common.constant.HttpStatus; |
|||
import com.win.common.core.domain.AjaxResult; |
|||
import com.win.common.utils.ProfileUtil; |
|||
import com.win.common.utils.command.CommandUtil; |
|||
import com.win.common.utils.shell.ShellVo; |
|||
import com.win.web.config.ShellConfig; |
|||
import lombok.extern.slf4j.Slf4j; |
|||
import org.apache.commons.lang3.StringUtils; |
|||
import org.slf4j.Logger; |
|||
import org.slf4j.LoggerFactory; |
|||
import org.springframework.beans.factory.annotation.Autowired; |
|||
import org.springframework.util.DigestUtils; |
|||
import org.springframework.web.bind.annotation.PostMapping; |
|||
import org.springframework.web.bind.annotation.RequestBody; |
|||
import org.springframework.web.bind.annotation.RequestMapping; |
|||
import org.springframework.web.bind.annotation.RestController; |
|||
|
|||
import javax.servlet.http.HttpServletRequest; |
|||
import java.io.IOException; |
|||
import java.lang.reflect.InvocationTargetException; |
|||
import java.lang.reflect.Method; |
|||
import java.util.List; |
|||
|
|||
@Slf4j |
|||
@RestController |
|||
@RequestMapping("/command") |
|||
public class CommandController { |
|||
|
|||
private static final Logger logger = LoggerFactory.getLogger("sys-user"); |
|||
|
|||
@Autowired |
|||
private ShellConfig shellConfig; |
|||
|
|||
/** |
|||
* 对外提供一个接口,通过header中的interfaceName反射机制调用方法,方法必须写到这个controller中,并且不用加PostMapping注解。 |
|||
* |
|||
* @param request request |
|||
* @param body 请求主体 |
|||
* @return 结果 |
|||
*/ |
|||
@PostMapping("/api") |
|||
@SuppressWarnings("unchecked") |
|||
public AjaxResult api(HttpServletRequest request, @RequestBody String body) throws NoSuchMethodException, InvocationTargetException, IllegalAccessException { |
|||
String interfaceName = request.getHeader("interface"); |
|||
String sign = request.getHeader("sign"); |
|||
String timeStr = request.getHeader("timestamp"); |
|||
if(timeStr == null || timeStr.isEmpty()) { |
|||
return AjaxResult.error(HttpStatus.TIMESTAMP_ERROR, "时间戳不正确"); |
|||
} |
|||
long timestamp = 0; |
|||
try { |
|||
timestamp = Long.parseLong(timeStr); |
|||
} catch (NumberFormatException e) { |
|||
return AjaxResult.error(HttpStatus.TIMESTAMP_ERROR, "时间戳不正确"); |
|||
} |
|||
String tmp = interfaceName + body + timestamp; |
|||
String computeSign = DigestUtils.md5DigestAsHex(tmp.getBytes()); |
|||
long tenTimestamp = timestamp + (10 * 60 * 1000); // 计算10分钟后的时间戳
|
|||
long currentTimestamp = System.currentTimeMillis(); // 获取当前时间戳
|
|||
//过期
|
|||
if(timestamp > currentTimestamp || tenTimestamp < currentTimestamp) { |
|||
return AjaxResult.error(HttpStatus.EXPIRE_ERROR, "请求已过期"); |
|||
} |
|||
List<String> activeProfile = ProfileUtil.getActiveProfile(); |
|||
//dev环境不校验签名
|
|||
if(!activeProfile.contains("dev") && !StringUtils.equals(sign, computeSign.toUpperCase())) { |
|||
return AjaxResult.error(HttpStatus.SIGN_ERROR, "签名不正确"); |
|||
} |
|||
Method method = this.getClass().getMethod(interfaceName, String.class); |
|||
return (AjaxResult) method.invoke(this, body); |
|||
} |
|||
|
|||
public AjaxResult itemmastercreate(String body) throws IOException, InterruptedException { |
|||
String result = CommandUtil.execute("cmd /c ping www.baidu.com -n 5"); |
|||
return AjaxResult.success(result); |
|||
} |
|||
|
|||
public AjaxResult itemdetailcreate(String body) throws IOException, InterruptedException { |
|||
String result = CommandUtil.execute("cmd dir"); |
|||
return AjaxResult.success(result); |
|||
} |
|||
|
|||
public AjaxResult discretepo(String body) throws IOException, InterruptedException { |
|||
JSONObject jsonObject = JSONObject.parseObject(body); |
|||
jsonObject = JSONObject.parseObject(jsonObject.getString("dsDescreteOrder")); |
|||
ShellVo shellVo; |
|||
if(jsonObject.getString("domain") != null && jsonObject.getString("domain").equals("JLHT2")) { |
|||
shellVo = shellConfig.getJlht2(); |
|||
} else { |
|||
shellVo = shellConfig.getJlht(); |
|||
} |
|||
//生成traceid
|
|||
String traceid = jsonObject.getString("traceid"); |
|||
jsonObject.remove("traceid"); |
|||
jsonObject.remove("company"); |
|||
jsonObject.remove("domain"); |
|||
String inJson = "{\"dsDescreteOrder\":"+ jsonObject+"}"; |
|||
log.info("inJson: {}", inJson); |
|||
//写入json
|
|||
String result = CommandUtil.execute("touch /home/mfg/work/cim/po/"+traceid+".json && echo '"+inJson+"'>/home/mfg/work/cim/po/"+traceid+".json"); |
|||
log.info("write json result : " + result); |
|||
//写入dat.json
|
|||
String datJson = "\"/home/mfg/work/cim/po/"+traceid+".json\" \"xxdspoapi.p\" \"/home/mfg/work/out/po/"+traceid+".out.log\" \""+shellVo.getQadUser()+"\" \""+shellVo.getQadPassword()+"\"\r\n\""+shellVo.getQadDomain()+"\""; |
|||
log.info("datJson: {}", datJson); |
|||
result = CommandUtil.execute("touch /home/mfg/work/cim/po/"+traceid+".dat && echo '"+datJson+"'>/home/mfg/work/cim/po/"+traceid+".dat"); |
|||
log.info("write dat json result : " + result); |
|||
//写入执行文件
|
|||
String pJson = "output to /home/mfg/work/out/po/" + traceid + ".run.log.\r\n" + |
|||
"input from /home/mfg/work/cim/po/" + traceid + ".dat.\r\n" + |
|||
"run /home/mfg/work/scripts/xxcommon01.p.\r\n" + |
|||
"input close.\r\n" + |
|||
"output close."; |
|||
log.info("pJson: {}", pJson); |
|||
result = CommandUtil.execute("touch /home/mfg/work/cim/po/"+traceid+".p && echo '"+pJson+"'>/home/mfg/work/cim/po/"+traceid+".p"); |
|||
log.info("write p result : " + result); |
|||
//执行QAD脚本
|
|||
result = CommandUtil.execute("sh /home/mfg/work/scripts/client-ch-cimload /home/mfg/work/cim/po/"+traceid+".p"); |
|||
log.info("execute client-ch-loaddata : " + result); |
|||
result = CommandUtil.execute("cat /home/mfg/work/out/po/" + traceid + ".run.out.json"); |
|||
log.info("cat execute log : " + result); |
|||
if(result.indexOf("\"SUCCESS\"") > 0) { |
|||
//移动执行结果文件
|
|||
CommandUtil.execute("mv /home/mfg/work/out/po/" + traceid + ".run.out.json /home/mfg/work/success/po/" + traceid + ".run.out.json"); |
|||
return AjaxResult.success(traceid); |
|||
} |
|||
CommandUtil.execute("mv /home/mfg/work/out/po/" + traceid + ".run.out.json /home/mfg/work/err/po/" + traceid + ".run.out.json"); |
|||
return AjaxResult.error(HttpStatus.EXECUTE_FAIL, result); |
|||
} |
|||
|
|||
} |
@ -0,0 +1,140 @@ |
|||
package com.win.web.controller.base; |
|||
|
|||
import com.alibaba.fastjson2.JSONObject; |
|||
import com.jcraft.jsch.JSchException; |
|||
import com.jcraft.jsch.Session; |
|||
import com.win.common.constant.HttpStatus; |
|||
import com.win.common.core.domain.AjaxResult; |
|||
import com.win.common.utils.ProfileUtil; |
|||
import com.win.common.utils.shell.ShellUtil; |
|||
import com.win.common.utils.shell.ShellVo; |
|||
import com.win.web.config.ShellConfig; |
|||
import lombok.extern.slf4j.Slf4j; |
|||
import org.apache.commons.lang3.StringUtils; |
|||
import org.slf4j.Logger; |
|||
import org.slf4j.LoggerFactory; |
|||
import org.springframework.beans.factory.annotation.Autowired; |
|||
import org.springframework.util.DigestUtils; |
|||
import org.springframework.web.bind.annotation.PostMapping; |
|||
import org.springframework.web.bind.annotation.RequestBody; |
|||
import org.springframework.web.bind.annotation.RequestMapping; |
|||
import org.springframework.web.bind.annotation.RestController; |
|||
|
|||
import javax.servlet.http.HttpServletRequest; |
|||
import java.io.IOException; |
|||
import java.lang.reflect.InvocationTargetException; |
|||
import java.lang.reflect.Method; |
|||
import java.util.List; |
|||
|
|||
@Slf4j |
|||
@RestController |
|||
@RequestMapping("/shell") |
|||
public class ShellController { |
|||
|
|||
private static final Logger logger = LoggerFactory.getLogger("sys-user"); |
|||
|
|||
@Autowired |
|||
private ShellUtil shellUtil; |
|||
@Autowired |
|||
private ShellConfig shellConfig; |
|||
|
|||
/** |
|||
* 对外提供一个接口,通过header中的interfaceName反射机制调用方法,方法必须写到这个controller中,并且不用加PostMapping注解。 |
|||
* |
|||
* @param request request |
|||
* @param body 请求主体 |
|||
* @return 结果 |
|||
*/ |
|||
@PostMapping("/api") |
|||
@SuppressWarnings("unchecked") |
|||
public AjaxResult api(HttpServletRequest request, @RequestBody String body) throws NoSuchMethodException, InvocationTargetException, IllegalAccessException { |
|||
String interfaceName = request.getHeader("interface"); |
|||
String sign = request.getHeader("sign"); |
|||
String timeStr = request.getHeader("timestamp"); |
|||
if(timeStr == null || timeStr.isEmpty()) { |
|||
return AjaxResult.error(HttpStatus.TIMESTAMP_ERROR, "时间戳不正确"); |
|||
} |
|||
long timestamp = 0; |
|||
try { |
|||
timestamp = Long.parseLong(timeStr); |
|||
} catch (NumberFormatException e) { |
|||
return AjaxResult.error(HttpStatus.TIMESTAMP_ERROR, "时间戳不正确"); |
|||
} |
|||
String tmp = interfaceName + body + timestamp; |
|||
String computeSign = DigestUtils.md5DigestAsHex(tmp.getBytes()); |
|||
long tenTimestamp = timestamp + (10 * 60 * 1000); // 计算10分钟后的时间戳
|
|||
long currentTimestamp = System.currentTimeMillis(); // 获取当前时间戳
|
|||
//过期
|
|||
if(timestamp > currentTimestamp || tenTimestamp < currentTimestamp) { |
|||
return AjaxResult.error(HttpStatus.EXPIRE_ERROR, "请求已过期"); |
|||
} |
|||
List<String> activeProfile = ProfileUtil.getActiveProfile(); |
|||
//dev环境不校验签名
|
|||
if(!activeProfile.contains("dev") && !StringUtils.equals(sign, computeSign.toUpperCase())) { |
|||
return AjaxResult.error(HttpStatus.SIGN_ERROR, "签名不正确"); |
|||
} |
|||
Method method = this.getClass().getMethod(interfaceName, String.class); |
|||
return (AjaxResult) method.invoke(this, body); |
|||
} |
|||
|
|||
public AjaxResult itemmastercreate(String body) throws JSchException, IOException { |
|||
Session session = shellUtil.getShellSession(shellConfig.getJlht2()); |
|||
String result = shellUtil.execute(session, "cd /opt && ls -l"); |
|||
return AjaxResult.success(result); |
|||
} |
|||
|
|||
public AjaxResult itemdetailcreate(String body) throws JSchException, IOException { |
|||
Session session = shellUtil.getShellSession(shellConfig.getJlht2()); |
|||
String result = shellUtil.execute(session, "cd /opt && ls -l"); |
|||
return AjaxResult.success(result); |
|||
} |
|||
|
|||
public AjaxResult discretepo(String body) throws JSchException, IOException { |
|||
JSONObject jsonObject = JSONObject.parseObject(body); |
|||
jsonObject = JSONObject.parseObject(jsonObject.getString("dsDescreteOrder")); |
|||
ShellVo shellVo; |
|||
if(jsonObject.getString("domain") != null && jsonObject.getString("domain").equals("JLHT2")) { |
|||
shellVo = shellConfig.getJlht2(); |
|||
} else { |
|||
shellVo = shellConfig.getJlht(); |
|||
} |
|||
Session session = shellUtil.getShellSession(shellVo); |
|||
//生成traceid
|
|||
String traceid = jsonObject.getString("traceid"); |
|||
jsonObject.remove("traceid"); |
|||
jsonObject.remove("company"); |
|||
jsonObject.remove("domain"); |
|||
String inJson = "{\"dsDescreteOrder\":"+ jsonObject+"}"; |
|||
log.info("inJson: {}", inJson); |
|||
//写入json
|
|||
String result = shellUtil.execute(session, "touch /home/mfg/work/cim/po/"+traceid+".json && echo '"+inJson+"'>/home/mfg/work/cim/po/"+traceid+".json"); |
|||
log.info("write json result : " + result); |
|||
//写入dat.json
|
|||
String datJson = "\"/home/mfg/work/cim/po/"+traceid+".json\" \"xxdspoapi.p\" \"/home/mfg/work/out/po/"+traceid+".out.log\" \""+shellVo.getQadUser()+"\" \""+shellVo.getQadPassword()+"\"\r\n\""+shellVo.getQadDomain()+"\""; |
|||
log.info("datJson: {}", datJson); |
|||
result = shellUtil.execute(session, "touch /home/mfg/work/cim/po/"+traceid+".dat && echo '"+datJson+"'>/home/mfg/work/cim/po/"+traceid+".dat"); |
|||
log.info("write dat json result : " + result); |
|||
//写入执行文件
|
|||
String pJson = "output to /home/mfg/work/out/po/" + traceid + ".run.log.\r\n" + |
|||
"input from /home/mfg/work/cim/po/" + traceid + ".dat.\r\n" + |
|||
"run /home/mfg/work/scripts/xxcommon01.p.\r\n" + |
|||
"input close.\r\n" + |
|||
"output close."; |
|||
log.info("pJson: {}", pJson); |
|||
result = shellUtil.execute(session, "touch /home/mfg/work/cim/po/"+traceid+".p && echo '"+pJson+"'>/home/mfg/work/cim/po/"+traceid+".p"); |
|||
log.info("write p result : " + result); |
|||
//执行QAD脚本
|
|||
result = shellUtil.execute(session, "/home/mfg/work/scripts/client-ch-cimload /home/mfg/work/cim/po/"+traceid+".p"); |
|||
log.info("execute client-ch-loaddata : " + result); |
|||
result = shellUtil.execute(session, "cat /home/mfg/work/out/po/" + traceid + ".run.out.json"); |
|||
log.info("cat execute log : " + result); |
|||
if(result.indexOf("\"SUCCESS\"") > 0) { |
|||
//移动执行结果文件
|
|||
shellUtil.execute(session, "mv /home/mfg/work/out/po/" + traceid + ".run.out.json /home/mfg/work/success/po/" + traceid + ".run.out.json"); |
|||
return AjaxResult.success(traceid); |
|||
} |
|||
shellUtil.execute(session, "mv /home/mfg/work/out/po/" + traceid + ".run.out.json /home/mfg/work/err/po/" + traceid + ".run.out.json"); |
|||
return AjaxResult.error(HttpStatus.EXECUTE_FAIL, result); |
|||
} |
|||
|
|||
} |
@ -0,0 +1,95 @@ |
|||
package com.win.web.controller.common; |
|||
|
|||
import com.google.code.kaptcha.Producer; |
|||
import com.win.common.config.WinConfig; |
|||
import com.win.common.constant.CacheConstants; |
|||
import com.win.common.constant.Constants; |
|||
import com.win.common.core.domain.AjaxResult; |
|||
import com.win.common.core.redis.RedisCache; |
|||
import com.win.common.utils.sign.Base64; |
|||
import com.win.common.utils.uuid.IdUtils; |
|||
import com.win.system.service.SysConfigService; |
|||
import org.springframework.beans.factory.annotation.Autowired; |
|||
import org.springframework.util.FastByteArrayOutputStream; |
|||
import org.springframework.web.bind.annotation.GetMapping; |
|||
import org.springframework.web.bind.annotation.RestController; |
|||
|
|||
import javax.annotation.Resource; |
|||
import javax.imageio.ImageIO; |
|||
import javax.servlet.http.HttpServletResponse; |
|||
import java.awt.image.BufferedImage; |
|||
import java.io.IOException; |
|||
import java.util.concurrent.TimeUnit; |
|||
|
|||
/** |
|||
* 验证码操作处理 |
|||
* |
|||
* @author win |
|||
*/ |
|||
@RestController |
|||
public class CaptchaController |
|||
{ |
|||
@Resource(name = "captchaProducer") |
|||
private Producer captchaProducer; |
|||
|
|||
@Resource(name = "captchaProducerMath") |
|||
private Producer captchaProducerMath; |
|||
|
|||
@Autowired |
|||
private RedisCache redisCache; |
|||
|
|||
@Autowired |
|||
private SysConfigService configService; |
|||
/** |
|||
* 生成验证码 |
|||
*/ |
|||
@GetMapping("/captchaImage") |
|||
public AjaxResult getCode(HttpServletResponse response) throws IOException |
|||
{ |
|||
AjaxResult ajax = AjaxResult.success(); |
|||
boolean captchaEnabled = configService.selectCaptchaEnabled(); |
|||
ajax.put("captchaEnabled", captchaEnabled); |
|||
if (!captchaEnabled) |
|||
{ |
|||
return ajax; |
|||
} |
|||
|
|||
// 保存验证码信息
|
|||
String uuid = IdUtils.simpleUUID(); |
|||
String verifyKey = CacheConstants.CAPTCHA_CODE_KEY + uuid; |
|||
|
|||
String capStr = null, code = null; |
|||
BufferedImage image = null; |
|||
|
|||
// 生成验证码
|
|||
String captchaType = WinConfig.getCaptchaType(); |
|||
if ("math".equals(captchaType)) |
|||
{ |
|||
String capText = captchaProducerMath.createText(); |
|||
capStr = capText.substring(0, capText.lastIndexOf("@")); |
|||
code = capText.substring(capText.lastIndexOf("@") + 1); |
|||
image = captchaProducerMath.createImage(capStr); |
|||
} |
|||
else if ("char".equals(captchaType)) |
|||
{ |
|||
capStr = code = captchaProducer.createText(); |
|||
image = captchaProducer.createImage(capStr); |
|||
} |
|||
|
|||
redisCache.setCacheObject(verifyKey, code, Constants.CAPTCHA_EXPIRATION, TimeUnit.MINUTES); |
|||
// 转换流信息写出
|
|||
FastByteArrayOutputStream os = new FastByteArrayOutputStream(); |
|||
try |
|||
{ |
|||
ImageIO.write(image, "jpg", os); |
|||
} |
|||
catch (IOException e) |
|||
{ |
|||
return AjaxResult.error(e.getMessage()); |
|||
} |
|||
|
|||
ajax.put("uuid", uuid); |
|||
ajax.put("img", Base64.encode(os.toByteArray())); |
|||
return ajax; |
|||
} |
|||
} |
@ -0,0 +1,169 @@ |
|||
package com.win.web.controller.common; |
|||
|
|||
import com.win.common.config.WinConfig; |
|||
import com.win.common.constant.Constants; |
|||
import com.win.common.core.domain.AjaxResult; |
|||
import com.win.common.utils.StringUtils; |
|||
import com.win.common.utils.file.FileUploadUtils; |
|||
import com.win.common.utils.file.FileUtils; |
|||
import com.win.framework.config.ServerConfig; |
|||
import com.win.system.domain.Accessory; |
|||
import com.win.system.service.AccessoryService; |
|||
import org.slf4j.Logger; |
|||
import org.slf4j.LoggerFactory; |
|||
import org.springframework.beans.factory.annotation.Autowired; |
|||
import org.springframework.http.MediaType; |
|||
import org.springframework.web.bind.annotation.GetMapping; |
|||
import org.springframework.web.bind.annotation.PostMapping; |
|||
import org.springframework.web.bind.annotation.RequestMapping; |
|||
import org.springframework.web.bind.annotation.RestController; |
|||
import org.springframework.web.multipart.MultipartFile; |
|||
|
|||
import javax.servlet.http.HttpServletRequest; |
|||
import javax.servlet.http.HttpServletResponse; |
|||
import java.time.LocalDateTime; |
|||
import java.util.ArrayList; |
|||
import java.util.List; |
|||
|
|||
/** |
|||
* 通用请求处理 |
|||
* |
|||
* @author win |
|||
*/ |
|||
@RestController |
|||
@RequestMapping("/common") |
|||
public class CommonController { |
|||
private static final Logger log = LoggerFactory.getLogger(CommonController.class); |
|||
|
|||
@Autowired |
|||
private ServerConfig serverConfig; |
|||
@Autowired |
|||
private AccessoryService accessoryService; |
|||
|
|||
private static final String FILE_DELIMETER = ","; |
|||
|
|||
/** |
|||
* 通用下载请求 |
|||
* |
|||
* @param fileName 文件名称 |
|||
* @param delete 是否删除 |
|||
*/ |
|||
@GetMapping("/download") |
|||
public void fileDownload(String fileName, Boolean delete, HttpServletResponse response, HttpServletRequest request) { |
|||
try { |
|||
if (!FileUtils.checkAllowDownload(fileName)) { |
|||
throw new Exception(StringUtils.format("文件名称({})非法,不允许下载。 ", fileName)); |
|||
} |
|||
String realFileName = System.currentTimeMillis() + fileName.substring(fileName.indexOf("_") + 1); |
|||
String filePath = WinConfig.getDownloadPath() + fileName; |
|||
|
|||
response.setContentType(MediaType.APPLICATION_OCTET_STREAM_VALUE); |
|||
FileUtils.setAttachmentResponseHeader(response, realFileName); |
|||
FileUtils.writeBytes(filePath, response.getOutputStream()); |
|||
if (delete) { |
|||
FileUtils.deleteFile(filePath); |
|||
} |
|||
} catch (Exception e) { |
|||
log.error("下载文件失败", e); |
|||
} |
|||
} |
|||
|
|||
/** |
|||
* 通用上传请求(单个) |
|||
*/ |
|||
@PostMapping("/upload") |
|||
public AjaxResult uploadFile(MultipartFile file) throws Exception { |
|||
try { |
|||
// 上传文件路径
|
|||
String filePath = WinConfig.getUploadPath(); |
|||
// 上传并返回新文件名称
|
|||
String fileName = FileUploadUtils.upload(filePath, file); |
|||
String url = serverConfig.getUrl() + fileName; |
|||
String originalFilename = file.getOriginalFilename(); |
|||
AjaxResult ajax = AjaxResult.success(); |
|||
ajax.put("url", url); |
|||
ajax.put("fileName", fileName); |
|||
ajax.put("newFileName", FileUtils.getName(fileName)); |
|||
ajax.put("originalFilename", originalFilename); |
|||
Accessory accessory = new Accessory(); |
|||
String suffix = originalFilename.substring(originalFilename.lastIndexOf(".") + 1); |
|||
String name = originalFilename.replace("." + suffix, ""); |
|||
accessory.setName(name); |
|||
accessory.setSuffix(suffix); |
|||
accessory.setUrl(fileName); |
|||
accessory.setCreateTime(LocalDateTime.now()); |
|||
accessoryService.save(accessory); |
|||
ajax.put("accessoryId", accessory.getId()); |
|||
return ajax; |
|||
} catch (Exception e) { |
|||
return AjaxResult.error(e.getMessage()); |
|||
} |
|||
} |
|||
|
|||
/** |
|||
* 通用上传请求(多个) |
|||
*/ |
|||
@PostMapping("/uploads") |
|||
public AjaxResult uploadFiles(List<MultipartFile> files) throws Exception { |
|||
try { |
|||
// 上传文件路径
|
|||
String filePath = WinConfig.getUploadPath(); |
|||
List<String> urls = new ArrayList<String>(); |
|||
List<String> fileNames = new ArrayList<String>(); |
|||
List<String> newFileNames = new ArrayList<String>(); |
|||
List<String> originalFilenames = new ArrayList<String>(); |
|||
List<Long> accessoryIds = new ArrayList<>(); |
|||
for (int i = 0; i < files.size(); i++) { |
|||
MultipartFile file = files.get(i); |
|||
String originalFilename = originalFilenames.get(i); |
|||
// 上传并返回新文件名称
|
|||
String fileName = FileUploadUtils.upload(filePath, file); |
|||
String url = serverConfig.getUrl() + fileName; |
|||
urls.add(url); |
|||
fileNames.add(fileName); |
|||
newFileNames.add(FileUtils.getName(fileName)); |
|||
originalFilenames.add(file.getOriginalFilename()); |
|||
String suffix = originalFilename.substring(originalFilename.lastIndexOf(".") + 1); |
|||
String name = originalFilename.replace("." + suffix, ""); |
|||
Accessory accessory = new Accessory(); |
|||
accessory.setName(name); |
|||
accessory.setSuffix(suffix); |
|||
accessory.setUrl(fileName); |
|||
accessoryService.save(accessory); |
|||
accessoryIds.add(accessory.getId()); |
|||
} |
|||
AjaxResult ajax = AjaxResult.success(); |
|||
ajax.put("urls", StringUtils.join(urls, FILE_DELIMETER)); |
|||
ajax.put("fileNames", StringUtils.join(fileNames, FILE_DELIMETER)); |
|||
ajax.put("newFileNames", StringUtils.join(newFileNames, FILE_DELIMETER)); |
|||
ajax.put("originalFilenames", StringUtils.join(originalFilenames, FILE_DELIMETER)); |
|||
ajax.put("accessoryIds", accessoryIds); |
|||
return ajax; |
|||
} catch (Exception e) { |
|||
return AjaxResult.error(e.getMessage()); |
|||
} |
|||
} |
|||
|
|||
/** |
|||
* 本地资源通用下载 |
|||
*/ |
|||
@GetMapping("/download/resource") |
|||
public void resourceDownload(String resource, HttpServletRequest request, HttpServletResponse response) throws Exception { |
|||
try { |
|||
if (!FileUtils.checkAllowDownload(resource)) { |
|||
throw new Exception(StringUtils.format("资源文件({})非法,不允许下载。 ", resource)); |
|||
} |
|||
// 本地资源路径
|
|||
String localPath = WinConfig.getProfile(); |
|||
// 数据库资源地址
|
|||
String downloadPath = localPath + StringUtils.substringAfter(resource, Constants.RESOURCE_PREFIX); |
|||
// 下载名称
|
|||
String downloadName = StringUtils.substringAfterLast(downloadPath, "/"); |
|||
response.setContentType(MediaType.APPLICATION_OCTET_STREAM_VALUE); |
|||
FileUtils.setAttachmentResponseHeader(response, downloadName); |
|||
FileUtils.writeBytes(downloadPath, response.getOutputStream()); |
|||
} catch (Exception e) { |
|||
log.error("下载文件失败", e); |
|||
} |
|||
} |
|||
} |
@ -0,0 +1,96 @@ |
|||
package com.win.web.controller.monitor; |
|||
|
|||
import com.win.common.constant.CacheConstants; |
|||
import com.win.common.core.domain.AjaxResult; |
|||
import com.win.common.utils.StringUtils; |
|||
import com.win.system.domain.SysCache; |
|||
import org.springframework.beans.factory.annotation.Autowired; |
|||
import org.springframework.data.redis.core.RedisCallback; |
|||
import org.springframework.data.redis.core.RedisTemplate; |
|||
import org.springframework.web.bind.annotation.*; |
|||
|
|||
import java.util.*; |
|||
|
|||
/** |
|||
* 缓存监控 |
|||
* |
|||
* @author win |
|||
*/ |
|||
@RestController |
|||
@RequestMapping("/monitor/cache") |
|||
public class CacheController { |
|||
@Autowired |
|||
private RedisTemplate<String, String> redisTemplate; |
|||
|
|||
private final static List<SysCache> caches = new ArrayList<SysCache>(); |
|||
|
|||
{ |
|||
caches.add(new SysCache(CacheConstants.LOGIN_TOKEN_KEY, "用户信息")); |
|||
caches.add(new SysCache(CacheConstants.SYS_CONFIG_KEY, "配置信息")); |
|||
caches.add(new SysCache(CacheConstants.SYS_DICT_KEY, "数据字典")); |
|||
caches.add(new SysCache(CacheConstants.CAPTCHA_CODE_KEY, "验证码")); |
|||
caches.add(new SysCache(CacheConstants.REPEAT_SUBMIT_KEY, "防重提交")); |
|||
caches.add(new SysCache(CacheConstants.RATE_LIMIT_KEY, "限流处理")); |
|||
caches.add(new SysCache(CacheConstants.PWD_ERR_CNT_KEY, "密码错误次数")); |
|||
} |
|||
|
|||
@GetMapping() |
|||
public AjaxResult getInfo() throws Exception { |
|||
Properties info = (Properties) redisTemplate.execute((RedisCallback<Object>) connection -> connection.info()); |
|||
Properties commandStats = (Properties) redisTemplate.execute((RedisCallback<Object>) connection -> connection.info("commandstats")); |
|||
Object dbSize = redisTemplate.execute((RedisCallback<Object>) connection -> connection.dbSize()); |
|||
|
|||
Map<String, Object> result = new HashMap<>(3); |
|||
result.put("info", info); |
|||
result.put("dbSize", dbSize); |
|||
|
|||
List<Map<String, String>> pieList = new ArrayList<>(); |
|||
commandStats.stringPropertyNames().forEach(key -> { |
|||
Map<String, String> data = new HashMap<>(2); |
|||
String property = commandStats.getProperty(key); |
|||
data.put("name", StringUtils.removeStart(key, "cmdstat_")); |
|||
data.put("value", StringUtils.substringBetween(property, "calls=", ",usec")); |
|||
pieList.add(data); |
|||
}); |
|||
result.put("commandStats", pieList); |
|||
return AjaxResult.success(result); |
|||
} |
|||
|
|||
@GetMapping("/getNames") |
|||
public AjaxResult cache() { |
|||
return AjaxResult.success(caches); |
|||
} |
|||
|
|||
@GetMapping("/getKeys/{cacheName}") |
|||
public AjaxResult getCacheKeys(@PathVariable String cacheName) { |
|||
Set<String> cacheKeys = redisTemplate.keys(cacheName + "*"); |
|||
return AjaxResult.success(cacheKeys); |
|||
} |
|||
|
|||
@GetMapping("/getValue/{cacheName}/{cacheKey}") |
|||
public AjaxResult getCacheValue(@PathVariable String cacheName, @PathVariable String cacheKey) { |
|||
String cacheValue = redisTemplate.opsForValue().get(cacheKey); |
|||
SysCache sysCache = new SysCache(cacheName, cacheKey, cacheValue); |
|||
return AjaxResult.success(sysCache); |
|||
} |
|||
|
|||
@DeleteMapping("/clearCacheName/{cacheName}") |
|||
public AjaxResult clearCacheName(@PathVariable String cacheName) { |
|||
Collection<String> cacheKeys = redisTemplate.keys(cacheName + "*"); |
|||
redisTemplate.delete(cacheKeys); |
|||
return AjaxResult.success(); |
|||
} |
|||
|
|||
@DeleteMapping("/clearCacheKey/{cacheKey}") |
|||
public AjaxResult clearCacheKey(@PathVariable String cacheKey) { |
|||
redisTemplate.delete(cacheKey); |
|||
return AjaxResult.success(); |
|||
} |
|||
|
|||
@DeleteMapping("/clearCacheAll") |
|||
public AjaxResult clearCacheAll() { |
|||
Collection<String> cacheKeys = redisTemplate.keys("*"); |
|||
redisTemplate.delete(cacheKeys); |
|||
return AjaxResult.success(); |
|||
} |
|||
} |
@ -0,0 +1,23 @@ |
|||
package com.win.web.controller.monitor; |
|||
|
|||
import com.win.common.core.domain.AjaxResult; |
|||
import com.win.framework.web.domain.Server; |
|||
import org.springframework.web.bind.annotation.GetMapping; |
|||
import org.springframework.web.bind.annotation.RequestMapping; |
|||
import org.springframework.web.bind.annotation.RestController; |
|||
|
|||
/** |
|||
* 服务器监控 |
|||
* |
|||
* @author win |
|||
*/ |
|||
@RestController |
|||
@RequestMapping("/monitor/server") |
|||
public class ServerController { |
|||
@GetMapping() |
|||
public AjaxResult getInfo() throws Exception { |
|||
Server server = new Server(); |
|||
server.copyTo(); |
|||
return AjaxResult.success(server); |
|||
} |
|||
} |
@ -0,0 +1,66 @@ |
|||
package com.win.web.controller.monitor; |
|||
|
|||
import com.win.common.annotation.Log; |
|||
import com.win.common.core.controller.BaseController; |
|||
import com.win.common.core.domain.AjaxResult; |
|||
import com.win.common.core.page.TableDataInfo; |
|||
import com.win.common.enums.BusinessType; |
|||
import com.win.common.utils.poi.ExcelUtil; |
|||
import com.win.framework.web.service.SysPasswordService; |
|||
import com.win.system.domain.SysLogininfor; |
|||
import com.win.system.service.SysLogininforService; |
|||
import org.springframework.beans.factory.annotation.Autowired; |
|||
import org.springframework.web.bind.annotation.*; |
|||
|
|||
import javax.servlet.http.HttpServletResponse; |
|||
import java.util.List; |
|||
|
|||
/** |
|||
* 系统访问记录 |
|||
* |
|||
* @author win |
|||
*/ |
|||
@RestController |
|||
@RequestMapping("/monitor/logininfor") |
|||
public class SysLogininforController extends BaseController { |
|||
@Autowired |
|||
private SysLogininforService logininforService; |
|||
|
|||
@Autowired |
|||
private SysPasswordService passwordService; |
|||
|
|||
@GetMapping("/list") |
|||
public TableDataInfo list(SysLogininfor logininfor) { |
|||
startPage(); |
|||
List<SysLogininfor> list = logininforService.selectLogininforList(logininfor); |
|||
return getDataTable(list); |
|||
} |
|||
|
|||
@Log(title = "登录日志", businessType = BusinessType.EXPORT) |
|||
@PostMapping("/export") |
|||
public void export(HttpServletResponse response, SysLogininfor logininfor) { |
|||
List<SysLogininfor> list = logininforService.selectLogininforList(logininfor); |
|||
ExcelUtil<SysLogininfor> util = new ExcelUtil<SysLogininfor>(SysLogininfor.class); |
|||
util.exportExcel(response, list, "登录日志"); |
|||
} |
|||
|
|||
@Log(title = "登录日志", businessType = BusinessType.DELETE) |
|||
@DeleteMapping("/{infoIds}") |
|||
public AjaxResult remove(@PathVariable Long[] infoIds) { |
|||
return toAjax(logininforService.deleteLogininforByIds(infoIds)); |
|||
} |
|||
|
|||
@Log(title = "登录日志", businessType = BusinessType.CLEAN) |
|||
@DeleteMapping("/clean") |
|||
public AjaxResult clean() { |
|||
logininforService.cleanLogininfor(); |
|||
return success(); |
|||
} |
|||
|
|||
@Log(title = "账户解锁", businessType = BusinessType.OTHER) |
|||
@GetMapping("/unlock/{userName}") |
|||
public AjaxResult unlock(@PathVariable("userName") String userName) { |
|||
passwordService.clearLoginRecordCache(userName); |
|||
return success(); |
|||
} |
|||
} |
@ -0,0 +1,55 @@ |
|||
package com.win.web.controller.monitor; |
|||
|
|||
import com.win.common.annotation.Log; |
|||
import com.win.common.core.controller.BaseController; |
|||
import com.win.common.core.domain.AjaxResult; |
|||
import com.win.common.core.page.TableDataInfo; |
|||
import com.win.common.enums.BusinessType; |
|||
import com.win.common.utils.poi.ExcelUtil; |
|||
import com.win.system.domain.SysOperLog; |
|||
import com.win.system.service.SysOperLogService; |
|||
import org.springframework.beans.factory.annotation.Autowired; |
|||
import org.springframework.web.bind.annotation.*; |
|||
|
|||
import javax.servlet.http.HttpServletResponse; |
|||
import java.util.List; |
|||
|
|||
/** |
|||
* 操作日志记录 |
|||
* |
|||
* @author win |
|||
*/ |
|||
@RestController |
|||
@RequestMapping("/monitor/operlog") |
|||
public class SysOperlogController extends BaseController { |
|||
@Autowired |
|||
private SysOperLogService operLogService; |
|||
|
|||
@GetMapping("/list") |
|||
public TableDataInfo list(SysOperLog operLog) { |
|||
startPage(); |
|||
List<SysOperLog> list = operLogService.selectOperLogList(operLog); |
|||
return getDataTable(list); |
|||
} |
|||
|
|||
@Log(title = "操作日志", businessType = BusinessType.EXPORT) |
|||
@PostMapping("/export") |
|||
public void export(HttpServletResponse response, SysOperLog operLog) { |
|||
List<SysOperLog> list = operLogService.selectOperLogList(operLog); |
|||
ExcelUtil<SysOperLog> util = new ExcelUtil<SysOperLog>(SysOperLog.class); |
|||
util.exportExcel(response, list, "操作日志"); |
|||
} |
|||
|
|||
@Log(title = "操作日志", businessType = BusinessType.DELETE) |
|||
@DeleteMapping("/{operIds}") |
|||
public AjaxResult remove(@PathVariable Long[] operIds) { |
|||
return toAjax(operLogService.deleteOperLogByIds(operIds)); |
|||
} |
|||
|
|||
@Log(title = "操作日志", businessType = BusinessType.CLEAN) |
|||
@DeleteMapping("/clean") |
|||
public AjaxResult clean() { |
|||
operLogService.cleanOperLog(); |
|||
return success(); |
|||
} |
|||
} |
@ -0,0 +1,72 @@ |
|||
package com.win.web.controller.monitor; |
|||
|
|||
import com.win.common.annotation.Log; |
|||
import com.win.common.constant.CacheConstants; |
|||
import com.win.common.core.controller.BaseController; |
|||
import com.win.common.core.domain.AjaxResult; |
|||
import com.win.common.core.domain.model.LoginUser; |
|||
import com.win.common.core.page.TableDataInfo; |
|||
import com.win.common.core.redis.RedisCache; |
|||
import com.win.common.enums.BusinessType; |
|||
import com.win.common.utils.StringUtils; |
|||
import com.win.system.domain.SysUserOnline; |
|||
import com.win.system.service.SysUserOnlineService; |
|||
import org.springframework.beans.factory.annotation.Autowired; |
|||
import org.springframework.web.bind.annotation.*; |
|||
|
|||
import java.util.ArrayList; |
|||
import java.util.Collection; |
|||
import java.util.Collections; |
|||
import java.util.List; |
|||
|
|||
/** |
|||
* 在线用户监控 |
|||
* |
|||
* @author win |
|||
*/ |
|||
@RestController |
|||
@RequestMapping("/monitor/online") |
|||
public class SysUserOnlineController extends BaseController { |
|||
@Autowired |
|||
private SysUserOnlineService userOnlineService; |
|||
|
|||
@Autowired |
|||
private RedisCache redisCache; |
|||
|
|||
@GetMapping("/list") |
|||
public TableDataInfo list(String ipaddr, String userName) { |
|||
Collection<String> keys = redisCache.keys(CacheConstants.LOGIN_TOKEN_KEY + "*"); |
|||
List<SysUserOnline> userOnlineList = new ArrayList<SysUserOnline>(); |
|||
for (String key : keys) { |
|||
LoginUser user = redisCache.getCacheObject(key); |
|||
if (StringUtils.isNotEmpty(ipaddr) && StringUtils.isNotEmpty(userName)) { |
|||
if (StringUtils.equals(ipaddr, user.getIpaddr()) && StringUtils.equals(userName, user.getUsername())) { |
|||
userOnlineList.add(userOnlineService.selectOnlineByInfo(ipaddr, userName, user)); |
|||
} |
|||
} else if (StringUtils.isNotEmpty(ipaddr)) { |
|||
if (StringUtils.equals(ipaddr, user.getIpaddr())) { |
|||
userOnlineList.add(userOnlineService.selectOnlineByIpaddr(ipaddr, user)); |
|||
} |
|||
} else if (StringUtils.isNotEmpty(userName) && StringUtils.isNotNull(user.getUser())) { |
|||
if (StringUtils.equals(userName, user.getUsername())) { |
|||
userOnlineList.add(userOnlineService.selectOnlineByUserName(userName, user)); |
|||
} |
|||
} else { |
|||
userOnlineList.add(userOnlineService.loginUserToUserOnline(user)); |
|||
} |
|||
} |
|||
Collections.reverse(userOnlineList); |
|||
userOnlineList.removeAll(Collections.singleton(null)); |
|||
return getDataTable(userOnlineList); |
|||
} |
|||
|
|||
/** |
|||
* 强退用户 |
|||
*/ |
|||
@Log(title = "在线用户", businessType = BusinessType.FORCE) |
|||
@DeleteMapping("/{tokenId}") |
|||
public AjaxResult forceLogout(@PathVariable String tokenId) { |
|||
redisCache.deleteObject(CacheConstants.LOGIN_TOKEN_KEY + tokenId); |
|||
return success(); |
|||
} |
|||
} |
@ -0,0 +1,109 @@ |
|||
package com.win.web.controller.system; |
|||
|
|||
import com.win.common.annotation.Log; |
|||
import com.win.common.constant.UserConstants; |
|||
import com.win.common.core.controller.BaseController; |
|||
import com.win.common.core.domain.AjaxResult; |
|||
import com.win.common.core.page.TableDataInfo; |
|||
import com.win.common.enums.BusinessType; |
|||
import com.win.common.utils.poi.ExcelUtil; |
|||
import com.win.system.domain.SysConfig; |
|||
import com.win.system.service.SysConfigService; |
|||
import org.springframework.beans.factory.annotation.Autowired; |
|||
import org.springframework.validation.annotation.Validated; |
|||
import org.springframework.web.bind.annotation.*; |
|||
|
|||
import javax.servlet.http.HttpServletResponse; |
|||
import java.util.List; |
|||
|
|||
/** |
|||
* 参数配置 信息操作处理 |
|||
* |
|||
* @author win |
|||
*/ |
|||
@RestController |
|||
@RequestMapping("/system/config") |
|||
public class SysConfigController extends BaseController { |
|||
@Autowired |
|||
private SysConfigService configService; |
|||
|
|||
/** |
|||
* 获取参数配置列表 |
|||
*/ |
|||
@GetMapping("/list") |
|||
public TableDataInfo list(SysConfig config) { |
|||
startPage(); |
|||
List<SysConfig> list = configService.selectConfigList(config); |
|||
return getDataTable(list); |
|||
} |
|||
|
|||
@Log(title = "参数管理", businessType = BusinessType.EXPORT) |
|||
@PostMapping("/export") |
|||
public void export(HttpServletResponse response, SysConfig config) { |
|||
List<SysConfig> list = configService.selectConfigList(config); |
|||
ExcelUtil<SysConfig> util = new ExcelUtil<SysConfig>(SysConfig.class); |
|||
util.exportExcel(response, list, "参数数据"); |
|||
} |
|||
|
|||
/** |
|||
* 根据参数编号获取详细信息 |
|||
*/ |
|||
@GetMapping(value = "/{configId}") |
|||
public AjaxResult getInfo(@PathVariable Long configId) { |
|||
return success(configService.selectConfigById(configId)); |
|||
} |
|||
|
|||
/** |
|||
* 根据参数键名查询参数值 |
|||
*/ |
|||
@GetMapping(value = "/configKey/{configKey}") |
|||
public AjaxResult getConfigKey(@PathVariable String configKey) { |
|||
return success(configService.selectConfigByKey(configKey)); |
|||
} |
|||
|
|||
/** |
|||
* 新增参数配置 |
|||
*/ |
|||
@Log(title = "参数管理", businessType = BusinessType.INSERT) |
|||
@PostMapping |
|||
public AjaxResult add(@Validated @RequestBody SysConfig config) { |
|||
if (UserConstants.NOT_UNIQUE.equals(configService.checkConfigKeyUnique(config))) { |
|||
return error("新增参数'" + config.getConfigName() + "'失败,参数键名已存在"); |
|||
} |
|||
config.setCreateBy(getUsername()); |
|||
return toAjax(configService.insertConfig(config)); |
|||
} |
|||
|
|||
/** |
|||
* 修改参数配置 |
|||
*/ |
|||
@Log(title = "参数管理", businessType = BusinessType.UPDATE) |
|||
@PutMapping |
|||
public AjaxResult edit(@Validated @RequestBody SysConfig config) { |
|||
if (UserConstants.NOT_UNIQUE.equals(configService.checkConfigKeyUnique(config))) { |
|||
return error("修改参数'" + config.getConfigName() + "'失败,参数键名已存在"); |
|||
} |
|||
config.setUpdateBy(getUsername()); |
|||
return toAjax(configService.updateConfig(config)); |
|||
} |
|||
|
|||
/** |
|||
* 删除参数配置 |
|||
*/ |
|||
@Log(title = "参数管理", businessType = BusinessType.DELETE) |
|||
@DeleteMapping("/{configIds}") |
|||
public AjaxResult remove(@PathVariable Long[] configIds) { |
|||
configService.deleteConfigByIds(configIds); |
|||
return success(); |
|||
} |
|||
|
|||
/** |
|||
* 刷新参数缓存 |
|||
*/ |
|||
@Log(title = "参数管理", businessType = BusinessType.CLEAN) |
|||
@DeleteMapping("/refreshCache") |
|||
public AjaxResult refreshCache() { |
|||
configService.resetConfigCache(); |
|||
return success(); |
|||
} |
|||
} |
@ -0,0 +1,104 @@ |
|||
package com.win.web.controller.system; |
|||
|
|||
import com.win.common.annotation.Log; |
|||
import com.win.common.constant.UserConstants; |
|||
import com.win.common.core.controller.BaseController; |
|||
import com.win.common.core.domain.AjaxResult; |
|||
import com.win.common.core.domain.entity.SysDept; |
|||
import com.win.common.enums.BusinessType; |
|||
import com.win.common.utils.StringUtils; |
|||
import com.win.system.service.SysDeptService; |
|||
import org.apache.commons.lang3.ArrayUtils; |
|||
import org.springframework.beans.factory.annotation.Autowired; |
|||
import org.springframework.validation.annotation.Validated; |
|||
import org.springframework.web.bind.annotation.*; |
|||
|
|||
import java.util.List; |
|||
|
|||
/** |
|||
* 部门信息 |
|||
* |
|||
* @author win |
|||
*/ |
|||
@RestController |
|||
@RequestMapping("/system/dept") |
|||
public class SysDeptController extends BaseController { |
|||
@Autowired |
|||
private SysDeptService deptService; |
|||
|
|||
/** |
|||
* 获取部门列表 |
|||
*/ |
|||
@GetMapping("/list") |
|||
public AjaxResult list(SysDept dept) { |
|||
List<SysDept> depts = deptService.selectDeptList(dept); |
|||
return success(depts); |
|||
} |
|||
|
|||
/** |
|||
* 查询部门列表(排除节点) |
|||
*/ |
|||
@GetMapping("/list/exclude/{deptId}") |
|||
public AjaxResult excludeChild(@PathVariable(value = "deptId", required = false) Long deptId) { |
|||
List<SysDept> depts = deptService.selectDeptList(new SysDept()); |
|||
depts.removeIf(d -> d.getDeptId().intValue() == deptId || ArrayUtils.contains(StringUtils.split(d.getAncestors(), ","), deptId + "")); |
|||
return success(depts); |
|||
} |
|||
|
|||
/** |
|||
* 根据部门编号获取详细信息 |
|||
*/ |
|||
@GetMapping(value = "/{deptId}") |
|||
public AjaxResult getInfo(@PathVariable Long deptId) { |
|||
deptService.checkDeptDataScope(deptId); |
|||
return success(deptService.selectDeptById(deptId)); |
|||
} |
|||
|
|||
/** |
|||
* 新增部门 |
|||
*/ |
|||
@Log(title = "部门管理", businessType = BusinessType.INSERT) |
|||
@PostMapping |
|||
public AjaxResult add(@Validated @RequestBody SysDept dept) { |
|||
if (UserConstants.NOT_UNIQUE.equals(deptService.checkDeptNameUnique(dept))) { |
|||
return error("新增部门'" + dept.getDeptName() + "'失败,部门名称已存在"); |
|||
} |
|||
dept.setCreateBy(getUsername()); |
|||
return toAjax(deptService.insertDept(dept)); |
|||
} |
|||
|
|||
/** |
|||
* 修改部门 |
|||
*/ |
|||
@Log(title = "部门管理", businessType = BusinessType.UPDATE) |
|||
@PutMapping |
|||
public AjaxResult edit(@Validated @RequestBody SysDept dept) { |
|||
Long deptId = dept.getDeptId(); |
|||
deptService.checkDeptDataScope(deptId); |
|||
if (UserConstants.NOT_UNIQUE.equals(deptService.checkDeptNameUnique(dept))) { |
|||
return error("修改部门'" + dept.getDeptName() + "'失败,部门名称已存在"); |
|||
} else if (dept.getParentId().equals(deptId)) { |
|||
return error("修改部门'" + dept.getDeptName() + "'失败,上级部门不能是自己"); |
|||
} else if (StringUtils.equals(UserConstants.DEPT_DISABLE, dept.getStatus()) && deptService.selectNormalChildrenDeptById(deptId) > 0) { |
|||
return error("该部门包含未停用的子部门!"); |
|||
} |
|||
dept.setUpdateBy(getUsername()); |
|||
return toAjax(deptService.updateDept(dept)); |
|||
} |
|||
|
|||
/** |
|||
* 删除部门 |
|||
*/ |
|||
@Log(title = "部门管理", businessType = BusinessType.DELETE) |
|||
@DeleteMapping("/{deptId}") |
|||
public AjaxResult remove(@PathVariable Long deptId) { |
|||
if (deptService.hasChildByDeptId(deptId)) { |
|||
return warn("存在下级部门,不允许删除"); |
|||
} |
|||
if (deptService.checkDeptExistUser(deptId)) { |
|||
return warn("部门存在用户,不允许删除"); |
|||
} |
|||
deptService.checkDeptDataScope(deptId); |
|||
return toAjax(deptService.deleteDeptById(deptId)); |
|||
} |
|||
} |
@ -0,0 +1,99 @@ |
|||
package com.win.web.controller.system; |
|||
|
|||
import com.win.common.annotation.Log; |
|||
import com.win.common.core.controller.BaseController; |
|||
import com.win.common.core.domain.AjaxResult; |
|||
import com.win.common.core.domain.entity.SysDictData; |
|||
import com.win.common.core.page.TableDataInfo; |
|||
import com.win.common.enums.BusinessType; |
|||
import com.win.common.utils.StringUtils; |
|||
import com.win.common.utils.poi.ExcelUtil; |
|||
import com.win.system.service.SysDictDataService; |
|||
import com.win.system.service.SysDictTypeService; |
|||
import org.springframework.beans.factory.annotation.Autowired; |
|||
import org.springframework.validation.annotation.Validated; |
|||
import org.springframework.web.bind.annotation.*; |
|||
|
|||
import javax.servlet.http.HttpServletResponse; |
|||
import java.util.ArrayList; |
|||
import java.util.List; |
|||
|
|||
/** |
|||
* 数据字典信息 |
|||
* |
|||
* @author win |
|||
*/ |
|||
@RestController |
|||
@RequestMapping("/system/dict/data") |
|||
public class SysDictDataController extends BaseController { |
|||
@Autowired |
|||
private SysDictDataService dictDataService; |
|||
|
|||
@Autowired |
|||
private SysDictTypeService dictTypeService; |
|||
|
|||
@GetMapping("/list") |
|||
public TableDataInfo list(SysDictData dictData) { |
|||
startPage(); |
|||
List<SysDictData> list = dictDataService.selectDictDataList(dictData); |
|||
return getDataTable(list); |
|||
} |
|||
|
|||
@Log(title = "字典数据", businessType = BusinessType.EXPORT) |
|||
@PostMapping("/export") |
|||
public void export(HttpServletResponse response, SysDictData dictData) { |
|||
List<SysDictData> list = dictDataService.selectDictDataList(dictData); |
|||
ExcelUtil<SysDictData> util = new ExcelUtil<SysDictData>(SysDictData.class); |
|||
util.exportExcel(response, list, "字典数据"); |
|||
} |
|||
|
|||
/** |
|||
* 查询字典数据详细 |
|||
*/ |
|||
@GetMapping(value = "/{dictCode}") |
|||
public AjaxResult getInfo(@PathVariable Long dictCode) { |
|||
return success(dictDataService.selectDictDataById(dictCode)); |
|||
} |
|||
|
|||
/** |
|||
* 根据字典类型查询字典数据信息 |
|||
*/ |
|||
@GetMapping(value = "/type/{dictType}") |
|||
public AjaxResult dictType(@PathVariable String dictType) { |
|||
List<SysDictData> data = dictTypeService.selectDictDataByType(dictType); |
|||
if (StringUtils.isNull(data)) { |
|||
data = new ArrayList<SysDictData>(); |
|||
} |
|||
return success(data); |
|||
} |
|||
|
|||
/** |
|||
* 新增字典类型 |
|||
*/ |
|||
@Log(title = "字典数据", businessType = BusinessType.INSERT) |
|||
@PostMapping |
|||
public AjaxResult add(@Validated @RequestBody SysDictData dict) { |
|||
dict.setCreateBy(getUsername()); |
|||
return toAjax(dictDataService.insertDictData(dict)); |
|||
} |
|||
|
|||
/** |
|||
* 修改保存字典类型 |
|||
*/ |
|||
@Log(title = "字典数据", businessType = BusinessType.UPDATE) |
|||
@PutMapping |
|||
public AjaxResult edit(@Validated @RequestBody SysDictData dict) { |
|||
dict.setUpdateBy(getUsername()); |
|||
return toAjax(dictDataService.updateDictData(dict)); |
|||
} |
|||
|
|||
/** |
|||
* 删除字典类型 |
|||
*/ |
|||
@Log(title = "字典类型", businessType = BusinessType.DELETE) |
|||
@DeleteMapping("/{dictCodes}") |
|||
public AjaxResult remove(@PathVariable Long[] dictCodes) { |
|||
dictDataService.deleteDictDataByIds(dictCodes); |
|||
return success(); |
|||
} |
|||
} |
@ -0,0 +1,116 @@ |
|||
package com.win.web.controller.system; |
|||
|
|||
import com.win.common.annotation.Log; |
|||
import com.win.common.constant.UserConstants; |
|||
import com.win.common.core.controller.BaseController; |
|||
import com.win.common.core.domain.AjaxResult; |
|||
import com.win.common.core.domain.entity.SysDictType; |
|||
import com.win.common.core.page.TableDataInfo; |
|||
import com.win.common.enums.BusinessType; |
|||
import com.win.common.utils.poi.ExcelUtil; |
|||
import com.win.system.service.SysDictTypeService; |
|||
import org.springframework.beans.factory.annotation.Autowired; |
|||
import org.springframework.validation.annotation.Validated; |
|||
import org.springframework.web.bind.annotation.*; |
|||
|
|||
import javax.annotation.PostConstruct; |
|||
import javax.servlet.http.HttpServletResponse; |
|||
import java.util.List; |
|||
|
|||
/** |
|||
* 数据字典信息 |
|||
* |
|||
* @author win |
|||
*/ |
|||
@RestController |
|||
@RequestMapping("/system/dict/type") |
|||
public class SysDictTypeController extends BaseController { |
|||
@Autowired |
|||
private SysDictTypeService dictTypeService; |
|||
|
|||
/** |
|||
* 项目启动时,初始化字典到缓存 |
|||
*/ |
|||
@PostConstruct |
|||
public void init() { |
|||
dictTypeService.loadingDictCache(); |
|||
} |
|||
|
|||
@GetMapping("/list") |
|||
public TableDataInfo list(SysDictType dictType) { |
|||
startPage(); |
|||
List<SysDictType> list = dictTypeService.selectDictTypeList(dictType); |
|||
return getDataTable(list); |
|||
} |
|||
|
|||
@Log(title = "字典类型", businessType = BusinessType.EXPORT) |
|||
@PostMapping("/export") |
|||
public void export(HttpServletResponse response, SysDictType dictType) { |
|||
List<SysDictType> list = dictTypeService.selectDictTypeList(dictType); |
|||
ExcelUtil<SysDictType> util = new ExcelUtil<SysDictType>(SysDictType.class); |
|||
util.exportExcel(response, list, "字典类型"); |
|||
} |
|||
|
|||
/** |
|||
* 查询字典类型详细 |
|||
*/ |
|||
@GetMapping(value = "/{dictId}") |
|||
public AjaxResult getInfo(@PathVariable Long dictId) { |
|||
return success(dictTypeService.selectDictTypeById(dictId)); |
|||
} |
|||
|
|||
/** |
|||
* 新增字典类型 |
|||
*/ |
|||
@Log(title = "字典类型", businessType = BusinessType.INSERT) |
|||
@PostMapping |
|||
public AjaxResult add(@Validated @RequestBody SysDictType dict) { |
|||
if (UserConstants.NOT_UNIQUE.equals(dictTypeService.checkDictTypeUnique(dict))) { |
|||
return error("新增字典'" + dict.getDictName() + "'失败,字典类型已存在"); |
|||
} |
|||
dict.setCreateBy(getUsername()); |
|||
return toAjax(dictTypeService.insertDictType(dict)); |
|||
} |
|||
|
|||
/** |
|||
* 修改字典类型 |
|||
*/ |
|||
@Log(title = "字典类型", businessType = BusinessType.UPDATE) |
|||
@PutMapping |
|||
public AjaxResult edit(@Validated @RequestBody SysDictType dict) { |
|||
if (UserConstants.NOT_UNIQUE.equals(dictTypeService.checkDictTypeUnique(dict))) { |
|||
return error("修改字典'" + dict.getDictName() + "'失败,字典类型已存在"); |
|||
} |
|||
dict.setUpdateBy(getUsername()); |
|||
return toAjax(dictTypeService.updateDictType(dict)); |
|||
} |
|||
|
|||
/** |
|||
* 删除字典类型 |
|||
*/ |
|||
@Log(title = "字典类型", businessType = BusinessType.DELETE) |
|||
@DeleteMapping("/{dictIds}") |
|||
public AjaxResult remove(@PathVariable Long[] dictIds) { |
|||
dictTypeService.deleteDictTypeByIds(dictIds); |
|||
return success(); |
|||
} |
|||
|
|||
/** |
|||
* 刷新字典缓存 |
|||
*/ |
|||
@Log(title = "字典类型", businessType = BusinessType.CLEAN) |
|||
@DeleteMapping("/refreshCache") |
|||
public AjaxResult refreshCache() { |
|||
dictTypeService.resetDictCache(); |
|||
return success(); |
|||
} |
|||
|
|||
/** |
|||
* 获取字典选择框列表 |
|||
*/ |
|||
@GetMapping("/optionselect") |
|||
public AjaxResult optionselect() { |
|||
List<SysDictType> dictTypes = dictTypeService.selectDictTypeAll(); |
|||
return success(dictTypes); |
|||
} |
|||
} |
@ -0,0 +1,84 @@ |
|||
package com.win.web.controller.system; |
|||
|
|||
import com.win.common.annotation.Log; |
|||
import com.win.common.core.controller.BaseController; |
|||
import com.win.common.core.domain.AjaxResult; |
|||
import com.win.common.core.page.TableDataInfo; |
|||
import com.win.common.enums.BusinessType; |
|||
import com.win.common.utils.poi.ExcelUtil; |
|||
import com.win.system.domain.SysExpression; |
|||
import com.win.system.service.SysExpressionService; |
|||
import org.springframework.beans.factory.annotation.Autowired; |
|||
import org.springframework.web.bind.annotation.*; |
|||
|
|||
import javax.servlet.http.HttpServletResponse; |
|||
import java.util.List; |
|||
|
|||
/** |
|||
* 流程达式Controller |
|||
* |
|||
* @author ruoyi |
|||
* @date 2022-12-12 |
|||
*/ |
|||
@RestController |
|||
@RequestMapping("/system/expression") |
|||
public class SysExpressionController extends BaseController { |
|||
@Autowired |
|||
private SysExpressionService sysExpressionService; |
|||
|
|||
/** |
|||
* 查询流程达式列表 |
|||
*/ |
|||
@GetMapping("/list") |
|||
public TableDataInfo list(SysExpression sysExpression) { |
|||
startPage(); |
|||
List<SysExpression> list = sysExpressionService.selectSysExpressionList(sysExpression); |
|||
return getDataTable(list); |
|||
} |
|||
|
|||
/** |
|||
* 导出流程达式列表 |
|||
*/ |
|||
@Log(title = "流程达式", businessType = BusinessType.EXPORT) |
|||
@PostMapping("/export") |
|||
public void export(HttpServletResponse response, SysExpression sysExpression) { |
|||
List<SysExpression> list = sysExpressionService.selectSysExpressionList(sysExpression); |
|||
ExcelUtil<SysExpression> util = new ExcelUtil<SysExpression>(SysExpression.class); |
|||
util.exportExcel(response, list, "流程达式数据"); |
|||
} |
|||
|
|||
/** |
|||
* 获取流程达式详细信息 |
|||
*/ |
|||
@GetMapping(value = "/{id}") |
|||
public AjaxResult getInfo(@PathVariable("id") Long id) { |
|||
return success(sysExpressionService.selectSysExpressionById(id)); |
|||
} |
|||
|
|||
/** |
|||
* 新增流程达式 |
|||
*/ |
|||
@Log(title = "流程达式", businessType = BusinessType.INSERT) |
|||
@PostMapping |
|||
public AjaxResult add(@RequestBody SysExpression sysExpression) { |
|||
return toAjax(sysExpressionService.insertSysExpression(sysExpression)); |
|||
} |
|||
|
|||
/** |
|||
* 修改流程达式 |
|||
*/ |
|||
@Log(title = "流程达式", businessType = BusinessType.UPDATE) |
|||
@PutMapping |
|||
public AjaxResult edit(@RequestBody SysExpression sysExpression) { |
|||
return toAjax(sysExpressionService.updateSysExpression(sysExpression)); |
|||
} |
|||
|
|||
/** |
|||
* 删除流程达式 |
|||
*/ |
|||
@Log(title = "流程达式", businessType = BusinessType.DELETE) |
|||
@DeleteMapping("/{ids}") |
|||
public AjaxResult remove(@PathVariable Long[] ids) { |
|||
return toAjax(sysExpressionService.deleteSysExpressionByIds(ids)); |
|||
} |
|||
} |
@ -0,0 +1,29 @@ |
|||
package com.win.web.controller.system; |
|||
|
|||
import org.springframework.beans.factory.annotation.Autowired; |
|||
import org.springframework.web.bind.annotation.RequestMapping; |
|||
import org.springframework.web.bind.annotation.RestController; |
|||
import com.win.common.config.WinConfig; |
|||
import com.win.common.utils.StringUtils; |
|||
|
|||
/** |
|||
* 首页 |
|||
* |
|||
* @author win |
|||
*/ |
|||
@RestController |
|||
public class SysIndexController { |
|||
/** |
|||
* 系统基础配置 |
|||
*/ |
|||
@Autowired |
|||
private WinConfig winConfig; |
|||
|
|||
/** |
|||
* 访问首页,提示语 |
|||
*/ |
|||
@RequestMapping("/") |
|||
public String index() { |
|||
return StringUtils.format("欢迎使用{}后台管理框架,当前版本:v{},请通过前端地址访问。", winConfig.getName(), winConfig.getVersion()); |
|||
} |
|||
} |
@ -0,0 +1,84 @@ |
|||
package com.win.web.controller.system; |
|||
|
|||
import com.win.common.annotation.Log; |
|||
import com.win.common.core.controller.BaseController; |
|||
import com.win.common.core.domain.AjaxResult; |
|||
import com.win.common.core.page.TableDataInfo; |
|||
import com.win.common.enums.BusinessType; |
|||
import com.win.common.utils.poi.ExcelUtil; |
|||
import com.win.system.domain.SysListener; |
|||
import com.win.system.service.SysListenerService; |
|||
import org.springframework.beans.factory.annotation.Autowired; |
|||
import org.springframework.web.bind.annotation.*; |
|||
|
|||
import javax.servlet.http.HttpServletResponse; |
|||
import java.util.List; |
|||
|
|||
/** |
|||
* 流程监听Controller |
|||
* |
|||
* @author Tony |
|||
* @date 2022-12-25 |
|||
*/ |
|||
@RestController |
|||
@RequestMapping("/system/listener") |
|||
public class SysListenerController extends BaseController { |
|||
@Autowired |
|||
private SysListenerService sysListenerService; |
|||
|
|||
/** |
|||
* 查询流程监听列表 |
|||
*/ |
|||
@GetMapping("/list") |
|||
public TableDataInfo list(SysListener sysListener) { |
|||
startPage(); |
|||
List<SysListener> list = sysListenerService.selectSysListenerList(sysListener); |
|||
return getDataTable(list); |
|||
} |
|||
|
|||
/** |
|||
* 导出流程监听列表 |
|||
*/ |
|||
@Log(title = "流程监听", businessType = BusinessType.EXPORT) |
|||
@PostMapping("/export") |
|||
public void export(HttpServletResponse response, SysListener sysListener) { |
|||
List<SysListener> list = sysListenerService.selectSysListenerList(sysListener); |
|||
ExcelUtil<SysListener> util = new ExcelUtil<SysListener>(SysListener.class); |
|||
util.exportExcel(response, list, "流程监听数据"); |
|||
} |
|||
|
|||
/** |
|||
* 获取流程监听详细信息 |
|||
*/ |
|||
@GetMapping(value = "/{id}") |
|||
public AjaxResult getInfo(@PathVariable("id") Long id) { |
|||
return success(sysListenerService.selectSysListenerById(id)); |
|||
} |
|||
|
|||
/** |
|||
* 新增流程监听 |
|||
*/ |
|||
@Log(title = "流程监听", businessType = BusinessType.INSERT) |
|||
@PostMapping |
|||
public AjaxResult add(@RequestBody SysListener sysListener) { |
|||
return toAjax(sysListenerService.insertSysListener(sysListener)); |
|||
} |
|||
|
|||
/** |
|||
* 修改流程监听 |
|||
*/ |
|||
@Log(title = "流程监听", businessType = BusinessType.UPDATE) |
|||
@PutMapping |
|||
public AjaxResult edit(@RequestBody SysListener sysListener) { |
|||
return toAjax(sysListenerService.updateSysListener(sysListener)); |
|||
} |
|||
|
|||
/** |
|||
* 删除流程监听 |
|||
*/ |
|||
@Log(title = "流程监听", businessType = BusinessType.DELETE) |
|||
@DeleteMapping("/{ids}") |
|||
public AjaxResult remove(@PathVariable Long[] ids) { |
|||
return toAjax(sysListenerService.deleteSysListenerByIds(ids)); |
|||
} |
|||
} |
@ -0,0 +1,83 @@ |
|||
package com.win.web.controller.system; |
|||
|
|||
import com.win.common.constant.Constants; |
|||
import com.win.common.core.domain.AjaxResult; |
|||
import com.win.common.core.domain.entity.SysMenu; |
|||
import com.win.common.core.domain.entity.SysUser; |
|||
import com.win.common.core.domain.model.LoginBody; |
|||
import com.win.common.utils.SecurityUtils; |
|||
import com.win.framework.web.service.SysLoginService; |
|||
import com.win.framework.web.service.SysPermissionService; |
|||
import com.win.system.service.SysMenuService; |
|||
import org.springframework.beans.factory.annotation.Autowired; |
|||
import org.springframework.web.bind.annotation.GetMapping; |
|||
import org.springframework.web.bind.annotation.PostMapping; |
|||
import org.springframework.web.bind.annotation.RequestBody; |
|||
import org.springframework.web.bind.annotation.RestController; |
|||
|
|||
import java.util.List; |
|||
import java.util.Set; |
|||
|
|||
/** |
|||
* 登录验证 |
|||
* |
|||
* @author win |
|||
*/ |
|||
@RestController |
|||
public class SysLoginController { |
|||
@Autowired |
|||
private SysLoginService loginService; |
|||
|
|||
@Autowired |
|||
private SysMenuService menuService; |
|||
|
|||
@Autowired |
|||
private SysPermissionService permissionService; |
|||
|
|||
/** |
|||
* 登录方法 |
|||
* |
|||
* @param loginBody 登录信息 |
|||
* @return 结果 |
|||
*/ |
|||
@PostMapping("/login") |
|||
public AjaxResult login(@RequestBody LoginBody loginBody) { |
|||
AjaxResult ajax = AjaxResult.success(); |
|||
// 生成令牌
|
|||
String token = loginService.login(loginBody.getUsername(), loginBody.getPassword(), loginBody.getCode(), |
|||
loginBody.getUuid()); |
|||
ajax.put(Constants.TOKEN, token); |
|||
return ajax; |
|||
} |
|||
|
|||
/** |
|||
* 获取用户信息 |
|||
* |
|||
* @return 用户信息 |
|||
*/ |
|||
@GetMapping("getInfo") |
|||
public AjaxResult getInfo() { |
|||
SysUser user = SecurityUtils.getLoginUser().getUser(); |
|||
// 角色集合
|
|||
Set<String> roles = permissionService.getRolePermission(user); |
|||
// 权限集合
|
|||
Set<String> permissions = permissionService.getMenuPermission(user); |
|||
AjaxResult ajax = AjaxResult.success(); |
|||
ajax.put("user", user); |
|||
ajax.put("roles", roles); |
|||
ajax.put("permissions", permissions); |
|||
return ajax; |
|||
} |
|||
|
|||
/** |
|||
* 获取路由信息 |
|||
* |
|||
* @return 路由信息 |
|||
*/ |
|||
@GetMapping("getRouters") |
|||
public AjaxResult getRouters() { |
|||
Long userId = SecurityUtils.getUserId(); |
|||
List<SysMenu> menus = menuService.selectMenuTreeByUserId(userId); |
|||
return AjaxResult.success(menuService.buildMenus(menus)); |
|||
} |
|||
} |
@ -0,0 +1,112 @@ |
|||
package com.win.web.controller.system; |
|||
|
|||
import com.win.common.annotation.Log; |
|||
import com.win.common.constant.UserConstants; |
|||
import com.win.common.core.controller.BaseController; |
|||
import com.win.common.core.domain.AjaxResult; |
|||
import com.win.common.core.domain.entity.SysMenu; |
|||
import com.win.common.enums.BusinessType; |
|||
import com.win.common.utils.StringUtils; |
|||
import com.win.system.service.SysMenuService; |
|||
import org.springframework.beans.factory.annotation.Autowired; |
|||
import org.springframework.validation.annotation.Validated; |
|||
import org.springframework.web.bind.annotation.*; |
|||
|
|||
import java.util.List; |
|||
|
|||
/** |
|||
* 菜单信息 |
|||
* |
|||
* @author win |
|||
*/ |
|||
@RestController |
|||
@RequestMapping("/system/menu") |
|||
public class SysMenuController extends BaseController { |
|||
@Autowired |
|||
private SysMenuService menuService; |
|||
|
|||
/** |
|||
* 获取菜单列表 |
|||
*/ |
|||
@GetMapping("/list") |
|||
public AjaxResult list(SysMenu menu) { |
|||
List<SysMenu> menus = menuService.selectMenuList(menu, getUserId()); |
|||
return success(menus); |
|||
} |
|||
|
|||
/** |
|||
* 根据菜单编号获取详细信息 |
|||
*/ |
|||
@GetMapping(value = "/{menuId}") |
|||
public AjaxResult getInfo(@PathVariable Long menuId) { |
|||
return success(menuService.selectMenuById(menuId)); |
|||
} |
|||
|
|||
/** |
|||
* 获取菜单下拉树列表 |
|||
*/ |
|||
@GetMapping("/treeselect") |
|||
public AjaxResult treeselect(SysMenu menu) { |
|||
List<SysMenu> menus = menuService.selectMenuList(menu, getUserId()); |
|||
return success(menuService.buildMenuTreeSelect(menus)); |
|||
} |
|||
|
|||
/** |
|||
* 加载对应角色菜单列表树 |
|||
*/ |
|||
@GetMapping(value = "/roleMenuTreeselect/{roleId}") |
|||
public AjaxResult roleMenuTreeselect(@PathVariable("roleId") Long roleId) { |
|||
List<SysMenu> menus = menuService.selectMenuList(getUserId()); |
|||
AjaxResult ajax = AjaxResult.success(); |
|||
ajax.put("checkedKeys", menuService.selectMenuListByRoleId(roleId)); |
|||
ajax.put("menus", menuService.buildMenuTreeSelect(menus)); |
|||
return ajax; |
|||
} |
|||
|
|||
/** |
|||
* 新增菜单 |
|||
*/ |
|||
@Log(title = "菜单管理", businessType = BusinessType.INSERT) |
|||
@PostMapping |
|||
public AjaxResult add(@Validated @RequestBody SysMenu menu) { |
|||
if (UserConstants.NOT_UNIQUE.equals(menuService.checkMenuNameUnique(menu))) { |
|||
return error("新增菜单'" + menu.getMenuName() + "'失败,菜单名称已存在"); |
|||
} else if (UserConstants.YES_FRAME.equals(menu.getIsFrame()) && !StringUtils.ishttp(menu.getPath())) { |
|||
return error("新增菜单'" + menu.getMenuName() + "'失败,地址必须以http(s)://开头"); |
|||
} |
|||
menu.setCreateBy(getUsername()); |
|||
return toAjax(menuService.insertMenu(menu)); |
|||
} |
|||
|
|||
/** |
|||
* 修改菜单 |
|||
*/ |
|||
@Log(title = "菜单管理", businessType = BusinessType.UPDATE) |
|||
@PutMapping |
|||
public AjaxResult edit(@Validated @RequestBody SysMenu menu) { |
|||
if (UserConstants.NOT_UNIQUE.equals(menuService.checkMenuNameUnique(menu))) { |
|||
return error("修改菜单'" + menu.getMenuName() + "'失败,菜单名称已存在"); |
|||
} else if (UserConstants.YES_FRAME.equals(menu.getIsFrame()) && !StringUtils.ishttp(menu.getPath())) { |
|||
return error("修改菜单'" + menu.getMenuName() + "'失败,地址必须以http(s)://开头"); |
|||
} else if (menu.getMenuId().equals(menu.getParentId())) { |
|||
return error("修改菜单'" + menu.getMenuName() + "'失败,上级菜单不能选择自己"); |
|||
} |
|||
menu.setUpdateBy(getUsername()); |
|||
return toAjax(menuService.updateMenu(menu)); |
|||
} |
|||
|
|||
/** |
|||
* 删除菜单 |
|||
*/ |
|||
@Log(title = "菜单管理", businessType = BusinessType.DELETE) |
|||
@DeleteMapping("/{menuId}") |
|||
public AjaxResult remove(@PathVariable("menuId") Long menuId) { |
|||
if (menuService.hasChildByMenuId(menuId)) { |
|||
return warn("存在子菜单,不允许删除"); |
|||
} |
|||
if (menuService.checkMenuExistRole(menuId)) { |
|||
return warn("菜单已分配,不允许删除"); |
|||
} |
|||
return toAjax(menuService.deleteMenuById(menuId)); |
|||
} |
|||
} |
@ -0,0 +1,73 @@ |
|||
package com.win.web.controller.system; |
|||
|
|||
import com.win.common.annotation.Log; |
|||
import com.win.common.core.controller.BaseController; |
|||
import com.win.common.core.domain.AjaxResult; |
|||
import com.win.common.core.page.TableDataInfo; |
|||
import com.win.common.enums.BusinessType; |
|||
import com.win.system.domain.SysNotice; |
|||
import com.win.system.service.SysNoticeService; |
|||
import org.springframework.beans.factory.annotation.Autowired; |
|||
import org.springframework.validation.annotation.Validated; |
|||
import org.springframework.web.bind.annotation.*; |
|||
|
|||
import java.util.List; |
|||
|
|||
/** |
|||
* 公告 信息操作处理 |
|||
* |
|||
* @author win |
|||
*/ |
|||
@RestController |
|||
@RequestMapping("/system/notice") |
|||
public class SysNoticeController extends BaseController { |
|||
@Autowired |
|||
private SysNoticeService noticeService; |
|||
|
|||
/** |
|||
* 获取通知公告列表 |
|||
*/ |
|||
@GetMapping("/list") |
|||
public TableDataInfo list(SysNotice notice) { |
|||
startPage(); |
|||
List<SysNotice> list = noticeService.selectNoticeList(notice); |
|||
return getDataTable(list); |
|||
} |
|||
|
|||
/** |
|||
* 根据通知公告编号获取详细信息 |
|||
*/ |
|||
@GetMapping(value = "/{noticeId}") |
|||
public AjaxResult getInfo(@PathVariable Long noticeId) { |
|||
return success(noticeService.selectNoticeById(noticeId)); |
|||
} |
|||
|
|||
/** |
|||
* 新增通知公告 |
|||
*/ |
|||
@Log(title = "通知公告", businessType = BusinessType.INSERT) |
|||
@PostMapping |
|||
public AjaxResult add(@Validated @RequestBody SysNotice notice) { |
|||
notice.setCreateBy(getUsername()); |
|||
return toAjax(noticeService.insertNotice(notice)); |
|||
} |
|||
|
|||
/** |
|||
* 修改通知公告 |
|||
*/ |
|||
@Log(title = "通知公告", businessType = BusinessType.UPDATE) |
|||
@PutMapping |
|||
public AjaxResult edit(@Validated @RequestBody SysNotice notice) { |
|||
notice.setUpdateBy(getUsername()); |
|||
return toAjax(noticeService.updateNotice(notice)); |
|||
} |
|||
|
|||
/** |
|||
* 删除通知公告 |
|||
*/ |
|||
@Log(title = "通知公告", businessType = BusinessType.DELETE) |
|||
@DeleteMapping("/{noticeIds}") |
|||
public AjaxResult remove(@PathVariable Long[] noticeIds) { |
|||
return toAjax(noticeService.deleteNoticeByIds(noticeIds)); |
|||
} |
|||
} |
@ -0,0 +1,103 @@ |
|||
package com.win.web.controller.system; |
|||
|
|||
import com.win.common.annotation.Log; |
|||
import com.win.common.constant.UserConstants; |
|||
import com.win.common.core.controller.BaseController; |
|||
import com.win.common.core.domain.AjaxResult; |
|||
import com.win.common.core.page.TableDataInfo; |
|||
import com.win.common.enums.BusinessType; |
|||
import com.win.common.utils.poi.ExcelUtil; |
|||
import com.win.system.domain.SysPost; |
|||
import com.win.system.service.SysPostService; |
|||
import org.springframework.beans.factory.annotation.Autowired; |
|||
import org.springframework.validation.annotation.Validated; |
|||
import org.springframework.web.bind.annotation.*; |
|||
|
|||
import javax.servlet.http.HttpServletResponse; |
|||
import java.util.List; |
|||
|
|||
/** |
|||
* 岗位信息操作处理 |
|||
* |
|||
* @author win |
|||
*/ |
|||
@RestController |
|||
@RequestMapping("/system/post") |
|||
public class SysPostController extends BaseController { |
|||
@Autowired |
|||
private SysPostService postService; |
|||
|
|||
/** |
|||
* 获取岗位列表 |
|||
*/ |
|||
@GetMapping("/list") |
|||
public TableDataInfo list(SysPost post) { |
|||
startPage(); |
|||
List<SysPost> list = postService.selectPostList(post); |
|||
return getDataTable(list); |
|||
} |
|||
|
|||
@Log(title = "岗位管理", businessType = BusinessType.EXPORT) |
|||
@PostMapping("/export") |
|||
public void export(HttpServletResponse response, SysPost post) { |
|||
List<SysPost> list = postService.selectPostList(post); |
|||
ExcelUtil<SysPost> util = new ExcelUtil<SysPost>(SysPost.class); |
|||
util.exportExcel(response, list, "岗位数据"); |
|||
} |
|||
|
|||
/** |
|||
* 根据岗位编号获取详细信息 |
|||
*/ |
|||
@GetMapping(value = "/{postId}") |
|||
public AjaxResult getInfo(@PathVariable Long postId) { |
|||
return success(postService.selectPostById(postId)); |
|||
} |
|||
|
|||
/** |
|||
* 新增岗位 |
|||
*/ |
|||
@Log(title = "岗位管理", businessType = BusinessType.INSERT) |
|||
@PostMapping |
|||
public AjaxResult add(@Validated @RequestBody SysPost post) { |
|||
if (UserConstants.NOT_UNIQUE.equals(postService.checkPostNameUnique(post))) { |
|||
return error("新增岗位'" + post.getPostName() + "'失败,岗位名称已存在"); |
|||
} else if (UserConstants.NOT_UNIQUE.equals(postService.checkPostCodeUnique(post))) { |
|||
return error("新增岗位'" + post.getPostName() + "'失败,岗位编码已存在"); |
|||
} |
|||
post.setCreateBy(getUsername()); |
|||
return toAjax(postService.insertPost(post)); |
|||
} |
|||
|
|||
/** |
|||
* 修改岗位 |
|||
*/ |
|||
@Log(title = "岗位管理", businessType = BusinessType.UPDATE) |
|||
@PutMapping |
|||
public AjaxResult edit(@Validated @RequestBody SysPost post) { |
|||
if (UserConstants.NOT_UNIQUE.equals(postService.checkPostNameUnique(post))) { |
|||
return error("修改岗位'" + post.getPostName() + "'失败,岗位名称已存在"); |
|||
} else if (UserConstants.NOT_UNIQUE.equals(postService.checkPostCodeUnique(post))) { |
|||
return error("修改岗位'" + post.getPostName() + "'失败,岗位编码已存在"); |
|||
} |
|||
post.setUpdateBy(getUsername()); |
|||
return toAjax(postService.updatePost(post)); |
|||
} |
|||
|
|||
/** |
|||
* 删除岗位 |
|||
*/ |
|||
@Log(title = "岗位管理", businessType = BusinessType.DELETE) |
|||
@DeleteMapping("/{postIds}") |
|||
public AjaxResult remove(@PathVariable Long[] postIds) { |
|||
return toAjax(postService.deletePostByIds(postIds)); |
|||
} |
|||
|
|||
/** |
|||
* 获取岗位选择框列表 |
|||
*/ |
|||
@GetMapping("/optionselect") |
|||
public AjaxResult optionselect() { |
|||
List<SysPost> posts = postService.selectPostAll(); |
|||
return success(posts); |
|||
} |
|||
} |
@ -0,0 +1,131 @@ |
|||
package com.win.web.controller.system; |
|||
|
|||
import com.win.system.service.SysUserService; |
|||
import com.win.common.core.controller.BaseController; |
|||
import com.win.common.core.domain.AjaxResult; |
|||
import com.win.common.core.domain.entity.SysUser; |
|||
import com.win.common.core.domain.model.LoginUser; |
|||
import com.win.common.enums.BusinessType; |
|||
import com.win.framework.web.service.TokenService; |
|||
import org.springframework.beans.factory.annotation.Autowired; |
|||
import org.springframework.web.bind.annotation.GetMapping; |
|||
import org.springframework.web.bind.annotation.PostMapping; |
|||
import org.springframework.web.bind.annotation.PutMapping; |
|||
import org.springframework.web.bind.annotation.RequestBody; |
|||
import org.springframework.web.bind.annotation.RequestMapping; |
|||
import org.springframework.web.bind.annotation.RequestParam; |
|||
import org.springframework.web.bind.annotation.RestController; |
|||
import org.springframework.web.multipart.MultipartFile; |
|||
import com.win.common.annotation.Log; |
|||
import com.win.common.config.WinConfig; |
|||
import com.win.common.constant.UserConstants; |
|||
import com.win.common.utils.SecurityUtils; |
|||
import com.win.common.utils.StringUtils; |
|||
import com.win.common.utils.file.FileUploadUtils; |
|||
import com.win.common.utils.file.MimeTypeUtils; |
|||
|
|||
/** |
|||
* 个人信息 业务处理 |
|||
* |
|||
* @author win |
|||
*/ |
|||
@RestController |
|||
@RequestMapping("/system/user/profile") |
|||
public class SysProfileController extends BaseController { |
|||
@Autowired |
|||
private SysUserService userService; |
|||
|
|||
@Autowired |
|||
private TokenService tokenService; |
|||
|
|||
/** |
|||
* 个人信息 |
|||
*/ |
|||
@GetMapping |
|||
public AjaxResult profile() { |
|||
LoginUser loginUser = getLoginUser(); |
|||
SysUser user = loginUser.getUser(); |
|||
AjaxResult ajax = AjaxResult.success(user); |
|||
ajax.put("roleGroup", userService.selectUserRoleGroup(loginUser.getUsername())); |
|||
ajax.put("postGroup", userService.selectUserPostGroup(loginUser.getUsername())); |
|||
return ajax; |
|||
} |
|||
|
|||
/** |
|||
* 修改用户 |
|||
*/ |
|||
@Log(title = "个人信息", businessType = BusinessType.UPDATE) |
|||
@PutMapping |
|||
public AjaxResult updateProfile(@RequestBody SysUser user) { |
|||
LoginUser loginUser = getLoginUser(); |
|||
SysUser sysUser = loginUser.getUser(); |
|||
user.setUserName(sysUser.getUserName()); |
|||
if (StringUtils.isNotEmpty(user.getPhonenumber()) |
|||
&& UserConstants.NOT_UNIQUE.equals(userService.checkPhoneUnique(user))) { |
|||
return error("修改用户'" + user.getUserName() + "'失败,手机号码已存在"); |
|||
} |
|||
if (StringUtils.isNotEmpty(user.getEmail()) |
|||
&& UserConstants.NOT_UNIQUE.equals(userService.checkEmailUnique(user))) { |
|||
return error("修改用户'" + user.getUserName() + "'失败,邮箱账号已存在"); |
|||
} |
|||
user.setUserId(sysUser.getUserId()); |
|||
user.setPassword(null); |
|||
user.setAvatar(null); |
|||
user.setDeptId(null); |
|||
if (userService.updateUserProfile(user) > 0) { |
|||
// 更新缓存用户信息
|
|||
sysUser.setNickName(user.getNickName()); |
|||
sysUser.setPhonenumber(user.getPhonenumber()); |
|||
sysUser.setEmail(user.getEmail()); |
|||
sysUser.setSex(user.getSex()); |
|||
tokenService.setLoginUser(loginUser); |
|||
return success(); |
|||
} |
|||
return error("修改个人信息异常,请联系管理员"); |
|||
} |
|||
|
|||
/** |
|||
* 重置密码 |
|||
*/ |
|||
@Log(title = "个人信息", businessType = BusinessType.UPDATE) |
|||
@PutMapping("/updatePwd") |
|||
public AjaxResult updatePwd(String oldPassword, String newPassword) { |
|||
LoginUser loginUser = getLoginUser(); |
|||
String userName = loginUser.getUsername(); |
|||
String password = loginUser.getPassword(); |
|||
if (!SecurityUtils.matchesPassword(oldPassword, password)) { |
|||
return error("修改密码失败,旧密码错误"); |
|||
} |
|||
if (SecurityUtils.matchesPassword(newPassword, password)) { |
|||
return error("新密码不能与旧密码相同"); |
|||
} |
|||
if (userService.resetUserPwd(userName, SecurityUtils.encryptPassword(newPassword)) > 0) { |
|||
// 更新缓存用户密码
|
|||
loginUser.getUser().setPassword(SecurityUtils.encryptPassword(newPassword)); |
|||
tokenService.setLoginUser(loginUser); |
|||
return success(); |
|||
} |
|||
return error("修改密码异常,请联系管理员"); |
|||
} |
|||
|
|||
/** |
|||
* 头像上传 |
|||
*/ |
|||
@Log(title = "用户头像", businessType = BusinessType.UPDATE) |
|||
@PostMapping("/avatar") |
|||
public AjaxResult avatar(@RequestParam("avatarfile") MultipartFile file) throws Exception { |
|||
if (!file.isEmpty()) { |
|||
LoginUser loginUser = getLoginUser(); |
|||
String avatar = FileUploadUtils.upload(WinConfig.getAvatarPath(), file, MimeTypeUtils.IMAGE_EXTENSION); |
|||
if (userService.updateUserAvatar(loginUser.getUsername(), avatar)) { |
|||
AjaxResult ajax = AjaxResult.success(); |
|||
ajax.put("imgUrl", avatar); |
|||
// 更新缓存用户头像
|
|||
loginUser.getUser().setAvatar(avatar); |
|||
tokenService.setLoginUser(loginUser); |
|||
return ajax; |
|||
} |
|||
} |
|||
return error("上传图片异常,请联系管理员"); |
|||
} |
|||
} |
@ -0,0 +1,35 @@ |
|||
package com.win.web.controller.system; |
|||
|
|||
import com.win.system.service.SysConfigService; |
|||
import com.win.common.core.controller.BaseController; |
|||
import com.win.common.core.domain.AjaxResult; |
|||
import com.win.common.core.domain.model.RegisterBody; |
|||
import com.win.framework.web.service.SysRegisterService; |
|||
import org.springframework.beans.factory.annotation.Autowired; |
|||
import org.springframework.web.bind.annotation.PostMapping; |
|||
import org.springframework.web.bind.annotation.RequestBody; |
|||
import org.springframework.web.bind.annotation.RestController; |
|||
import com.win.common.utils.StringUtils; |
|||
|
|||
/** |
|||
* 注册验证 |
|||
* |
|||
* @author win |
|||
*/ |
|||
@RestController |
|||
public class SysRegisterController extends BaseController { |
|||
@Autowired |
|||
private SysRegisterService registerService; |
|||
|
|||
@Autowired |
|||
private SysConfigService configService; |
|||
|
|||
@PostMapping("/register") |
|||
public AjaxResult register(@RequestBody RegisterBody user) { |
|||
if (!("true".equals(configService.selectConfigByKey("sys.account.registerUser")))) { |
|||
return error("当前系统没有开启注册功能!"); |
|||
} |
|||
String msg = registerService.register(user); |
|||
return StringUtils.isEmpty(msg) ? success() : error(msg); |
|||
} |
|||
} |
@ -0,0 +1,217 @@ |
|||
package com.win.web.controller.system; |
|||
|
|||
import com.win.common.annotation.Log; |
|||
import com.win.common.constant.UserConstants; |
|||
import com.win.common.core.controller.BaseController; |
|||
import com.win.common.core.domain.AjaxResult; |
|||
import com.win.common.core.domain.entity.SysDept; |
|||
import com.win.common.core.domain.entity.SysRole; |
|||
import com.win.common.core.domain.entity.SysUser; |
|||
import com.win.common.core.domain.model.LoginUser; |
|||
import com.win.common.core.page.TableDataInfo; |
|||
import com.win.common.enums.BusinessType; |
|||
import com.win.common.utils.StringUtils; |
|||
import com.win.common.utils.poi.ExcelUtil; |
|||
import com.win.framework.web.service.SysPermissionService; |
|||
import com.win.framework.web.service.TokenService; |
|||
import com.win.system.domain.SysUserRole; |
|||
import com.win.system.service.SysDeptService; |
|||
import com.win.system.service.SysRoleService; |
|||
import com.win.system.service.SysUserService; |
|||
import org.springframework.beans.factory.annotation.Autowired; |
|||
import org.springframework.validation.annotation.Validated; |
|||
import org.springframework.web.bind.annotation.*; |
|||
|
|||
import javax.servlet.http.HttpServletResponse; |
|||
import java.util.List; |
|||
|
|||
/** |
|||
* 角色信息 |
|||
* |
|||
* @author win |
|||
*/ |
|||
@RestController |
|||
@RequestMapping("/system/role") |
|||
public class SysRoleController extends BaseController { |
|||
@Autowired |
|||
private SysRoleService roleService; |
|||
|
|||
@Autowired |
|||
private TokenService tokenService; |
|||
|
|||
@Autowired |
|||
private SysPermissionService permissionService; |
|||
|
|||
@Autowired |
|||
private SysUserService userService; |
|||
|
|||
@Autowired |
|||
private SysDeptService deptService; |
|||
|
|||
@GetMapping("/list") |
|||
public TableDataInfo list(SysRole role) { |
|||
startPage(); |
|||
List<SysRole> list = roleService.selectRoleList(role); |
|||
return getDataTable(list); |
|||
} |
|||
|
|||
@Log(title = "角色管理", businessType = BusinessType.EXPORT) |
|||
@PostMapping("/export") |
|||
public void export(HttpServletResponse response, SysRole role) { |
|||
List<SysRole> list = roleService.selectRoleList(role); |
|||
ExcelUtil<SysRole> util = new ExcelUtil<SysRole>(SysRole.class); |
|||
util.exportExcel(response, list, "角色数据"); |
|||
} |
|||
|
|||
/** |
|||
* 根据角色编号获取详细信息 |
|||
*/ |
|||
@GetMapping(value = "/{roleId}") |
|||
public AjaxResult getInfo(@PathVariable Long roleId) { |
|||
roleService.checkRoleDataScope(roleId); |
|||
return success(roleService.selectRoleById(roleId)); |
|||
} |
|||
|
|||
/** |
|||
* 新增角色 |
|||
*/ |
|||
@Log(title = "角色管理", businessType = BusinessType.INSERT) |
|||
@PostMapping |
|||
public AjaxResult add(@Validated @RequestBody SysRole role) { |
|||
if (UserConstants.NOT_UNIQUE.equals(roleService.checkRoleNameUnique(role))) { |
|||
return error("新增角色'" + role.getRoleName() + "'失败,角色名称已存在"); |
|||
} else if (UserConstants.NOT_UNIQUE.equals(roleService.checkRoleKeyUnique(role))) { |
|||
return error("新增角色'" + role.getRoleName() + "'失败,角色权限已存在"); |
|||
} |
|||
role.setCreateBy(getUsername()); |
|||
return toAjax(roleService.insertRole(role)); |
|||
|
|||
} |
|||
|
|||
/** |
|||
* 修改保存角色 |
|||
*/ |
|||
@Log(title = "角色管理", businessType = BusinessType.UPDATE) |
|||
@PutMapping |
|||
public AjaxResult edit(@Validated @RequestBody SysRole role) { |
|||
roleService.checkRoleAllowed(role); |
|||
roleService.checkRoleDataScope(role.getRoleId()); |
|||
if (UserConstants.NOT_UNIQUE.equals(roleService.checkRoleNameUnique(role))) { |
|||
return error("修改角色'" + role.getRoleName() + "'失败,角色名称已存在"); |
|||
} else if (UserConstants.NOT_UNIQUE.equals(roleService.checkRoleKeyUnique(role))) { |
|||
return error("修改角色'" + role.getRoleName() + "'失败,角色权限已存在"); |
|||
} |
|||
role.setUpdateBy(getUsername()); |
|||
|
|||
if (roleService.updateRole(role) > 0) { |
|||
// 更新缓存用户权限
|
|||
LoginUser loginUser = getLoginUser(); |
|||
if (StringUtils.isNotNull(loginUser.getUser()) && !loginUser.getUser().isAdmin()) { |
|||
loginUser.setPermissions(permissionService.getMenuPermission(loginUser.getUser())); |
|||
loginUser.setUser(userService.selectUserByUserName(loginUser.getUser().getUserName())); |
|||
tokenService.setLoginUser(loginUser); |
|||
} |
|||
return success(); |
|||
} |
|||
return error("修改角色'" + role.getRoleName() + "'失败,请联系管理员"); |
|||
} |
|||
|
|||
/** |
|||
* 修改保存数据权限 |
|||
*/ |
|||
@Log(title = "角色管理", businessType = BusinessType.UPDATE) |
|||
@PutMapping("/dataScope") |
|||
public AjaxResult dataScope(@RequestBody SysRole role) { |
|||
roleService.checkRoleAllowed(role); |
|||
roleService.checkRoleDataScope(role.getRoleId()); |
|||
return toAjax(roleService.authDataScope(role)); |
|||
} |
|||
|
|||
/** |
|||
* 状态修改 |
|||
*/ |
|||
@Log(title = "角色管理", businessType = BusinessType.UPDATE) |
|||
@PutMapping("/changeStatus") |
|||
public AjaxResult changeStatus(@RequestBody SysRole role) { |
|||
roleService.checkRoleAllowed(role); |
|||
roleService.checkRoleDataScope(role.getRoleId()); |
|||
role.setUpdateBy(getUsername()); |
|||
return toAjax(roleService.updateRoleStatus(role)); |
|||
} |
|||
|
|||
/** |
|||
* 删除角色 |
|||
*/ |
|||
@Log(title = "角色管理", businessType = BusinessType.DELETE) |
|||
@DeleteMapping("/{roleIds}") |
|||
public AjaxResult remove(@PathVariable Long[] roleIds) { |
|||
return toAjax(roleService.deleteRoleByIds(roleIds)); |
|||
} |
|||
|
|||
/** |
|||
* 获取角色选择框列表 |
|||
*/ |
|||
@GetMapping("/optionselect") |
|||
public AjaxResult optionselect() { |
|||
return success(roleService.selectRoleAll()); |
|||
} |
|||
|
|||
/** |
|||
* 查询已分配用户角色列表 |
|||
*/ |
|||
@GetMapping("/authUser/allocatedList") |
|||
public TableDataInfo allocatedList(SysUser user) { |
|||
startPage(); |
|||
List<SysUser> list = userService.selectAllocatedList(user); |
|||
return getDataTable(list); |
|||
} |
|||
|
|||
/** |
|||
* 查询未分配用户角色列表 |
|||
*/ |
|||
@GetMapping("/authUser/unallocatedList") |
|||
public TableDataInfo unallocatedList(SysUser user) { |
|||
startPage(); |
|||
List<SysUser> list = userService.selectUnallocatedList(user); |
|||
return getDataTable(list); |
|||
} |
|||
|
|||
/** |
|||
* 取消授权用户 |
|||
*/ |
|||
@Log(title = "角色管理", businessType = BusinessType.GRANT) |
|||
@PutMapping("/authUser/cancel") |
|||
public AjaxResult cancelAuthUser(@RequestBody SysUserRole userRole) { |
|||
return toAjax(roleService.deleteAuthUser(userRole)); |
|||
} |
|||
|
|||
/** |
|||
* 批量取消授权用户 |
|||
*/ |
|||
@Log(title = "角色管理", businessType = BusinessType.GRANT) |
|||
@PutMapping("/authUser/cancelAll") |
|||
public AjaxResult cancelAuthUserAll(Long roleId, Long[] userIds) { |
|||
return toAjax(roleService.deleteAuthUsers(roleId, userIds)); |
|||
} |
|||
|
|||
/** |
|||
* 批量选择用户授权 |
|||
*/ |
|||
@Log(title = "角色管理", businessType = BusinessType.GRANT) |
|||
@PutMapping("/authUser/selectAll") |
|||
public AjaxResult selectAuthUserAll(Long roleId, Long[] userIds) { |
|||
roleService.checkRoleDataScope(roleId); |
|||
return toAjax(roleService.insertAuthUsers(roleId, userIds)); |
|||
} |
|||
|
|||
/** |
|||
* 获取对应角色部门树列表 |
|||
*/ |
|||
@GetMapping(value = "/deptTree/{roleId}") |
|||
public AjaxResult deptTree(@PathVariable("roleId") Long roleId) { |
|||
AjaxResult ajax = AjaxResult.success(); |
|||
ajax.put("checkedKeys", deptService.selectDeptListByRoleId(roleId)); |
|||
ajax.put("depts", deptService.selectDeptTreeList(new SysDept())); |
|||
return ajax; |
|||
} |
|||
} |
@ -0,0 +1,211 @@ |
|||
package com.win.web.controller.system; |
|||
|
|||
import com.win.common.annotation.Log; |
|||
import com.win.common.constant.UserConstants; |
|||
import com.win.common.core.controller.BaseController; |
|||
import com.win.common.core.domain.AjaxResult; |
|||
import com.win.common.core.domain.entity.SysDept; |
|||
import com.win.common.core.domain.entity.SysRole; |
|||
import com.win.common.core.domain.entity.SysUser; |
|||
import com.win.common.core.page.TableDataInfo; |
|||
import com.win.common.enums.BusinessType; |
|||
import com.win.common.utils.SecurityUtils; |
|||
import com.win.common.utils.StringUtils; |
|||
import com.win.common.utils.poi.ExcelUtil; |
|||
import com.win.system.service.SysDeptService; |
|||
import com.win.system.service.SysPostService; |
|||
import com.win.system.service.SysRoleService; |
|||
import com.win.system.service.SysUserService; |
|||
import org.apache.commons.lang3.ArrayUtils; |
|||
import org.springframework.beans.factory.annotation.Autowired; |
|||
import org.springframework.validation.annotation.Validated; |
|||
import org.springframework.web.bind.annotation.*; |
|||
import org.springframework.web.multipart.MultipartFile; |
|||
|
|||
import javax.servlet.http.HttpServletResponse; |
|||
import java.util.List; |
|||
import java.util.stream.Collectors; |
|||
|
|||
/** |
|||
* 用户信息 |
|||
* |
|||
* @author win |
|||
*/ |
|||
@RestController |
|||
@RequestMapping("/system/user") |
|||
public class SysUserController extends BaseController { |
|||
@Autowired |
|||
private SysUserService userService; |
|||
|
|||
@Autowired |
|||
private SysRoleService roleService; |
|||
|
|||
@Autowired |
|||
private SysDeptService deptService; |
|||
|
|||
@Autowired |
|||
private SysPostService postService; |
|||
|
|||
/** |
|||
* 获取用户列表 |
|||
*/ |
|||
@GetMapping("/list") |
|||
public TableDataInfo list(SysUser user) { |
|||
startPage(); |
|||
List<SysUser> list = userService.selectUserList(user); |
|||
return getDataTable(list); |
|||
} |
|||
|
|||
@Log(title = "用户管理", businessType = BusinessType.EXPORT) |
|||
@PostMapping("/export") |
|||
public void export(HttpServletResponse response, SysUser user) { |
|||
List<SysUser> list = userService.selectUserList(user); |
|||
ExcelUtil<SysUser> util = new ExcelUtil<SysUser>(SysUser.class); |
|||
util.exportExcel(response, list, "用户数据"); |
|||
} |
|||
|
|||
@Log(title = "用户管理", businessType = BusinessType.IMPORT) |
|||
@PostMapping("/importData") |
|||
public AjaxResult importData(MultipartFile file, boolean updateSupport) throws Exception { |
|||
ExcelUtil<SysUser> util = new ExcelUtil<SysUser>(SysUser.class); |
|||
List<SysUser> userList = util.importExcel(file.getInputStream()); |
|||
String operName = getUsername(); |
|||
String message = userService.importUser(userList, updateSupport, operName); |
|||
return success(message); |
|||
} |
|||
|
|||
@PostMapping("/importTemplate") |
|||
public void importTemplate(HttpServletResponse response) { |
|||
ExcelUtil<SysUser> util = new ExcelUtil<SysUser>(SysUser.class); |
|||
util.importTemplateExcel(response, "用户数据"); |
|||
} |
|||
|
|||
/** |
|||
* 根据用户编号获取详细信息 |
|||
*/ |
|||
@GetMapping(value = {"/", "/{userId}"}) |
|||
public AjaxResult getInfo(@PathVariable(value = "userId", required = false) Long userId) { |
|||
userService.checkUserDataScope(userId); |
|||
AjaxResult ajax = AjaxResult.success(); |
|||
List<SysRole> roles = roleService.selectRoleAll(); |
|||
ajax.put("roles", SysUser.isAdmin(userId) ? roles : roles.stream().filter(r -> !r.isAdmin()).collect(Collectors.toList())); |
|||
ajax.put("posts", postService.selectPostAll()); |
|||
if (StringUtils.isNotNull(userId)) { |
|||
SysUser sysUser = userService.selectUserById(userId); |
|||
ajax.put(AjaxResult.DATA_TAG, sysUser); |
|||
ajax.put("postIds", postService.selectPostListByUserId(userId)); |
|||
ajax.put("roleIds", sysUser.getRoles().stream().map(SysRole::getRoleId).collect(Collectors.toList())); |
|||
} |
|||
return ajax; |
|||
} |
|||
|
|||
/** |
|||
* 新增用户 |
|||
*/ |
|||
@Log(title = "用户管理", businessType = BusinessType.INSERT) |
|||
@PostMapping |
|||
public AjaxResult add(@Validated @RequestBody SysUser user) { |
|||
if (UserConstants.NOT_UNIQUE.equals(userService.checkUserNameUnique(user))) { |
|||
return error("新增用户'" + user.getUserName() + "'失败,登录账号已存在"); |
|||
} else if (StringUtils.isNotEmpty(user.getPhonenumber()) |
|||
&& UserConstants.NOT_UNIQUE.equals(userService.checkPhoneUnique(user))) { |
|||
return error("新增用户'" + user.getUserName() + "'失败,手机号码已存在"); |
|||
} else if (StringUtils.isNotEmpty(user.getEmail()) |
|||
&& UserConstants.NOT_UNIQUE.equals(userService.checkEmailUnique(user))) { |
|||
return error("新增用户'" + user.getUserName() + "'失败,邮箱账号已存在"); |
|||
} |
|||
user.setCreateBy(getUsername()); |
|||
user.setPassword(SecurityUtils.encryptPassword(user.getPassword())); |
|||
return toAjax(userService.insertUser(user)); |
|||
} |
|||
|
|||
/** |
|||
* 修改用户 |
|||
*/ |
|||
@Log(title = "用户管理", businessType = BusinessType.UPDATE) |
|||
@PutMapping |
|||
public AjaxResult edit(@Validated @RequestBody SysUser user) { |
|||
userService.checkUserAllowed(user); |
|||
userService.checkUserDataScope(user.getUserId()); |
|||
if (UserConstants.NOT_UNIQUE.equals(userService.checkUserNameUnique(user))) { |
|||
return error("修改用户'" + user.getUserName() + "'失败,登录账号已存在"); |
|||
} else if (StringUtils.isNotEmpty(user.getPhonenumber()) |
|||
&& UserConstants.NOT_UNIQUE.equals(userService.checkPhoneUnique(user))) { |
|||
return error("修改用户'" + user.getUserName() + "'失败,手机号码已存在"); |
|||
} else if (StringUtils.isNotEmpty(user.getEmail()) |
|||
&& UserConstants.NOT_UNIQUE.equals(userService.checkEmailUnique(user))) { |
|||
return error("修改用户'" + user.getUserName() + "'失败,邮箱账号已存在"); |
|||
} |
|||
user.setUpdateBy(getUsername()); |
|||
return toAjax(userService.updateUser(user)); |
|||
} |
|||
|
|||
/** |
|||
* 删除用户 |
|||
*/ |
|||
@Log(title = "用户管理", businessType = BusinessType.DELETE) |
|||
@DeleteMapping("/{userIds}") |
|||
public AjaxResult remove(@PathVariable Long[] userIds) { |
|||
if (ArrayUtils.contains(userIds, getUserId())) { |
|||
return error("当前用户不能删除"); |
|||
} |
|||
return toAjax(userService.deleteUserByIds(userIds)); |
|||
} |
|||
|
|||
/** |
|||
* 重置密码 |
|||
*/ |
|||
@Log(title = "用户管理", businessType = BusinessType.UPDATE) |
|||
@PutMapping("/resetPwd") |
|||
public AjaxResult resetPwd(@RequestBody SysUser user) { |
|||
userService.checkUserAllowed(user); |
|||
userService.checkUserDataScope(user.getUserId()); |
|||
user.setPassword(SecurityUtils.encryptPassword(user.getPassword())); |
|||
user.setUpdateBy(getUsername()); |
|||
return toAjax(userService.resetPwd(user)); |
|||
} |
|||
|
|||
/** |
|||
* 状态修改 |
|||
*/ |
|||
@Log(title = "用户管理", businessType = BusinessType.UPDATE) |
|||
@PutMapping("/changeStatus") |
|||
public AjaxResult changeStatus(@RequestBody SysUser user) { |
|||
userService.checkUserAllowed(user); |
|||
userService.checkUserDataScope(user.getUserId()); |
|||
user.setUpdateBy(getUsername()); |
|||
return toAjax(userService.updateUserStatus(user)); |
|||
} |
|||
|
|||
/** |
|||
* 根据用户编号获取授权角色 |
|||
*/ |
|||
@GetMapping("/authRole/{userId}") |
|||
public AjaxResult authRole(@PathVariable("userId") Long userId) { |
|||
AjaxResult ajax = AjaxResult.success(); |
|||
SysUser user = userService.selectUserById(userId); |
|||
List<SysRole> roles = roleService.selectRolesByUserId(userId); |
|||
ajax.put("user", user); |
|||
ajax.put("roles", SysUser.isAdmin(userId) ? roles : roles.stream().filter(r -> !r.isAdmin()).collect(Collectors.toList())); |
|||
return ajax; |
|||
} |
|||
|
|||
/** |
|||
* 用户授权角色 |
|||
*/ |
|||
@Log(title = "用户管理", businessType = BusinessType.GRANT) |
|||
@PutMapping("/authRole") |
|||
public AjaxResult insertAuthRole(Long userId, Long[] roleIds) { |
|||
userService.checkUserDataScope(userId); |
|||
userService.insertUserAuth(userId, roleIds); |
|||
return success(); |
|||
} |
|||
|
|||
/** |
|||
* 获取部门树列表 |
|||
*/ |
|||
@GetMapping("/deptTree") |
|||
public AjaxResult deptTree(SysDept dept) { |
|||
return success(deptService.selectDeptTreeList(dept)); |
|||
} |
|||
} |
@ -0,0 +1,20 @@ |
|||
package com.win.web.controller.tool; |
|||
|
|||
import com.win.common.core.controller.BaseController; |
|||
import org.springframework.stereotype.Controller; |
|||
import org.springframework.web.bind.annotation.GetMapping; |
|||
import org.springframework.web.bind.annotation.RequestMapping; |
|||
|
|||
/** |
|||
* swagger 接口 |
|||
* |
|||
* @author win |
|||
*/ |
|||
@Controller |
|||
@RequestMapping("/tool/swagger") |
|||
public class SwaggerController extends BaseController { |
|||
@GetMapping() |
|||
public String index() { |
|||
return redirect("/doc.html"); |
|||
} |
|||
} |
@ -0,0 +1,142 @@ |
|||
package com.win.web.controller.tool; |
|||
|
|||
import com.win.common.core.controller.BaseController; |
|||
import com.win.common.core.domain.R; |
|||
import com.win.common.utils.StringUtils; |
|||
import io.swagger.annotations.*; |
|||
import org.springframework.web.bind.annotation.*; |
|||
|
|||
import java.util.ArrayList; |
|||
import java.util.LinkedHashMap; |
|||
import java.util.List; |
|||
import java.util.Map; |
|||
|
|||
/** |
|||
* swagger 用户测试方法 |
|||
* |
|||
* @author win |
|||
*/ |
|||
@Api("用户信息管理") |
|||
@RestController |
|||
@RequestMapping("/test/user") |
|||
public class TestController extends BaseController { |
|||
private final static Map<Integer, UserEntity> users = new LinkedHashMap<Integer, UserEntity>(); |
|||
|
|||
{ |
|||
users.put(1, new UserEntity(1, "admin", "admin123", "15888888888")); |
|||
users.put(2, new UserEntity(2, "ry", "admin123", "15666666666")); |
|||
} |
|||
|
|||
@GetMapping("/list") |
|||
public R<List<UserEntity>> userList() { |
|||
List<UserEntity> userList = new ArrayList<UserEntity>(users.values()); |
|||
return R.ok(userList); |
|||
} |
|||
|
|||
@ApiImplicitParam(name = "userId", value = "用户ID", required = true, dataType = "int", paramType = "path", dataTypeClass = Integer.class) |
|||
@GetMapping("/{userId}") |
|||
public R<UserEntity> getUser(@PathVariable Integer userId) { |
|||
if (!users.isEmpty() && users.containsKey(userId)) { |
|||
return R.ok(users.get(userId)); |
|||
} else { |
|||
return R.fail("用户不存在"); |
|||
} |
|||
} |
|||
|
|||
@ApiImplicitParams({ |
|||
@ApiImplicitParam(name = "userId", value = "用户id", dataType = "Integer", dataTypeClass = Integer.class), |
|||
@ApiImplicitParam(name = "username", value = "用户名称", dataType = "String", dataTypeClass = String.class), |
|||
@ApiImplicitParam(name = "password", value = "用户密码", dataType = "String", dataTypeClass = String.class), |
|||
@ApiImplicitParam(name = "mobile", value = "用户手机", dataType = "String", dataTypeClass = String.class) |
|||
}) |
|||
@PostMapping("/save") |
|||
public R<String> save(UserEntity user) { |
|||
if (StringUtils.isNull(user) || StringUtils.isNull(user.getUserId())) { |
|||
return R.fail("用户ID不能为空"); |
|||
} |
|||
users.put(user.getUserId(), user); |
|||
return R.ok(); |
|||
} |
|||
|
|||
@PutMapping("/update") |
|||
public R<String> update(@RequestBody UserEntity user) { |
|||
if (StringUtils.isNull(user) || StringUtils.isNull(user.getUserId())) { |
|||
return R.fail("用户ID不能为空"); |
|||
} |
|||
if (users.isEmpty() || !users.containsKey(user.getUserId())) { |
|||
return R.fail("用户不存在"); |
|||
} |
|||
users.remove(user.getUserId()); |
|||
users.put(user.getUserId(), user); |
|||
return R.ok(); |
|||
} |
|||
|
|||
@ApiImplicitParam(name = "userId", value = "用户ID", required = true, dataType = "int", paramType = "path", dataTypeClass = Integer.class) |
|||
@DeleteMapping("/{userId}") |
|||
public R<String> delete(@PathVariable Integer userId) { |
|||
if (!users.isEmpty() && users.containsKey(userId)) { |
|||
users.remove(userId); |
|||
return R.ok(); |
|||
} else { |
|||
return R.fail("用户不存在"); |
|||
} |
|||
} |
|||
} |
|||
|
|||
@ApiModel(value = "UserEntity", description = "用户实体") |
|||
class UserEntity { |
|||
@ApiModelProperty("用户ID") |
|||
private Integer userId; |
|||
|
|||
@ApiModelProperty("用户名称") |
|||
private String username; |
|||
|
|||
@ApiModelProperty("用户密码") |
|||
private String password; |
|||
|
|||
@ApiModelProperty("用户手机") |
|||
private String mobile; |
|||
|
|||
public UserEntity() { |
|||
|
|||
} |
|||
|
|||
public UserEntity(Integer userId, String username, String password, String mobile) { |
|||
this.userId = userId; |
|||
this.username = username; |
|||
this.password = password; |
|||
this.mobile = mobile; |
|||
} |
|||
|
|||
public Integer getUserId() { |
|||
return userId; |
|||
} |
|||
|
|||
public void setUserId(Integer userId) { |
|||
this.userId = userId; |
|||
} |
|||
|
|||
public String getUsername() { |
|||
return username; |
|||
} |
|||
|
|||
public void setUsername(String username) { |
|||
this.username = username; |
|||
} |
|||
|
|||
public String getPassword() { |
|||
return password; |
|||
} |
|||
|
|||
public void setPassword(String password) { |
|||
this.password = password; |
|||
} |
|||
|
|||
public String getMobile() { |
|||
return mobile; |
|||
} |
|||
|
|||
public void setMobile(String mobile) { |
|||
this.mobile = mobile; |
|||
} |
|||
} |
@ -0,0 +1 @@ |
|||
restart.include.json=/com.alibaba.fastjson.*.jar |
@ -0,0 +1,157 @@ |
|||
# 开发环境配置 |
|||
server: |
|||
# 服务器的HTTP端口,默认为8080 |
|||
port: 8080 |
|||
servlet: |
|||
# 应用的访问路径 |
|||
context-path: / |
|||
tomcat: |
|||
# tomcat的URI编码 |
|||
uri-encoding: UTF-8 |
|||
# 连接数满后的排队数,默认为100 |
|||
accept-count: 1000 |
|||
threads: |
|||
# tomcat最大线程数,默认为200 |
|||
max: 800 |
|||
# Tomcat启动初始化的线程数,默认值10 |
|||
min-spare: 100 |
|||
|
|||
# 日志配置 |
|||
logging: |
|||
file: |
|||
path: logs |
|||
level: |
|||
com.win: debug |
|||
org.springframework: warn |
|||
|
|||
# 用户配置 |
|||
user: |
|||
password: |
|||
# 密码最大错误次数 |
|||
maxRetryCount: 5 |
|||
# 密码锁定时间(默认10分钟) |
|||
lockTime: 10 |
|||
|
|||
# Spring配置 |
|||
spring: |
|||
shardingsphere: |
|||
mode: |
|||
type: Memory |
|||
# 属性配置 |
|||
props: |
|||
sql.show: true |
|||
## 数据源配置 |
|||
datasource: |
|||
names: master,slave0,slave1 |
|||
# 主数据源 |
|||
master: |
|||
type: com.alibaba.druid.pool.DruidDataSource |
|||
driverClassName: com.mysql.cj.jdbc.Driver |
|||
url: jdbc:mysql://dev.ccwin-in.com:23113/qad_dev?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8 |
|||
username: learun |
|||
password: Microdoft@2021 |
|||
# 读数据源 |
|||
slave0: |
|||
type: com.alibaba.druid.pool.DruidDataSource |
|||
driverClassName: com.mysql.cj.jdbc.Driver |
|||
url: jdbc:mysql://dev.ccwin-in.com:23113/qad_dev?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8 |
|||
username: learun |
|||
password: Microdoft@2021 |
|||
# 读数据源 |
|||
slave1: |
|||
type: com.alibaba.druid.pool.DruidDataSource |
|||
driverClassName: com.mysql.cj.jdbc.Driver |
|||
url: jdbc:mysql://dev.ccwin-in.com:23113/qad_dev?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8 |
|||
username: learun |
|||
password: Microdoft@2021 |
|||
# 读写分离类型,如: Static,Dynamic |
|||
rules: |
|||
readwrite-splitting: |
|||
data-sources: |
|||
myds: |
|||
type: Static |
|||
props: |
|||
write-data-source-name: master |
|||
read-data-source-names: slave0,slave1 |
|||
load-balancer-name: alg_round |
|||
load-balancers: |
|||
alg_round: |
|||
type: ROUND_ROBIN |
|||
datasource: |
|||
dynamic: |
|||
strict: true |
|||
primary: master |
|||
datasource: |
|||
master: |
|||
type: com.alibaba.druid.pool.DruidDataSource |
|||
driver-class-name: com.mysql.cj.jdbc.Driver |
|||
url: jdbc:mysql://dev.ccwin-in.com:23113/qad_dev?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8 |
|||
username: learun |
|||
password: Microdoft@2021 |
|||
# 资源信息 |
|||
messages: |
|||
# 国际化资源文件路径 |
|||
basename: i18n/messages |
|||
# 文件上传 |
|||
servlet: |
|||
multipart: |
|||
# 单个文件大小 |
|||
max-file-size: 10MB |
|||
# 设置总上传的文件大小 |
|||
max-request-size: 20MB |
|||
# 服务模块 |
|||
devtools: |
|||
restart: |
|||
# 热部署开关 |
|||
enabled: true |
|||
# 彩色日志开关 |
|||
output: |
|||
ansi: |
|||
enabled: ALWAYS |
|||
# redis 配置 |
|||
redis: |
|||
# 地址 |
|||
host: dev.ccwin-in.com |
|||
# 端口,默认为6379 |
|||
port: 23114 |
|||
# 数据库索引 |
|||
database: 0 |
|||
# 密码 |
|||
password: |
|||
# 连接超时时间 |
|||
timeout: 10s |
|||
lettuce: |
|||
pool: |
|||
# 连接池中的最小空闲连接 |
|||
min-idle: 0 |
|||
# 连接池中的最大空闲连接 |
|||
max-idle: 8 |
|||
# 连接池的最大数据库连接数 |
|||
max-active: 8 |
|||
# #连接池最大阻塞等待时间(使用负值表示没有限制) |
|||
max-wait: -1ms |
|||
|
|||
# token配置 |
|||
token: |
|||
# 令牌自定义标识 |
|||
header: Authorization |
|||
# 令牌密钥 |
|||
secret: ccwin-in.com |
|||
# 令牌有效期(12小时) |
|||
expireTime: 720 |
|||
# 是否允许账户多终端同时登录(true允许 false不允许) |
|||
soloLogin: true |
|||
|
|||
# Swagger配置 |
|||
swagger: |
|||
# 是否开启swagger |
|||
enabled: true |
|||
# 请求前缀 |
|||
pathMapping: / |
|||
|
|||
# flowable相关表 |
|||
flowable: |
|||
# true 会对数据库中所有表进行更新操作。如果表不存在,则自动创建(建议开发时使用) |
|||
database-schema-update: false |
|||
# 关闭定时任务JOB |
|||
async-executor-activate: false |
@ -0,0 +1,47 @@ |
|||
# 数据源配置 |
|||
spring: |
|||
datasource: |
|||
druid: |
|||
# 初始连接数 |
|||
initialSize: 20 |
|||
# 最小连接池数量 |
|||
minIdle: 20 |
|||
# 最大连接池数量 |
|||
maxActive: 200 |
|||
# 配置获取连接等待超时的时间 |
|||
maxWait: 60000 |
|||
# 配置间隔多久才进行一次检测,检测需要关闭的空闲连接,单位是毫秒 |
|||
timeBetweenEvictionRunsMillis: 60000 |
|||
# 配置一个连接在池中最小生存的时间,单位是毫秒 |
|||
minEvictableIdleTimeMillis: 300000 |
|||
# 配置一个连接在池中最大生存的时间,单位是毫秒 |
|||
maxEvictableIdleTimeMillis: 900000 |
|||
# 配置检测连接是否有效 |
|||
validationQuery: SELECT 1 FROM DUAL |
|||
testWhileIdle: true |
|||
testOnBorrow: false |
|||
testOnReturn: false |
|||
webStatFilter: |
|||
enabled: false |
|||
url-pattern: /* # 过滤所有url |
|||
exclusions: "*.js,*.gif,*.jpg,*.png,*.css,*.ico,/druid/*" # 排除一些不必要的url |
|||
session-stat-enable: true # 开启session统计功能 |
|||
session-stat-max-count: 1000 # session的最大个数,默认100 |
|||
statViewServlet: |
|||
enabled: true |
|||
# 设置白名单,不填则允许所有访问 |
|||
allow: |
|||
url-pattern: /druid/* |
|||
# 控制台管理用户名和密码 |
|||
login-username: win |
|||
login-password: 123456 |
|||
filter: |
|||
stat: |
|||
enabled: true |
|||
# 慢SQL记录 |
|||
log-slow-sql: true |
|||
slow-sql-millis: 1000 |
|||
merge-sql: true |
|||
wall: |
|||
config: |
|||
multi-statement-allow: true |
@ -0,0 +1,57 @@ |
|||
# MyBatis Plus配置 |
|||
mybatis-plus: |
|||
# 不支持多包, 如有需要可在注解配置 或 提升扫包等级 |
|||
# 例如 com.**.**.mapper |
|||
mapperPackage: com.win.**.mapper |
|||
# 对应的 XML 文件位置 |
|||
mapperLocations: classpath*:mapper/**/*Mapper.xml |
|||
# 实体扫描,多个package用逗号或者分号分隔 |
|||
typeAliasesPackage: com.win.**.domain |
|||
# 加载全局的配置文件 |
|||
configLocation: classpath:mybatis/mybatis-config.xml |
|||
# 启动时是否检查 MyBatis XML 文件的存在,默认不检查 |
|||
checkConfigLocation: false |
|||
configuration: |
|||
# 自动驼峰命名规则(camel case)映射 |
|||
mapUnderscoreToCamelCase: true |
|||
# MyBatis 自动映射策略 |
|||
# NONE:不启用 PARTIAL:只对非嵌套 resultMap 自动映射 FULL:对所有 resultMap 自动映射 |
|||
autoMappingBehavior: PARTIAL |
|||
# MyBatis 自动映射时未知列或未知属性处理策 |
|||
# NONE:不做处理 WARNING:打印相关警告 FAILING:抛出异常和详细信息 |
|||
autoMappingUnknownColumnBehavior: NONE |
|||
# 开启缓存 |
|||
cache-enabled: true |
|||
# 更详细的日志输出 会有性能损耗 org.apache.ibatis.logging.stdout.StdOutImpl |
|||
# 关闭日志记录 (可单纯使用 p6spy 分析) org.apache.ibatis.logging.nologging.NoLoggingImpl |
|||
# 默认日志输出 org.apache.ibatis.logging.slf4j.Slf4jImpl |
|||
logImpl: org.apache.ibatis.logging.slf4j.Slf4jImpl |
|||
global-config: |
|||
# 是否打印 Logo banner |
|||
banner: false |
|||
dbConfig: |
|||
# 主键类型 |
|||
# AUTO 自增 NONE 空 INPUT 用户输入 ASSIGN_ID 雪花 ASSIGN_UUID 唯一 UUID |
|||
id_type: AUTO |
|||
# 全局逻辑删除的实体字段名(since 3.3.0,配置后可以忽略不配置步骤2) |
|||
# logic-delete-field: flag |
|||
# 逻辑已删除值(默认为 1) |
|||
logic-delete-value: 1 |
|||
# 逻辑未删除值(默认为 0) |
|||
logic-not-delete-value: 0 |
|||
# 逻辑已删除值 |
|||
logicDeleteValue: 2 |
|||
logicNotDeleteValue: 0 |
|||
# 字段验证策略之 insert,在 insert 的时候的字段验证策略 |
|||
# IGNORED 忽略 NOT_NULL 非NULL NOT_EMPTY 非空 DEFAULT 默认 NEVER 不加入 SQL |
|||
insert_strategy: NOT_NULL |
|||
# 字段验证策略之 update,在 update 的时候的字段验证策略 |
|||
update_strategy: NOT_NULL |
|||
# 字段验证策略之 select,在 select 的时候的字段验证策略既 wrapper 根据内部 entity 生成的 where 条件 |
|||
where-strategy: NOT_NULL |
|||
|
|||
# PageHelper分页插件 |
|||
pagehelper: |
|||
helperDialect: mysql |
|||
supportMethodsArguments: true |
|||
params: count=countSql |
@ -0,0 +1,157 @@ |
|||
# 开发环境配置 |
|||
server: |
|||
# 服务器的HTTP端口,默认为8080 |
|||
port: 8080 |
|||
servlet: |
|||
# 应用的访问路径 |
|||
context-path: / |
|||
tomcat: |
|||
# tomcat的URI编码 |
|||
uri-encoding: UTF-8 |
|||
# 连接数满后的排队数,默认为100 |
|||
accept-count: 1000 |
|||
threads: |
|||
# tomcat最大线程数,默认为200 |
|||
max: 800 |
|||
# Tomcat启动初始化的线程数,默认值10 |
|||
min-spare: 100 |
|||
|
|||
# 日志配置 |
|||
logging: |
|||
file: |
|||
path: logs |
|||
level: |
|||
com.win: warn |
|||
org.springframework: warn |
|||
|
|||
# 用户配置 |
|||
user: |
|||
password: |
|||
# 密码最大错误次数 |
|||
maxRetryCount: 5 |
|||
# 密码锁定时间(默认10分钟) |
|||
lockTime: 10 |
|||
|
|||
# Spring配置 |
|||
spring: |
|||
shardingsphere: |
|||
mode: |
|||
type: Memory |
|||
# 属性配置 |
|||
props: |
|||
sql.show: true |
|||
## 数据源配置 |
|||
datasource: |
|||
names: master,slave0,slave1 |
|||
# 主数据源 |
|||
master: |
|||
type: com.alibaba.druid.pool.DruidDataSource |
|||
driverClassName: com.mysql.cj.jdbc.Driver |
|||
url: jdbc:mysql://localhost:3306/ccwin?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8 |
|||
username: ccwin |
|||
password: Microdoft@2021 |
|||
# 读数据源 |
|||
slave0: |
|||
type: com.alibaba.druid.pool.DruidDataSource |
|||
driverClassName: com.mysql.cj.jdbc.Driver |
|||
url: jdbc:mysql://localhost:3306/ccwin?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8 |
|||
username: ccwin |
|||
password: Microdoft@2021 |
|||
# 读数据源 |
|||
slave1: |
|||
type: com.alibaba.druid.pool.DruidDataSource |
|||
driverClassName: com.mysql.cj.jdbc.Driver |
|||
url: jdbc:mysql://localhost:3306/ccwin?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8 |
|||
username: ccwin |
|||
password: Microdoft@2021 |
|||
# 读写分离类型,如: Static,Dynamic |
|||
rules: |
|||
readwrite-splitting: |
|||
data-sources: |
|||
myds: |
|||
type: Static |
|||
props: |
|||
write-data-source-name: master |
|||
read-data-source-names: slave0,slave1 |
|||
load-balancer-name: alg_round |
|||
load-balancers: |
|||
alg_round: |
|||
type: ROUND_ROBIN |
|||
datasource: |
|||
dynamic: |
|||
strict: true |
|||
datasource: |
|||
ccwin: |
|||
driver-class-name: com.mysql.cj.jdbc.Driver |
|||
type: com.alibaba.druid.pool.DruidDataSource |
|||
url: jdbc:mysql://localhost:3306/ccwin?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8 |
|||
username: ccwin |
|||
password: Microdoft@2021 |
|||
primary: ccwin |
|||
# 资源信息 |
|||
messages: |
|||
# 国际化资源文件路径 |
|||
basename: i18n/messages |
|||
# 文件上传 |
|||
servlet: |
|||
multipart: |
|||
# 单个文件大小 |
|||
max-file-size: 10MB |
|||
# 设置总上传的文件大小 |
|||
max-request-size: 20MB |
|||
# 服务模块 |
|||
devtools: |
|||
restart: |
|||
# 热部署开关 |
|||
enabled: true |
|||
# 彩色日志开关 |
|||
output: |
|||
ansi: |
|||
enabled: ALWAYS |
|||
# redis 配置 |
|||
redis: |
|||
# 地址 |
|||
host: localhost |
|||
# 端口,默认为6379 |
|||
port: 6379 |
|||
# 数据库索引 |
|||
database: 1 |
|||
# 密码 |
|||
password: |
|||
# 连接超时时间 |
|||
timeout: 10s |
|||
lettuce: |
|||
pool: |
|||
# 连接池中的最小空闲连接 |
|||
min-idle: 0 |
|||
# 连接池中的最大空闲连接 |
|||
max-idle: 8 |
|||
# 连接池的最大数据库连接数 |
|||
max-active: 8 |
|||
# #连接池最大阻塞等待时间(使用负值表示没有限制) |
|||
max-wait: -1ms |
|||
|
|||
# token配置 |
|||
token: |
|||
# 令牌自定义标识 |
|||
header: Authorization |
|||
# 令牌密钥 |
|||
secret: ccwin-in.com |
|||
# 令牌有效期(12小时) |
|||
expireTime: 720 |
|||
# 是否允许账户多终端同时登录(true允许 false不允许) |
|||
soloLogin: true |
|||
|
|||
# Swagger配置 |
|||
swagger: |
|||
# 是否开启swagger |
|||
enabled: false |
|||
# 请求前缀 |
|||
pathMapping: / |
|||
|
|||
# flowable相关表 |
|||
flowable: |
|||
# true 会对数据库中所有表进行更新操作。如果表不存在,则自动创建(建议开发时使用) |
|||
database-schema-update: false |
|||
# 关闭定时任务JOB |
|||
async-executor-activate: false |
@ -0,0 +1,157 @@ |
|||
# 开发环境配置 |
|||
server: |
|||
# 服务器的HTTP端口,默认为8080 |
|||
port: 8080 |
|||
servlet: |
|||
# 应用的访问路径 |
|||
context-path: / |
|||
tomcat: |
|||
# tomcat的URI编码 |
|||
uri-encoding: UTF-8 |
|||
# 连接数满后的排队数,默认为100 |
|||
accept-count: 1000 |
|||
threads: |
|||
# tomcat最大线程数,默认为200 |
|||
max: 800 |
|||
# Tomcat启动初始化的线程数,默认值10 |
|||
min-spare: 100 |
|||
|
|||
# 日志配置 |
|||
logging: |
|||
file: |
|||
path: logs |
|||
level: |
|||
com.win: debug |
|||
org.springframework: warn |
|||
|
|||
# 用户配置 |
|||
user: |
|||
password: |
|||
# 密码最大错误次数 |
|||
maxRetryCount: 5 |
|||
# 密码锁定时间(默认10分钟) |
|||
lockTime: 10 |
|||
|
|||
# Spring配置 |
|||
spring: |
|||
shardingsphere: |
|||
mode: |
|||
type: Memory |
|||
# 属性配置 |
|||
props: |
|||
sql.show: true |
|||
## 数据源配置 |
|||
datasource: |
|||
names: master,slave0,slave1 |
|||
# 主数据源 |
|||
master: |
|||
type: com.alibaba.druid.pool.DruidDataSource |
|||
driverClassName: com.mysql.cj.jdbc.Driver |
|||
url: jdbc:mysql://dev.ccwin-in.com:23113/qad?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8 |
|||
username: learun |
|||
password: Microdoft@2021 |
|||
# 读数据源 |
|||
slave0: |
|||
type: com.alibaba.druid.pool.DruidDataSource |
|||
driverClassName: com.mysql.cj.jdbc.Driver |
|||
url: jdbc:mysql://dev.ccwin-in.com:23113/qad?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8 |
|||
username: learun |
|||
password: Microdoft@2021 |
|||
# 读数据源 |
|||
slave1: |
|||
type: com.alibaba.druid.pool.DruidDataSource |
|||
driverClassName: com.mysql.cj.jdbc.Driver |
|||
url: jdbc:mysql://dev.ccwin-in.com:23113/qad?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8 |
|||
username: learun |
|||
password: Microdoft@2021 |
|||
# 读写分离类型,如: Static,Dynamic |
|||
rules: |
|||
readwrite-splitting: |
|||
data-sources: |
|||
myds: |
|||
type: Static |
|||
props: |
|||
write-data-source-name: master |
|||
read-data-source-names: slave0,slave1 |
|||
load-balancer-name: alg_round |
|||
load-balancers: |
|||
alg_round: |
|||
type: ROUND_ROBIN |
|||
datasource: |
|||
dynamic: |
|||
strict: true |
|||
datasource: |
|||
ccwin: |
|||
driver-class-name: com.mysql.cj.jdbc.Driver |
|||
type: com.alibaba.druid.pool.DruidDataSource |
|||
url: jdbc:mysql://dev.ccwin-in.com:23113/qad?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8 |
|||
username: learun |
|||
password: Microdoft@2021 |
|||
primary: qad |
|||
# 资源信息 |
|||
messages: |
|||
# 国际化资源文件路径 |
|||
basename: i18n/messages |
|||
# 文件上传 |
|||
servlet: |
|||
multipart: |
|||
# 单个文件大小 |
|||
max-file-size: 10MB |
|||
# 设置总上传的文件大小 |
|||
max-request-size: 20MB |
|||
# 服务模块 |
|||
devtools: |
|||
restart: |
|||
# 热部署开关 |
|||
enabled: true |
|||
# 彩色日志开关 |
|||
output: |
|||
ansi: |
|||
enabled: ALWAYS |
|||
# redis 配置 |
|||
redis: |
|||
# 地址 |
|||
host: dev.ccwin-in.com |
|||
# 端口,默认为6379 |
|||
port: 23114 |
|||
# 数据库索引 |
|||
database: 1 |
|||
# 密码 |
|||
password: |
|||
# 连接超时时间 |
|||
timeout: 10s |
|||
lettuce: |
|||
pool: |
|||
# 连接池中的最小空闲连接 |
|||
min-idle: 0 |
|||
# 连接池中的最大空闲连接 |
|||
max-idle: 8 |
|||
# 连接池的最大数据库连接数 |
|||
max-active: 8 |
|||
# #连接池最大阻塞等待时间(使用负值表示没有限制) |
|||
max-wait: -1ms |
|||
|
|||
# token配置 |
|||
token: |
|||
# 令牌自定义标识 |
|||
header: Authorization |
|||
# 令牌密钥 |
|||
secret: ccwin-in.com |
|||
# 令牌有效期(12小时) |
|||
expireTime: 720 |
|||
# 是否允许账户多终端同时登录(true允许 false不允许) |
|||
soloLogin: true |
|||
|
|||
# Swagger配置 |
|||
swagger: |
|||
# 是否开启swagger |
|||
enabled: true |
|||
# 请求前缀 |
|||
pathMapping: / |
|||
|
|||
# flowable相关表 |
|||
flowable: |
|||
# true 会对数据库中所有表进行更新操作。如果表不存在,则自动创建(建议开发时使用) |
|||
database-schema-update: false |
|||
# 关闭定时任务JOB |
|||
async-executor-activate: false |
@ -0,0 +1,39 @@ |
|||
spring: |
|||
application: |
|||
name: win |
|||
profiles: |
|||
include: druid,mybatis |
|||
active: dev |
|||
main: |
|||
allow-bean-definition-overriding: true |
|||
servlet: |
|||
multipart: |
|||
enabled: true |
|||
max-file-size: 200MB |
|||
max-request-size: 1000MB |
|||
|
|||
# 项目相关配置 |
|||
win: |
|||
# 名称 |
|||
name: win-in |
|||
# 版本 |
|||
version: 3.8.5 |
|||
# 版权年份 |
|||
copyrightYear: 2023 |
|||
# 实例演示开关 |
|||
demoEnabled: true |
|||
# 文件路径 示例( Windows配置D:/win/uploadPath,Linux配置 /home/win/uploadPath) |
|||
profile: /opt/uploadPath |
|||
# 获取ip地址开关 |
|||
addressEnabled: false |
|||
# 验证码类型 math 数组计算 char 字符验证 |
|||
captchaType: math |
|||
|
|||
# 防止XSS攻击 |
|||
xss: |
|||
# 过滤开关 |
|||
enabled: true |
|||
# 排除链接(多个用逗号分隔) |
|||
excludes: /system/notice |
|||
# 匹配链接 |
|||
urlPatterns: /system/*,/monitor/*,/tool/* |
@ -0,0 +1,37 @@ |
|||
#错误消息 |
|||
not.null=* 必须填写 |
|||
user.jcaptcha.error=验证码错误 |
|||
user.jcaptcha.expire=验证码已失效 |
|||
user.not.exists=用户不存在/密码错误 |
|||
user.password.not.match=用户不存在/密码错误 |
|||
user.password.retry.limit.count=密码输入错误{0}次 |
|||
user.password.retry.limit.exceed=密码输入错误{0}次,帐户锁定{1}分钟 |
|||
user.password.delete=对不起,您的账号已被删除 |
|||
user.blocked=用户已封禁,请联系管理员 |
|||
role.blocked=角色已封禁,请联系管理员 |
|||
user.logout.success=退出成功 |
|||
|
|||
length.not.valid=长度必须在{min}到{max}个字符之间 |
|||
|
|||
user.username.not.valid=* 2到20个汉字、字母、数字或下划线组成,且必须以非数字开头 |
|||
user.password.not.valid=* 5-50个字符 |
|||
|
|||
user.email.not.valid=邮箱格式错误 |
|||
user.mobile.phone.number.not.valid=手机号格式错误 |
|||
user.login.success=登录成功 |
|||
user.register.success=注册成功 |
|||
user.notfound=请重新登录 |
|||
user.forcelogout=管理员强制退出,请重新登录 |
|||
user.unknown.error=未知错误,请重新登录 |
|||
|
|||
##文件上传消息 |
|||
upload.exceed.maxSize=上传的文件大小超出限制的文件大小!<br/>允许的文件最大大小是:{0}MB! |
|||
upload.filename.exceed.length=上传的文件名最长{0}个字符 |
|||
|
|||
##权限 |
|||
no.permission=您没有数据的权限,请联系管理员添加权限 [{0}] |
|||
no.create.permission=您没有创建数据的权限,请联系管理员添加权限 [{0}] |
|||
no.update.permission=您没有修改数据的权限,请联系管理员添加权限 [{0}] |
|||
no.delete.permission=您没有删除数据的权限,请联系管理员添加权限 [{0}] |
|||
no.export.permission=您没有导出数据的权限,请联系管理员添加权限 [{0}] |
|||
no.view.permission=您没有查看数据的权限,请联系管理员添加权限 [{0}] |
@ -0,0 +1,108 @@ |
|||
<?xml version="1.0" encoding="UTF-8"?> |
|||
<configuration> |
|||
<springProperty scope="context" name="logPath" source="logging.file.path" defaultValue="logs"/> |
|||
<!-- 日志存放路径 --> |
|||
<property name="log.path" value="${logPath}" /> |
|||
|
|||
<!--0. 日志格式和颜色渲染 --> |
|||
<!-- 彩色日志依赖的渲染类 --> |
|||
<conversionRule conversionWord="clr" converterClass="org.springframework.boot.logging.logback.ColorConverter" /> |
|||
<conversionRule conversionWord="wex" converterClass="org.springframework.boot.logging.logback.WhitespaceThrowableProxyConverter" /> |
|||
<conversionRule conversionWord="wEx" converterClass="org.springframework.boot.logging.logback.ExtendedWhitespaceThrowableProxyConverter" /> |
|||
<!-- 彩色日志格式 --> |
|||
<property name="CONSOLE_LOG_PATTERN" value="${CONSOLE_LOG_PATTERN:-%clr(%d{yyyy-MM-dd HH:mm:ss.SSS}){faint} %clr(${LOG_LEVEL_PATTERN:-%5p}) %clr(${PID:- }){magenta} %clr(---){faint} %clr([%15.15t]){faint} %clr(%-40.40logger{39}){cyan} %clr(:){faint} %m%n${LOG_EXCEPTION_CONVERSION_WORD:-%wEx}}" /> |
|||
<!-- 日志输出格式 --> |
|||
<property name="log.pattern" value="%d{HH:mm:ss.SSS} [%thread] %-5level %logger{20} - [%method,%line] - %msg%n" /> |
|||
|
|||
<!-- 控制台输出 --> |
|||
<appender name="console" class="ch.qos.logback.core.ConsoleAppender"> |
|||
<!-- 此日志appender是为开发使用,只配置最底级别,控制台输出的日志级别是大于或等于此级别的日志信息 --> |
|||
<filter class="ch.qos.logback.classic.filter.ThresholdFilter"> |
|||
<level>debug</level> |
|||
</filter> |
|||
<encoder> |
|||
<Pattern>${CONSOLE_LOG_PATTERN}</Pattern> |
|||
<!-- 设置字符集 --> |
|||
<charset>UTF-8</charset> |
|||
</encoder> |
|||
</appender> |
|||
|
|||
<!-- 系统日志输出 --> |
|||
<appender name="file_info" class="ch.qos.logback.core.rolling.RollingFileAppender"> |
|||
<file>${log.path}/sys-info.log</file> |
|||
<!-- 循环政策:基于时间创建日志文件 --> |
|||
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy"> |
|||
<!-- 日志文件名格式 --> |
|||
<fileNamePattern>${log.path}/sys-info.%d{yyyy-MM-dd}.log</fileNamePattern> |
|||
<!-- 日志最大的历史 60天 --> |
|||
<maxHistory>60</maxHistory> |
|||
</rollingPolicy> |
|||
<encoder> |
|||
<pattern>${log.pattern}</pattern> |
|||
</encoder> |
|||
<filter class="ch.qos.logback.classic.filter.LevelFilter"> |
|||
<!-- 过滤的级别 --> |
|||
<level>INFO</level> |
|||
<!-- 匹配时的操作:接收(记录) --> |
|||
<onMatch>ACCEPT</onMatch> |
|||
<!-- 不匹配时的操作:拒绝(不记录) --> |
|||
<onMismatch>DENY</onMismatch> |
|||
</filter> |
|||
</appender> |
|||
|
|||
<appender name="file_error" class="ch.qos.logback.core.rolling.RollingFileAppender"> |
|||
<file>${log.path}/sys-error.log</file> |
|||
<!-- 循环政策:基于时间创建日志文件 --> |
|||
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy"> |
|||
<!-- 日志文件名格式 --> |
|||
<fileNamePattern>${log.path}/sys-error.%d{yyyy-MM-dd}.log</fileNamePattern> |
|||
<!-- 日志最大的历史 60天 --> |
|||
<maxHistory>60</maxHistory> |
|||
</rollingPolicy> |
|||
<encoder> |
|||
<pattern>${log.pattern}</pattern> |
|||
</encoder> |
|||
<filter class="ch.qos.logback.classic.filter.LevelFilter"> |
|||
<!-- 过滤的级别 --> |
|||
<level>ERROR</level> |
|||
<!-- 匹配时的操作:接收(记录) --> |
|||
<onMatch>ACCEPT</onMatch> |
|||
<!-- 不匹配时的操作:拒绝(不记录) --> |
|||
<onMismatch>DENY</onMismatch> |
|||
</filter> |
|||
</appender> |
|||
|
|||
<!-- 用户访问日志输出 --> |
|||
<appender name="sys-user" class="ch.qos.logback.core.rolling.RollingFileAppender"> |
|||
<file>${log.path}/sys-user.log</file> |
|||
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy"> |
|||
<!-- 按天回滚 daily --> |
|||
<fileNamePattern>${log.path}/sys-user.%d{yyyy-MM-dd}.log</fileNamePattern> |
|||
<!-- 日志最大的历史 60天 --> |
|||
<maxHistory>60</maxHistory> |
|||
</rollingPolicy> |
|||
<encoder> |
|||
<pattern>${log.pattern}</pattern> |
|||
</encoder> |
|||
</appender> |
|||
|
|||
<!-- 系统模块日志级别控制 --> |
|||
<logger name="com.hc" level="info" /> |
|||
<!-- Spring日志级别控制 --> |
|||
<logger name="org.springframework" level="warn" /> |
|||
|
|||
<root level="error"> |
|||
<appender-ref ref="console" /> |
|||
</root> |
|||
|
|||
<!--系统操作日志--> |
|||
<root level="info"> |
|||
<appender-ref ref="file_info" /> |
|||
<appender-ref ref="file_error" /> |
|||
</root> |
|||
|
|||
<!--系统用户操作日志--> |
|||
<logger name="sys-user" level="info"> |
|||
<appender-ref ref="sys-user"/> |
|||
</logger> |
|||
</configuration> |
@ -0,0 +1,20 @@ |
|||
<?xml version="1.0" encoding="UTF-8" ?> |
|||
<!DOCTYPE configuration |
|||
PUBLIC "-//mybatis.org//DTD Config 3.0//EN" |
|||
"http://mybatis.org/dtd/mybatis-3-config.dtd"> |
|||
<configuration> |
|||
<!-- 全局参数 --> |
|||
<settings> |
|||
<!-- 使全局的映射器启用或禁用缓存 --> |
|||
<setting name="cacheEnabled" value="true" /> |
|||
<!-- 允许JDBC 支持自动生成主键 --> |
|||
<setting name="useGeneratedKeys" value="true" /> |
|||
<!-- 配置默认的执行器.SIMPLE就是普通执行器;REUSE执行器会重用预处理语句(prepared statements);BATCH执行器将重用语句并执行批量更新 --> |
|||
<setting name="defaultExecutorType" value="SIMPLE" /> |
|||
<!-- 指定 MyBatis 所用日志的具体实现 --> |
|||
<setting name="logImpl" value="SLF4J" /> |
|||
<!-- 使用驼峰命名法转换字段 --> |
|||
<!-- <setting name="mapUnderscoreToCamelCase" value="true"/> --> |
|||
</settings> |
|||
|
|||
</configuration> |
@ -0,0 +1,156 @@ |
|||
<?xml version="1.0" encoding="UTF-8"?> |
|||
<project xmlns="http://maven.apache.org/POM/4.0.0" |
|||
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" |
|||
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> |
|||
<parent> |
|||
<artifactId>win</artifactId> |
|||
<groupId>com.win</groupId> |
|||
<version>1.0.0</version> |
|||
</parent> |
|||
<modelVersion>4.0.0</modelVersion> |
|||
|
|||
<artifactId>win-common</artifactId> |
|||
|
|||
<description> |
|||
common通用工具 |
|||
</description> |
|||
|
|||
<dependencies> |
|||
|
|||
<!-- Spring框架基本的核心工具 --> |
|||
<dependency> |
|||
<groupId>org.springframework</groupId> |
|||
<artifactId>spring-context-support</artifactId> |
|||
</dependency> |
|||
|
|||
<!-- SpringWeb模块 --> |
|||
<dependency> |
|||
<groupId>org.springframework</groupId> |
|||
<artifactId>spring-web</artifactId> |
|||
</dependency> |
|||
|
|||
<!-- spring security 安全认证 --> |
|||
<dependency> |
|||
<groupId>org.springframework.boot</groupId> |
|||
<artifactId>spring-boot-starter-security</artifactId> |
|||
</dependency> |
|||
|
|||
<!-- pagehelper 分页插件 --> |
|||
<dependency> |
|||
<groupId>com.github.pagehelper</groupId> |
|||
<artifactId>pagehelper-spring-boot-starter</artifactId> |
|||
</dependency> |
|||
|
|||
<!-- 自定义验证注解 --> |
|||
<dependency> |
|||
<groupId>org.springframework.boot</groupId> |
|||
<artifactId>spring-boot-starter-validation</artifactId> |
|||
</dependency> |
|||
|
|||
<!--常用工具类 --> |
|||
<dependency> |
|||
<groupId>org.apache.commons</groupId> |
|||
<artifactId>commons-lang3</artifactId> |
|||
</dependency> |
|||
|
|||
<!-- JSON工具类 --> |
|||
<dependency> |
|||
<groupId>com.fasterxml.jackson.core</groupId> |
|||
<artifactId>jackson-databind</artifactId> |
|||
</dependency> |
|||
|
|||
<!-- 阿里JSON解析器 --> |
|||
<dependency> |
|||
<groupId>com.alibaba.fastjson2</groupId> |
|||
<artifactId>fastjson2</artifactId> |
|||
</dependency> |
|||
|
|||
<!-- io常用工具类 --> |
|||
<dependency> |
|||
<groupId>commons-io</groupId> |
|||
<artifactId>commons-io</artifactId> |
|||
</dependency> |
|||
|
|||
<!-- 文件上传工具类 --> |
|||
<dependency> |
|||
<groupId>commons-fileupload</groupId> |
|||
<artifactId>commons-fileupload</artifactId> |
|||
</dependency> |
|||
|
|||
<!-- excel工具 --> |
|||
<dependency> |
|||
<groupId>org.apache.poi</groupId> |
|||
<artifactId>poi-ooxml</artifactId> |
|||
</dependency> |
|||
|
|||
<!-- yml解析器 --> |
|||
<dependency> |
|||
<groupId>org.yaml</groupId> |
|||
<artifactId>snakeyaml</artifactId> |
|||
</dependency> |
|||
|
|||
<!-- Token生成与解析--> |
|||
<dependency> |
|||
<groupId>io.jsonwebtoken</groupId> |
|||
<artifactId>jjwt</artifactId> |
|||
</dependency> |
|||
|
|||
<!-- Jaxb --> |
|||
<dependency> |
|||
<groupId>javax.xml.bind</groupId> |
|||
<artifactId>jaxb-api</artifactId> |
|||
</dependency> |
|||
|
|||
<!-- redis 缓存操作 --> |
|||
<dependency> |
|||
<groupId>org.springframework.boot</groupId> |
|||
<artifactId>spring-boot-starter-data-redis</artifactId> |
|||
</dependency> |
|||
|
|||
<!-- pool 对象池 --> |
|||
<dependency> |
|||
<groupId>org.apache.commons</groupId> |
|||
<artifactId>commons-pool2</artifactId> |
|||
</dependency> |
|||
|
|||
<!-- 解析客户端操作系统、浏览器等 --> |
|||
<dependency> |
|||
<groupId>eu.bitwalker</groupId> |
|||
<artifactId>UserAgentUtils</artifactId> |
|||
</dependency> |
|||
|
|||
<!-- servlet包 --> |
|||
<dependency> |
|||
<groupId>javax.servlet</groupId> |
|||
<artifactId>javax.servlet-api</artifactId> |
|||
</dependency> |
|||
|
|||
<!-- 动态数据源 --> |
|||
<dependency> |
|||
<groupId>com.baomidou</groupId> |
|||
<artifactId>dynamic-datasource-spring-boot-starter</artifactId> |
|||
</dependency> |
|||
|
|||
<dependency> |
|||
<groupId>com.baomidou</groupId> |
|||
<artifactId>mybatis-plus-boot-starter</artifactId> |
|||
</dependency> |
|||
|
|||
<dependency> |
|||
<groupId>com.baomidou</groupId> |
|||
<artifactId>mybatis-plus-extension</artifactId> |
|||
</dependency> |
|||
|
|||
<dependency> |
|||
<groupId>org.apache.commons</groupId> |
|||
<artifactId>commons-exec</artifactId> |
|||
</dependency> |
|||
|
|||
<dependency> |
|||
<groupId>com.jcraft</groupId> |
|||
<artifactId>jsch</artifactId> |
|||
</dependency> |
|||
|
|||
</dependencies> |
|||
|
|||
</project> |
@ -0,0 +1,19 @@ |
|||
package com.win.common.annotation; |
|||
|
|||
import java.lang.annotation.Documented; |
|||
import java.lang.annotation.ElementType; |
|||
import java.lang.annotation.Retention; |
|||
import java.lang.annotation.RetentionPolicy; |
|||
import java.lang.annotation.Target; |
|||
|
|||
/** |
|||
* 匿名访问不鉴权注解 |
|||
* |
|||
* @author win |
|||
*/ |
|||
@Target({ ElementType.METHOD, ElementType.TYPE }) |
|||
@Retention(RetentionPolicy.RUNTIME) |
|||
@Documented |
|||
public @interface Anonymous |
|||
{ |
|||
} |
@ -0,0 +1,33 @@ |
|||
package com.win.common.annotation; |
|||
|
|||
import java.lang.annotation.Documented; |
|||
import java.lang.annotation.ElementType; |
|||
import java.lang.annotation.Retention; |
|||
import java.lang.annotation.RetentionPolicy; |
|||
import java.lang.annotation.Target; |
|||
|
|||
/** |
|||
* 数据权限过滤注解 |
|||
* |
|||
* @author win |
|||
*/ |
|||
@Target(ElementType.METHOD) |
|||
@Retention(RetentionPolicy.RUNTIME) |
|||
@Documented |
|||
public @interface DataScope |
|||
{ |
|||
/** |
|||
* 部门表的别名 |
|||
*/ |
|||
public String deptAlias() default ""; |
|||
|
|||
/** |
|||
* 用户表的别名 |
|||
*/ |
|||
public String userAlias() default ""; |
|||
|
|||
/** |
|||
* 权限字符(用于多个角色匹配符合要求的权限)默认根据权限注解@ss获取,多个权限用逗号分隔开来 |
|||
*/ |
|||
public String permission() default ""; |
|||
} |
@ -0,0 +1,23 @@ |
|||
package com.win.common.annotation; |
|||
|
|||
import java.lang.annotation.*; |
|||
|
|||
@Target(ElementType.METHOD) |
|||
@Retention(RetentionPolicy.RUNTIME) |
|||
@Documented |
|||
public @interface DataScopeCommon { |
|||
/** |
|||
* 部门表的别名 |
|||
*/ |
|||
public String deptAlias() default ""; |
|||
|
|||
/** |
|||
* 用户表的别名 |
|||
*/ |
|||
public String userAlias() default ""; |
|||
|
|||
/** |
|||
* 权限字符(用于多个角色匹配符合要求的权限)默认根据权限注解@ss获取,多个权限用逗号分隔开来 |
|||
*/ |
|||
public String permission() default ""; |
|||
} |
@ -0,0 +1,188 @@ |
|||
package com.win.common.annotation; |
|||
|
|||
import java.lang.annotation.ElementType; |
|||
import java.lang.annotation.Retention; |
|||
import java.lang.annotation.RetentionPolicy; |
|||
import java.lang.annotation.Target; |
|||
import java.math.BigDecimal; |
|||
|
|||
import com.win.common.utils.poi.ExcelHandlerAdapter; |
|||
import org.apache.poi.ss.usermodel.HorizontalAlignment; |
|||
import org.apache.poi.ss.usermodel.IndexedColors; |
|||
|
|||
/** |
|||
* 自定义导出Excel数据注解 |
|||
* |
|||
* @author win |
|||
*/ |
|||
@Retention(RetentionPolicy.RUNTIME) |
|||
@Target(ElementType.FIELD) |
|||
public @interface Excel |
|||
{ |
|||
/** |
|||
* 导出时在excel中排序 |
|||
*/ |
|||
public int sort() default Integer.MAX_VALUE; |
|||
|
|||
/** |
|||
* 导出到Excel中的名字. |
|||
*/ |
|||
public String name() default ""; |
|||
|
|||
/** |
|||
* 日期格式, 如: yyyy-MM-dd |
|||
*/ |
|||
public String dateFormat() default ""; |
|||
|
|||
/** |
|||
* 如果是字典类型,请设置字典的type值 (如: sys_user_sex) |
|||
*/ |
|||
public String dictType() default ""; |
|||
|
|||
/** |
|||
* 读取内容转表达式 (如: 0=男,1=女,2=未知) |
|||
*/ |
|||
public String readConverterExp() default ""; |
|||
|
|||
/** |
|||
* 分隔符,读取字符串组内容 |
|||
*/ |
|||
public String separator() default ","; |
|||
|
|||
/** |
|||
* BigDecimal 精度 默认:-1(默认不开启BigDecimal格式化) |
|||
*/ |
|||
public int scale() default -1; |
|||
|
|||
/** |
|||
* BigDecimal 舍入规则 默认:BigDecimal.ROUND_HALF_EVEN |
|||
*/ |
|||
public int roundingMode() default BigDecimal.ROUND_HALF_EVEN; |
|||
|
|||
/** |
|||
* 导出时在excel中每个列的高度 单位为字符 |
|||
*/ |
|||
public double height() default 14; |
|||
|
|||
/** |
|||
* 导出时在excel中每个列的宽 单位为字符 |
|||
*/ |
|||
public double width() default 16; |
|||
|
|||
/** |
|||
* 文字后缀,如% 90 变成90% |
|||
*/ |
|||
public String suffix() default ""; |
|||
|
|||
/** |
|||
* 当值为空时,字段的默认值 |
|||
*/ |
|||
public String defaultValue() default ""; |
|||
|
|||
/** |
|||
* 提示信息 |
|||
*/ |
|||
public String prompt() default ""; |
|||
|
|||
/** |
|||
* 设置只能选择不能输入的列内容. |
|||
*/ |
|||
public String[] combo() default {}; |
|||
|
|||
/** |
|||
* 是否需要纵向合并单元格,应对需求:含有list集合单元格) |
|||
*/ |
|||
public boolean needMerge() default false; |
|||
|
|||
/** |
|||
* 是否导出数据,应对需求:有时我们需要导出一份模板,这是标题需要但内容需要用户手工填写. |
|||
*/ |
|||
public boolean isExport() default true; |
|||
|
|||
/** |
|||
* 另一个类中的属性名称,支持多级获取,以小数点隔开 |
|||
*/ |
|||
public String targetAttr() default ""; |
|||
|
|||
/** |
|||
* 是否自动统计数据,在最后追加一行统计数据总和 |
|||
*/ |
|||
public boolean isStatistics() default false; |
|||
|
|||
/** |
|||
* 导出类型(0数字 1字符串 2图片) |
|||
*/ |
|||
public ColumnType cellType() default ColumnType.STRING; |
|||
|
|||
/** |
|||
* 导出列头背景色 |
|||
*/ |
|||
public IndexedColors headerBackgroundColor() default IndexedColors.GREY_50_PERCENT; |
|||
|
|||
/** |
|||
* 导出列头字体颜色 |
|||
*/ |
|||
public IndexedColors headerColor() default IndexedColors.WHITE; |
|||
|
|||
/** |
|||
* 导出单元格背景色 |
|||
*/ |
|||
public IndexedColors backgroundColor() default IndexedColors.WHITE; |
|||
|
|||
/** |
|||
* 导出单元格字体颜色 |
|||
*/ |
|||
public IndexedColors color() default IndexedColors.BLACK; |
|||
|
|||
/** |
|||
* 导出字段对齐方式 |
|||
*/ |
|||
public HorizontalAlignment align() default HorizontalAlignment.CENTER; |
|||
|
|||
/** |
|||
* 自定义数据处理器 |
|||
*/ |
|||
public Class<?> handler() default ExcelHandlerAdapter.class; |
|||
|
|||
/** |
|||
* 自定义数据处理器参数 |
|||
*/ |
|||
public String[] args() default {}; |
|||
|
|||
/** |
|||
* 字段类型(0:导出导入;1:仅导出;2:仅导入) |
|||
*/ |
|||
Type type() default Type.ALL; |
|||
|
|||
public enum Type |
|||
{ |
|||
ALL(0), EXPORT(1), IMPORT(2); |
|||
private final int value; |
|||
|
|||
Type(int value) |
|||
{ |
|||
this.value = value; |
|||
} |
|||
|
|||
public int value() |
|||
{ |
|||
return this.value; |
|||
} |
|||
} |
|||
|
|||
public enum ColumnType |
|||
{ |
|||
NUMERIC(0), STRING(1), IMAGE(2); |
|||
private final int value; |
|||
|
|||
ColumnType(int value) |
|||
{ |
|||
this.value = value; |
|||
} |
|||
|
|||
public int value() |
|||
{ |
|||
return this.value; |
|||
} |
|||
} |
|||
} |
@ -0,0 +1,18 @@ |
|||
package com.win.common.annotation; |
|||
|
|||
import java.lang.annotation.ElementType; |
|||
import java.lang.annotation.Retention; |
|||
import java.lang.annotation.RetentionPolicy; |
|||
import java.lang.annotation.Target; |
|||
|
|||
/** |
|||
* Excel注解集 |
|||
* |
|||
* @author win |
|||
*/ |
|||
@Target(ElementType.FIELD) |
|||
@Retention(RetentionPolicy.RUNTIME) |
|||
public @interface Excels |
|||
{ |
|||
public Excel[] value(); |
|||
} |
@ -0,0 +1,45 @@ |
|||
package com.win.common.annotation; |
|||
|
|||
import com.win.common.enums.BusinessType; |
|||
import com.win.common.enums.OperatorType; |
|||
|
|||
import java.lang.annotation.*; |
|||
|
|||
/** |
|||
* 自定义操作日志记录注解 |
|||
* |
|||
* @author win |
|||
* |
|||
*/ |
|||
@Target({ ElementType.PARAMETER, ElementType.METHOD }) |
|||
@Retention(RetentionPolicy.RUNTIME) |
|||
@Documented |
|||
public @interface Log |
|||
{ |
|||
/** |
|||
* 模块 |
|||
*/ |
|||
public String title() default ""; |
|||
|
|||
/** |
|||
* 功能 |
|||
*/ |
|||
public BusinessType businessType() default BusinessType.OTHER; |
|||
|
|||
/** |
|||
* 操作人类别 |
|||
*/ |
|||
public OperatorType operatorType() default OperatorType.MANAGE; |
|||
|
|||
/** |
|||
* 是否保存请求的参数 |
|||
*/ |
|||
public boolean isSaveRequestData() default true; |
|||
|
|||
/** |
|||
* 是否保存响应的参数 |
|||
*/ |
|||
public boolean isSaveResponseData() default true; |
|||
|
|||
public boolean isManager() default true; |
|||
} |
@ -0,0 +1,37 @@ |
|||
package com.win.common.annotation; |
|||
|
|||
import com.win.common.constant.CacheConstants; |
|||
import com.win.common.enums.LimitType; |
|||
|
|||
import java.lang.annotation.*; |
|||
|
|||
/** |
|||
* 限流注解 |
|||
* |
|||
* @author win |
|||
*/ |
|||
@Target(ElementType.METHOD) |
|||
@Retention(RetentionPolicy.RUNTIME) |
|||
@Documented |
|||
public @interface RateLimiter |
|||
{ |
|||
/** |
|||
* 限流key |
|||
*/ |
|||
public String key() default CacheConstants.RATE_LIMIT_KEY; |
|||
|
|||
/** |
|||
* 限流时间,单位秒 |
|||
*/ |
|||
public int time() default 60; |
|||
|
|||
/** |
|||
* 限流次数 |
|||
*/ |
|||
public int count() default 100; |
|||
|
|||
/** |
|||
* 限流类型 |
|||
*/ |
|||
public LimitType limitType() default LimitType.DEFAULT; |
|||
} |
@ -0,0 +1,31 @@ |
|||
package com.win.common.annotation; |
|||
|
|||
import java.lang.annotation.Documented; |
|||
import java.lang.annotation.ElementType; |
|||
import java.lang.annotation.Inherited; |
|||
import java.lang.annotation.Retention; |
|||
import java.lang.annotation.RetentionPolicy; |
|||
import java.lang.annotation.Target; |
|||
|
|||
/** |
|||
* 自定义注解防止表单重复提交 |
|||
* |
|||
* @author win |
|||
* |
|||
*/ |
|||
@Inherited |
|||
@Target(ElementType.METHOD) |
|||
@Retention(RetentionPolicy.RUNTIME) |
|||
@Documented |
|||
public @interface RepeatSubmit |
|||
{ |
|||
/** |
|||
* 间隔时间(ms),小于此时间视为重复提交 |
|||
*/ |
|||
public int interval() default 5000; |
|||
|
|||
/** |
|||
* 提示消息 |
|||
*/ |
|||
public String message() default "不允许重复提交,请稍候再试"; |
|||
} |
@ -0,0 +1,135 @@ |
|||
package com.win.common.config; |
|||
|
|||
import org.springframework.boot.context.properties.ConfigurationProperties; |
|||
import org.springframework.stereotype.Component; |
|||
|
|||
/** |
|||
* 读取项目相关配置 |
|||
* |
|||
* @author win |
|||
*/ |
|||
@Component |
|||
@ConfigurationProperties(prefix = "win") |
|||
public class WinConfig |
|||
{ |
|||
/** 项目名称 */ |
|||
private String name; |
|||
|
|||
/** 版本 */ |
|||
private String version; |
|||
|
|||
/** 版权年份 */ |
|||
private String copyrightYear; |
|||
|
|||
/** 实例演示开关 */ |
|||
private boolean demoEnabled; |
|||
|
|||
/** 上传路径 */ |
|||
private static String profile; |
|||
|
|||
/** 获取地址开关 */ |
|||
private static boolean addressEnabled; |
|||
|
|||
/** 验证码类型 */ |
|||
private static String captchaType; |
|||
|
|||
public String getName() |
|||
{ |
|||
return name; |
|||
} |
|||
|
|||
public void setName(String name) |
|||
{ |
|||
this.name = name; |
|||
} |
|||
|
|||
public String getVersion() |
|||
{ |
|||
return version; |
|||
} |
|||
|
|||
public void setVersion(String version) |
|||
{ |
|||
this.version = version; |
|||
} |
|||
|
|||
public String getCopyrightYear() |
|||
{ |
|||
return copyrightYear; |
|||
} |
|||
|
|||
public void setCopyrightYear(String copyrightYear) |
|||
{ |
|||
this.copyrightYear = copyrightYear; |
|||
} |
|||
|
|||
public boolean isDemoEnabled() |
|||
{ |
|||
return demoEnabled; |
|||
} |
|||
|
|||
public void setDemoEnabled(boolean demoEnabled) |
|||
{ |
|||
this.demoEnabled = demoEnabled; |
|||
} |
|||
|
|||
public static String getProfile() |
|||
{ |
|||
return profile; |
|||
} |
|||
|
|||
public void setProfile(String profile) |
|||
{ |
|||
WinConfig.profile = profile; |
|||
} |
|||
|
|||
public static boolean isAddressEnabled() |
|||
{ |
|||
return addressEnabled; |
|||
} |
|||
|
|||
public void setAddressEnabled(boolean addressEnabled) |
|||
{ |
|||
WinConfig.addressEnabled = addressEnabled; |
|||
} |
|||
|
|||
public static String getCaptchaType() { |
|||
return captchaType; |
|||
} |
|||
|
|||
public void setCaptchaType(String captchaType) { |
|||
WinConfig.captchaType = captchaType; |
|||
} |
|||
|
|||
/** |
|||
* 获取导入上传路径 |
|||
*/ |
|||
public static String getImportPath() |
|||
{ |
|||
return getProfile() + "/import"; |
|||
} |
|||
|
|||
/** |
|||
* 获取头像上传路径 |
|||
*/ |
|||
public static String getAvatarPath() |
|||
{ |
|||
return getProfile() + "/avatar"; |
|||
} |
|||
|
|||
/** |
|||
* 获取下载路径 |
|||
*/ |
|||
public static String getDownloadPath() |
|||
{ |
|||
return getProfile() + "/download/"; |
|||
} |
|||
|
|||
/** |
|||
* 获取上传路径 |
|||
*/ |
|||
public static String getUploadPath() |
|||
{ |
|||
return getProfile() + "/upload"; |
|||
} |
|||
} |
@ -0,0 +1,44 @@ |
|||
package com.win.common.constant; |
|||
|
|||
/** |
|||
* 缓存的key 常量 |
|||
* |
|||
* @author win |
|||
*/ |
|||
public class CacheConstants |
|||
{ |
|||
/** |
|||
* 登录用户 redis key |
|||
*/ |
|||
public static final String LOGIN_TOKEN_KEY = "login_tokens:"; |
|||
|
|||
/** |
|||
* 验证码 redis key |
|||
*/ |
|||
public static final String CAPTCHA_CODE_KEY = "captcha_codes:"; |
|||
|
|||
/** |
|||
* 参数管理 cache key |
|||
*/ |
|||
public static final String SYS_CONFIG_KEY = "sys_config:"; |
|||
|
|||
/** |
|||
* 字典管理 cache key |
|||
*/ |
|||
public static final String SYS_DICT_KEY = "sys_dict:"; |
|||
|
|||
/** |
|||
* 防重提交 redis key |
|||
*/ |
|||
public static final String REPEAT_SUBMIT_KEY = "repeat_submit:"; |
|||
|
|||
/** |
|||
* 限流 redis key |
|||
*/ |
|||
public static final String RATE_LIMIT_KEY = "rate_limit:"; |
|||
|
|||
/** |
|||
* 登录账户密码错误次数 redis key |
|||
*/ |
|||
public static final String PWD_ERR_CNT_KEY = "pwd_err_cnt:"; |
|||
} |
@ -0,0 +1,148 @@ |
|||
package com.win.common.constant; |
|||
|
|||
import io.jsonwebtoken.Claims; |
|||
|
|||
/** |
|||
* 通用常量信息 |
|||
* |
|||
* @author win |
|||
*/ |
|||
public class Constants |
|||
{ |
|||
/** |
|||
* UTF-8 字符集 |
|||
*/ |
|||
public static final String UTF8 = "UTF-8"; |
|||
|
|||
/** |
|||
* GBK 字符集 |
|||
*/ |
|||
public static final String GBK = "GBK"; |
|||
|
|||
/** |
|||
* www主域 |
|||
*/ |
|||
public static final String WWW = "www."; |
|||
|
|||
/** |
|||
* http请求 |
|||
*/ |
|||
public static final String HTTP = "http://"; |
|||
|
|||
/** |
|||
* https请求 |
|||
*/ |
|||
public static final String HTTPS = "https://"; |
|||
|
|||
/** |
|||
* 通用成功标识 |
|||
*/ |
|||
public static final String SUCCESS = "0"; |
|||
|
|||
/** |
|||
* 通用失败标识 |
|||
*/ |
|||
public static final String FAIL = "1"; |
|||
|
|||
/** |
|||
* 登录成功 |
|||
*/ |
|||
public static final String LOGIN_SUCCESS = "Success"; |
|||
|
|||
/** |
|||
* 注销 |
|||
*/ |
|||
public static final String LOGOUT = "Logout"; |
|||
|
|||
/** |
|||
* 注册 |
|||
*/ |
|||
public static final String REGISTER = "Register"; |
|||
|
|||
/** |
|||
* 登录失败 |
|||
*/ |
|||
public static final String LOGIN_FAIL = "Error"; |
|||
|
|||
/** |
|||
* 验证码有效期(分钟) |
|||
*/ |
|||
public static final Integer CAPTCHA_EXPIRATION = 2; |
|||
|
|||
/** |
|||
* 令牌 |
|||
*/ |
|||
public static final String TOKEN = "token"; |
|||
|
|||
/** |
|||
* 令牌前缀 |
|||
*/ |
|||
public static final String TOKEN_PREFIX = "Bearer "; |
|||
|
|||
/** |
|||
* 令牌前缀 |
|||
*/ |
|||
public static final String LOGIN_USER_KEY = "login_user_key"; |
|||
|
|||
/** |
|||
* 用户ID |
|||
*/ |
|||
public static final String JWT_USERID = "userid"; |
|||
|
|||
/** |
|||
* 用户名称 |
|||
*/ |
|||
public static final String JWT_USERNAME = Claims.SUBJECT; |
|||
|
|||
/** |
|||
* 用户头像 |
|||
*/ |
|||
public static final String JWT_AVATAR = "avatar"; |
|||
|
|||
/** |
|||
* 创建时间 |
|||
*/ |
|||
public static final String JWT_CREATED = "created"; |
|||
|
|||
/** |
|||
* 用户权限 |
|||
*/ |
|||
public static final String JWT_AUTHORITIES = "authorities"; |
|||
|
|||
/** |
|||
* 资源映射路径 前缀 |
|||
*/ |
|||
public static final String RESOURCE_PREFIX = "/profile"; |
|||
|
|||
/** |
|||
* RMI 远程方法调用 |
|||
*/ |
|||
public static final String LOOKUP_RMI = "rmi:"; |
|||
|
|||
/** |
|||
* LDAP 远程方法调用 |
|||
*/ |
|||
public static final String LOOKUP_LDAP = "ldap:"; |
|||
|
|||
/** |
|||
* LDAPS 远程方法调用 |
|||
*/ |
|||
public static final String LOOKUP_LDAPS = "ldaps:"; |
|||
|
|||
/** |
|||
* 定时任务白名单配置(仅允许访问的包名,如其他需要可以自行添加) |
|||
*/ |
|||
public static final String[] JOB_WHITELIST_STR = { "com.ruoyi" }; |
|||
|
|||
/** |
|||
* 定时任务违规的字符 |
|||
*/ |
|||
public static final String[] JOB_ERROR_STR = { "java.net.URL", "javax.naming.InitialContext", "org.yaml.snakeyaml", |
|||
"org.springframework", "org.apache", "com.ruoyi.common.utils.file", "com.ruoyi.common.config" }; |
|||
|
|||
/** |
|||
* 登录用户编号 redis key |
|||
*/ |
|||
public static final String LOGIN_USERID_KEY = "login_userid:"; |
|||
|
|||
} |
@ -0,0 +1,117 @@ |
|||
package com.win.common.constant; |
|||
|
|||
/** |
|||
* 代码生成通用常量 |
|||
* |
|||
* @author win |
|||
*/ |
|||
public class GenConstants |
|||
{ |
|||
/** 单表(增删改查) */ |
|||
public static final String TPL_CRUD = "crud"; |
|||
|
|||
/** 树表(增删改查) */ |
|||
public static final String TPL_TREE = "tree"; |
|||
|
|||
/** 主子表(增删改查) */ |
|||
public static final String TPL_SUB = "sub"; |
|||
|
|||
/** 树编码字段 */ |
|||
public static final String TREE_CODE = "treeCode"; |
|||
|
|||
/** 树父编码字段 */ |
|||
public static final String TREE_PARENT_CODE = "treeParentCode"; |
|||
|
|||
/** 树名称字段 */ |
|||
public static final String TREE_NAME = "treeName"; |
|||
|
|||
/** 上级菜单ID字段 */ |
|||
public static final String PARENT_MENU_ID = "parentMenuId"; |
|||
|
|||
/** 上级菜单名称字段 */ |
|||
public static final String PARENT_MENU_NAME = "parentMenuName"; |
|||
|
|||
/** 数据库字符串类型 */ |
|||
public static final String[] COLUMNTYPE_STR = { "char", "varchar", "nvarchar", "varchar2" }; |
|||
|
|||
/** 数据库文本类型 */ |
|||
public static final String[] COLUMNTYPE_TEXT = { "tinytext", "text", "mediumtext", "longtext" }; |
|||
|
|||
/** 数据库时间类型 */ |
|||
public static final String[] COLUMNTYPE_TIME = { "datetime", "time", "date", "timestamp" }; |
|||
|
|||
/** 数据库数字类型 */ |
|||
public static final String[] COLUMNTYPE_NUMBER = { "tinyint", "smallint", "mediumint", "int", "number", "integer", |
|||
"bit", "bigint", "float", "double", "decimal" }; |
|||
|
|||
/** 页面不需要编辑字段 */ |
|||
public static final String[] COLUMNNAME_NOT_EDIT = { "id", "create_by", "create_time", "del_flag" }; |
|||
|
|||
/** 页面不需要显示的列表字段 */ |
|||
public static final String[] COLUMNNAME_NOT_LIST = { "id", "create_by", "create_time", "del_flag", "update_by", |
|||
"update_time" }; |
|||
|
|||
/** 页面不需要查询字段 */ |
|||
public static final String[] COLUMNNAME_NOT_QUERY = { "id", "create_by", "create_time", "del_flag", "update_by", |
|||
"update_time", "remark" }; |
|||
|
|||
/** Entity基类字段 */ |
|||
public static final String[] BASE_ENTITY = { "createBy", "createTime", "updateBy", "updateTime", "remark" }; |
|||
|
|||
/** Tree基类字段 */ |
|||
public static final String[] TREE_ENTITY = { "parentName", "parentId", "orderNum", "ancestors", "children" }; |
|||
|
|||
/** 文本框 */ |
|||
public static final String HTML_INPUT = "input"; |
|||
|
|||
/** 文本域 */ |
|||
public static final String HTML_TEXTAREA = "textarea"; |
|||
|
|||
/** 下拉框 */ |
|||
public static final String HTML_SELECT = "select"; |
|||
|
|||
/** 单选框 */ |
|||
public static final String HTML_RADIO = "radio"; |
|||
|
|||
/** 复选框 */ |
|||
public static final String HTML_CHECKBOX = "checkbox"; |
|||
|
|||
/** 日期控件 */ |
|||
public static final String HTML_DATETIME = "datetime"; |
|||
|
|||
/** 图片上传控件 */ |
|||
public static final String HTML_IMAGE_UPLOAD = "imageUpload"; |
|||
|
|||
/** 文件上传控件 */ |
|||
public static final String HTML_FILE_UPLOAD = "fileUpload"; |
|||
|
|||
/** 富文本控件 */ |
|||
public static final String HTML_EDITOR = "editor"; |
|||
|
|||
/** 字符串类型 */ |
|||
public static final String TYPE_STRING = "String"; |
|||
|
|||
/** 整型 */ |
|||
public static final String TYPE_INTEGER = "Integer"; |
|||
|
|||
/** 长整型 */ |
|||
public static final String TYPE_LONG = "Long"; |
|||
|
|||
/** 浮点型 */ |
|||
public static final String TYPE_DOUBLE = "Double"; |
|||
|
|||
/** 高精度计算类型 */ |
|||
public static final String TYPE_BIGDECIMAL = "BigDecimal"; |
|||
|
|||
/** 时间类型 */ |
|||
public static final String TYPE_DATE = "Date"; |
|||
|
|||
/** 模糊查询 */ |
|||
public static final String QUERY_LIKE = "LIKE"; |
|||
|
|||
/** 相等查询 */ |
|||
public static final String QUERY_EQ = "EQ"; |
|||
|
|||
/** 需要 */ |
|||
public static final String REQUIRE = "1"; |
|||
} |
@ -0,0 +1,114 @@ |
|||
package com.win.common.constant; |
|||
|
|||
/** |
|||
* 返回状态码 |
|||
* |
|||
* @author win |
|||
*/ |
|||
public class HttpStatus |
|||
{ |
|||
/** |
|||
* 操作成功 |
|||
*/ |
|||
public static final int SUCCESS = 200; |
|||
|
|||
/** |
|||
* 对象创建成功 |
|||
*/ |
|||
public static final int CREATED = 201; |
|||
|
|||
/** |
|||
* 请求已经被接受 |
|||
*/ |
|||
public static final int ACCEPTED = 202; |
|||
|
|||
/** |
|||
* 操作已经执行成功,但是没有返回数据 |
|||
*/ |
|||
public static final int NO_CONTENT = 204; |
|||
|
|||
/** |
|||
* 资源已被移除 |
|||
*/ |
|||
public static final int MOVED_PERM = 301; |
|||
|
|||
/** |
|||
* 重定向 |
|||
*/ |
|||
public static final int SEE_OTHER = 303; |
|||
|
|||
/** |
|||
* 资源没有被修改 |
|||
*/ |
|||
public static final int NOT_MODIFIED = 304; |
|||
|
|||
/** |
|||
* 签名不正确 |
|||
*/ |
|||
public static final int SIGN_ERROR = 305; |
|||
|
|||
/** |
|||
* 时间戳不正确 |
|||
*/ |
|||
public static final int TIMESTAMP_ERROR = 306; |
|||
|
|||
/** |
|||
* 请求已过期 |
|||
*/ |
|||
public static final int EXPIRE_ERROR = 307; |
|||
|
|||
/** |
|||
* 参数列表错误(缺少,格式不匹配) |
|||
*/ |
|||
public static final int BAD_REQUEST = 400; |
|||
|
|||
/** |
|||
* 未授权 |
|||
*/ |
|||
public static final int UNAUTHORIZED = 401; |
|||
|
|||
/** |
|||
* 访问受限,授权过期 |
|||
*/ |
|||
public static final int FORBIDDEN = 403; |
|||
|
|||
/** |
|||
* 资源,服务未找到 |
|||
*/ |
|||
public static final int NOT_FOUND = 404; |
|||
|
|||
/** |
|||
* 不允许的http方法 |
|||
*/ |
|||
public static final int BAD_METHOD = 405; |
|||
|
|||
/** |
|||
* 资源冲突,或者资源被锁 |
|||
*/ |
|||
public static final int CONFLICT = 409; |
|||
|
|||
/** |
|||
* 不支持的数据,媒体类型 |
|||
*/ |
|||
public static final int UNSUPPORTED_TYPE = 415; |
|||
|
|||
/** |
|||
* 系统内部错误 |
|||
*/ |
|||
public static final int ERROR = 500; |
|||
|
|||
/** |
|||
* 接口未实现 |
|||
*/ |
|||
public static final int NOT_IMPLEMENTED = 501; |
|||
|
|||
/** |
|||
* 接口未实现 |
|||
*/ |
|||
public static final int EXECUTE_FAIL = 502; |
|||
|
|||
/** |
|||
* 系统警告消息 |
|||
*/ |
|||
public static final int WARN = 601; |
|||
} |
@ -0,0 +1,50 @@ |
|||
package com.win.common.constant; |
|||
|
|||
/** |
|||
* 任务调度通用常量 |
|||
* |
|||
* @author win |
|||
*/ |
|||
public class ScheduleConstants |
|||
{ |
|||
public static final String TASK_CLASS_NAME = "TASK_CLASS_NAME"; |
|||
|
|||
/** 执行目标key */ |
|||
public static final String TASK_PROPERTIES = "TASK_PROPERTIES"; |
|||
|
|||
/** 默认 */ |
|||
public static final String MISFIRE_DEFAULT = "0"; |
|||
|
|||
/** 立即触发执行 */ |
|||
public static final String MISFIRE_IGNORE_MISFIRES = "1"; |
|||
|
|||
/** 触发一次执行 */ |
|||
public static final String MISFIRE_FIRE_AND_PROCEED = "2"; |
|||
|
|||
/** 不触发立即执行 */ |
|||
public static final String MISFIRE_DO_NOTHING = "3"; |
|||
|
|||
public enum Status |
|||
{ |
|||
/** |
|||
* 正常 |
|||
*/ |
|||
NORMAL("0"), |
|||
/** |
|||
* 暂停 |
|||
*/ |
|||
PAUSE("1"); |
|||
|
|||
private String value; |
|||
|
|||
private Status(String value) |
|||
{ |
|||
this.value = value; |
|||
} |
|||
|
|||
public String getValue() |
|||
{ |
|||
return value; |
|||
} |
|||
} |
|||
} |
@ -0,0 +1,78 @@ |
|||
package com.win.common.constant; |
|||
|
|||
/** |
|||
* 用户常量信息 |
|||
* |
|||
* @author win |
|||
*/ |
|||
public class UserConstants |
|||
{ |
|||
/** |
|||
* 平台内系统用户的唯一标志 |
|||
*/ |
|||
public static final String SYS_USER = "SYS_USER"; |
|||
|
|||
/** 正常状态 */ |
|||
public static final String NORMAL = "0"; |
|||
|
|||
/** 异常状态 */ |
|||
public static final String EXCEPTION = "1"; |
|||
|
|||
/** 用户封禁状态 */ |
|||
public static final String USER_DISABLE = "1"; |
|||
|
|||
/** 角色封禁状态 */ |
|||
public static final String ROLE_DISABLE = "1"; |
|||
|
|||
/** 部门正常状态 */ |
|||
public static final String DEPT_NORMAL = "0"; |
|||
|
|||
/** 部门停用状态 */ |
|||
public static final String DEPT_DISABLE = "1"; |
|||
|
|||
/** 字典正常状态 */ |
|||
public static final String DICT_NORMAL = "0"; |
|||
|
|||
/** 是否为系统默认(是) */ |
|||
public static final String YES = "Y"; |
|||
|
|||
/** 是否菜单外链(是) */ |
|||
public static final String YES_FRAME = "0"; |
|||
|
|||
/** 是否菜单外链(否) */ |
|||
public static final String NO_FRAME = "1"; |
|||
|
|||
/** 菜单类型(目录) */ |
|||
public static final String TYPE_DIR = "M"; |
|||
|
|||
/** 菜单类型(菜单) */ |
|||
public static final String TYPE_MENU = "C"; |
|||
|
|||
/** 菜单类型(按钮) */ |
|||
public static final String TYPE_BUTTON = "F"; |
|||
|
|||
/** Layout组件标识 */ |
|||
public final static String LAYOUT = "Layout"; |
|||
|
|||
/** ParentView组件标识 */ |
|||
public final static String PARENT_VIEW = "ParentView"; |
|||
|
|||
/** InnerLink组件标识 */ |
|||
public final static String INNER_LINK = "InnerLink"; |
|||
|
|||
/** 校验返回结果码 */ |
|||
public final static String UNIQUE = "0"; |
|||
public final static String NOT_UNIQUE = "1"; |
|||
|
|||
/** |
|||
* 用户名长度限制 |
|||
*/ |
|||
public static final int USERNAME_MIN_LENGTH = 2; |
|||
public static final int USERNAME_MAX_LENGTH = 20; |
|||
|
|||
/** |
|||
* 密码长度限制 |
|||
*/ |
|||
public static final int PASSWORD_MIN_LENGTH = 5; |
|||
public static final int PASSWORD_MAX_LENGTH = 20; |
|||
} |
@ -0,0 +1,28 @@ |
|||
package com.win.common.context; |
|||
|
|||
/** |
|||
* @ClassName TableAliasHolder |
|||
* @Description TODO |
|||
* @Author longlongxiaogege |
|||
* @Date 2023/6/27 13:32 |
|||
* @Version 1.0 |
|||
*/ |
|||
public class DataScopeHolder { |
|||
|
|||
private static ThreadLocal<Object> dataScopeSql = new ThreadLocal<>(); |
|||
|
|||
public static void addDataScopeSql(Object sql){ |
|||
if(dataScopeSql.get() == null){ |
|||
dataScopeSql.set(sql); |
|||
} |
|||
} |
|||
|
|||
public static Object getDataScopeSql(){ |
|||
return dataScopeSql.get(); |
|||
} |
|||
|
|||
public static void removeDataScopeSql() { |
|||
dataScopeSql.remove(); |
|||
} |
|||
|
|||
} |
@ -0,0 +1,213 @@ |
|||
package com.win.common.core.controller; |
|||
|
|||
import com.github.pagehelper.PageHelper; |
|||
import com.github.pagehelper.PageInfo; |
|||
import com.win.common.constant.HttpStatus; |
|||
import com.win.common.context.DataScopeHolder; |
|||
import com.win.common.core.domain.AjaxResult; |
|||
import com.win.common.core.domain.model.LoginUser; |
|||
import com.win.common.core.page.PageDomain; |
|||
import com.win.common.core.page.TableDataInfo; |
|||
import com.win.common.core.page.TableSupport; |
|||
import com.win.common.utils.DateUtils; |
|||
import com.win.common.utils.PageUtils; |
|||
import com.win.common.utils.SecurityUtils; |
|||
import com.win.common.utils.StringUtils; |
|||
import com.win.common.utils.sql.SqlUtil; |
|||
import org.slf4j.Logger; |
|||
import org.slf4j.LoggerFactory; |
|||
import org.springframework.web.bind.WebDataBinder; |
|||
import org.springframework.web.bind.annotation.InitBinder; |
|||
|
|||
import java.beans.PropertyEditorSupport; |
|||
import java.util.Date; |
|||
import java.util.List; |
|||
|
|||
/** |
|||
* web层通用数据处理 |
|||
* |
|||
* @author win |
|||
*/ |
|||
public class BaseController |
|||
{ |
|||
protected final Logger logger = LoggerFactory.getLogger(this.getClass()); |
|||
|
|||
/** |
|||
* 将前台传递过来的日期格式的字符串,自动转化为Date类型 |
|||
*/ |
|||
@InitBinder |
|||
public void initBinder(WebDataBinder binder) |
|||
{ |
|||
// Date 类型转换
|
|||
binder.registerCustomEditor(Date.class, new PropertyEditorSupport() |
|||
{ |
|||
@Override |
|||
public void setAsText(String text) |
|||
{ |
|||
setValue(DateUtils.parseDate(text)); |
|||
} |
|||
}); |
|||
} |
|||
|
|||
/** |
|||
* 设置请求分页数据 |
|||
*/ |
|||
protected void startPage() |
|||
{ |
|||
PageUtils.startPage(); |
|||
} |
|||
|
|||
/** |
|||
* 设置请求排序数据 |
|||
*/ |
|||
protected void startOrderBy() |
|||
{ |
|||
PageDomain pageDomain = TableSupport.buildPageRequest(); |
|||
if (StringUtils.isNotEmpty(pageDomain.getOrderBy())) |
|||
{ |
|||
String orderBy = SqlUtil.escapeOrderBySql(pageDomain.getOrderBy()); |
|||
PageHelper.orderBy(orderBy); |
|||
} |
|||
} |
|||
|
|||
/** |
|||
* 清理分页的线程变量 |
|||
*/ |
|||
protected void clearPage() |
|||
{ |
|||
PageUtils.clearPage(); |
|||
} |
|||
|
|||
/** |
|||
* 响应请求分页数据 |
|||
*/ |
|||
@SuppressWarnings({ "rawtypes", "unchecked" }) |
|||
protected TableDataInfo getDataTable(List<?> list) |
|||
{ |
|||
TableDataInfo rspData = new TableDataInfo(); |
|||
rspData.setCode(HttpStatus.SUCCESS); |
|||
rspData.setMsg("查询成功"); |
|||
rspData.setRows(list); |
|||
rspData.setTotal(new PageInfo(list).getTotal()); |
|||
return rspData; |
|||
} |
|||
|
|||
/** |
|||
* 返回成功 |
|||
*/ |
|||
public AjaxResult success() |
|||
{ |
|||
return AjaxResult.success(); |
|||
} |
|||
|
|||
/** |
|||
* 返回失败消息 |
|||
*/ |
|||
public AjaxResult error() |
|||
{ |
|||
return AjaxResult.error(); |
|||
} |
|||
|
|||
/** |
|||
* 返回成功消息 |
|||
*/ |
|||
public AjaxResult success(String message) |
|||
{ |
|||
return AjaxResult.success(message); |
|||
} |
|||
|
|||
/** |
|||
* 返回成功消息 |
|||
*/ |
|||
public AjaxResult success(Object data) |
|||
{ |
|||
return AjaxResult.success(data); |
|||
} |
|||
|
|||
/** |
|||
* 返回失败消息 |
|||
*/ |
|||
public AjaxResult error(String message) |
|||
{ |
|||
return AjaxResult.error(message); |
|||
} |
|||
|
|||
/** |
|||
* 返回警告消息 |
|||
*/ |
|||
public AjaxResult warn(String message) |
|||
{ |
|||
return AjaxResult.warn(message); |
|||
} |
|||
|
|||
/** |
|||
* 响应返回结果 |
|||
* |
|||
* @param rows 影响行数 |
|||
* @return 操作结果 |
|||
*/ |
|||
protected AjaxResult toAjax(int rows) |
|||
{ |
|||
return rows > 0 ? AjaxResult.success() : AjaxResult.error(); |
|||
} |
|||
|
|||
/** |
|||
* 响应返回结果 |
|||
* |
|||
* @param result 结果 |
|||
* @return 操作结果 |
|||
*/ |
|||
protected AjaxResult toAjax(boolean result) |
|||
{ |
|||
return result ? success() : error(); |
|||
} |
|||
|
|||
/** |
|||
* 页面跳转 |
|||
*/ |
|||
public String redirect(String url) |
|||
{ |
|||
return StringUtils.format("redirect:{}", url); |
|||
} |
|||
|
|||
/** |
|||
* 获取用户缓存信息 |
|||
*/ |
|||
public LoginUser getLoginUser() |
|||
{ |
|||
return SecurityUtils.getLoginUser(); |
|||
} |
|||
|
|||
/** |
|||
* 获取登录用户id |
|||
*/ |
|||
public Long getUserId() |
|||
{ |
|||
return getLoginUser().getUserId(); |
|||
} |
|||
|
|||
/** |
|||
* 获取登录部门id |
|||
*/ |
|||
public Long getDeptId() |
|||
{ |
|||
return getLoginUser().getDeptId(); |
|||
} |
|||
|
|||
/** |
|||
* 获取登录用户名 |
|||
*/ |
|||
public String getUsername() |
|||
{ |
|||
return getLoginUser().getUsername(); |
|||
} |
|||
|
|||
/** |
|||
* 获取移动端unionId |
|||
* @return |
|||
*/ |
|||
public String getOpenId() { |
|||
return SecurityUtils.getOpenId(); |
|||
} |
|||
|
|||
} |
@ -0,0 +1,186 @@ |
|||
package com.win.common.core.domain; |
|||
|
|||
import com.win.common.constant.HttpStatus; |
|||
import com.win.common.utils.StringUtils; |
|||
|
|||
import java.util.HashMap; |
|||
|
|||
/** |
|||
* 操作消息提醒 |
|||
* |
|||
* @author win |
|||
*/ |
|||
public class AjaxResult extends HashMap<String, Object> |
|||
{ |
|||
private static final long serialVersionUID = 1L; |
|||
|
|||
/** 状态码 */ |
|||
public static final String CODE_TAG = "code"; |
|||
|
|||
/** 返回内容 */ |
|||
public static final String MSG_TAG = "msg"; |
|||
|
|||
/** 数据对象 */ |
|||
public static final String DATA_TAG = "data"; |
|||
|
|||
/** |
|||
* 初始化一个新创建的 AjaxResult 对象,使其表示一个空消息。 |
|||
*/ |
|||
public AjaxResult() |
|||
{ |
|||
} |
|||
|
|||
/** |
|||
* 初始化一个新创建的 AjaxResult 对象 |
|||
* |
|||
* @param code 状态码 |
|||
* @param msg 返回内容 |
|||
*/ |
|||
public AjaxResult(int code, String msg) |
|||
{ |
|||
super.put(CODE_TAG, code); |
|||
super.put(MSG_TAG, msg); |
|||
} |
|||
|
|||
/** |
|||
* 初始化一个新创建的 AjaxResult 对象 |
|||
* |
|||
* @param code 状态码 |
|||
* @param msg 返回内容 |
|||
* @param data 数据对象 |
|||
*/ |
|||
public AjaxResult(int code, String msg, Object data) |
|||
{ |
|||
super.put(CODE_TAG, code); |
|||
super.put(MSG_TAG, msg); |
|||
if (StringUtils.isNotNull(data)) |
|||
{ |
|||
super.put(DATA_TAG, data); |
|||
} |
|||
} |
|||
|
|||
/** |
|||
* 返回成功消息 |
|||
* |
|||
* @return 成功消息 |
|||
*/ |
|||
public static AjaxResult success() |
|||
{ |
|||
return AjaxResult.success("操作成功"); |
|||
} |
|||
|
|||
/** |
|||
* 返回成功数据 |
|||
* |
|||
* @return 成功消息 |
|||
*/ |
|||
public static AjaxResult success(Object data) |
|||
{ |
|||
return AjaxResult.success("操作成功", data); |
|||
} |
|||
|
|||
/** |
|||
* 返回成功消息 |
|||
* |
|||
* @param msg 返回内容 |
|||
* @return 成功消息 |
|||
*/ |
|||
public static AjaxResult success(String msg) |
|||
{ |
|||
return AjaxResult.success(msg, null); |
|||
} |
|||
|
|||
/** |
|||
* 返回成功消息 |
|||
* |
|||
* @param msg 返回内容 |
|||
* @param data 数据对象 |
|||
* @return 成功消息 |
|||
*/ |
|||
public static AjaxResult success(String msg, Object data) |
|||
{ |
|||
return new AjaxResult(HttpStatus.SUCCESS, msg, data); |
|||
} |
|||
|
|||
/** |
|||
* 返回警告消息 |
|||
* |
|||
* @param msg 返回内容 |
|||
* @return 警告消息 |
|||
*/ |
|||
public static AjaxResult warn(String msg) |
|||
{ |
|||
return AjaxResult.warn(msg, null); |
|||
} |
|||
|
|||
/** |
|||
* 返回警告消息 |
|||
* |
|||
* @param msg 返回内容 |
|||
* @param data 数据对象 |
|||
* @return 警告消息 |
|||
*/ |
|||
public static AjaxResult warn(String msg, Object data) |
|||
{ |
|||
return new AjaxResult(HttpStatus.WARN, msg, data); |
|||
} |
|||
|
|||
/** |
|||
* 返回错误消息 |
|||
* |
|||
* @return 错误消息 |
|||
*/ |
|||
public static AjaxResult error() |
|||
{ |
|||
return AjaxResult.error("操作失败"); |
|||
} |
|||
|
|||
/** |
|||
* 返回错误消息 |
|||
* |
|||
* @param msg 返回内容 |
|||
* @return 错误消息 |
|||
*/ |
|||
public static AjaxResult error(String msg) |
|||
{ |
|||
return AjaxResult.error(msg, null); |
|||
} |
|||
|
|||
/** |
|||
* 返回错误消息 |
|||
* |
|||
* @param msg 返回内容 |
|||
* @param data 数据对象 |
|||
* @return 错误消息 |
|||
*/ |
|||
public static AjaxResult error(String msg, Object data) |
|||
{ |
|||
return new AjaxResult(HttpStatus.ERROR, msg, data); |
|||
} |
|||
|
|||
/** |
|||
* 返回错误消息 |
|||
* |
|||
* @param code 状态码 |
|||
* @param msg 返回内容 |
|||
* @return 错误消息 |
|||
*/ |
|||
public static AjaxResult error(int code, String msg) |
|||
{ |
|||
return new AjaxResult(code, msg, null); |
|||
} |
|||
|
|||
/** |
|||
* 方便链式调用 |
|||
* |
|||
* @param key 键 |
|||
* @param value 值 |
|||
* @return 数据对象 |
|||
*/ |
|||
@Override |
|||
public AjaxResult put(String key, Object value) |
|||
{ |
|||
super.put(key, value); |
|||
return this; |
|||
} |
|||
} |
@ -0,0 +1,82 @@ |
|||
package com.win.common.core.domain; |
|||
|
|||
import com.baomidou.mybatisplus.annotation.*; |
|||
import com.baomidou.mybatisplus.extension.activerecord.Model; |
|||
import com.fasterxml.jackson.annotation.JsonFormat; |
|||
import com.fasterxml.jackson.annotation.JsonIgnore; |
|||
import com.win.common.annotation.Excel; |
|||
import lombok.*; |
|||
import lombok.experimental.Accessors; |
|||
import org.springframework.format.annotation.DateTimeFormat; |
|||
|
|||
import java.time.LocalDateTime; |
|||
|
|||
@Data |
|||
@Accessors(chain = true) |
|||
public abstract class BaseEntity<T extends Model<?>> extends Model<T> { |
|||
|
|||
/** |
|||
* id |
|||
*/ |
|||
@TableId(type = IdType.AUTO) |
|||
private Long id; |
|||
|
|||
/** |
|||
* 部门id |
|||
*/ |
|||
@JsonIgnore |
|||
private Long deptId; |
|||
|
|||
/** |
|||
* 部门id |
|||
*/ |
|||
@JsonIgnore |
|||
private Long userId; |
|||
|
|||
/** |
|||
* 版本号,乐观锁 |
|||
*/ |
|||
@Version |
|||
@TableField("`version`") |
|||
private Integer version; |
|||
|
|||
/** |
|||
* 创建人 |
|||
*/ |
|||
@JsonIgnore |
|||
private Long createBy; |
|||
|
|||
/** |
|||
* 创建时间 |
|||
*/ |
|||
@Excel(name = "创建时间", type = Excel.Type.EXPORT, dateFormat = "yyyy-MM-dd HH:mm:ss", sort = 100) |
|||
@JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss") |
|||
@DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss") |
|||
private LocalDateTime createTime; |
|||
|
|||
/** |
|||
* 修改人 |
|||
*/ |
|||
@JsonIgnore |
|||
private Long updateBy; |
|||
|
|||
/** |
|||
* 修改时间 |
|||
*/ |
|||
@JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss") |
|||
private LocalDateTime updateTime; |
|||
|
|||
/** |
|||
* 删除人 |
|||
*/ |
|||
@JsonIgnore |
|||
private Long deleteBy; |
|||
|
|||
/** |
|||
* 删除时间 |
|||
*/ |
|||
@JsonIgnore |
|||
@JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss") |
|||
private LocalDateTime deleteTime; |
|||
|
|||
} |
@ -0,0 +1,62 @@ |
|||
package com.win.common.core.domain; |
|||
|
|||
import com.baomidou.mybatisplus.annotation.IdType; |
|||
import com.baomidou.mybatisplus.annotation.TableId; |
|||
import lombok.Getter; |
|||
import lombok.Setter; |
|||
import lombok.experimental.Accessors; |
|||
|
|||
@Setter |
|||
@Getter |
|||
@Accessors(chain = true) |
|||
public abstract class IdEntity<T extends BaseEntity<?>> extends BaseEntity<T> { |
|||
|
|||
/** |
|||
* id |
|||
*/ |
|||
//@JsonIgnore
|
|||
@TableId(type = IdType.AUTO) |
|||
private Long id; |
|||
// public Long getId() {
|
|||
// return id;
|
|||
// }
|
|||
// public void setId(Long id) {
|
|||
// this.id = id;
|
|||
// genIdStr();
|
|||
// }
|
|||
/** |
|||
* id |
|||
*/ |
|||
// @JsonProperty("id")
|
|||
// @TableField(exist = false)
|
|||
// private String idStr;
|
|||
// public String getIdStr() {
|
|||
// return idStr;
|
|||
// }
|
|||
// public void setIdStr(String idStr) {
|
|||
// this.idStr = idStr;
|
|||
// genId();
|
|||
// }
|
|||
|
|||
/** |
|||
* 根据 id 给 _id 赋值 |
|||
*/ |
|||
// private void genIdStr() {
|
|||
// if (StringUtils.isEmpty(idStr) && null != id) {
|
|||
// idStr = IdEncodes.encode(id); //;
|
|||
// }
|
|||
// }
|
|||
|
|||
/** |
|||
* 根据_id 给 id 赋值 |
|||
*/ |
|||
// private void genId() {
|
|||
// if ((null == id || 0 == id) && StringUtils.isNotEmpty(idStr)) {
|
|||
// Long id = IdEncodes.decode(idStr);
|
|||
// if (null != id && id > 0) {
|
|||
// this.id = id;
|
|||
// }
|
|||
// }
|
|||
// }
|
|||
|
|||
} |
@ -0,0 +1,116 @@ |
|||
package com.win.common.core.domain; |
|||
|
|||
import com.win.common.constant.HttpStatus; |
|||
|
|||
import java.io.Serializable; |
|||
|
|||
/** |
|||
* 响应信息主体 |
|||
* |
|||
* @author win |
|||
*/ |
|||
public class R<T> implements Serializable |
|||
{ |
|||
private static final long serialVersionUID = 1L; |
|||
|
|||
/** 成功 */ |
|||
public static final int SUCCESS = HttpStatus.SUCCESS; |
|||
|
|||
/** 失败 */ |
|||
public static final int FAIL = HttpStatus.ERROR; |
|||
|
|||
private int code; |
|||
|
|||
private String msg; |
|||
|
|||
private T data; |
|||
|
|||
public static <T> R<T> ok() |
|||
{ |
|||
return restResult(null, SUCCESS, "操作成功"); |
|||
} |
|||
|
|||
public static <T> R<T> ok(T data) |
|||
{ |
|||
return restResult(data, SUCCESS, "操作成功"); |
|||
} |
|||
|
|||
public static <T> R<T> ok(T data, String msg) |
|||
{ |
|||
return restResult(data, SUCCESS, msg); |
|||
} |
|||
|
|||
public static <T> R<T> fail() |
|||
{ |
|||
return restResult(null, FAIL, "操作失败"); |
|||
} |
|||
|
|||
public static <T> R<T> fail(String msg) |
|||
{ |
|||
return restResult(null, FAIL, msg); |
|||
} |
|||
|
|||
public static <T> R<T> fail(T data) |
|||
{ |
|||
return restResult(data, FAIL, "操作失败"); |
|||
} |
|||
|
|||
public static <T> R<T> fail(T data, String msg) |
|||
{ |
|||
return restResult(data, FAIL, msg); |
|||
} |
|||
|
|||
public static <T> R<T> fail(int code, String msg) |
|||
{ |
|||
return restResult(null, code, msg); |
|||
} |
|||
|
|||
private static <T> R<T> restResult(T data, int code, String msg) |
|||
{ |
|||
R<T> apiResult = new R<>(); |
|||
apiResult.setCode(code); |
|||
apiResult.setData(data); |
|||
apiResult.setMsg(msg); |
|||
return apiResult; |
|||
} |
|||
|
|||
public int getCode() |
|||
{ |
|||
return code; |
|||
} |
|||
|
|||
public void setCode(int code) |
|||
{ |
|||
this.code = code; |
|||
} |
|||
|
|||
public String getMsg() |
|||
{ |
|||
return msg; |
|||
} |
|||
|
|||
public void setMsg(String msg) |
|||
{ |
|||
this.msg = msg; |
|||
} |
|||
|
|||
public T getData() |
|||
{ |
|||
return data; |
|||
} |
|||
|
|||
public void setData(T data) |
|||
{ |
|||
this.data = data; |
|||
} |
|||
|
|||
public static <T> Boolean isError(R<T> ret) |
|||
{ |
|||
return !isSuccess(ret); |
|||
} |
|||
|
|||
public static <T> Boolean isSuccess(R<T> ret) |
|||
{ |
|||
return R.SUCCESS == ret.getCode(); |
|||
} |
|||
} |
@ -0,0 +1,79 @@ |
|||
package com.win.common.core.domain; |
|||
|
|||
import java.util.ArrayList; |
|||
import java.util.List; |
|||
|
|||
/** |
|||
* Tree基类 |
|||
* |
|||
* @author win |
|||
*/ |
|||
public class TreeEntity extends WinBaseEntity |
|||
{ |
|||
private static final long serialVersionUID = 1L; |
|||
|
|||
/** 父菜单名称 */ |
|||
private String parentName; |
|||
|
|||
/** 父菜单ID */ |
|||
private Long parentId; |
|||
|
|||
/** 显示顺序 */ |
|||
private Integer orderNum; |
|||
|
|||
/** 祖级列表 */ |
|||
private String ancestors; |
|||
|
|||
/** 子部门 */ |
|||
private List<?> children = new ArrayList<>(); |
|||
|
|||
public String getParentName() |
|||
{ |
|||
return parentName; |
|||
} |
|||
|
|||
public void setParentName(String parentName) |
|||
{ |
|||
this.parentName = parentName; |
|||
} |
|||
|
|||
public Long getParentId() |
|||
{ |
|||
return parentId; |
|||
} |
|||
|
|||
public void setParentId(Long parentId) |
|||
{ |
|||
this.parentId = parentId; |
|||
} |
|||
|
|||
public Integer getOrderNum() |
|||
{ |
|||
return orderNum; |
|||
} |
|||
|
|||
public void setOrderNum(Integer orderNum) |
|||
{ |
|||
this.orderNum = orderNum; |
|||
} |
|||
|
|||
public String getAncestors() |
|||
{ |
|||
return ancestors; |
|||
} |
|||
|
|||
public void setAncestors(String ancestors) |
|||
{ |
|||
this.ancestors = ancestors; |
|||
} |
|||
|
|||
public List<?> getChildren() |
|||
{ |
|||
return children; |
|||
} |
|||
|
|||
public void setChildren(List<?> children) |
|||
{ |
|||
this.children = children; |
|||
} |
|||
} |
@ -0,0 +1,78 @@ |
|||
package com.win.common.core.domain; |
|||
|
|||
import com.fasterxml.jackson.annotation.JsonInclude; |
|||
import com.win.common.core.domain.entity.SysDept; |
|||
import com.win.common.core.domain.entity.SysMenu; |
|||
|
|||
import java.io.Serializable; |
|||
import java.util.List; |
|||
import java.util.stream.Collectors; |
|||
|
|||
/** |
|||
* Treeselect树结构实体类 |
|||
* |
|||
* @author win |
|||
*/ |
|||
public class TreeSelect implements Serializable |
|||
{ |
|||
private static final long serialVersionUID = 1L; |
|||
|
|||
/** 节点ID */ |
|||
private Long id; |
|||
|
|||
/** 节点名称 */ |
|||
private String label; |
|||
|
|||
/** 子节点 */ |
|||
@JsonInclude(JsonInclude.Include.NON_EMPTY) |
|||
private List<TreeSelect> children; |
|||
|
|||
public TreeSelect() |
|||
{ |
|||
|
|||
} |
|||
|
|||
public TreeSelect(SysDept dept) |
|||
{ |
|||
this.id = dept.getDeptId(); |
|||
this.label = dept.getDeptName(); |
|||
this.children = dept.getChildren().stream().map(TreeSelect::new).collect(Collectors.toList()); |
|||
} |
|||
|
|||
public TreeSelect(SysMenu menu) |
|||
{ |
|||
this.id = menu.getMenuId(); |
|||
this.label = menu.getMenuName(); |
|||
this.children = menu.getChildren().stream().map(TreeSelect::new).collect(Collectors.toList()); |
|||
} |
|||
|
|||
public Long getId() |
|||
{ |
|||
return id; |
|||
} |
|||
|
|||
public void setId(Long id) |
|||
{ |
|||
this.id = id; |
|||
} |
|||
|
|||
public String getLabel() |
|||
{ |
|||
return label; |
|||
} |
|||
|
|||
public void setLabel(String label) |
|||
{ |
|||
this.label = label; |
|||
} |
|||
|
|||
public List<TreeSelect> getChildren() |
|||
{ |
|||
return children; |
|||
} |
|||
|
|||
public void setChildren(List<TreeSelect> children) |
|||
{ |
|||
this.children = children; |
|||
} |
|||
} |
@ -0,0 +1,119 @@ |
|||
package com.win.common.core.domain; |
|||
|
|||
import com.fasterxml.jackson.annotation.JsonFormat; |
|||
import com.fasterxml.jackson.annotation.JsonIgnore; |
|||
import com.fasterxml.jackson.annotation.JsonInclude; |
|||
|
|||
import java.io.Serializable; |
|||
import java.util.Date; |
|||
import java.util.HashMap; |
|||
import java.util.Map; |
|||
|
|||
/** |
|||
* Entity基类 |
|||
* |
|||
* @author win |
|||
*/ |
|||
public class WinBaseEntity implements Serializable |
|||
{ |
|||
private static final long serialVersionUID = 1L; |
|||
|
|||
/** 搜索值 */ |
|||
@JsonIgnore |
|||
private String searchValue; |
|||
|
|||
/** 创建者 */ |
|||
private String createBy; |
|||
|
|||
/** 创建时间 */ |
|||
@JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss") |
|||
private Date createTime; |
|||
|
|||
/** 更新者 */ |
|||
private String updateBy; |
|||
|
|||
/** 更新时间 */ |
|||
@JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss") |
|||
private Date updateTime; |
|||
|
|||
/** 备注 */ |
|||
private String remark; |
|||
|
|||
/** 请求参数 */ |
|||
@JsonInclude(JsonInclude.Include.NON_EMPTY) |
|||
private Map<String, Object> params; |
|||
|
|||
public String getSearchValue() |
|||
{ |
|||
return searchValue; |
|||
} |
|||
|
|||
public void setSearchValue(String searchValue) |
|||
{ |
|||
this.searchValue = searchValue; |
|||
} |
|||
|
|||
public String getCreateBy() |
|||
{ |
|||
return createBy; |
|||
} |
|||
|
|||
public void setCreateBy(String createBy) |
|||
{ |
|||
this.createBy = createBy; |
|||
} |
|||
|
|||
public Date getCreateTime() |
|||
{ |
|||
return createTime; |
|||
} |
|||
|
|||
public void setCreateTime(Date createTime) |
|||
{ |
|||
this.createTime = createTime; |
|||
} |
|||
|
|||
public String getUpdateBy() |
|||
{ |
|||
return updateBy; |
|||
} |
|||
|
|||
public void setUpdateBy(String updateBy) |
|||
{ |
|||
this.updateBy = updateBy; |
|||
} |
|||
|
|||
public Date getUpdateTime() |
|||
{ |
|||
return updateTime; |
|||
} |
|||
|
|||
public void setUpdateTime(Date updateTime) |
|||
{ |
|||
this.updateTime = updateTime; |
|||
} |
|||
|
|||
public String getRemark() |
|||
{ |
|||
return remark; |
|||
} |
|||
|
|||
public void setRemark(String remark) |
|||
{ |
|||
this.remark = remark; |
|||
} |
|||
|
|||
public Map<String, Object> getParams() |
|||
{ |
|||
if (params == null) |
|||
{ |
|||
params = new HashMap<>(); |
|||
} |
|||
return params; |
|||
} |
|||
|
|||
public void setParams(Map<String, Object> params) |
|||
{ |
|||
this.params = params; |
|||
} |
|||
} |
@ -0,0 +1,207 @@ |
|||
package com.win.common.core.domain.entity; |
|||
|
|||
import com.baomidou.mybatisplus.annotation.IdType; |
|||
import com.baomidou.mybatisplus.annotation.TableId; |
|||
import com.win.common.core.domain.WinBaseEntity; |
|||
import org.apache.commons.lang3.builder.ToStringBuilder; |
|||
import org.apache.commons.lang3.builder.ToStringStyle; |
|||
|
|||
import javax.validation.constraints.Email; |
|||
import javax.validation.constraints.NotBlank; |
|||
import javax.validation.constraints.NotNull; |
|||
import javax.validation.constraints.Size; |
|||
import java.util.ArrayList; |
|||
import java.util.List; |
|||
|
|||
/** |
|||
* 部门表 sys_dept |
|||
* |
|||
* @author win |
|||
*/ |
|||
public class SysDept extends WinBaseEntity |
|||
{ |
|||
private static final long serialVersionUID = 1L; |
|||
|
|||
/** 部门ID */ |
|||
@TableId(type = IdType.AUTO) |
|||
private Long deptId; |
|||
|
|||
/** 父部门ID */ |
|||
private Long parentId; |
|||
|
|||
/** 祖级列表 */ |
|||
private String ancestors; |
|||
|
|||
/** 部门名称 */ |
|||
private String deptName; |
|||
|
|||
/** 显示顺序 */ |
|||
private Integer orderNum; |
|||
|
|||
/** 负责人 */ |
|||
private String leader; |
|||
|
|||
/** 联系电话 */ |
|||
private String phone; |
|||
|
|||
/** 邮箱 */ |
|||
private String email; |
|||
|
|||
/** 部门状态:0正常,1停用 */ |
|||
private String status; |
|||
|
|||
/** 删除标志(0代表存在 2代表删除) */ |
|||
private String delFlag; |
|||
|
|||
/** 父部门名称 */ |
|||
private String parentName; |
|||
|
|||
/** 子部门 */ |
|||
private List<SysDept> children = new ArrayList<SysDept>(); |
|||
|
|||
public Long getDeptId() |
|||
{ |
|||
return deptId; |
|||
} |
|||
|
|||
public void setDeptId(Long deptId) |
|||
{ |
|||
this.deptId = deptId; |
|||
} |
|||
|
|||
public Long getParentId() |
|||
{ |
|||
return parentId; |
|||
} |
|||
|
|||
public void setParentId(Long parentId) |
|||
{ |
|||
this.parentId = parentId; |
|||
} |
|||
|
|||
public String getAncestors() |
|||
{ |
|||
return ancestors; |
|||
} |
|||
|
|||
public void setAncestors(String ancestors) |
|||
{ |
|||
this.ancestors = ancestors; |
|||
} |
|||
|
|||
@NotBlank(message = "部门名称不能为空") |
|||
@Size(min = 0, max = 30, message = "部门名称长度不能超过30个字符") |
|||
public String getDeptName() |
|||
{ |
|||
return deptName; |
|||
} |
|||
|
|||
public void setDeptName(String deptName) |
|||
{ |
|||
this.deptName = deptName; |
|||
} |
|||
|
|||
@NotNull(message = "显示顺序不能为空") |
|||
public Integer getOrderNum() |
|||
{ |
|||
return orderNum; |
|||
} |
|||
|
|||
public void setOrderNum(Integer orderNum) |
|||
{ |
|||
this.orderNum = orderNum; |
|||
} |
|||
|
|||
public String getLeader() |
|||
{ |
|||
return leader; |
|||
} |
|||
|
|||
public void setLeader(String leader) |
|||
{ |
|||
this.leader = leader; |
|||
} |
|||
|
|||
@Size(min = 0, max = 11, message = "联系电话长度不能超过11个字符") |
|||
public String getPhone() |
|||
{ |
|||
return phone; |
|||
} |
|||
|
|||
public void setPhone(String phone) |
|||
{ |
|||
this.phone = phone; |
|||
} |
|||
|
|||
@Email(message = "邮箱格式不正确") |
|||
@Size(min = 0, max = 50, message = "邮箱长度不能超过50个字符") |
|||
public String getEmail() |
|||
{ |
|||
return email; |
|||
} |
|||
|
|||
public void setEmail(String email) |
|||
{ |
|||
this.email = email; |
|||
} |
|||
|
|||
public String getStatus() |
|||
{ |
|||
return status; |
|||
} |
|||
|
|||
public void setStatus(String status) |
|||
{ |
|||
this.status = status; |
|||
} |
|||
|
|||
public String getDelFlag() |
|||
{ |
|||
return delFlag; |
|||
} |
|||
|
|||
public void setDelFlag(String delFlag) |
|||
{ |
|||
this.delFlag = delFlag; |
|||
} |
|||
|
|||
public String getParentName() |
|||
{ |
|||
return parentName; |
|||
} |
|||
|
|||
public void setParentName(String parentName) |
|||
{ |
|||
this.parentName = parentName; |
|||
} |
|||
|
|||
public List<SysDept> getChildren() |
|||
{ |
|||
return children; |
|||
} |
|||
|
|||
public void setChildren(List<SysDept> children) |
|||
{ |
|||
this.children = children; |
|||
} |
|||
|
|||
@Override |
|||
public String toString() { |
|||
return new ToStringBuilder(this,ToStringStyle.MULTI_LINE_STYLE) |
|||
.append("deptId", getDeptId()) |
|||
.append("parentId", getParentId()) |
|||
.append("ancestors", getAncestors()) |
|||
.append("deptName", getDeptName()) |
|||
.append("orderNum", getOrderNum()) |
|||
.append("leader", getLeader()) |
|||
.append("phone", getPhone()) |
|||
.append("email", getEmail()) |
|||
.append("status", getStatus()) |
|||
.append("delFlag", getDelFlag()) |
|||
.append("createBy", getCreateBy()) |
|||
.append("createTime", getCreateTime()) |
|||
.append("updateBy", getUpdateBy()) |
|||
.append("updateTime", getUpdateTime()) |
|||
.toString(); |
|||
} |
|||
} |
@ -0,0 +1,179 @@ |
|||
package com.win.common.core.domain.entity; |
|||
|
|||
import com.baomidou.mybatisplus.annotation.IdType; |
|||
import com.baomidou.mybatisplus.annotation.TableId; |
|||
import com.win.common.annotation.Excel; |
|||
import com.win.common.constant.UserConstants; |
|||
import com.win.common.core.domain.WinBaseEntity; |
|||
import org.apache.commons.lang3.builder.ToStringBuilder; |
|||
import org.apache.commons.lang3.builder.ToStringStyle; |
|||
|
|||
import javax.validation.constraints.NotBlank; |
|||
import javax.validation.constraints.Size; |
|||
|
|||
/** |
|||
* 字典数据表 sys_dict_data |
|||
* |
|||
* @author win |
|||
*/ |
|||
public class SysDictData extends WinBaseEntity |
|||
{ |
|||
private static final long serialVersionUID = 1L; |
|||
|
|||
/** 字典编码 */ |
|||
@Excel(name = "字典编码", cellType = Excel.ColumnType.NUMERIC) |
|||
@TableId(type = IdType.AUTO) |
|||
private Long dictCode; |
|||
|
|||
/** 字典排序 */ |
|||
@Excel(name = "字典排序", cellType = Excel.ColumnType.NUMERIC) |
|||
private Long dictSort; |
|||
|
|||
/** 字典标签 */ |
|||
@Excel(name = "字典标签") |
|||
private String dictLabel; |
|||
|
|||
/** 字典键值 */ |
|||
@Excel(name = "字典键值") |
|||
private String dictValue; |
|||
|
|||
/** 字典类型 */ |
|||
@Excel(name = "字典类型") |
|||
private String dictType; |
|||
|
|||
/** 样式属性(其他样式扩展) */ |
|||
private String cssClass; |
|||
|
|||
/** 表格字典样式 */ |
|||
private String listClass; |
|||
|
|||
/** 是否默认(Y是 N否) */ |
|||
@Excel(name = "是否默认", readConverterExp = "Y=是,N=否") |
|||
private String isDefault; |
|||
|
|||
/** 状态(0正常 1停用) */ |
|||
@Excel(name = "状态", readConverterExp = "0=正常,1=停用") |
|||
private String status; |
|||
|
|||
public Long getDictCode() |
|||
{ |
|||
return dictCode; |
|||
} |
|||
|
|||
public void setDictCode(Long dictCode) |
|||
{ |
|||
this.dictCode = dictCode; |
|||
} |
|||
|
|||
public Long getDictSort() |
|||
{ |
|||
return dictSort; |
|||
} |
|||
|
|||
public void setDictSort(Long dictSort) |
|||
{ |
|||
this.dictSort = dictSort; |
|||
} |
|||
|
|||
@NotBlank(message = "字典标签不能为空") |
|||
@Size(min = 0, max = 100, message = "字典标签长度不能超过100个字符") |
|||
public String getDictLabel() |
|||
{ |
|||
return dictLabel; |
|||
} |
|||
|
|||
public void setDictLabel(String dictLabel) |
|||
{ |
|||
this.dictLabel = dictLabel; |
|||
} |
|||
|
|||
@NotBlank(message = "字典键值不能为空") |
|||
@Size(min = 0, max = 100, message = "字典键值长度不能超过100个字符") |
|||
public String getDictValue() |
|||
{ |
|||
return dictValue; |
|||
} |
|||
|
|||
public void setDictValue(String dictValue) |
|||
{ |
|||
this.dictValue = dictValue; |
|||
} |
|||
|
|||
@NotBlank(message = "字典类型不能为空") |
|||
@Size(min = 0, max = 100, message = "字典类型长度不能超过100个字符") |
|||
public String getDictType() |
|||
{ |
|||
return dictType; |
|||
} |
|||
|
|||
public void setDictType(String dictType) |
|||
{ |
|||
this.dictType = dictType; |
|||
} |
|||
|
|||
@Size(min = 0, max = 100, message = "样式属性长度不能超过100个字符") |
|||
public String getCssClass() |
|||
{ |
|||
return cssClass; |
|||
} |
|||
|
|||
public void setCssClass(String cssClass) |
|||
{ |
|||
this.cssClass = cssClass; |
|||
} |
|||
|
|||
public String getListClass() |
|||
{ |
|||
return listClass; |
|||
} |
|||
|
|||
public void setListClass(String listClass) |
|||
{ |
|||
this.listClass = listClass; |
|||
} |
|||
|
|||
public boolean getDefault() |
|||
{ |
|||
return UserConstants.YES.equals(this.isDefault); |
|||
} |
|||
|
|||
public String getIsDefault() |
|||
{ |
|||
return isDefault; |
|||
} |
|||
|
|||
public void setIsDefault(String isDefault) |
|||
{ |
|||
this.isDefault = isDefault; |
|||
} |
|||
|
|||
public String getStatus() |
|||
{ |
|||
return status; |
|||
} |
|||
|
|||
public void setStatus(String status) |
|||
{ |
|||
this.status = status; |
|||
} |
|||
|
|||
@Override |
|||
public String toString() { |
|||
return new ToStringBuilder(this,ToStringStyle.MULTI_LINE_STYLE) |
|||
.append("dictCode", getDictCode()) |
|||
.append("dictSort", getDictSort()) |
|||
.append("dictLabel", getDictLabel()) |
|||
.append("dictValue", getDictValue()) |
|||
.append("dictType", getDictType()) |
|||
.append("cssClass", getCssClass()) |
|||
.append("listClass", getListClass()) |
|||
.append("isDefault", getIsDefault()) |
|||
.append("status", getStatus()) |
|||
.append("createBy", getCreateBy()) |
|||
.append("createTime", getCreateTime()) |
|||
.append("updateBy", getUpdateBy()) |
|||
.append("updateTime", getUpdateTime()) |
|||
.append("remark", getRemark()) |
|||
.toString(); |
|||
} |
|||
} |
@ -0,0 +1,99 @@ |
|||
package com.win.common.core.domain.entity; |
|||
|
|||
import com.baomidou.mybatisplus.annotation.IdType; |
|||
import com.baomidou.mybatisplus.annotation.TableId; |
|||
import com.win.common.annotation.Excel; |
|||
import com.win.common.core.domain.WinBaseEntity; |
|||
import org.apache.commons.lang3.builder.ToStringBuilder; |
|||
import org.apache.commons.lang3.builder.ToStringStyle; |
|||
|
|||
import javax.validation.constraints.NotBlank; |
|||
import javax.validation.constraints.Pattern; |
|||
import javax.validation.constraints.Size; |
|||
|
|||
/** |
|||
* 字典类型表 sys_dict_type |
|||
* |
|||
* @author win |
|||
*/ |
|||
public class SysDictType extends WinBaseEntity |
|||
{ |
|||
private static final long serialVersionUID = 1L; |
|||
|
|||
/** 字典主键 */ |
|||
@Excel(name = "字典主键", cellType = Excel.ColumnType.NUMERIC) |
|||
@TableId(type = IdType.AUTO) |
|||
private Long dictId; |
|||
|
|||
/** 字典名称 */ |
|||
@Excel(name = "字典名称") |
|||
private String dictName; |
|||
|
|||
/** 字典类型 */ |
|||
@Excel(name = "字典类型") |
|||
private String dictType; |
|||
|
|||
/** 状态(0正常 1停用) */ |
|||
@Excel(name = "状态", readConverterExp = "0=正常,1=停用") |
|||
private String status; |
|||
|
|||
public Long getDictId() |
|||
{ |
|||
return dictId; |
|||
} |
|||
|
|||
public void setDictId(Long dictId) |
|||
{ |
|||
this.dictId = dictId; |
|||
} |
|||
|
|||
@NotBlank(message = "字典名称不能为空") |
|||
@Size(min = 0, max = 100, message = "字典类型名称长度不能超过100个字符") |
|||
public String getDictName() |
|||
{ |
|||
return dictName; |
|||
} |
|||
|
|||
public void setDictName(String dictName) |
|||
{ |
|||
this.dictName = dictName; |
|||
} |
|||
|
|||
@NotBlank(message = "字典类型不能为空") |
|||
@Size(min = 0, max = 100, message = "字典类型类型长度不能超过100个字符") |
|||
@Pattern(regexp = "^[a-z][a-z0-9_]*$", message = "字典类型必须以字母开头,且只能为(小写字母,数字,下滑线)") |
|||
public String getDictType() |
|||
{ |
|||
return dictType; |
|||
} |
|||
|
|||
public void setDictType(String dictType) |
|||
{ |
|||
this.dictType = dictType; |
|||
} |
|||
|
|||
public String getStatus() |
|||
{ |
|||
return status; |
|||
} |
|||
|
|||
public void setStatus(String status) |
|||
{ |
|||
this.status = status; |
|||
} |
|||
|
|||
@Override |
|||
public String toString() { |
|||
return new ToStringBuilder(this,ToStringStyle.MULTI_LINE_STYLE) |
|||
.append("dictId", getDictId()) |
|||
.append("dictName", getDictName()) |
|||
.append("dictType", getDictType()) |
|||
.append("status", getStatus()) |
|||
.append("createBy", getCreateBy()) |
|||
.append("createTime", getCreateTime()) |
|||
.append("updateBy", getUpdateBy()) |
|||
.append("updateTime", getUpdateTime()) |
|||
.append("remark", getRemark()) |
|||
.toString(); |
|||
} |
|||
} |
@ -0,0 +1,263 @@ |
|||
package com.win.common.core.domain.entity; |
|||
|
|||
import com.baomidou.mybatisplus.annotation.IdType; |
|||
import com.baomidou.mybatisplus.annotation.TableId; |
|||
import com.win.common.core.domain.WinBaseEntity; |
|||
import org.apache.commons.lang3.builder.ToStringBuilder; |
|||
import org.apache.commons.lang3.builder.ToStringStyle; |
|||
|
|||
import javax.validation.constraints.NotBlank; |
|||
import javax.validation.constraints.NotNull; |
|||
import javax.validation.constraints.Size; |
|||
import java.util.ArrayList; |
|||
import java.util.List; |
|||
|
|||
/** |
|||
* 菜单权限表 sys_menu |
|||
* |
|||
* @author win |
|||
*/ |
|||
public class SysMenu extends WinBaseEntity |
|||
{ |
|||
private static final long serialVersionUID = 1L; |
|||
|
|||
/** 菜单ID */ |
|||
@TableId(type = IdType.AUTO) |
|||
private Long menuId; |
|||
|
|||
/** 菜单名称 */ |
|||
private String menuName; |
|||
|
|||
/** 父菜单名称 */ |
|||
private String parentName; |
|||
|
|||
/** 父菜单ID */ |
|||
private Long parentId; |
|||
|
|||
/** 显示顺序 */ |
|||
private Integer orderNum; |
|||
|
|||
/** 路由地址 */ |
|||
private String path; |
|||
|
|||
/** 组件路径 */ |
|||
private String component; |
|||
|
|||
/** 路由参数 */ |
|||
private String query; |
|||
|
|||
/** 是否为外链(0是 1否) */ |
|||
private String isFrame; |
|||
|
|||
/** 是否缓存(0缓存 1不缓存) */ |
|||
private String isCache; |
|||
|
|||
/** 类型(M目录 C菜单 F按钮) */ |
|||
private String menuType; |
|||
|
|||
/** 显示状态(0显示 1隐藏) */ |
|||
private String visible; |
|||
|
|||
/** 菜单状态(0正常 1停用) */ |
|||
private String status; |
|||
|
|||
/** 权限字符串 */ |
|||
private String perms; |
|||
|
|||
/** 菜单图标 */ |
|||
private String icon; |
|||
|
|||
/** 子菜单 */ |
|||
private List<SysMenu> children = new ArrayList<SysMenu>(); |
|||
|
|||
public Long getMenuId() |
|||
{ |
|||
return menuId; |
|||
} |
|||
|
|||
public void setMenuId(Long menuId) |
|||
{ |
|||
this.menuId = menuId; |
|||
} |
|||
|
|||
@NotBlank(message = "菜单名称不能为空") |
|||
@Size(min = 0, max = 50, message = "菜单名称长度不能超过50个字符") |
|||
public String getMenuName() |
|||
{ |
|||
return menuName; |
|||
} |
|||
|
|||
public void setMenuName(String menuName) |
|||
{ |
|||
this.menuName = menuName; |
|||
} |
|||
|
|||
public String getParentName() |
|||
{ |
|||
return parentName; |
|||
} |
|||
|
|||
public void setParentName(String parentName) |
|||
{ |
|||
this.parentName = parentName; |
|||
} |
|||
|
|||
public Long getParentId() |
|||
{ |
|||
return parentId; |
|||
} |
|||
|
|||
public void setParentId(Long parentId) |
|||
{ |
|||
this.parentId = parentId; |
|||
} |
|||
|
|||
@NotNull(message = "显示顺序不能为空") |
|||
public Integer getOrderNum() |
|||
{ |
|||
return orderNum; |
|||
} |
|||
|
|||
public void setOrderNum(Integer orderNum) |
|||
{ |
|||
this.orderNum = orderNum; |
|||
} |
|||
|
|||
@Size(min = 0, max = 200, message = "路由地址不能超过200个字符") |
|||
public String getPath() |
|||
{ |
|||
return path; |
|||
} |
|||
|
|||
public void setPath(String path) |
|||
{ |
|||
this.path = path; |
|||
} |
|||
|
|||
@Size(min = 0, max = 200, message = "组件路径不能超过255个字符") |
|||
public String getComponent() |
|||
{ |
|||
return component; |
|||
} |
|||
|
|||
public void setComponent(String component) |
|||
{ |
|||
this.component = component; |
|||
} |
|||
|
|||
public String getQuery() |
|||
{ |
|||
return query; |
|||
} |
|||
|
|||
public void setQuery(String query) |
|||
{ |
|||
this.query = query; |
|||
} |
|||
|
|||
public String getIsFrame() |
|||
{ |
|||
return isFrame; |
|||
} |
|||
|
|||
public void setIsFrame(String isFrame) |
|||
{ |
|||
this.isFrame = isFrame; |
|||
} |
|||
|
|||
public String getIsCache() |
|||
{ |
|||
return isCache; |
|||
} |
|||
|
|||
public void setIsCache(String isCache) |
|||
{ |
|||
this.isCache = isCache; |
|||
} |
|||
|
|||
@NotBlank(message = "菜单类型不能为空") |
|||
public String getMenuType() |
|||
{ |
|||
return menuType; |
|||
} |
|||
|
|||
public void setMenuType(String menuType) |
|||
{ |
|||
this.menuType = menuType; |
|||
} |
|||
|
|||
public String getVisible() |
|||
{ |
|||
return visible; |
|||
} |
|||
|
|||
public void setVisible(String visible) |
|||
{ |
|||
this.visible = visible; |
|||
} |
|||
|
|||
public String getStatus() |
|||
{ |
|||
return status; |
|||
} |
|||
|
|||
public void setStatus(String status) |
|||
{ |
|||
this.status = status; |
|||
} |
|||
|
|||
@Size(min = 0, max = 100, message = "权限标识长度不能超过100个字符") |
|||
public String getPerms() |
|||
{ |
|||
return perms; |
|||
} |
|||
|
|||
public void setPerms(String perms) |
|||
{ |
|||
this.perms = perms; |
|||
} |
|||
|
|||
public String getIcon() |
|||
{ |
|||
return icon; |
|||
} |
|||
|
|||
public void setIcon(String icon) |
|||
{ |
|||
this.icon = icon; |
|||
} |
|||
|
|||
public List<SysMenu> getChildren() |
|||
{ |
|||
return children; |
|||
} |
|||
|
|||
public void setChildren(List<SysMenu> children) |
|||
{ |
|||
this.children = children; |
|||
} |
|||
|
|||
@Override |
|||
public String toString() { |
|||
return new ToStringBuilder(this,ToStringStyle.MULTI_LINE_STYLE) |
|||
.append("menuId", getMenuId()) |
|||
.append("menuName", getMenuName()) |
|||
.append("parentId", getParentId()) |
|||
.append("orderNum", getOrderNum()) |
|||
.append("path", getPath()) |
|||
.append("component", getComponent()) |
|||
.append("isFrame", getIsFrame()) |
|||
.append("IsCache", getIsCache()) |
|||
.append("menuType", getMenuType()) |
|||
.append("visible", getVisible()) |
|||
.append("status ", getStatus()) |
|||
.append("perms", getPerms()) |
|||
.append("icon", getIcon()) |
|||
.append("createBy", getCreateBy()) |
|||
.append("createTime", getCreateTime()) |
|||
.append("updateBy", getUpdateBy()) |
|||
.append("updateTime", getUpdateTime()) |
|||
.append("remark", getRemark()) |
|||
.toString(); |
|||
} |
|||
} |
@ -0,0 +1,258 @@ |
|||
package com.win.common.core.domain.entity; |
|||
|
|||
import com.baomidou.mybatisplus.annotation.IdType; |
|||
import com.baomidou.mybatisplus.annotation.TableId; |
|||
import com.win.common.annotation.Excel; |
|||
import com.win.common.core.domain.WinBaseEntity; |
|||
import org.apache.commons.lang3.builder.ToStringBuilder; |
|||
import org.apache.commons.lang3.builder.ToStringStyle; |
|||
|
|||
import javax.validation.constraints.NotBlank; |
|||
import javax.validation.constraints.NotNull; |
|||
import javax.validation.constraints.Size; |
|||
import java.util.List; |
|||
import java.util.Set; |
|||
|
|||
/** |
|||
* 角色表 sys_role |
|||
* |
|||
* @author win |
|||
*/ |
|||
public class SysRole extends WinBaseEntity |
|||
{ |
|||
private static final long serialVersionUID = 1L; |
|||
|
|||
/** 角色ID */ |
|||
@Excel(name = "角色序号", cellType = Excel.ColumnType.NUMERIC) |
|||
@TableId(type = IdType.AUTO) |
|||
private Long roleId; |
|||
|
|||
/** 角色名称 */ |
|||
@Excel(name = "角色名称") |
|||
private String roleName; |
|||
|
|||
/** 角色权限 */ |
|||
@Excel(name = "角色权限") |
|||
private String roleKey; |
|||
|
|||
/** 角色排序 */ |
|||
@Excel(name = "角色排序") |
|||
private Integer roleSort; |
|||
|
|||
/** 数据范围(1:所有数据权限;2:自定义数据权限;3:本部门数据权限;4:本部门及以下数据权限;5:仅本人数据权限) */ |
|||
@Excel(name = "数据范围", readConverterExp = "1=所有数据权限,2=自定义数据权限,3=本部门数据权限,4=本部门及以下数据权限,5=仅本人数据权限") |
|||
private String dataScope; |
|||
|
|||
/** 菜单树选择项是否关联显示( 0:父子不互相关联显示 1:父子互相关联显示) */ |
|||
private boolean menuCheckStrictly; |
|||
|
|||
/** 部门树选择项是否关联显示(0:父子不互相关联显示 1:父子互相关联显示 ) */ |
|||
private boolean deptCheckStrictly; |
|||
|
|||
/** 角色状态(0正常 1停用) */ |
|||
@Excel(name = "角色状态", readConverterExp = "0=正常,1=停用") |
|||
private String status; |
|||
|
|||
/** 删除标志(0代表存在 2代表删除) */ |
|||
private String delFlag; |
|||
|
|||
/** 用户是否存在此角色标识 默认不存在 */ |
|||
private boolean flag = false; |
|||
|
|||
/** 菜单组 */ |
|||
private Long[] menuIds; |
|||
|
|||
/** 部门组(数据权限) */ |
|||
private Long[] deptIds; |
|||
|
|||
/** 角色菜单权限 */ |
|||
private Set<String> permissions; |
|||
|
|||
/** 角色下的菜单 */ |
|||
private List<SysMenu> menuList; |
|||
|
|||
public SysRole() |
|||
{ |
|||
|
|||
} |
|||
|
|||
public SysRole(Long roleId) |
|||
{ |
|||
this.roleId = roleId; |
|||
} |
|||
|
|||
public Long getRoleId() |
|||
{ |
|||
return roleId; |
|||
} |
|||
|
|||
public void setRoleId(Long roleId) |
|||
{ |
|||
this.roleId = roleId; |
|||
} |
|||
|
|||
public boolean isAdmin() |
|||
{ |
|||
return isAdmin(this.roleId); |
|||
} |
|||
|
|||
public static boolean isAdmin(Long roleId) |
|||
{ |
|||
return roleId != null && 1L == roleId; |
|||
} |
|||
|
|||
@NotBlank(message = "角色名称不能为空") |
|||
@Size(min = 0, max = 30, message = "角色名称长度不能超过30个字符") |
|||
public String getRoleName() |
|||
{ |
|||
return roleName; |
|||
} |
|||
|
|||
public void setRoleName(String roleName) |
|||
{ |
|||
this.roleName = roleName; |
|||
} |
|||
|
|||
@NotBlank(message = "权限字符不能为空") |
|||
@Size(min = 0, max = 100, message = "权限字符长度不能超过100个字符") |
|||
public String getRoleKey() |
|||
{ |
|||
return roleKey; |
|||
} |
|||
|
|||
public void setRoleKey(String roleKey) |
|||
{ |
|||
this.roleKey = roleKey; |
|||
} |
|||
|
|||
@NotNull(message = "显示顺序不能为空") |
|||
public Integer getRoleSort() |
|||
{ |
|||
return roleSort; |
|||
} |
|||
|
|||
public void setRoleSort(Integer roleSort) |
|||
{ |
|||
this.roleSort = roleSort; |
|||
} |
|||
|
|||
public String getDataScope() |
|||
{ |
|||
return dataScope; |
|||
} |
|||
|
|||
public void setDataScope(String dataScope) |
|||
{ |
|||
this.dataScope = dataScope; |
|||
} |
|||
|
|||
public boolean isMenuCheckStrictly() |
|||
{ |
|||
return menuCheckStrictly; |
|||
} |
|||
|
|||
public void setMenuCheckStrictly(boolean menuCheckStrictly) |
|||
{ |
|||
this.menuCheckStrictly = menuCheckStrictly; |
|||
} |
|||
|
|||
public boolean isDeptCheckStrictly() |
|||
{ |
|||
return deptCheckStrictly; |
|||
} |
|||
|
|||
public void setDeptCheckStrictly(boolean deptCheckStrictly) |
|||
{ |
|||
this.deptCheckStrictly = deptCheckStrictly; |
|||
} |
|||
|
|||
public String getStatus() |
|||
{ |
|||
return status; |
|||
} |
|||
|
|||
public void setStatus(String status) |
|||
{ |
|||
this.status = status; |
|||
} |
|||
|
|||
public String getDelFlag() |
|||
{ |
|||
return delFlag; |
|||
} |
|||
|
|||
public void setDelFlag(String delFlag) |
|||
{ |
|||
this.delFlag = delFlag; |
|||
} |
|||
|
|||
public boolean isFlag() |
|||
{ |
|||
return flag; |
|||
} |
|||
|
|||
public void setFlag(boolean flag) |
|||
{ |
|||
this.flag = flag; |
|||
} |
|||
|
|||
public Long[] getMenuIds() |
|||
{ |
|||
return menuIds; |
|||
} |
|||
|
|||
public void setMenuIds(Long[] menuIds) |
|||
{ |
|||
this.menuIds = menuIds; |
|||
} |
|||
|
|||
public Long[] getDeptIds() |
|||
{ |
|||
return deptIds; |
|||
} |
|||
|
|||
public void setDeptIds(Long[] deptIds) |
|||
{ |
|||
this.deptIds = deptIds; |
|||
} |
|||
|
|||
public Set<String> getPermissions() |
|||
{ |
|||
return permissions; |
|||
} |
|||
|
|||
public void setPermissions(Set<String> permissions) |
|||
{ |
|||
this.permissions = permissions; |
|||
} |
|||
|
|||
public List<SysMenu> getMenuList() |
|||
{ |
|||
return menuList; |
|||
} |
|||
|
|||
public void setMenuList(List<SysMenu> menuList) |
|||
{ |
|||
this.menuList = menuList; |
|||
} |
|||
|
|||
@Override |
|||
public String toString() { |
|||
return new ToStringBuilder(this,ToStringStyle.MULTI_LINE_STYLE) |
|||
.append("roleId", getRoleId()) |
|||
.append("roleName", getRoleName()) |
|||
.append("roleKey", getRoleKey()) |
|||
.append("roleSort", getRoleSort()) |
|||
.append("dataScope", getDataScope()) |
|||
.append("menuCheckStrictly", isMenuCheckStrictly()) |
|||
.append("deptCheckStrictly", isDeptCheckStrictly()) |
|||
.append("status", getStatus()) |
|||
.append("delFlag", getDelFlag()) |
|||
.append("createBy", getCreateBy()) |
|||
.append("createTime", getCreateTime()) |
|||
.append("updateBy", getUpdateBy()) |
|||
.append("updateTime", getUpdateTime()) |
|||
.append("remark", getRemark()) |
|||
.toString(); |
|||
} |
|||
} |
@ -0,0 +1,335 @@ |
|||
package com.win.common.core.domain.entity; |
|||
|
|||
import com.baomidou.mybatisplus.annotation.IdType; |
|||
import com.baomidou.mybatisplus.annotation.TableField; |
|||
import com.baomidou.mybatisplus.annotation.TableId; |
|||
import com.win.common.utils.SecurityUtils; |
|||
import com.win.common.xss.Xss; |
|||
import com.win.common.annotation.Excel; |
|||
import com.win.common.annotation.Excels; |
|||
import com.win.common.core.domain.WinBaseEntity; |
|||
import org.apache.commons.lang3.builder.ToStringBuilder; |
|||
import org.apache.commons.lang3.builder.ToStringStyle; |
|||
|
|||
import javax.validation.constraints.Email; |
|||
import javax.validation.constraints.NotBlank; |
|||
import javax.validation.constraints.Size; |
|||
import java.util.Date; |
|||
import java.util.List; |
|||
|
|||
/** |
|||
* 用户对象 sys_user |
|||
* |
|||
* @author win |
|||
*/ |
|||
public class SysUser extends WinBaseEntity |
|||
{ |
|||
private static final long serialVersionUID = 1L; |
|||
|
|||
/** 用户ID */ |
|||
@Excel(name = "用户序号", cellType = Excel.ColumnType.NUMERIC, prompt = "用户编号") |
|||
@TableId(type = IdType.AUTO) |
|||
private Long userId; |
|||
|
|||
/** 部门ID */ |
|||
@Excel(name = "部门编号", type = Excel.Type.IMPORT) |
|||
private Long deptId; |
|||
|
|||
/** 用户账号 */ |
|||
@Excel(name = "登录名称") |
|||
private String userName; |
|||
|
|||
/** 用户昵称 */ |
|||
@Excel(name = "用户名称") |
|||
private String nickName; |
|||
|
|||
/** 用户邮箱 */ |
|||
@Excel(name = "用户邮箱") |
|||
private String email; |
|||
|
|||
/** 手机号码 */ |
|||
@Excel(name = "手机号码") |
|||
private String phonenumber; |
|||
|
|||
/** 用户性别 */ |
|||
@Excel(name = "用户性别", readConverterExp = "0=男,1=女,2=未知") |
|||
private String sex; |
|||
|
|||
/** 用户头像 */ |
|||
private String avatar; |
|||
|
|||
/** 密码 */ |
|||
private String password; |
|||
|
|||
/** 帐号状态(0正常 1停用) */ |
|||
@Excel(name = "帐号状态", readConverterExp = "0=正常,1=停用") |
|||
private String status; |
|||
|
|||
/** 删除标志(0代表存在 2代表删除) */ |
|||
private String delFlag; |
|||
|
|||
/** 最后登录IP */ |
|||
@Excel(name = "最后登录IP", type = Excel.Type.EXPORT) |
|||
private String loginIp; |
|||
|
|||
/** 最后登录时间 */ |
|||
@Excel(name = "最后登录时间", width = 30, dateFormat = "yyyy-MM-dd HH:mm:ss", type = Excel.Type.EXPORT) |
|||
private Date loginDate; |
|||
|
|||
/** 部门对象 */ |
|||
@Excels({ |
|||
@Excel(name = "部门名称", targetAttr = "deptName", type = Excel.Type.EXPORT), |
|||
@Excel(name = "部门负责人", targetAttr = "leader", type = Excel.Type.EXPORT) |
|||
}) |
|||
@TableField(exist = false) |
|||
private SysDept dept; |
|||
|
|||
/** 角色对象 */ |
|||
@TableField(exist = false) |
|||
private List<SysRole> roles; |
|||
|
|||
/** 角色组 */ |
|||
@TableField(exist = false) |
|||
private Long[] roleIds; |
|||
|
|||
/** 岗位组 */ |
|||
@TableField(exist = false) |
|||
private Long[] postIds; |
|||
|
|||
/** 角色ID */ |
|||
@TableField(exist = false) |
|||
private Long roleId; |
|||
|
|||
public SysUser() |
|||
{ |
|||
|
|||
} |
|||
|
|||
public SysUser(Long userId) |
|||
{ |
|||
this.userId = userId; |
|||
} |
|||
|
|||
public Long getUserId() |
|||
{ |
|||
return userId; |
|||
} |
|||
|
|||
public void setUserId(Long userId) |
|||
{ |
|||
this.userId = userId; |
|||
} |
|||
|
|||
public boolean isAdmin() |
|||
{ |
|||
return isAdmin(this.userId); |
|||
} |
|||
|
|||
public static boolean isAdmin(Long userId) |
|||
{ |
|||
return userId != null && 1L == userId; |
|||
} |
|||
|
|||
public Long getDeptId() |
|||
{ |
|||
return deptId; |
|||
} |
|||
|
|||
public void setDeptId(Long deptId) |
|||
{ |
|||
this.deptId = deptId; |
|||
} |
|||
|
|||
@Xss(message = "用户昵称不能包含脚本字符") |
|||
@Size(min = 0, max = 30, message = "用户昵称长度不能超过30个字符") |
|||
public String getNickName() |
|||
{ |
|||
return nickName; |
|||
} |
|||
|
|||
public void setNickName(String nickName) |
|||
{ |
|||
this.nickName = nickName; |
|||
} |
|||
|
|||
@Xss(message = "用户账号不能包含脚本字符") |
|||
@NotBlank(message = "用户账号不能为空") |
|||
@Size(min = 0, max = 30, message = "用户账号长度不能超过30个字符") |
|||
public String getUserName() |
|||
{ |
|||
return userName; |
|||
} |
|||
|
|||
public void setUserName(String userName) |
|||
{ |
|||
this.userName = userName; |
|||
} |
|||
|
|||
@Email(message = "邮箱格式不正确") |
|||
@Size(min = 0, max = 50, message = "邮箱长度不能超过50个字符") |
|||
public String getEmail() |
|||
{ |
|||
return email; |
|||
} |
|||
|
|||
public void setEmail(String email) |
|||
{ |
|||
this.email = email; |
|||
} |
|||
|
|||
@Size(min = 0, max = 11, message = "手机号码长度不能超过11个字符") |
|||
public String getPhonenumber() |
|||
{ |
|||
return phonenumber; |
|||
} |
|||
|
|||
public void setPhonenumber(String phonenumber) |
|||
{ |
|||
this.phonenumber = phonenumber; |
|||
} |
|||
|
|||
public String getSex() |
|||
{ |
|||
return sex; |
|||
} |
|||
|
|||
public void setSex(String sex) |
|||
{ |
|||
this.sex = sex; |
|||
} |
|||
|
|||
public String getAvatar() |
|||
{ |
|||
return avatar; |
|||
} |
|||
|
|||
public void setAvatar(String avatar) |
|||
{ |
|||
this.avatar = avatar; |
|||
} |
|||
|
|||
public String getPassword() |
|||
{ |
|||
return password; |
|||
} |
|||
|
|||
public void setPassword(String password) |
|||
{ |
|||
this.password = password; |
|||
} |
|||
|
|||
public String getStatus() |
|||
{ |
|||
return status; |
|||
} |
|||
|
|||
public void setStatus(String status) |
|||
{ |
|||
this.status = status; |
|||
} |
|||
|
|||
public String getDelFlag() |
|||
{ |
|||
return delFlag; |
|||
} |
|||
|
|||
public void setDelFlag(String delFlag) |
|||
{ |
|||
this.delFlag = delFlag; |
|||
} |
|||
|
|||
public String getLoginIp() |
|||
{ |
|||
return loginIp; |
|||
} |
|||
|
|||
public void setLoginIp(String loginIp) |
|||
{ |
|||
this.loginIp = loginIp; |
|||
} |
|||
|
|||
public Date getLoginDate() |
|||
{ |
|||
return loginDate; |
|||
} |
|||
|
|||
public void setLoginDate(Date loginDate) |
|||
{ |
|||
this.loginDate = loginDate; |
|||
} |
|||
|
|||
public SysDept getDept() |
|||
{ |
|||
return dept; |
|||
} |
|||
|
|||
public void setDept(SysDept dept) |
|||
{ |
|||
this.dept = dept; |
|||
} |
|||
|
|||
public List<SysRole> getRoles() |
|||
{ |
|||
return roles; |
|||
} |
|||
|
|||
public void setRoles(List<SysRole> roles) |
|||
{ |
|||
this.roles = roles; |
|||
} |
|||
|
|||
public Long[] getRoleIds() |
|||
{ |
|||
return roleIds; |
|||
} |
|||
|
|||
public void setRoleIds(Long[] roleIds) |
|||
{ |
|||
this.roleIds = roleIds; |
|||
} |
|||
|
|||
public Long[] getPostIds() |
|||
{ |
|||
return postIds; |
|||
} |
|||
|
|||
public void setPostIds(Long[] postIds) |
|||
{ |
|||
this.postIds = postIds; |
|||
} |
|||
|
|||
public Long getRoleId() |
|||
{ |
|||
return roleId; |
|||
} |
|||
|
|||
public void setRoleId(Long roleId) |
|||
{ |
|||
this.roleId = roleId; |
|||
} |
|||
|
|||
@Override |
|||
public String toString() { |
|||
return new ToStringBuilder(this,ToStringStyle.MULTI_LINE_STYLE) |
|||
.append("userId", getUserId()) |
|||
.append("deptId", getDeptId()) |
|||
.append("userName", getUserName()) |
|||
.append("nickName", getNickName()) |
|||
.append("email", getEmail()) |
|||
.append("phonenumber", getPhonenumber()) |
|||
.append("sex", getSex()) |
|||
.append("avatar", getAvatar()) |
|||
.append("password", getPassword()) |
|||
.append("status", getStatus()) |
|||
.append("delFlag", getDelFlag()) |
|||
.append("loginIp", getLoginIp()) |
|||
.append("loginDate", getLoginDate()) |
|||
.append("createBy", getCreateBy()) |
|||
.append("createTime", getCreateTime()) |
|||
.append("updateBy", getUpdateBy()) |
|||
.append("updateTime", getUpdateTime()) |
|||
.append("remark", getRemark()) |
|||
.append("dept", getDept()) |
|||
.toString(); |
|||
} |
|||
} |
@ -0,0 +1,69 @@ |
|||
package com.win.common.core.domain.model; |
|||
|
|||
/** |
|||
* 用户登录对象 |
|||
* |
|||
* @author win |
|||
*/ |
|||
public class LoginBody |
|||
{ |
|||
/** |
|||
* 用户名 |
|||
*/ |
|||
private String username; |
|||
|
|||
/** |
|||
* 用户密码 |
|||
*/ |
|||
private String password; |
|||
|
|||
/** |
|||
* 验证码 |
|||
*/ |
|||
private String code; |
|||
|
|||
/** |
|||
* 唯一标识 |
|||
*/ |
|||
private String uuid; |
|||
|
|||
public String getUsername() |
|||
{ |
|||
return username; |
|||
} |
|||
|
|||
public void setUsername(String username) |
|||
{ |
|||
this.username = username; |
|||
} |
|||
|
|||
public String getPassword() |
|||
{ |
|||
return password; |
|||
} |
|||
|
|||
public void setPassword(String password) |
|||
{ |
|||
this.password = password; |
|||
} |
|||
|
|||
public String getCode() |
|||
{ |
|||
return code; |
|||
} |
|||
|
|||
public void setCode(String code) |
|||
{ |
|||
this.code = code; |
|||
} |
|||
|
|||
public String getUuid() |
|||
{ |
|||
return uuid; |
|||
} |
|||
|
|||
public void setUuid(String uuid) |
|||
{ |
|||
this.uuid = uuid; |
|||
} |
|||
} |
@ -0,0 +1,267 @@ |
|||
package com.win.common.core.domain.model; |
|||
|
|||
import java.util.Collection; |
|||
import java.util.Set; |
|||
|
|||
import com.win.common.core.domain.entity.SysUser; |
|||
import org.springframework.security.core.GrantedAuthority; |
|||
import org.springframework.security.core.userdetails.UserDetails; |
|||
import com.alibaba.fastjson2.annotation.JSONField; |
|||
|
|||
/** |
|||
* 登录用户身份权限 |
|||
* |
|||
* @author win |
|||
*/ |
|||
public class LoginUser implements UserDetails |
|||
{ |
|||
private static final long serialVersionUID = 1L; |
|||
|
|||
/** |
|||
* 用户ID |
|||
*/ |
|||
private Long userId; |
|||
|
|||
/** |
|||
* 部门ID |
|||
*/ |
|||
private Long deptId; |
|||
|
|||
/** |
|||
* 用户唯一标识 |
|||
*/ |
|||
private String token; |
|||
|
|||
/** |
|||
* 登录时间 |
|||
*/ |
|||
private Long loginTime; |
|||
|
|||
/** |
|||
* 过期时间 |
|||
*/ |
|||
private Long expireTime; |
|||
|
|||
/** |
|||
* 登录IP地址 |
|||
*/ |
|||
private String ipaddr; |
|||
|
|||
/** |
|||
* 登录地点 |
|||
*/ |
|||
private String loginLocation; |
|||
|
|||
/** |
|||
* 浏览器类型 |
|||
*/ |
|||
private String browser; |
|||
|
|||
/** |
|||
* 操作系统 |
|||
*/ |
|||
private String os; |
|||
|
|||
/** |
|||
* 权限列表 |
|||
*/ |
|||
private Set<String> permissions; |
|||
|
|||
/** |
|||
* 用户信息 |
|||
*/ |
|||
private SysUser user; |
|||
|
|||
public Long getUserId() |
|||
{ |
|||
return userId; |
|||
} |
|||
|
|||
public void setUserId(Long userId) |
|||
{ |
|||
this.userId = userId; |
|||
} |
|||
|
|||
public Long getDeptId() |
|||
{ |
|||
return deptId; |
|||
} |
|||
|
|||
public void setDeptId(Long deptId) |
|||
{ |
|||
this.deptId = deptId; |
|||
} |
|||
|
|||
public String getToken() |
|||
{ |
|||
return token; |
|||
} |
|||
|
|||
public void setToken(String token) |
|||
{ |
|||
this.token = token; |
|||
} |
|||
|
|||
public LoginUser() |
|||
{ |
|||
} |
|||
|
|||
public LoginUser(SysUser user, Set<String> permissions) |
|||
{ |
|||
this.user = user; |
|||
this.permissions = permissions; |
|||
} |
|||
|
|||
public LoginUser(Long userId, Long deptId, SysUser user, Set<String> permissions) |
|||
{ |
|||
this.userId = userId; |
|||
this.deptId = deptId; |
|||
this.user = user; |
|||
this.permissions = permissions; |
|||
} |
|||
|
|||
@JSONField(serialize = false) |
|||
@Override |
|||
public String getPassword() |
|||
{ |
|||
return user.getPassword(); |
|||
} |
|||
|
|||
@Override |
|||
public String getUsername() |
|||
{ |
|||
return user.getUserName(); |
|||
} |
|||
|
|||
/** |
|||
* 账户是否未过期,过期无法验证 |
|||
*/ |
|||
@JSONField(serialize = false) |
|||
@Override |
|||
public boolean isAccountNonExpired() |
|||
{ |
|||
return true; |
|||
} |
|||
|
|||
/** |
|||
* 指定用户是否解锁,锁定的用户无法进行身份验证 |
|||
* |
|||
* @return |
|||
*/ |
|||
@JSONField(serialize = false) |
|||
@Override |
|||
public boolean isAccountNonLocked() |
|||
{ |
|||
return true; |
|||
} |
|||
|
|||
/** |
|||
* 指示是否已过期的用户的凭据(密码),过期的凭据防止认证 |
|||
* |
|||
* @return |
|||
*/ |
|||
@JSONField(serialize = false) |
|||
@Override |
|||
public boolean isCredentialsNonExpired() |
|||
{ |
|||
return true; |
|||
} |
|||
|
|||
/** |
|||
* 是否可用 ,禁用的用户不能身份验证 |
|||
* |
|||
* @return |
|||
*/ |
|||
@JSONField(serialize = false) |
|||
@Override |
|||
public boolean isEnabled() |
|||
{ |
|||
return true; |
|||
} |
|||
|
|||
public Long getLoginTime() |
|||
{ |
|||
return loginTime; |
|||
} |
|||
|
|||
public void setLoginTime(Long loginTime) |
|||
{ |
|||
this.loginTime = loginTime; |
|||
} |
|||
|
|||
public String getIpaddr() |
|||
{ |
|||
return ipaddr; |
|||
} |
|||
|
|||
public void setIpaddr(String ipaddr) |
|||
{ |
|||
this.ipaddr = ipaddr; |
|||
} |
|||
|
|||
public String getLoginLocation() |
|||
{ |
|||
return loginLocation; |
|||
} |
|||
|
|||
public void setLoginLocation(String loginLocation) |
|||
{ |
|||
this.loginLocation = loginLocation; |
|||
} |
|||
|
|||
public String getBrowser() |
|||
{ |
|||
return browser; |
|||
} |
|||
|
|||
public void setBrowser(String browser) |
|||
{ |
|||
this.browser = browser; |
|||
} |
|||
|
|||
public String getOs() |
|||
{ |
|||
return os; |
|||
} |
|||
|
|||
public void setOs(String os) |
|||
{ |
|||
this.os = os; |
|||
} |
|||
|
|||
public Long getExpireTime() |
|||
{ |
|||
return expireTime; |
|||
} |
|||
|
|||
public void setExpireTime(Long expireTime) |
|||
{ |
|||
this.expireTime = expireTime; |
|||
} |
|||
|
|||
public Set<String> getPermissions() |
|||
{ |
|||
return permissions; |
|||
} |
|||
|
|||
public void setPermissions(Set<String> permissions) |
|||
{ |
|||
this.permissions = permissions; |
|||
} |
|||
|
|||
public SysUser getUser() |
|||
{ |
|||
return user; |
|||
} |
|||
|
|||
public void setUser(SysUser user) |
|||
{ |
|||
this.user = user; |
|||
} |
|||
|
|||
@Override |
|||
public Collection<? extends GrantedAuthority> getAuthorities() |
|||
{ |
|||
return null; |
|||
} |
|||
} |
@ -0,0 +1,11 @@ |
|||
package com.win.common.core.domain.model; |
|||
|
|||
/** |
|||
* 用户注册对象 |
|||
* |
|||
* @author win |
|||
*/ |
|||
public class RegisterBody extends LoginBody |
|||
{ |
|||
|
|||
} |
@ -0,0 +1,101 @@ |
|||
package com.win.common.core.page; |
|||
|
|||
import com.win.common.utils.StringUtils; |
|||
|
|||
/** |
|||
* 分页数据 |
|||
* |
|||
* @author win |
|||
*/ |
|||
public class PageDomain |
|||
{ |
|||
/** 当前记录起始索引 */ |
|||
private Integer pageNum; |
|||
|
|||
/** 每页显示记录数 */ |
|||
private Integer pageSize; |
|||
|
|||
/** 排序列 */ |
|||
private String orderByColumn; |
|||
|
|||
/** 排序的方向desc或者asc */ |
|||
private String isAsc = "asc"; |
|||
|
|||
/** 分页参数合理化 */ |
|||
private Boolean reasonable = true; |
|||
|
|||
public String getOrderBy() |
|||
{ |
|||
if (StringUtils.isEmpty(orderByColumn)) |
|||
{ |
|||
return ""; |
|||
} |
|||
return StringUtils.toUnderScoreCase(orderByColumn) + " " + isAsc; |
|||
} |
|||
|
|||
public Integer getPageNum() |
|||
{ |
|||
return pageNum; |
|||
} |
|||
|
|||
public void setPageNum(Integer pageNum) |
|||
{ |
|||
this.pageNum = pageNum; |
|||
} |
|||
|
|||
public Integer getPageSize() |
|||
{ |
|||
return pageSize; |
|||
} |
|||
|
|||
public void setPageSize(Integer pageSize) |
|||
{ |
|||
this.pageSize = pageSize; |
|||
} |
|||
|
|||
public String getOrderByColumn() |
|||
{ |
|||
return orderByColumn; |
|||
} |
|||
|
|||
public void setOrderByColumn(String orderByColumn) |
|||
{ |
|||
this.orderByColumn = orderByColumn; |
|||
} |
|||
|
|||
public String getIsAsc() |
|||
{ |
|||
return isAsc; |
|||
} |
|||
|
|||
public void setIsAsc(String isAsc) |
|||
{ |
|||
if (StringUtils.isNotEmpty(isAsc)) |
|||
{ |
|||
// 兼容前端排序类型
|
|||
if ("ascending".equals(isAsc)) |
|||
{ |
|||
isAsc = "asc"; |
|||
} |
|||
else if ("descending".equals(isAsc)) |
|||
{ |
|||
isAsc = "desc"; |
|||
} |
|||
this.isAsc = isAsc; |
|||
} |
|||
} |
|||
|
|||
public Boolean getReasonable() |
|||
{ |
|||
if (StringUtils.isNull(reasonable)) |
|||
{ |
|||
return Boolean.TRUE; |
|||
} |
|||
return reasonable; |
|||
} |
|||
|
|||
public void setReasonable(Boolean reasonable) |
|||
{ |
|||
this.reasonable = reasonable; |
|||
} |
|||
} |
@ -0,0 +1,85 @@ |
|||
package com.win.common.core.page; |
|||
|
|||
import java.io.Serializable; |
|||
import java.util.List; |
|||
|
|||
/** |
|||
* 表格分页数据对象 |
|||
* |
|||
* @author win |
|||
*/ |
|||
public class TableDataInfo implements Serializable |
|||
{ |
|||
private static final long serialVersionUID = 1L; |
|||
|
|||
/** 总记录数 */ |
|||
private long total; |
|||
|
|||
/** 列表数据 */ |
|||
private List<?> rows; |
|||
|
|||
/** 消息状态码 */ |
|||
private int code; |
|||
|
|||
/** 消息内容 */ |
|||
private String msg; |
|||
|
|||
/** |
|||
* 表格数据对象 |
|||
*/ |
|||
public TableDataInfo() |
|||
{ |
|||
} |
|||
|
|||
/** |
|||
* 分页 |
|||
* |
|||
* @param list 列表数据 |
|||
* @param total 总记录数 |
|||
*/ |
|||
public TableDataInfo(List<?> list, int total) |
|||
{ |
|||
this.rows = list; |
|||
this.total = total; |
|||
} |
|||
|
|||
public long getTotal() |
|||
{ |
|||
return total; |
|||
} |
|||
|
|||
public void setTotal(long total) |
|||
{ |
|||
this.total = total; |
|||
} |
|||
|
|||
public List<?> getRows() |
|||
{ |
|||
return rows; |
|||
} |
|||
|
|||
public void setRows(List<?> rows) |
|||
{ |
|||
this.rows = rows; |
|||
} |
|||
|
|||
public int getCode() |
|||
{ |
|||
return code; |
|||
} |
|||
|
|||
public void setCode(int code) |
|||
{ |
|||
this.code = code; |
|||
} |
|||
|
|||
public String getMsg() |
|||
{ |
|||
return msg; |
|||
} |
|||
|
|||
public void setMsg(String msg) |
|||
{ |
|||
this.msg = msg; |
|||
} |
|||
} |
@ -0,0 +1,56 @@ |
|||
package com.win.common.core.page; |
|||
|
|||
import com.win.common.core.text.Convert; |
|||
import com.win.common.utils.ServletUtils; |
|||
|
|||
/** |
|||
* 表格数据处理 |
|||
* |
|||
* @author win |
|||
*/ |
|||
public class TableSupport |
|||
{ |
|||
/** |
|||
* 当前记录起始索引 |
|||
*/ |
|||
public static final String PAGE_NUM = "pageNum"; |
|||
|
|||
/** |
|||
* 每页显示记录数 |
|||
*/ |
|||
public static final String PAGE_SIZE = "pageSize"; |
|||
|
|||
/** |
|||
* 排序列 |
|||
*/ |
|||
public static final String ORDER_BY_COLUMN = "orderByColumn"; |
|||
|
|||
/** |
|||
* 排序的方向 "desc" 或者 "asc". |
|||
*/ |
|||
public static final String IS_ASC = "isAsc"; |
|||
|
|||
/** |
|||
* 分页参数合理化 |
|||
*/ |
|||
public static final String REASONABLE = "reasonable"; |
|||
|
|||
/** |
|||
* 封装分页对象 |
|||
*/ |
|||
public static PageDomain getPageDomain() |
|||
{ |
|||
PageDomain pageDomain = new PageDomain(); |
|||
pageDomain.setPageNum(Convert.toInt(ServletUtils.getParameter(PAGE_NUM), 1)); |
|||
pageDomain.setPageSize(Convert.toInt(ServletUtils.getParameter(PAGE_SIZE), 10)); |
|||
pageDomain.setOrderByColumn(ServletUtils.getParameter(ORDER_BY_COLUMN)); |
|||
pageDomain.setIsAsc(ServletUtils.getParameter(IS_ASC)); |
|||
pageDomain.setReasonable(ServletUtils.getParameterToBool(REASONABLE)); |
|||
return pageDomain; |
|||
} |
|||
|
|||
public static PageDomain buildPageRequest() |
|||
{ |
|||
return getPageDomain(); |
|||
} |
|||
} |
@ -0,0 +1,282 @@ |
|||
package com.win.common.core.redis; |
|||
|
|||
import org.springframework.beans.factory.annotation.Autowired; |
|||
import org.springframework.data.redis.core.BoundSetOperations; |
|||
import org.springframework.data.redis.core.HashOperations; |
|||
import org.springframework.data.redis.core.RedisTemplate; |
|||
import org.springframework.data.redis.core.ValueOperations; |
|||
import org.springframework.data.redis.support.atomic.RedisAtomicLong; |
|||
import org.springframework.stereotype.Component; |
|||
|
|||
import java.util.*; |
|||
import java.util.concurrent.TimeUnit; |
|||
|
|||
/** |
|||
* spring redis 工具类 |
|||
* |
|||
* @author win |
|||
**/ |
|||
@SuppressWarnings(value = { "unchecked", "rawtypes" }) |
|||
@Component |
|||
public class RedisCache |
|||
{ |
|||
@Autowired |
|||
public RedisTemplate redisTemplate; |
|||
|
|||
/** |
|||
* 缓存基本的对象,Integer、String、实体类等 |
|||
* |
|||
* @param key 缓存的键值 |
|||
* @param value 缓存的值 |
|||
*/ |
|||
public <T> void setCacheObject(final String key, final T value) |
|||
{ |
|||
redisTemplate.opsForValue().set(key, value); |
|||
} |
|||
|
|||
/** |
|||
* 缓存基本的对象,Integer、String、实体类等 |
|||
* |
|||
* @param key 缓存的键值 |
|||
* @param value 缓存的值 |
|||
* @param timeout 时间 |
|||
* @param timeUnit 时间颗粒度 |
|||
*/ |
|||
public <T> void setCacheObject(final String key, final T value, final Integer timeout, final TimeUnit timeUnit) |
|||
{ |
|||
redisTemplate.opsForValue().set(key, value, timeout, timeUnit); |
|||
} |
|||
|
|||
/** |
|||
* 设置有效时间 |
|||
* |
|||
* @param key Redis键 |
|||
* @param timeout 超时时间 |
|||
* @return true=设置成功;false=设置失败 |
|||
*/ |
|||
public boolean expire(final String key, final long timeout) |
|||
{ |
|||
return expire(key, timeout, TimeUnit.SECONDS); |
|||
} |
|||
|
|||
/** |
|||
* 设置有效时间 |
|||
* |
|||
* @param key Redis键 |
|||
* @param timeout 超时时间 |
|||
* @param unit 时间单位 |
|||
* @return true=设置成功;false=设置失败 |
|||
*/ |
|||
public boolean expire(final String key, final long timeout, final TimeUnit unit) |
|||
{ |
|||
return redisTemplate.expire(key, timeout, unit); |
|||
} |
|||
|
|||
/** |
|||
* 获取有效时间 |
|||
* |
|||
* @param key Redis键 |
|||
* @return 有效时间 |
|||
*/ |
|||
public long getExpire(final String key) |
|||
{ |
|||
return redisTemplate.getExpire(key); |
|||
} |
|||
|
|||
/** |
|||
* 判断 key是否存在 |
|||
* |
|||
* @param key 键 |
|||
* @return true 存在 false不存在 |
|||
*/ |
|||
public Boolean hasKey(String key) |
|||
{ |
|||
return redisTemplate.hasKey(key); |
|||
} |
|||
|
|||
/** |
|||
* 获得缓存的基本对象。 |
|||
* |
|||
* @param key 缓存键值 |
|||
* @return 缓存键值对应的数据 |
|||
*/ |
|||
public <T> T getCacheObject(final String key) |
|||
{ |
|||
ValueOperations<String, T> operation = redisTemplate.opsForValue(); |
|||
return operation.get(key); |
|||
} |
|||
|
|||
/** |
|||
* 删除单个对象 |
|||
* |
|||
* @param key |
|||
*/ |
|||
public boolean deleteObject(final String key) |
|||
{ |
|||
return redisTemplate.delete(key); |
|||
} |
|||
|
|||
/** |
|||
* 删除集合对象 |
|||
* |
|||
* @param collection 多个对象 |
|||
* @return |
|||
*/ |
|||
public boolean deleteObject(final Collection collection) |
|||
{ |
|||
return redisTemplate.delete(collection) > 0; |
|||
} |
|||
|
|||
/** |
|||
* 缓存List数据 |
|||
* |
|||
* @param key 缓存的键值 |
|||
* @param dataList 待缓存的List数据 |
|||
* @return 缓存的对象 |
|||
*/ |
|||
public <T> long setCacheList(final String key, final List<T> dataList) |
|||
{ |
|||
Long count = redisTemplate.opsForList().rightPushAll(key, dataList); |
|||
return count == null ? 0 : count; |
|||
} |
|||
|
|||
/** |
|||
* 获得缓存的list对象 |
|||
* |
|||
* @param key 缓存的键值 |
|||
* @return 缓存键值对应的数据 |
|||
*/ |
|||
public <T> List<T> getCacheList(final String key) |
|||
{ |
|||
return redisTemplate.opsForList().range(key, 0, -1); |
|||
} |
|||
|
|||
/** |
|||
* 缓存Set |
|||
* |
|||
* @param key 缓存键值 |
|||
* @param dataSet 缓存的数据 |
|||
* @return 缓存数据的对象 |
|||
*/ |
|||
public <T> BoundSetOperations<String, T> setCacheSet(final String key, final Set<T> dataSet) |
|||
{ |
|||
BoundSetOperations<String, T> setOperation = redisTemplate.boundSetOps(key); |
|||
Iterator<T> it = dataSet.iterator(); |
|||
while (it.hasNext()) |
|||
{ |
|||
setOperation.add(it.next()); |
|||
} |
|||
return setOperation; |
|||
} |
|||
|
|||
/** |
|||
* 获得缓存的set |
|||
* |
|||
* @param key |
|||
* @return |
|||
*/ |
|||
public <T> Set<T> getCacheSet(final String key) |
|||
{ |
|||
return redisTemplate.opsForSet().members(key); |
|||
} |
|||
|
|||
/** |
|||
* 缓存Map |
|||
* |
|||
* @param key |
|||
* @param dataMap |
|||
*/ |
|||
public <T> void setCacheMap(final String key, final Map<String, T> dataMap) |
|||
{ |
|||
if (dataMap != null) { |
|||
redisTemplate.opsForHash().putAll(key, dataMap); |
|||
} |
|||
} |
|||
|
|||
/** |
|||
* 获得缓存的Map |
|||
* |
|||
* @param key |
|||
* @return |
|||
*/ |
|||
public <T> Map<String, T> getCacheMap(final String key) |
|||
{ |
|||
return redisTemplate.opsForHash().entries(key); |
|||
} |
|||
|
|||
/** |
|||
* 往Hash中存入数据 |
|||
* |
|||
* @param key Redis键 |
|||
* @param hKey Hash键 |
|||
* @param value 值 |
|||
*/ |
|||
public <T> void setCacheMapValue(final String key, final String hKey, final T value) |
|||
{ |
|||
redisTemplate.opsForHash().put(key, hKey, value); |
|||
} |
|||
|
|||
/** |
|||
* 获取Hash中的数据 |
|||
* |
|||
* @param key Redis键 |
|||
* @param hKey Hash键 |
|||
* @return Hash中的对象 |
|||
*/ |
|||
public <T> T getCacheMapValue(final String key, final String hKey) |
|||
{ |
|||
HashOperations<String, String, T> opsForHash = redisTemplate.opsForHash(); |
|||
return opsForHash.get(key, hKey); |
|||
} |
|||
|
|||
/** |
|||
* 获取多个Hash中的数据 |
|||
* |
|||
* @param key Redis键 |
|||
* @param hKeys Hash键集合 |
|||
* @return Hash对象集合 |
|||
*/ |
|||
public <T> List<T> getMultiCacheMapValue(final String key, final Collection<Object> hKeys) |
|||
{ |
|||
return redisTemplate.opsForHash().multiGet(key, hKeys); |
|||
} |
|||
|
|||
/** |
|||
* 删除Hash中的某条数据 |
|||
* |
|||
* @param key Redis键 |
|||
* @param hKey Hash键 |
|||
* @return 是否成功 |
|||
*/ |
|||
public boolean deleteCacheMapValue(final String key, final String hKey) |
|||
{ |
|||
return redisTemplate.opsForHash().delete(key, hKey) > 0; |
|||
} |
|||
|
|||
/** |
|||
* 获得缓存的基本对象列表 |
|||
* |
|||
* @param pattern 字符串前缀 |
|||
* @return 对象列表 |
|||
*/ |
|||
public Collection<String> keys(final String pattern) |
|||
{ |
|||
return redisTemplate.keys(pattern); |
|||
} |
|||
|
|||
/** |
|||
* 获取自增数 |
|||
* @param key |
|||
* @param liveTime 过期分钟 |
|||
* @return |
|||
*/ |
|||
public Long incr(String key, long liveTime) { |
|||
ValueOperations<String, Object> ops = redisTemplate.opsForValue(); |
|||
Long increment = ops.increment(key, 1); |
|||
if (increment != null && increment != 0 && liveTime > 0) { |
|||
expire(key, liveTime); |
|||
} |
|||
return increment; |
|||
} |
|||
|
|||
} |
@ -0,0 +1,87 @@ |
|||
package com.win.common.core.text; |
|||
|
|||
import com.win.common.utils.StringUtils; |
|||
|
|||
import java.nio.charset.Charset; |
|||
import java.nio.charset.StandardCharsets; |
|||
|
|||
/** |
|||
* 字符集工具类 |
|||
* |
|||
* @author win |
|||
*/ |
|||
public class CharsetKit |
|||
{ |
|||
/** ISO-8859-1 */ |
|||
public static final String ISO_8859_1 = "ISO-8859-1"; |
|||
/** UTF-8 */ |
|||
public static final String UTF_8 = "UTF-8"; |
|||
/** GBK */ |
|||
public static final String GBK = "GBK"; |
|||
|
|||
/** ISO-8859-1 */ |
|||
public static final Charset CHARSET_ISO_8859_1 = Charset.forName(ISO_8859_1); |
|||
/** UTF-8 */ |
|||
public static final Charset CHARSET_UTF_8 = Charset.forName(UTF_8); |
|||
/** GBK */ |
|||
public static final Charset CHARSET_GBK = Charset.forName(GBK); |
|||
|
|||
/** |
|||
* 转换为Charset对象 |
|||
* |
|||
* @param charset 字符集,为空则返回默认字符集 |
|||
* @return Charset |
|||
*/ |
|||
public static Charset charset(String charset) |
|||
{ |
|||
return StringUtils.isEmpty(charset) ? Charset.defaultCharset() : Charset.forName(charset); |
|||
} |
|||
|
|||
/** |
|||
* 转换字符串的字符集编码 |
|||
* |
|||
* @param source 字符串 |
|||
* @param srcCharset 源字符集,默认ISO-8859-1 |
|||
* @param destCharset 目标字符集,默认UTF-8 |
|||
* @return 转换后的字符集 |
|||
*/ |
|||
public static String convert(String source, String srcCharset, String destCharset) |
|||
{ |
|||
return convert(source, Charset.forName(srcCharset), Charset.forName(destCharset)); |
|||
} |
|||
|
|||
/** |
|||
* 转换字符串的字符集编码 |
|||
* |
|||
* @param source 字符串 |
|||
* @param srcCharset 源字符集,默认ISO-8859-1 |
|||
* @param destCharset 目标字符集,默认UTF-8 |
|||
* @return 转换后的字符集 |
|||
*/ |
|||
public static String convert(String source, Charset srcCharset, Charset destCharset) |
|||
{ |
|||
if (null == srcCharset) |
|||
{ |
|||
srcCharset = StandardCharsets.ISO_8859_1; |
|||
} |
|||
|
|||
if (null == destCharset) |
|||
{ |
|||
destCharset = StandardCharsets.UTF_8; |
|||
} |
|||
|
|||
if (StringUtils.isEmpty(source) || srcCharset.equals(destCharset)) |
|||
{ |
|||
return source; |
|||
} |
|||
return new String(source.getBytes(srcCharset), destCharset); |
|||
} |
|||
|
|||
/** |
|||
* @return 系统字符集编码 |
|||
*/ |
|||
public static String systemCharset() |
|||
{ |
|||
return Charset.defaultCharset().name(); |
|||
} |
|||
} |
File diff suppressed because it is too large
@ -0,0 +1,92 @@ |
|||
package com.win.common.core.text; |
|||
|
|||
import com.win.common.utils.StringUtils; |
|||
|
|||
/** |
|||
* 字符串格式化 |
|||
* |
|||
* @author win |
|||
*/ |
|||
public class StrFormatter |
|||
{ |
|||
public static final String EMPTY_JSON = "{}"; |
|||
public static final char C_BACKSLASH = '\\'; |
|||
public static final char C_DELIM_START = '{'; |
|||
public static final char C_DELIM_END = '}'; |
|||
|
|||
/** |
|||
* 格式化字符串<br> |
|||
* 此方法只是简单将占位符 {} 按照顺序替换为参数<br> |
|||
* 如果想输出 {} 使用 \\转义 { 即可,如果想输出 {} 之前的 \ 使用双转义符 \\\\ 即可<br> |
|||
* 例:<br> |
|||
* 通常使用:format("this is {} for {}", "a", "b") -> this is a for b<br> |
|||
* 转义{}: format("this is \\{} for {}", "a", "b") -> this is \{} for a<br> |
|||
* 转义\: format("this is \\\\{} for {}", "a", "b") -> this is \a for b<br> |
|||
* |
|||
* @param strPattern 字符串模板 |
|||
* @param argArray 参数列表 |
|||
* @return 结果 |
|||
*/ |
|||
public static String format(final String strPattern, final Object... argArray) |
|||
{ |
|||
if (StringUtils.isEmpty(strPattern) || StringUtils.isEmpty(argArray)) |
|||
{ |
|||
return strPattern; |
|||
} |
|||
final int strPatternLength = strPattern.length(); |
|||
|
|||
// 初始化定义好的长度以获得更好的性能
|
|||
StringBuilder sbuf = new StringBuilder(strPatternLength + 50); |
|||
|
|||
int handledPosition = 0; |
|||
int delimIndex;// 占位符所在位置
|
|||
for (int argIndex = 0; argIndex < argArray.length; argIndex++) |
|||
{ |
|||
delimIndex = strPattern.indexOf(EMPTY_JSON, handledPosition); |
|||
if (delimIndex == -1) |
|||
{ |
|||
if (handledPosition == 0) |
|||
{ |
|||
return strPattern; |
|||
} |
|||
else |
|||
{ // 字符串模板剩余部分不再包含占位符,加入剩余部分后返回结果
|
|||
sbuf.append(strPattern, handledPosition, strPatternLength); |
|||
return sbuf.toString(); |
|||
} |
|||
} |
|||
else |
|||
{ |
|||
if (delimIndex > 0 && strPattern.charAt(delimIndex - 1) == C_BACKSLASH) |
|||
{ |
|||
if (delimIndex > 1 && strPattern.charAt(delimIndex - 2) == C_BACKSLASH) |
|||
{ |
|||
// 转义符之前还有一个转义符,占位符依旧有效
|
|||
sbuf.append(strPattern, handledPosition, delimIndex - 1); |
|||
sbuf.append(Convert.utf8Str(argArray[argIndex])); |
|||
handledPosition = delimIndex + 2; |
|||
} |
|||
else |
|||
{ |
|||
// 占位符被转义
|
|||
argIndex--; |
|||
sbuf.append(strPattern, handledPosition, delimIndex - 1); |
|||
sbuf.append(C_DELIM_START); |
|||
handledPosition = delimIndex + 1; |
|||
} |
|||
} |
|||
else |
|||
{ |
|||
// 正常占位符
|
|||
sbuf.append(strPattern, handledPosition, delimIndex); |
|||
sbuf.append(Convert.utf8Str(argArray[argIndex])); |
|||
handledPosition = delimIndex + 2; |
|||
} |
|||
} |
|||
} |
|||
// 加入最后一个占位符后所有的字符
|
|||
sbuf.append(strPattern, handledPosition, strPattern.length()); |
|||
|
|||
return sbuf.toString(); |
|||
} |
|||
} |
@ -0,0 +1,40 @@ |
|||
package com.win.common.enums; |
|||
|
|||
/** |
|||
* 附件类型 |
|||
* |
|||
* @author win |
|||
* |
|||
*/ |
|||
public enum AccessoryType { |
|||
|
|||
PICK(1, "司机提货"), |
|||
DELIVERY(2, "司机交货"), |
|||
EVENT_LOG(3, "在途事件"), |
|||
AGREEMENT(4, "合同附件"), |
|||
DRIVER_AVATAR(5, "司机头像"), |
|||
FEEDBACK(6, "问题反馈"), |
|||
BASE_INFO(7, "基本信息"), |
|||
ID_CARD1(8, "身份证正面"), |
|||
ID_CARD2(9, "身份证反面"), |
|||
LICENSE(10, "驾驶证"), |
|||
VEHICLE(11, "车辆行驶证"), |
|||
SERVICE(12, "车辆营运证"); |
|||
|
|||
private final int code; |
|||
private final String info; |
|||
|
|||
AccessoryType(int code, String info) { |
|||
this.code = code; |
|||
this.info = info; |
|||
} |
|||
|
|||
public int getCode() { |
|||
return code; |
|||
} |
|||
|
|||
public String getInfo() { |
|||
return info; |
|||
} |
|||
|
|||
} |
@ -0,0 +1,20 @@ |
|||
package com.win.common.enums; |
|||
|
|||
/** |
|||
* 操作状态 |
|||
* |
|||
* @author win |
|||
* |
|||
*/ |
|||
public enum BusinessStatus |
|||
{ |
|||
/** |
|||
* 成功 |
|||
*/ |
|||
SUCCESS, |
|||
|
|||
/** |
|||
* 失败 |
|||
*/ |
|||
FAIL, |
|||
} |
@ -0,0 +1,59 @@ |
|||
package com.win.common.enums; |
|||
|
|||
/** |
|||
* 业务操作类型 |
|||
* |
|||
* @author win |
|||
*/ |
|||
public enum BusinessType |
|||
{ |
|||
/** |
|||
* 其它 |
|||
*/ |
|||
OTHER, |
|||
|
|||
/** |
|||
* 新增 |
|||
*/ |
|||
INSERT, |
|||
|
|||
/** |
|||
* 修改 |
|||
*/ |
|||
UPDATE, |
|||
|
|||
/** |
|||
* 删除 |
|||
*/ |
|||
DELETE, |
|||
|
|||
/** |
|||
* 授权 |
|||
*/ |
|||
GRANT, |
|||
|
|||
/** |
|||
* 导出 |
|||
*/ |
|||
EXPORT, |
|||
|
|||
/** |
|||
* 导入 |
|||
*/ |
|||
IMPORT, |
|||
|
|||
/** |
|||
* 强退 |
|||
*/ |
|||
FORCE, |
|||
|
|||
/** |
|||
* 生成代码 |
|||
*/ |
|||
GENCODE, |
|||
|
|||
/** |
|||
* 清空数据 |
|||
*/ |
|||
CLEAN, |
|||
} |
@ -0,0 +1,19 @@ |
|||
package com.win.common.enums; |
|||
|
|||
/** |
|||
* 数据源 |
|||
* |
|||
* @author win |
|||
*/ |
|||
public enum DataSourceType |
|||
{ |
|||
/** |
|||
* 主库 |
|||
*/ |
|||
MASTER, |
|||
|
|||
/** |
|||
* 从库 |
|||
*/ |
|||
SLAVE |
|||
} |
@ -0,0 +1,37 @@ |
|||
package com.win.common.enums; |
|||
|
|||
import org.springframework.lang.Nullable; |
|||
|
|||
import java.util.HashMap; |
|||
import java.util.Map; |
|||
|
|||
/** |
|||
* 请求方式 |
|||
* |
|||
* @author win |
|||
*/ |
|||
public enum HttpMethod |
|||
{ |
|||
GET, HEAD, POST, PUT, PATCH, DELETE, OPTIONS, TRACE; |
|||
|
|||
private static final Map<String, HttpMethod> mappings = new HashMap<>(16); |
|||
|
|||
static |
|||
{ |
|||
for (HttpMethod httpMethod : values()) |
|||
{ |
|||
mappings.put(httpMethod.name(), httpMethod); |
|||
} |
|||
} |
|||
|
|||
@Nullable |
|||
public static HttpMethod resolve(@Nullable String method) |
|||
{ |
|||
return (method != null ? mappings.get(method) : null); |
|||
} |
|||
|
|||
public boolean matches(String method) |
|||
{ |
|||
return (this == resolve(method)); |
|||
} |
|||
} |
Some files were not shown because too many files changed in this diff
Loading…
Reference in new issue