ljlong_2630
2 years ago
commit
ec4c372b1c
384 changed files with 57031 additions and 0 deletions
@ -0,0 +1,5 @@ |
|||
*.idea |
|||
*.gitignore |
|||
*/target/ |
|||
*.imi |
|||
*.DS_Store |
@ -0,0 +1,20 @@ |
|||
The MIT License (MIT) |
|||
|
|||
Copyright (c) 2018 Dc |
|||
|
|||
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 ../dc-admin/target |
|||
|
|||
set JAVA_OPTS=-Xms256m -Xmx1024m -XX:MetaspaceSize=128m -XX:MaxMetaspaceSize=512m |
|||
|
|||
java -jar %JAVA_OPTS% dc-admin.jar |
|||
|
|||
cd bin |
|||
pause |
@ -0,0 +1,96 @@ |
|||
<?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>dc</artifactId> |
|||
<groupId>com.dc</groupId> |
|||
<version>1.0.0</version> |
|||
</parent> |
|||
<modelVersion>4.0.0</modelVersion> |
|||
<packaging>jar</packaging> |
|||
<artifactId>dc-admin</artifactId> |
|||
|
|||
<description> |
|||
web服务入口 |
|||
</description> |
|||
|
|||
<dependencies> |
|||
|
|||
<!-- spring-boot-devtools --> |
|||
<dependency> |
|||
<groupId>org.springframework.boot</groupId> |
|||
<artifactId>spring-boot-devtools</artifactId> |
|||
<optional>true</optional> <!-- 表示依赖不会传递 --> |
|||
</dependency> |
|||
|
|||
<!-- swagger3--> |
|||
<dependency> |
|||
<groupId>io.springfox</groupId> |
|||
<artifactId>springfox-boot-starter</artifactId> |
|||
</dependency> |
|||
|
|||
<!-- Mysql驱动包 --> |
|||
<dependency> |
|||
<groupId>mysql</groupId> |
|||
<artifactId>mysql-connector-java</artifactId> |
|||
</dependency> |
|||
|
|||
<!-- Postgresql驱动包 --> |
|||
<dependency> |
|||
<groupId>org.postgresql</groupId> |
|||
<artifactId>postgresql</artifactId> |
|||
<scope>runtime</scope> |
|||
</dependency> |
|||
|
|||
<!-- 核心模块--> |
|||
<dependency> |
|||
<groupId>com.dc</groupId> |
|||
<artifactId>dc-framework</artifactId> |
|||
</dependency> |
|||
|
|||
<!-- 定时任务--> |
|||
<dependency> |
|||
<groupId>com.dc</groupId> |
|||
<artifactId>dc-quartz</artifactId> |
|||
</dependency> |
|||
|
|||
<!-- 代码生成--> |
|||
<dependency> |
|||
<groupId>com.dc</groupId> |
|||
<artifactId>dc-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,24 @@ |
|||
package com.dc.web; |
|||
|
|||
import com.alibaba.druid.spring.boot.autoconfigure.DruidDataSourceAutoConfigure; |
|||
import org.springframework.boot.SpringApplication; |
|||
import org.springframework.boot.autoconfigure.SpringBootApplication; |
|||
import org.springframework.boot.autoconfigure.jdbc.DataSourceAutoConfiguration; |
|||
|
|||
/** |
|||
* 启动程序 |
|||
* |
|||
* @author win |
|||
*/ |
|||
@SpringBootApplication( |
|||
scanBasePackages = { "com.dc.common", "com.dc.system", "com.dc.framework", "com.dc.generator", "com.dc.quartz", "com.dc.web"}, |
|||
exclude = {DataSourceAutoConfiguration.class, DruidDataSourceAutoConfigure.class}) |
|||
public class DcApplication { |
|||
|
|||
public static void main(String[] args) { |
|||
// System.setProperty("spring.devtools.restart.enabled", "false");
|
|||
SpringApplication.run(DcApplication.class, args); |
|||
System.out.println("中台系统启动成功"); |
|||
} |
|||
|
|||
} |
@ -0,0 +1,18 @@ |
|||
package com.dc.web; |
|||
|
|||
import org.springframework.boot.builder.SpringApplicationBuilder; |
|||
import org.springframework.boot.web.servlet.support.SpringBootServletInitializer; |
|||
|
|||
/** |
|||
* web容器中进行部署 |
|||
* |
|||
* @author win |
|||
*/ |
|||
public class DcServletInitializer extends SpringBootServletInitializer |
|||
{ |
|||
@Override |
|||
protected SpringApplicationBuilder configure(SpringApplicationBuilder application) |
|||
{ |
|||
return application.sources(DcApplication.class); |
|||
} |
|||
} |
@ -0,0 +1,121 @@ |
|||
package com.dc.web.config; |
|||
|
|||
import com.dc.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.dc.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,95 @@ |
|||
package com.dc.web.controller.common; |
|||
|
|||
import com.google.code.kaptcha.Producer; |
|||
import com.dc.common.config.WinConfig; |
|||
import com.dc.common.constant.CacheConstants; |
|||
import com.dc.common.constant.Constants; |
|||
import com.dc.common.core.domain.AjaxResult; |
|||
import com.dc.common.core.redis.RedisCache; |
|||
import com.dc.common.utils.sign.Base64; |
|||
import com.dc.common.utils.uuid.IdUtils; |
|||
import com.dc.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.dc.web.controller.common; |
|||
|
|||
import com.dc.common.config.WinConfig; |
|||
import com.dc.common.constant.Constants; |
|||
import com.dc.common.core.domain.AjaxResult; |
|||
import com.dc.common.utils.StringUtils; |
|||
import com.dc.common.utils.file.FileUploadUtils; |
|||
import com.dc.common.utils.file.FileUtils; |
|||
import com.dc.framework.config.ServerConfig; |
|||
import com.dc.system.domain.Accessory; |
|||
import com.dc.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,103 @@ |
|||
package com.dc.web.controller.monitor; |
|||
|
|||
import com.dc.common.constant.CacheConstants; |
|||
import com.dc.common.core.domain.AjaxResult; |
|||
import com.dc.common.utils.StringUtils; |
|||
import com.dc.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,25 @@ |
|||
package com.dc.web.controller.monitor; |
|||
|
|||
import com.dc.common.core.domain.AjaxResult; |
|||
import com.dc.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,72 @@ |
|||
package com.dc.web.controller.monitor; |
|||
|
|||
import com.dc.common.annotation.Log; |
|||
import com.dc.common.core.controller.BaseController; |
|||
import com.dc.common.core.domain.AjaxResult; |
|||
import com.dc.common.core.page.TableDataInfo; |
|||
import com.dc.common.enums.BusinessType; |
|||
import com.dc.common.utils.poi.ExcelUtil; |
|||
import com.dc.framework.web.service.SysPasswordService; |
|||
import com.dc.system.domain.SysLogininfor; |
|||
import com.dc.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,60 @@ |
|||
package com.dc.web.controller.monitor; |
|||
|
|||
import com.dc.common.annotation.Log; |
|||
import com.dc.common.core.controller.BaseController; |
|||
import com.dc.common.core.domain.AjaxResult; |
|||
import com.dc.common.core.page.TableDataInfo; |
|||
import com.dc.common.enums.BusinessType; |
|||
import com.dc.common.utils.poi.ExcelUtil; |
|||
import com.dc.system.domain.SysOperLog; |
|||
import com.dc.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,86 @@ |
|||
package com.dc.web.controller.monitor; |
|||
|
|||
import com.dc.common.annotation.Log; |
|||
import com.dc.common.constant.CacheConstants; |
|||
import com.dc.common.core.controller.BaseController; |
|||
import com.dc.common.core.domain.AjaxResult; |
|||
import com.dc.common.core.domain.model.LoginUser; |
|||
import com.dc.common.core.page.TableDataInfo; |
|||
import com.dc.common.core.redis.RedisCache; |
|||
import com.dc.common.enums.BusinessType; |
|||
import com.dc.common.utils.StringUtils; |
|||
import com.dc.system.domain.SysUserOnline; |
|||
import com.dc.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,44 @@ |
|||
package com.dc.web.controller.system; |
|||
|
|||
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; |
|||
import com.dc.common.core.controller.BaseController; |
|||
import com.dc.common.core.domain.AjaxResult; |
|||
import com.dc.system.domain.SysCity; |
|||
import com.dc.system.service.SysCityService; |
|||
import io.swagger.annotations.ApiOperation; |
|||
import org.springframework.beans.factory.annotation.Autowired; |
|||
import org.springframework.web.bind.annotation.GetMapping; |
|||
import org.springframework.web.bind.annotation.PathVariable; |
|||
import org.springframework.web.bind.annotation.RequestMapping; |
|||
import org.springframework.web.bind.annotation.RestController; |
|||
|
|||
import java.util.List; |
|||
|
|||
/** |
|||
* 省市区Controller |
|||
* |
|||
* @author win |
|||
* @date 2023-03-14 |
|||
*/ |
|||
@RestController |
|||
@RequestMapping("/system/sysCity") |
|||
public class SysCityController extends BaseController { |
|||
|
|||
@Autowired |
|||
private SysCityService sysCityService; |
|||
|
|||
/** |
|||
* 根据pid查询省市区列表0是顶级 |
|||
*/ |
|||
@ApiOperation("根据pid查询省市区列表") |
|||
@GetMapping("/list/{pid}") |
|||
public AjaxResult list(@PathVariable("pid") Long pid) { |
|||
QueryWrapper<SysCity> queryWrapper = new QueryWrapper<>(); |
|||
queryWrapper.isNull("delete_time"); |
|||
queryWrapper.eq("pid", pid); |
|||
queryWrapper.orderByAsc("id"); |
|||
List<SysCity> list = sysCityService.list(queryWrapper); |
|||
return success(list); |
|||
} |
|||
|
|||
} |
@ -0,0 +1,120 @@ |
|||
package com.dc.web.controller.system; |
|||
|
|||
import com.dc.common.annotation.Log; |
|||
import com.dc.common.constant.UserConstants; |
|||
import com.dc.common.core.controller.BaseController; |
|||
import com.dc.common.core.domain.AjaxResult; |
|||
import com.dc.common.core.page.TableDataInfo; |
|||
import com.dc.common.enums.BusinessType; |
|||
import com.dc.common.utils.poi.ExcelUtil; |
|||
import com.dc.system.domain.SysConfig; |
|||
import com.dc.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,119 @@ |
|||
package com.dc.web.controller.system; |
|||
|
|||
import com.dc.common.annotation.Log; |
|||
import com.dc.common.constant.UserConstants; |
|||
import com.dc.common.core.controller.BaseController; |
|||
import com.dc.common.core.domain.AjaxResult; |
|||
import com.dc.common.core.domain.entity.SysDept; |
|||
import com.dc.common.enums.BusinessType; |
|||
import com.dc.common.utils.StringUtils; |
|||
import com.dc.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,108 @@ |
|||
package com.dc.web.controller.system; |
|||
|
|||
import com.dc.common.annotation.Log; |
|||
import com.dc.common.core.controller.BaseController; |
|||
import com.dc.common.core.domain.AjaxResult; |
|||
import com.dc.common.core.domain.entity.SysDictData; |
|||
import com.dc.common.core.page.TableDataInfo; |
|||
import com.dc.common.enums.BusinessType; |
|||
import com.dc.common.utils.StringUtils; |
|||
import com.dc.common.utils.poi.ExcelUtil; |
|||
import com.dc.system.service.SysDictDataService; |
|||
import com.dc.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,128 @@ |
|||
package com.dc.web.controller.system; |
|||
|
|||
import com.dc.common.annotation.Log; |
|||
import com.dc.common.constant.UserConstants; |
|||
import com.dc.common.core.controller.BaseController; |
|||
import com.dc.common.core.domain.AjaxResult; |
|||
import com.dc.common.core.domain.entity.SysDictType; |
|||
import com.dc.common.core.page.TableDataInfo; |
|||
import com.dc.common.enums.BusinessType; |
|||
import com.dc.common.utils.poi.ExcelUtil; |
|||
import com.dc.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,29 @@ |
|||
package com.dc.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.dc.common.config.WinConfig; |
|||
import com.dc.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,87 @@ |
|||
package com.dc.web.controller.system; |
|||
|
|||
import com.dc.common.constant.Constants; |
|||
import com.dc.common.core.domain.AjaxResult; |
|||
import com.dc.common.core.domain.entity.SysMenu; |
|||
import com.dc.common.core.domain.entity.SysUser; |
|||
import com.dc.common.core.domain.model.LoginBody; |
|||
import com.dc.common.utils.SecurityUtils; |
|||
import com.dc.framework.web.service.SysLoginService; |
|||
import com.dc.framework.web.service.SysPermissionService; |
|||
import com.dc.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,130 @@ |
|||
package com.dc.web.controller.system; |
|||
|
|||
import com.dc.common.annotation.Log; |
|||
import com.dc.common.constant.UserConstants; |
|||
import com.dc.common.core.controller.BaseController; |
|||
import com.dc.common.core.domain.AjaxResult; |
|||
import com.dc.common.core.domain.entity.SysMenu; |
|||
import com.dc.common.enums.BusinessType; |
|||
import com.dc.common.utils.StringUtils; |
|||
import com.dc.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,79 @@ |
|||
package com.dc.web.controller.system; |
|||
|
|||
import com.dc.common.annotation.Log; |
|||
import com.dc.common.core.controller.BaseController; |
|||
import com.dc.common.core.domain.AjaxResult; |
|||
import com.dc.common.core.page.TableDataInfo; |
|||
import com.dc.common.enums.BusinessType; |
|||
import com.dc.system.domain.SysNotice; |
|||
import com.dc.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,117 @@ |
|||
package com.dc.web.controller.system; |
|||
|
|||
import com.dc.common.annotation.Log; |
|||
import com.dc.common.constant.UserConstants; |
|||
import com.dc.common.core.controller.BaseController; |
|||
import com.dc.common.core.domain.AjaxResult; |
|||
import com.dc.common.core.page.TableDataInfo; |
|||
import com.dc.common.enums.BusinessType; |
|||
import com.dc.common.utils.poi.ExcelUtil; |
|||
import com.dc.system.domain.SysPost; |
|||
import com.dc.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,144 @@ |
|||
package com.dc.web.controller.system; |
|||
|
|||
import com.dc.system.service.SysUserService; |
|||
import com.dc.common.core.controller.BaseController; |
|||
import com.dc.common.core.domain.AjaxResult; |
|||
import com.dc.common.core.domain.entity.SysUser; |
|||
import com.dc.common.core.domain.model.LoginUser; |
|||
import com.dc.common.enums.BusinessType; |
|||
import com.dc.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.dc.common.annotation.Log; |
|||
import com.dc.common.config.WinConfig; |
|||
import com.dc.common.constant.UserConstants; |
|||
import com.dc.common.utils.SecurityUtils; |
|||
import com.dc.common.utils.StringUtils; |
|||
import com.dc.common.utils.file.FileUploadUtils; |
|||
import com.dc.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,38 @@ |
|||
package com.dc.web.controller.system; |
|||
|
|||
import com.dc.system.service.SysConfigService; |
|||
import com.dc.common.core.controller.BaseController; |
|||
import com.dc.common.core.domain.AjaxResult; |
|||
import com.dc.common.core.domain.model.RegisterBody; |
|||
import com.dc.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.dc.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,241 @@ |
|||
package com.dc.web.controller.system; |
|||
|
|||
import com.dc.common.annotation.Log; |
|||
import com.dc.common.constant.UserConstants; |
|||
import com.dc.common.core.controller.BaseController; |
|||
import com.dc.common.core.domain.AjaxResult; |
|||
import com.dc.common.core.domain.entity.SysDept; |
|||
import com.dc.common.core.domain.entity.SysRole; |
|||
import com.dc.common.core.domain.entity.SysUser; |
|||
import com.dc.common.core.domain.model.LoginUser; |
|||
import com.dc.common.core.page.TableDataInfo; |
|||
import com.dc.common.enums.BusinessType; |
|||
import com.dc.common.utils.StringUtils; |
|||
import com.dc.common.utils.poi.ExcelUtil; |
|||
import com.dc.framework.web.service.SysPermissionService; |
|||
import com.dc.framework.web.service.TokenService; |
|||
import com.dc.system.domain.SysUserRole; |
|||
import com.dc.system.service.SysDeptService; |
|||
import com.dc.system.service.SysRoleService; |
|||
import com.dc.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,237 @@ |
|||
package com.dc.web.controller.system; |
|||
|
|||
import com.dc.common.annotation.Log; |
|||
import com.dc.common.constant.UserConstants; |
|||
import com.dc.common.core.controller.BaseController; |
|||
import com.dc.common.core.domain.AjaxResult; |
|||
import com.dc.common.core.domain.entity.SysDept; |
|||
import com.dc.common.core.domain.entity.SysRole; |
|||
import com.dc.common.core.domain.entity.SysUser; |
|||
import com.dc.common.core.page.TableDataInfo; |
|||
import com.dc.common.enums.BusinessType; |
|||
import com.dc.common.utils.SecurityUtils; |
|||
import com.dc.common.utils.StringUtils; |
|||
import com.dc.common.utils.poi.ExcelUtil; |
|||
import com.dc.system.service.SysDeptService; |
|||
import com.dc.system.service.SysPostService; |
|||
import com.dc.system.service.SysRoleService; |
|||
import com.dc.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,22 @@ |
|||
package com.dc.web.controller.tool; |
|||
|
|||
import com.dc.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("/swagger-ui.html"); |
|||
} |
|||
} |
@ -0,0 +1,167 @@ |
|||
package com.dc.web.controller.tool; |
|||
|
|||
import com.dc.common.core.controller.BaseController; |
|||
import com.dc.common.core.domain.R; |
|||
import com.dc.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,46 @@ |
|||
package com.dc.web.websocket; |
|||
|
|||
import lombok.extern.slf4j.Slf4j; |
|||
|
|||
import java.util.concurrent.Semaphore; |
|||
|
|||
/** |
|||
* 信号量相关处理 |
|||
* |
|||
* @author ruoyi |
|||
*/ |
|||
@Slf4j |
|||
public class SemaphoreUtils { |
|||
|
|||
/** |
|||
* 获取信号量 |
|||
* |
|||
* @param semaphore |
|||
* @return |
|||
*/ |
|||
public static boolean tryAcquire(Semaphore semaphore) { |
|||
boolean flag = false; |
|||
|
|||
try { |
|||
flag = semaphore.tryAcquire(); |
|||
} catch (Exception e) { |
|||
log.error("获取信号量异常", e); |
|||
} |
|||
|
|||
return flag; |
|||
} |
|||
|
|||
/** |
|||
* 释放信号量 |
|||
* |
|||
* @param semaphore |
|||
*/ |
|||
public static void release(Semaphore semaphore) { |
|||
|
|||
try { |
|||
semaphore.release(); |
|||
} catch (Exception e) { |
|||
log.error("释放信号量异常", e); |
|||
} |
|||
} |
|||
} |
@ -0,0 +1,18 @@ |
|||
package com.dc.web.websocket; |
|||
|
|||
import org.springframework.context.annotation.Bean; |
|||
import org.springframework.context.annotation.Configuration; |
|||
import org.springframework.web.socket.server.standard.ServerEndpointExporter; |
|||
|
|||
/** |
|||
* websocket 配置 |
|||
* |
|||
* @author ruoyi |
|||
*/ |
|||
@Configuration |
|||
public class WebSocketConfig { |
|||
@Bean |
|||
public ServerEndpointExporter serverEndpointExporter() { |
|||
return new ServerEndpointExporter(); |
|||
} |
|||
} |
@ -0,0 +1,91 @@ |
|||
package com.dc.web.websocket; |
|||
|
|||
import lombok.extern.slf4j.Slf4j; |
|||
import org.springframework.stereotype.Component; |
|||
|
|||
import javax.websocket.*; |
|||
import javax.websocket.server.PathParam; |
|||
import javax.websocket.server.ServerEndpoint; |
|||
import java.util.concurrent.Semaphore; |
|||
|
|||
/** |
|||
* websocket 消息处理 |
|||
* |
|||
* @author ruoyi |
|||
*/ |
|||
@Slf4j |
|||
@Component |
|||
@ServerEndpoint("/websocket/{sessionId}") |
|||
public class WebSocketServer { |
|||
|
|||
/** |
|||
* 默认最多允许同时在线人数100 |
|||
*/ |
|||
public static int socketMaxOnlineCount = 100; |
|||
|
|||
private static Semaphore socketSemaphore = new Semaphore(socketMaxOnlineCount); |
|||
|
|||
/** |
|||
* 连接建立成功调用的方法 |
|||
*/ |
|||
@OnOpen |
|||
public void onOpen(Session session, @PathParam("sessionId") String sessionId) throws Exception { |
|||
log.info("sessionId - {}", sessionId); |
|||
boolean semaphoreFlag = false; |
|||
// 尝试获取信号量
|
|||
semaphoreFlag = SemaphoreUtils.tryAcquire(socketSemaphore); |
|||
if (!semaphoreFlag) { |
|||
// 未获取到信号量
|
|||
log.error("\n 当前在线人数超过限制数- {}", socketMaxOnlineCount); |
|||
WebSocketUsers.sendMessageToUserByText(session, "当前在线人数超过限制数:" + socketMaxOnlineCount); |
|||
session.close(); |
|||
} else { |
|||
// 添加用户
|
|||
WebSocketUsers.put(sessionId, session); |
|||
log.info("\n 建立连接 - {}", session); |
|||
log.info("\n 当前人数 - {}", WebSocketUsers.getUsers().size()); |
|||
WebSocketUsers.sendMessageToUserByText(session, "连接成功"); |
|||
} |
|||
} |
|||
|
|||
/** |
|||
* 连接关闭时处理 |
|||
*/ |
|||
@OnClose |
|||
public void onClose(Session session) { |
|||
log.info("\n 关闭连接 - {}", session); |
|||
// 移除用户
|
|||
WebSocketUsers.remove(session.getId()); |
|||
// 获取到信号量则需释放
|
|||
SemaphoreUtils.release(socketSemaphore); |
|||
} |
|||
|
|||
/** |
|||
* 抛出异常时处理 |
|||
*/ |
|||
@OnError |
|||
public void onError(Session session, Throwable exception) throws Exception { |
|||
if (session.isOpen()) { |
|||
// 关闭连接
|
|||
session.close(); |
|||
} |
|||
String sessionId = session.getId(); |
|||
log.info("\n 连接异常 - {}", sessionId); |
|||
log.info("\n 异常信息 - {}", exception); |
|||
// 移出用户
|
|||
WebSocketUsers.remove(sessionId); |
|||
// 获取到信号量则需释放
|
|||
SemaphoreUtils.release(socketSemaphore); |
|||
} |
|||
|
|||
/** |
|||
* 服务器接收到客户端消息时调用的方法 |
|||
* 自定义sessionId,每个设备不同的sessionId,这样就可以给每个设备发送消息了 |
|||
*/ |
|||
@OnMessage |
|||
public void onMessage(String message, @PathParam("sessionId") String sessionId) { |
|||
log.info("sessionId - {}", sessionId); |
|||
String msg = message.replace("你", "我").replace("吗", ""); |
|||
WebSocketUsers.sendMessageToUserByText(WebSocketUsers.getUsers().get(sessionId), msg); |
|||
} |
|||
} |
@ -0,0 +1,114 @@ |
|||
package com.dc.web.websocket; |
|||
|
|||
import lombok.extern.slf4j.Slf4j; |
|||
|
|||
import javax.websocket.Session; |
|||
import java.io.IOException; |
|||
import java.util.Collection; |
|||
import java.util.Map; |
|||
import java.util.Set; |
|||
import java.util.concurrent.ConcurrentHashMap; |
|||
|
|||
/** |
|||
* websocket 客户端用户集 |
|||
* |
|||
* @author ruoyi |
|||
*/ |
|||
@Slf4j |
|||
public class WebSocketUsers { |
|||
|
|||
/** |
|||
* 用户集 |
|||
*/ |
|||
private static Map<String, Session> USERS = new ConcurrentHashMap<String, Session>(); |
|||
|
|||
/** |
|||
* 存储用户 |
|||
* |
|||
* @param key 唯一键 |
|||
* @param session 用户信息 |
|||
*/ |
|||
public static void put(String key, Session session) { |
|||
USERS.put(key, session); |
|||
} |
|||
|
|||
/** |
|||
* 移除用户 |
|||
* |
|||
* @param session 用户信息 |
|||
* @return 移除结果 |
|||
*/ |
|||
public static boolean remove(Session session) { |
|||
String key = null; |
|||
boolean flag = USERS.containsValue(session); |
|||
if (flag) { |
|||
Set<Map.Entry<String, Session>> entries = USERS.entrySet(); |
|||
for (Map.Entry<String, Session> entry : entries) { |
|||
Session value = entry.getValue(); |
|||
if (value.equals(session)) { |
|||
key = entry.getKey(); |
|||
break; |
|||
} |
|||
} |
|||
} else { |
|||
return true; |
|||
} |
|||
return remove(key); |
|||
} |
|||
|
|||
/** |
|||
* 移出用户 |
|||
* |
|||
* @param key 键 |
|||
*/ |
|||
public static boolean remove(String key) { |
|||
log.info("\n 正在移出用户 - {}", key); |
|||
Session remove = USERS.remove(key); |
|||
if (remove != null) { |
|||
boolean containsValue = USERS.containsValue(remove); |
|||
log.info("\n 移出结果 - {}", containsValue ? "失败" : "成功"); |
|||
return containsValue; |
|||
} else { |
|||
return true; |
|||
} |
|||
} |
|||
|
|||
/** |
|||
* 获取在线用户列表 |
|||
* |
|||
* @return 返回用户集合 |
|||
*/ |
|||
public static Map<String, Session> getUsers() { |
|||
return USERS; |
|||
} |
|||
|
|||
/** |
|||
* 群发消息文本消息 |
|||
* |
|||
* @param message 消息内容 |
|||
*/ |
|||
public static void sendMessageToUsersByText(String message) { |
|||
Collection<Session> values = USERS.values(); |
|||
for (Session value : values) { |
|||
sendMessageToUserByText(value, message); |
|||
} |
|||
} |
|||
|
|||
/** |
|||
* 发送文本消息 |
|||
* |
|||
* @param session 自己的用户名 |
|||
* @param message 消息内容 |
|||
*/ |
|||
public static void sendMessageToUserByText(Session session, String message) { |
|||
if (session != null) { |
|||
try { |
|||
session.getBasicRemote().sendText(message); |
|||
} catch (IOException e) { |
|||
log.error("\n[发送消息异常]", e); |
|||
} |
|||
} else { |
|||
log.info("\n[你已离线]"); |
|||
} |
|||
} |
|||
} |
@ -0,0 +1 @@ |
|||
restart.include.json=/com.alibaba.fastjson.*.jar |
@ -0,0 +1,157 @@ |
|||
# 开发环境配置 |
|||
server: |
|||
# 服务器的HTTP端口,默认为8080 |
|||
port: 9000 |
|||
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.dc: 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/ccwin?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8 |
|||
# username: root |
|||
# password: Microdoft@2021 |
|||
# 读数据源 |
|||
slave0: |
|||
# type: com.alibaba.druid.pool.DruidDataSource |
|||
# driverClassName: com.mysql.cj.jdbc.Driver |
|||
# url: jdbc:mysql://dev.ccwin-in.com:23113/ccwin?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8 |
|||
# username: root |
|||
# password: Microdoft@2021 |
|||
# 读数据源 |
|||
slave1: |
|||
# type: com.alibaba.druid.pool.DruidDataSource |
|||
# driverClassName: com.mysql.cj.jdbc.Driver |
|||
# url: jdbc:mysql://dev.ccwin-in.com:23113/ccwin?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8 |
|||
# username: root |
|||
# 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: |
|||
dcdata: |
|||
driver-class-name: org.postgresql.Driver |
|||
type: com.alibaba.druid.pool.DruidDataSource |
|||
url: jdbc:postgresql://10.10.10.59:5432/dcdatabase?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai |
|||
username: postgres |
|||
password: 123456 |
|||
primary: dcdata |
|||
# 资源信息 |
|||
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: 10.10.10.55 |
|||
# 端口,默认为6379 |
|||
port: 7000 |
|||
# 数据库索引 |
|||
database: 0 |
|||
# 密码 |
|||
password: redis123 |
|||
# 连接超时时间 |
|||
timeout: 10s |
|||
lettuce: |
|||
pool: |
|||
# 连接池中的最小空闲连接 |
|||
min-idle: 0 |
|||
# 连接池中的最大空闲连接 |
|||
max-idle: 8 |
|||
# 连接池的最大数据库连接数 |
|||
max-active: 8 |
|||
# #连接池最大阻塞等待时间(使用负值表示没有限制) |
|||
max-wait: -1ms |
|||
|
|||
# token配置 |
|||
token: |
|||
# 令牌自定义标识 |
|||
header: Authorization |
|||
# 令牌密钥 |
|||
secret: data_center |
|||
# 令牌有效期(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.dc.**.mapper |
|||
# 对应的 XML 文件位置 |
|||
mapperLocations: classpath*:mapper/**/*Mapper.xml |
|||
# 实体扫描,多个package用逗号或者分号分隔 |
|||
typeAliasesPackage: com.dc.**.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: postgresql |
|||
supportMethodsArguments: true |
|||
params: count=countSql |
@ -0,0 +1,157 @@ |
|||
# 开发环境配置 |
|||
server: |
|||
# 服务器的HTTP端口,默认为8080 |
|||
port: 9000 |
|||
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.dc: 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: root |
|||
# 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: root |
|||
# 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: root |
|||
# 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: |
|||
dcdata: |
|||
driver-class-name: org.postgresql.Driver |
|||
type: com.alibaba.druid.pool.DruidDataSource |
|||
url: jdbc:postgresql://10.10.10.56:5432/dcdatabase?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai |
|||
username: postgres |
|||
password: 123456 |
|||
primary: dcdata |
|||
# 资源信息 |
|||
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: 10.10.10.55 |
|||
# 端口,默认为6379 |
|||
port: 7000 |
|||
# 数据库索引 |
|||
database: 1 |
|||
# 密码 |
|||
password: redis123 |
|||
# 连接超时时间 |
|||
timeout: 10s |
|||
lettuce: |
|||
pool: |
|||
# 连接池中的最小空闲连接 |
|||
min-idle: 0 |
|||
# 连接池中的最大空闲连接 |
|||
max-idle: 8 |
|||
# 连接池的最大数据库连接数 |
|||
max-active: 8 |
|||
# #连接池最大阻塞等待时间(使用负值表示没有限制) |
|||
max-wait: -1ms |
|||
|
|||
# token配置 |
|||
token: |
|||
# 令牌自定义标识 |
|||
header: Authorization |
|||
# 令牌密钥 |
|||
secret: data_center |
|||
# 令牌有效期(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.dc: 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/ccwin?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8 |
|||
username: root |
|||
password: Microdoft@2021 |
|||
# 读数据源 |
|||
slave0: |
|||
type: com.alibaba.druid.pool.DruidDataSource |
|||
driverClassName: com.mysql.cj.jdbc.Driver |
|||
url: jdbc:mysql://dev.ccwin-in.com:23113/ccwin?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8 |
|||
username: root |
|||
password: Microdoft@2021 |
|||
# 读数据源 |
|||
slave1: |
|||
type: com.alibaba.druid.pool.DruidDataSource |
|||
driverClassName: com.mysql.cj.jdbc.Driver |
|||
url: jdbc:mysql://dev.ccwin-in.com:23113/ccwin?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8 |
|||
username: root |
|||
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/ccwin?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8 |
|||
username: root |
|||
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: 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: data_center |
|||
profiles: |
|||
include: druid,mybatis |
|||
active: prod |
|||
main: |
|||
allow-bean-definition-overriding: true |
|||
servlet: |
|||
multipart: |
|||
enabled: true |
|||
max-file-size: 200MB |
|||
max-request-size: 1000MB |
|||
|
|||
# 项目相关配置 |
|||
dccenter: |
|||
# 名称 |
|||
name: dc |
|||
# 版本 |
|||
version: 3.8.5 |
|||
# 版权年份 |
|||
copyrightYear: 2023 |
|||
# 实例演示开关 |
|||
demoEnabled: true |
|||
# 文件路径 示例( Windows配置D:/win/uploadPath,Linux配置 /home/win/uploadPath) |
|||
profile: /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,84 @@ |
|||
<?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>dc</artifactId> |
|||
<groupId>com.dc</groupId> |
|||
<version>1.0.0</version> |
|||
</parent> |
|||
<modelVersion>4.0.0</modelVersion> |
|||
<packaging>jar</packaging> |
|||
<artifactId>dc-app</artifactId> |
|||
|
|||
<description> |
|||
web服务入口 |
|||
</description> |
|||
|
|||
<dependencies> |
|||
|
|||
<!-- spring-boot-devtools --> |
|||
<dependency> |
|||
<groupId>org.springframework.boot</groupId> |
|||
<artifactId>spring-boot-devtools</artifactId> |
|||
<optional>true</optional> <!-- 表示依赖不会传递 --> |
|||
</dependency> |
|||
|
|||
<!-- swagger3--> |
|||
<dependency> |
|||
<groupId>io.springfox</groupId> |
|||
<artifactId>springfox-boot-starter</artifactId> |
|||
</dependency> |
|||
|
|||
<!-- 防止进入swagger页面报类型转换错误,排除3.0.0中的引用,手动增加1.6.2版本 --> |
|||
<dependency> |
|||
<groupId>io.swagger</groupId> |
|||
<artifactId>swagger-models</artifactId> |
|||
<version>1.6.2</version> |
|||
</dependency> |
|||
|
|||
<!-- Mysql驱动包 --> |
|||
<dependency> |
|||
<groupId>mysql</groupId> |
|||
<artifactId>mysql-connector-java</artifactId> |
|||
</dependency> |
|||
|
|||
<!-- 核心模块--> |
|||
<dependency> |
|||
<groupId>com.dc</groupId> |
|||
<artifactId>dc-framework</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,25 @@ |
|||
package com.dc.app; |
|||
|
|||
import com.alibaba.druid.spring.boot.autoconfigure.DruidDataSourceAutoConfigure; |
|||
import org.springframework.boot.SpringApplication; |
|||
import org.springframework.boot.autoconfigure.SpringBootApplication; |
|||
import org.springframework.boot.autoconfigure.jdbc.DataSourceAutoConfiguration; |
|||
import org.springframework.boot.autoconfigure.security.servlet.SecurityAutoConfiguration; |
|||
|
|||
/** |
|||
* 启动程序 |
|||
* |
|||
* @author win |
|||
*/ |
|||
@SpringBootApplication( |
|||
scanBasePackages={"com.dc.system", "com.dc.framework", "com.dc.common", "com.dc.app"}, |
|||
exclude = { DataSourceAutoConfiguration.class, DruidDataSourceAutoConfigure.class, SecurityAutoConfiguration.class}) |
|||
public class AppApplication |
|||
{ |
|||
public static void main(String[] args) |
|||
{ |
|||
// System.setProperty("spring.devtools.restart.enabled", "false");
|
|||
SpringApplication.run(AppApplication.class, args); |
|||
System.out.println("闻音启动成功"); |
|||
} |
|||
} |
@ -0,0 +1,121 @@ |
|||
package com.dc.app.config; |
|||
|
|||
import com.dc.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.dc.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,35 @@ |
|||
package com.dc.app.config; |
|||
|
|||
import com.dc.framework.interceptor.UnionIdInterceptor; |
|||
import org.springframework.context.annotation.Bean; |
|||
import org.springframework.context.annotation.Configuration; |
|||
import org.springframework.web.servlet.config.annotation.EnableWebMvc; |
|||
import org.springframework.web.servlet.config.annotation.InterceptorRegistry; |
|||
import org.springframework.web.servlet.config.annotation.ResourceHandlerRegistry; |
|||
import org.springframework.web.servlet.config.annotation.WebMvcConfigurer; |
|||
|
|||
@Configuration |
|||
@EnableWebMvc |
|||
public class WebConfig implements WebMvcConfigurer { |
|||
|
|||
@Bean |
|||
UnionIdInterceptor localInterceptor() { |
|||
return new UnionIdInterceptor(); |
|||
} |
|||
|
|||
@Override |
|||
public void addInterceptors(InterceptorRegistry registry) { |
|||
registry.addInterceptor(localInterceptor()) |
|||
.addPathPatterns("/**") |
|||
.excludePathPatterns("/swagger-resources/**", "/webjars/**", "/v3/**", "/swagger-ui.html/**"); |
|||
} |
|||
|
|||
@Override |
|||
public void addResourceHandlers(ResourceHandlerRegistry registry) { |
|||
registry.addResourceHandler("swagger-ui.html") |
|||
.addResourceLocations("classpath:/META-INF/resources/"); |
|||
registry.addResourceHandler("/webjars/**") |
|||
.addResourceLocations("classpath:/META-INF/resources/webjars/"); |
|||
} |
|||
|
|||
} |
@ -0,0 +1,124 @@ |
|||
package com.dc.app.controller.common; |
|||
|
|||
import com.dc.framework.config.ServerConfig; |
|||
import com.dc.common.config.WinConfig; |
|||
import com.dc.common.core.domain.AjaxResult; |
|||
import com.dc.common.utils.StringUtils; |
|||
import com.dc.common.utils.file.FileUploadUtils; |
|||
import com.dc.common.utils.file.FileUtils; |
|||
import com.dc.system.domain.Accessory; |
|||
import com.dc.system.service.AccessoryService; |
|||
import io.swagger.annotations.ApiOperation; |
|||
import org.slf4j.Logger; |
|||
import org.slf4j.LoggerFactory; |
|||
import org.springframework.beans.factory.annotation.Autowired; |
|||
import org.springframework.beans.factory.annotation.Value; |
|||
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 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; |
|||
@Value("${upload-file.prefix}") |
|||
private String prefix; |
|||
|
|||
private static final String FILE_DELIMETER = ","; |
|||
|
|||
/** |
|||
* 上传文件(单个) |
|||
*/ |
|||
@ApiOperation("上传文件(单个)") |
|||
@PostMapping("/upload") |
|||
public AjaxResult uploadFile(MultipartFile file) throws Exception { |
|||
try { |
|||
// 上传文件路径
|
|||
String filePath = WinConfig.getUploadPath(); |
|||
// 上传并返回新文件名称
|
|||
String fileName = FileUploadUtils.upload(filePath, file); |
|||
String url = prefix + 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) { |
|||
log.error(e.getMessage(), 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 = prefix + 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) { |
|||
log.error(e.getMessage(), e); |
|||
return AjaxResult.error(e.getMessage()); |
|||
} |
|||
} |
|||
|
|||
} |
@ -0,0 +1,43 @@ |
|||
package com.dc.app.controller.system; |
|||
|
|||
import com.dc.common.core.controller.BaseController; |
|||
import com.dc.common.core.domain.AjaxResult; |
|||
import com.dc.common.core.domain.entity.SysDictData; |
|||
import com.dc.common.utils.StringUtils; |
|||
import com.dc.system.service.SysDictTypeService; |
|||
import io.swagger.annotations.ApiOperation; |
|||
import org.springframework.beans.factory.annotation.Autowired; |
|||
import org.springframework.web.bind.annotation.GetMapping; |
|||
import org.springframework.web.bind.annotation.PathVariable; |
|||
import org.springframework.web.bind.annotation.RequestMapping; |
|||
import org.springframework.web.bind.annotation.RestController; |
|||
|
|||
import java.util.ArrayList; |
|||
import java.util.List; |
|||
|
|||
/** |
|||
* 数据字典信息 |
|||
* |
|||
* @author win |
|||
*/ |
|||
@RestController |
|||
@RequestMapping("/system/dict/data") |
|||
public class SysDictDataController extends BaseController { |
|||
|
|||
@Autowired |
|||
private SysDictTypeService dictTypeService; |
|||
|
|||
/** |
|||
* 根据字典类型查询字典数据信息 |
|||
*/ |
|||
@ApiOperation("根据字典类型查询字典数据信息") |
|||
@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); |
|||
} |
|||
|
|||
} |
@ -0,0 +1 @@ |
|||
restart.include.json=/com.alibaba.fastjson.*.jar |
@ -0,0 +1,158 @@ |
|||
# 开发环境配置 |
|||
server: |
|||
# 服务器的HTTP端口,默认为8080 |
|||
port: 8090 |
|||
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.dc: 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/ccwin?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8 |
|||
username: root |
|||
password: Microdoft@2021 |
|||
# 读数据源 |
|||
slave0: |
|||
type: com.alibaba.druid.pool.DruidDataSource |
|||
driverClassName: com.mysql.cj.jdbc.Driver |
|||
url: jdbc:mysql://dev.ccwin-in.com:23113/ccwin?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8 |
|||
username: root |
|||
password: Microdoft@2021 |
|||
# 读数据源 |
|||
slave1: |
|||
type: com.alibaba.druid.pool.DruidDataSource |
|||
driverClassName: com.mysql.cj.jdbc.Driver |
|||
url: jdbc:mysql://dev.ccwin-in.com:23113/ccwin?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8 |
|||
username: root |
|||
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/ccwin?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8 |
|||
username: root |
|||
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: 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: abcdefghijklmnopqrstuvwxyz |
|||
# 令牌有效期(默认30分钟) |
|||
expireTime: 30 |
|||
# 是否允许账户多终端同时登录(true允许 false不允许) |
|||
soloLogin: true |
|||
|
|||
# Swagger配置 |
|||
swagger: |
|||
# 是否开启swagger |
|||
enabled: true |
|||
# 请求前缀 |
|||
pathMapping: / |
|||
#微信设置 |
|||
weixin: |
|||
union-id-url: https://api.weixin.qq.com/sns/jscode2session |
|||
app-id: wx6176535b0b0153f0 |
|||
app-secret: d8f9e009da15d8eb58c89f87a1e6081e |
|||
#上传文件url |
|||
upload-file: |
|||
prefix: http://192.168.0.136:8080 |
@ -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.dc.**.mapper |
|||
# 对应的 XML 文件位置 |
|||
mapperLocations: classpath*:mapper/**/*Mapper.xml |
|||
# 实体扫描,多个package用逗号或者分号分隔 |
|||
typeAliasesPackage: com.dc.**.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,156 @@ |
|||
# 开发环境配置 |
|||
server: |
|||
# 服务器的HTTP端口,默认为8090 |
|||
port: 8090 |
|||
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.dc: 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: root |
|||
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: root |
|||
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: root |
|||
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: root |
|||
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: |
|||
# 令牌自定义标识 |
|||
header: Authorization |
|||
# 令牌密钥 |
|||
secret: abcdefghijklmnopqrstuvwxyz |
|||
# 令牌有效期(默认30分钟) |
|||
expireTime: 30 |
|||
# 是否允许账户多终端同时登录(true允许 false不允许) |
|||
soloLogin: true |
|||
|
|||
# Swagger配置 |
|||
swagger: |
|||
# 是否开启swagger |
|||
enabled: false |
|||
# 请求前缀 |
|||
pathMapping: / |
|||
#微信设置 |
|||
weixin: |
|||
union-id-url: https://api.weixin.qq.com/sns/jscode2session |
|||
app-id: wx6176535b0b0153f0 |
|||
app-secret: d8f9e009da15d8eb58c89f87a1e6081e |
|||
#上传文件url |
|||
upload-file: |
|||
prefix: http://192.168.1.155:8080 |
@ -0,0 +1,158 @@ |
|||
# 开发环境配置 |
|||
server: |
|||
# 服务器的HTTP端口,默认为8080 |
|||
port: 8090 |
|||
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.dc: info |
|||
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/ccwin?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8 |
|||
username: root |
|||
password: Microdoft@2021 |
|||
# 读数据源 |
|||
slave0: |
|||
type: com.alibaba.druid.pool.DruidDataSource |
|||
driverClassName: com.mysql.cj.jdbc.Driver |
|||
url: jdbc:mysql://dev.ccwin-in.com:23113/ccwin?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8 |
|||
username: root |
|||
password: Microdoft@2021 |
|||
# 读数据源 |
|||
slave1: |
|||
type: com.alibaba.druid.pool.DruidDataSource |
|||
driverClassName: com.mysql.cj.jdbc.Driver |
|||
url: jdbc:mysql://dev.ccwin-in.com:23113/ccwin?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8 |
|||
username: root |
|||
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/ccwin?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8 |
|||
username: root |
|||
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: 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: abcdefghijklmnopqrstuvwxyz |
|||
# 令牌有效期(默认30分钟) |
|||
expireTime: 30 |
|||
# 是否允许账户多终端同时登录(true允许 false不允许) |
|||
soloLogin: true |
|||
|
|||
# Swagger配置 |
|||
swagger: |
|||
# 是否开启swagger |
|||
enabled: true |
|||
# 请求前缀 |
|||
pathMapping: / |
|||
#微信设置 |
|||
weixin: |
|||
union-id-url: https://api.weixin.qq.com/sns/jscode2session |
|||
app-id: wx6176535b0b0153f0 |
|||
app-secret: d8f9e009da15d8eb58c89f87a1e6081e |
|||
#上传文件url |
|||
upload-file: |
|||
prefix: http://dev.ccwin-in.com:23111 |
@ -0,0 +1,39 @@ |
|||
spring: |
|||
application: |
|||
name: app |
|||
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,146 @@ |
|||
<?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>dc</artifactId> |
|||
<groupId>com.dc</groupId> |
|||
<version>1.0.0</version> |
|||
</parent> |
|||
<modelVersion>4.0.0</modelVersion> |
|||
|
|||
<artifactId>dc-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> |
|||
|
|||
</dependencies> |
|||
|
|||
</project> |
@ -0,0 +1,19 @@ |
|||
package com.dc.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.dc.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.dc.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.dc.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.dc.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.dc.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.dc.common.annotation; |
|||
|
|||
import com.dc.common.enums.BusinessType; |
|||
import com.dc.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.dc.common.annotation; |
|||
|
|||
import com.dc.common.constant.CacheConstants; |
|||
import com.dc.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.dc.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.dc.common.config; |
|||
|
|||
import org.springframework.boot.context.properties.ConfigurationProperties; |
|||
import org.springframework.stereotype.Component; |
|||
|
|||
/** |
|||
* 读取项目相关配置 |
|||
* |
|||
* @author win |
|||
*/ |
|||
@Component |
|||
@ConfigurationProperties(prefix = "dccenter") |
|||
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.dc.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.dc.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.dc" }; |
|||
|
|||
/** |
|||
* 定时任务违规的字符 |
|||
*/ |
|||
public static final String[] JOB_ERROR_STR = { "java.net.URL", "javax.naming.InitialContext", "org.yaml.snakeyaml", |
|||
"org.springframework", "org.apache", "com.dc.common.utils.file", "com.dc.common.config" }; |
|||
|
|||
/** |
|||
* 登录用户编号 redis key |
|||
*/ |
|||
public static final String LOGIN_USERID_KEY = "login_userid:"; |
|||
|
|||
} |
@ -0,0 +1,9 @@ |
|||
package com.dc.common.constant; |
|||
|
|||
public class DBConstants { |
|||
|
|||
public static final String SHARDING = "sharding"; |
|||
|
|||
public static final String GIS = "gis"; |
|||
|
|||
} |
@ -0,0 +1,117 @@ |
|||
package com.dc.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,94 @@ |
|||
package com.dc.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 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 WARN = 601; |
|||
} |
@ -0,0 +1,50 @@ |
|||
package com.dc.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.dc.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.dc.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.dc.common.core.controller; |
|||
|
|||
import com.github.pagehelper.PageHelper; |
|||
import com.github.pagehelper.PageInfo; |
|||
import com.dc.common.constant.HttpStatus; |
|||
import com.dc.common.context.DataScopeHolder; |
|||
import com.dc.common.core.domain.AjaxResult; |
|||
import com.dc.common.core.domain.model.LoginUser; |
|||
import com.dc.common.core.page.PageDomain; |
|||
import com.dc.common.core.page.TableDataInfo; |
|||
import com.dc.common.core.page.TableSupport; |
|||
import com.dc.common.utils.DateUtils; |
|||
import com.dc.common.utils.PageUtils; |
|||
import com.dc.common.utils.SecurityUtils; |
|||
import com.dc.common.utils.StringUtils; |
|||
import com.dc.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.dc.common.core.domain; |
|||
|
|||
import com.dc.common.constant.HttpStatus; |
|||
import com.dc.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.dc.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.dc.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.dc.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.dc.common.core.domain; |
|||
|
|||
import com.dc.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.dc.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.dc.common.core.domain; |
|||
|
|||
import com.fasterxml.jackson.annotation.JsonInclude; |
|||
import com.dc.common.core.domain.entity.SysDept; |
|||
import com.dc.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.dc.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.dc.common.core.domain.entity; |
|||
|
|||
import com.baomidou.mybatisplus.annotation.IdType; |
|||
import com.baomidou.mybatisplus.annotation.TableId; |
|||
import com.dc.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.dc.common.core.domain.entity; |
|||
|
|||
import com.baomidou.mybatisplus.annotation.IdType; |
|||
import com.baomidou.mybatisplus.annotation.TableId; |
|||
import com.dc.common.annotation.Excel; |
|||
import com.dc.common.constant.UserConstants; |
|||
import com.dc.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.dc.common.core.domain.entity; |
|||
|
|||
import com.baomidou.mybatisplus.annotation.IdType; |
|||
import com.baomidou.mybatisplus.annotation.TableId; |
|||
import com.dc.common.annotation.Excel; |
|||
import com.dc.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,264 @@ |
|||
package com.dc.common.core.domain.entity; |
|||
|
|||
import com.baomidou.mybatisplus.annotation.IdType; |
|||
import com.baomidou.mybatisplus.annotation.TableId; |
|||
import com.dc.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,244 @@ |
|||
package com.dc.common.core.domain.entity; |
|||
|
|||
import com.baomidou.mybatisplus.annotation.IdType; |
|||
import com.baomidou.mybatisplus.annotation.TableId; |
|||
import com.dc.common.annotation.Excel; |
|||
import com.dc.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.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; |
|||
|
|||
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; |
|||
} |
|||
|
|||
@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,334 @@ |
|||
package com.dc.common.core.domain.entity; |
|||
|
|||
import com.baomidou.mybatisplus.annotation.IdType; |
|||
import com.baomidou.mybatisplus.annotation.TableField; |
|||
import com.baomidou.mybatisplus.annotation.TableId; |
|||
import com.dc.common.xss.Xss; |
|||
import com.dc.common.annotation.Excel; |
|||
import com.dc.common.annotation.Excels; |
|||
import com.dc.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.dc.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.dc.common.core.domain.model; |
|||
|
|||
import java.util.Collection; |
|||
import java.util.Set; |
|||
|
|||
import com.dc.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.dc.common.core.domain.model; |
|||
|
|||
/** |
|||
* 用户注册对象 |
|||
* |
|||
* @author win |
|||
*/ |
|||
public class RegisterBody extends LoginBody |
|||
{ |
|||
|
|||
} |
@ -0,0 +1,101 @@ |
|||
package com.dc.common.core.page; |
|||
|
|||
import com.dc.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.dc.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.dc.common.core.page; |
|||
|
|||
import com.dc.common.core.text.Convert; |
|||
import com.dc.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(); |
|||
} |
|||
} |
Some files were not shown because too many files changed in this diff
Loading…
Reference in new issue