mirror of
				https://github.com/dromara/RuoYi-Vue-Plus.git
				synced 2025-10-25 19:33:45 +08:00 
			
		
		
		
	Compare commits
	
		
			513 Commits
		
	
	
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | d98acffe4e | ||
|  | ed659da488 | ||
|  | a8227453fc | ||
|  | 225eda7176 | ||
|  | 295cd3670f | ||
|  | e4df0c6da1 | ||
|  | 2a421deaa3 | ||
|  | 7b23b6db6f | ||
|  | 5ca038d888 | ||
|  | 3454e34c7c | ||
|  | 619a80228f | ||
|  | 89de1beb6f | ||
|  | b6442b4640 | ||
|  | be412faf6c | ||
|  | fd3a699ad8 | ||
|  | 4c99cea3e4 | ||
|  | 1d54ef57c7 | ||
|  | 673b225da2 | ||
|  | c3fe137720 | ||
|  | c28aa299bd | ||
|  | b2189ae965 | ||
|  | a3504dac6e | ||
|  | a028b566ed | ||
|  | ca2405c104 | ||
|  | 08f4ae04e1 | ||
|  | 83d69ba507 | ||
|  | 63cb34b563 | ||
|  | 271e42176c | ||
|  | e5647793ce | ||
|  | b87e45ce32 | ||
|  | 903b5aebca | ||
|  | 7492dcc9e6 | ||
|  | 5d2b162bea | ||
|  | 3fce90dbb9 | ||
|  | d40b9324ca | ||
|  | 6875935d37 | ||
|  | 8978012f9d | ||
|  | 7cf4a5da87 | ||
|  | 47b67331d4 | ||
|  | 6e14601c7c | ||
|  | 3546ac2854 | ||
|  | d600cdd8a0 | ||
|  | d2c6e27d07 | ||
|  | 8041ced02d | ||
|  | d81056cbe7 | ||
|  | 44e8a012e2 | ||
|  | 30483dacfb | ||
|  | 9d81d95700 | ||
|  | e6b45d4cdb | ||
|  | c2e28b5d94 | ||
|  | fef7ead0d5 | ||
|  | 06aef0587a | ||
|  | bf7c259cdd | ||
|  | 43d76e5990 | ||
|  | ffde310d30 | ||
|  | 44bc7dd9a5 | ||
|  | 9e5b64e1b7 | ||
|  | 2599073f56 | ||
|  | a2d49f9981 | ||
|  | 877a9d510b | ||
|  | 2455d0b859 | ||
|  | b3c3afc2b4 | ||
|  | 3f97d19381 | ||
|  | 3ab3d49055 | ||
|  | bd89cc0287 | ||
|  | d365a52cd6 | ||
|  | 5e38e054a7 | ||
|  | 317f6d5c87 | ||
|  | c876776a25 | ||
|  | e1c7115d8c | ||
|  | bb4d75aff0 | ||
|  | c5dbd04c9c | ||
|  | 2a8a72a085 | ||
|  | 29c46a15f9 | ||
|  | aae3fe5305 | ||
|  | 2743785aaf | ||
|  | 4d92ef22c3 | ||
|  | 79fc16eeb7 | ||
|  | 2a235917dc | ||
|  | 8a5c8d0db5 | ||
|  | bcd5b713f8 | ||
|  | a9488ba3c9 | ||
|  | be13e3494a | ||
|  | a62d65a9b8 | ||
|  | 44ce6774dc | ||
|  | b911d7f78f | ||
|  | 4644176e26 | ||
|  | df6759b033 | ||
|  | bf8bac2bcc | ||
|  | 37def02ee1 | ||
|  | 09dfb25d73 | ||
|  | 850b98337b | ||
|  | 7f2921f26b | ||
|  | 836017f2b9 | ||
|  | ed22f395ba | ||
|  | bcbc7c1d47 | ||
|  | 1445d6d24a | ||
|  | 4de4763baf | ||
|  | 8362fe1b39 | ||
|  | 258dc16cfd | ||
|  | 8f8e796c77 | ||
|  | a39a98cda9 | ||
|  | 90ba39593a | ||
|  | c3061a19a2 | ||
|  | e11a6163dd | ||
|  | 1b752c35cc | ||
|  | 8b9d3541dd | ||
|  | d4f49b10d7 | ||
|  | 5ba39c0086 | ||
|  | b5db6fe186 | ||
|  | 8d2886e1ca | ||
|  | 965ebd0f03 | ||
|  | cb306b0793 | ||
|  | c5dc08e082 | ||
|  | b00c6dd89b | ||
|  | 2fd28ca5c8 | ||
|  | 14a05ddaca | ||
|  | 209654fdff | ||
|  | f30aa02e7c | ||
|  | dd4374229b | ||
|  | 7eedf37149 | ||
|  | 7aea32f48b | ||
|  | ac38f7b909 | ||
|  | 2c3f1c28e5 | ||
|  | e8ee5ad691 | ||
|  | 5322f5f707 | ||
|  | 408f5055a9 | ||
|  | 6bfae2652f | ||
|  | 9036370d67 | ||
|  | 9bc730866f | ||
|  | a2d3f987c0 | ||
|  | 255b5f2f07 | ||
|  | f43a5cb244 | ||
|  | bf4ac3ad7a | ||
|  | 4f0e73ba97 | ||
|  | f28a91969a | ||
|  | ca285f5e53 | ||
|  | 34f2552cad | ||
|  | c6fe27b040 | ||
|  | 3e2ddb3b25 | ||
|  | 230d19a7aa | ||
|  | d2b7843d97 | ||
|  | ebc6617a8e | ||
|  | dbba894544 | ||
|  | 65eb873f9a | ||
|  | 52673152cc | ||
|  | 36fd16562e | ||
|  | a8a4f2101d | ||
|  | f46bd8b6ba | ||
|  | a627de02c7 | ||
|  | a94a0589dd | ||
|  | 81755a280d | ||
|  | 89d776acb5 | ||
|  | daf660e66d | ||
|  | e4020faff3 | ||
|  | e11b727584 | ||
|  | 0a36a94b73 | ||
|  | 89e7cb19b9 | ||
|  | fa2bdcd5ac | ||
|  | ea71c9b214 | ||
|  | c00e397405 | ||
|  | a2a2640d29 | ||
|  | 7c4a104823 | ||
|  | 7892ec5a59 | ||
|  | e5fd1f76db | ||
|  | 6502f21072 | ||
|  | 48fd65d7f8 | ||
|  | 1010ccca4d | ||
|  | c21ff85b57 | ||
|  | c3bb4d2a61 | ||
|  | d2b7f8ef0f | ||
|  | af25588b88 | ||
|  | 7546ef649c | ||
|  | 2a3bf1d994 | ||
|  | 664192da0b | ||
|  | 9fc3e220a7 | ||
|  | 64f6a69d9a | ||
|  | 16734b1d88 | ||
|  | 31106c91fb | ||
|  | 026a427103 | ||
|  | 7a4f36c00e | ||
|  | 1f3ef4ffe1 | ||
|  | c364836a9d | ||
|  | 97a12075b1 | ||
|  | bafb1372a7 | ||
|  | b4f032fab4 | ||
|  | d36d944b3a | ||
|  | 7af22453ba | ||
|  | d0c4b5bc76 | ||
|  | 4f194aa101 | ||
|  | ef4bfde4a8 | ||
|  | 65a1245a03 | ||
|  | 486e4f8dd3 | ||
|  | 4cfbd8a9d2 | ||
|  | 7ab51b8960 | ||
|  | 18cbd96280 | ||
|  | 2cdea69719 | ||
|  | 6c053b6266 | ||
|  | 20eea9914e | ||
|  | 6d3f4f5a04 | ||
|  | 20e782eb21 | ||
|  | e30fa57ab4 | ||
|  | ef0b07d5c4 | ||
|  | b9b1ec8f41 | ||
|  | 019526fbe9 | ||
|  | 421593c0ba | ||
|  | 91ad85aec1 | ||
|  | d1eacc1d1c | ||
|  | e41dd8a0f1 | ||
|  | 5e1d4f215d | ||
|  | 9a7bb81cd0 | ||
|  | 321bb010cb | ||
|  | e24a79f87b | ||
|  | 2dd0add3e7 | ||
|  | ce279ca360 | ||
|  | fcf606acde | ||
|  | 084907eeca | ||
|  | f8487f581b | ||
|  | 40c9559d9e | ||
|  | 531e0ef918 | ||
|  | 2781655b0a | ||
|  | 64add90edd | ||
|  | 8de93d35ed | ||
|  | eb844e3260 | ||
|  | cedd2d1daf | ||
|  | 81d04fb31f | ||
|  | caba6fb01e | ||
|  | 1c8d44b309 | ||
|  | 984098abce | ||
|  | ead6da4760 | ||
|  | 2ab96587ef | ||
|  | cb9c0e79eb | ||
|  | 96d2b2d6b8 | ||
|  | b374ff4d6d | ||
|  | 149b136e0b | ||
|  | 5389663b72 | ||
|  | f99e24bf82 | ||
|  | a610c5c8c6 | ||
|  | 874cf18566 | ||
|  | 53cb0826bc | ||
|  | 6904f38ea2 | ||
|  | 223ff4ebff | ||
|  | d2ec3e7d9a | ||
|  | b00171366f | ||
|  | 4e817a1109 | ||
|  | d185d4e4cc | ||
|  | 3b574875cb | ||
|  | 4d5048435c | ||
|  | 57df7f8dfe | ||
|  | 74b36fbd98 | ||
|  | 8ea56d3b22 | ||
|  | 019f585c83 | ||
|  | c7c9bd6b08 | ||
|  | b132f04f71 | ||
|  | 2f21f293c1 | ||
|  | 5b3c390e08 | ||
|  | 8a93371baa | ||
|  | 95dcae1a85 | ||
|  | 03e2ff587e | ||
|  | 1ea73a67ca | ||
|  | 1d32420a27 | ||
|  | 9aa8438ced | ||
|  | 0b35927b16 | ||
|  | bbbe83b737 | ||
|  | 06f06ce390 | ||
|  | cc4c52c998 | ||
|  | bd09e5b11c | ||
|  | 181f62c15e | ||
|  | a2c8b0d13e | ||
|  | c4e17ff847 | ||
|  | 3ae5ec92a5 | ||
|  | 2fe919b6ce | ||
|  | a8ab3ffd01 | ||
|  | 2c6e1f0db7 | ||
|  | cd0aad10b0 | ||
|  | da2cb61cae | ||
|  | e4c691fd5f | ||
|  | ea2e560bd9 | ||
|  | 25321984fa | ||
|  | afbe1c98e6 | ||
|  | d6e080d546 | ||
|  | 5c6f30a8a9 | ||
|  | e8e8ae9fd7 | ||
|  | 3353ead5d3 | ||
|  | 160beb8e1c | ||
|  | 3f0d3ffb8a | ||
|  | 13c770b6be | ||
|  | 2eb55528ec | ||
|  | 839f631d6b | ||
|  | 8faae71157 | ||
|  | b87e0fa124 | ||
|  | bb205a5cdb | ||
|  | 7e3c9c1094 | ||
|  | dbb2d8462b | ||
|  | 3bf96c6cd7 | ||
|  | 61375c4bbb | ||
|  | 2e4689d557 | ||
|  | b6596d021b | ||
|  | 0628dc9b2f | ||
|  | 3117080be3 | ||
|  | 16d6e11e94 | ||
|  | 790aa0d24b | ||
|  | d254340b9b | ||
|  | 42a3117e2a | ||
|  | e47dcb10de | ||
|  | 8a7dcf8a80 | ||
|  | 0c30ffa11f | ||
|  | 0904bf6446 | ||
|  | 2173ed504d | ||
|  | 4583787759 | ||
|  | 17550a5f4b | ||
|  | a4558c32b2 | ||
|  | ef4fef3d56 | ||
|  | 3dbbc6a223 | ||
|  | d3696f5223 | ||
|  | b8a8b76c38 | ||
|  | 296e6171a1 | ||
|  | 2d7d137abd | ||
|  | 336adbd056 | ||
|  | 32bfe334c0 | ||
|  | c1c4fb2ca4 | ||
|  | 6c9dc9ae51 | ||
|  | f4b619d1d1 | ||
|  | 255c8a083e | ||
|  | d0700172fa | ||
|  | 83ce927d16 | ||
|  | 809774d87c | ||
|  | 6f3f89a0d3 | ||
|  | a870a1c6bc | ||
|  | e04938666c | ||
|  | c0eb3c53c1 | ||
|  | b6443e0c01 | ||
|  | 83922c5737 | ||
|  | 78cd6f36ef | ||
|  | eed4e09282 | ||
|  | aaa15b403a | ||
|  | 82f1f5d0cf | ||
|  | 2b0452207e | ||
|  | bc67d0b7b7 | ||
|  | a8092ace32 | ||
|  | 12d76e4f20 | ||
|  | c60130e534 | ||
|  | 3eeeb27d70 | ||
|  | c2a179e9dd | ||
|  | 8b6f7b4e4c | ||
|  | ce7097b498 | ||
|  | 60404a6564 | ||
|  | 519ea854d5 | ||
|  | e66d0e4f74 | ||
|  | 9e0ec2b03c | ||
|  | 36e501b457 | ||
|  | 284f47e76c | ||
|  | b47f8fd784 | ||
|  | 37a8addf52 | ||
|  | a6fb88d74c | ||
|  | bb43b2853d | ||
|  | ba1585de34 | ||
|  | 6684812014 | ||
|  | 1419700c43 | ||
|  | 14f6249031 | ||
|  | ea249c33fd | ||
|  | 1c0b410f55 | ||
|  | 1eaea5c81c | ||
|  | 64ec206ecb | ||
|  | e7afea4cb7 | ||
|  | 6d6271d6c9 | ||
|  | cbb0c98f98 | ||
|  | aaf9f57459 | ||
|  | 2006e5e51e | ||
|  | 741a5b275b | ||
|  | eb4376b649 | ||
|  | b1e5ebab8f | ||
|  | 8bd6296721 | ||
|  | ae5c68368b | ||
|  | 4fdb0f48ec | ||
|  | c4207f640b | ||
|  | f6e477b4f5 | ||
|  | 7ae47b50b8 | ||
|  | 0b14155a75 | ||
|  | f1fed76273 | ||
|  | 48813161f6 | ||
|  | a006904724 | ||
|  | 5477ce3c39 | ||
|  | f38d7811e3 | ||
|  | a09f1b8666 | ||
|  | c7071752a7 | ||
|  | 29163a41c2 | ||
|  | c0e4e27dcc | ||
|  | 3401f38edc | ||
|  | 85762f7c92 | ||
|  | 3f142dd0fa | ||
|  | 22b4f87232 | ||
|  | ca5823fcdf | ||
|  | 49fc74be5d | ||
|  | 25f50d74c5 | ||
|  | 266f4d6806 | ||
|  | a6a9814c06 | ||
|  | 5a8d3ddef0 | ||
|  | 99dcbe0207 | ||
|  | 75b22e9a23 | ||
|  | c4f8c1b296 | ||
|  | eecefdc4fa | ||
|  | ded99502ae | ||
|  | 02b95f95a8 | ||
|  | 2a6d2d733e | ||
|  | 3434610349 | ||
|  | bcac70b2ab | ||
|  | 369438a46d | ||
|  | aed8969498 | ||
|  | 4a8781f4d9 | ||
|  | bff9d0560d | ||
|  | 36f8eb71f3 | ||
|  | f7982ede73 | ||
|  | 92804151a3 | ||
|  | 0f2caf1cb6 | ||
|  | 8a81f37d22 | ||
|  | 125547f08f | ||
|  | 30c89b33fe | ||
|  | 7479ff4b06 | ||
|  | 9801e9c29a | ||
|  | 821f40882f | ||
|  | 02ce9868a7 | ||
|  | 6f870e11ff | ||
|  | a8f2ff4531 | ||
|  | eaa3baab3c | ||
|  | 77bce8b1e8 | ||
|  | 6480282826 | ||
|  | 6197ad5090 | ||
|  | b477e40d3c | ||
|  | 7c8eae3735 | ||
|  | f8cc7ce328 | ||
|  | 1a5881b1d0 | ||
|  | 071c4c1412 | ||
|  | 03b31652a2 | ||
|  | 852bc4887a | ||
|  | fa124aeb8b | ||
|  | 258335cc65 | ||
|  | bdebca94b3 | ||
|  | f85bad3388 | ||
|  | e9b0289eff | ||
|  | 40984e201e | ||
|  | 76bf987203 | ||
|  | 3b42abef44 | ||
|  | 26f0737c60 | ||
|  | ac94242875 | ||
|  | 54bfa627f0 | ||
|  | 36c058188a | ||
|  | 5306a45093 | ||
|  | a292cccb63 | ||
|  | 5ccd9877b4 | ||
|  | 7108ec41b5 | ||
|  | 5188d56b4a | ||
|  | 8f7ed66544 | ||
|  | c99b9262a8 | ||
|  | 2ccbaf9143 | ||
|  | d54ab2733c | ||
|  | 2f18d0d709 | ||
|  | 41c75a808a | ||
|  | 1e55853036 | ||
|  | 931ed0eb00 | ||
|  | 9342bbef56 | ||
|  | aaae404b2a | ||
|  | f3a8b4625f | ||
|  | 4021020d3b | ||
|  | 2569e8c0a4 | ||
|  | dcaeb18870 | ||
|  | 30fe14c0ff | ||
|  | 089b3d6e6d | ||
|  | 17b90f8381 | ||
|  | f9c62fc23b | ||
|  | 900867df02 | ||
|  | 12ab8b03d9 | ||
|  | 50599487f8 | ||
|  | 2b53e9d86a | ||
|  | 23270c60bc | ||
|  | 2cb6709323 | ||
|  | 917bc03a43 | ||
|  | c6963e1a96 | ||
|  | d71e35893d | ||
|  | efd277e7ed | ||
|  | dbe3446b63 | ||
|  | d3d3972bea | ||
|  | 5285735c7a | ||
|  | b84e7013d2 | ||
|  | 9bc5414b44 | ||
|  | 6e28683411 | ||
|  | b27a8afc3b | ||
|  | ed7e8d0e5c | ||
|  | 662251e208 | ||
|  | e314a5e333 | ||
|  | a0c165c418 | ||
|  | c604c2de98 | ||
|  | d6107025fa | ||
|  | a7ecfb68c1 | ||
|  | 188d27159d | ||
|  | 2af534eea4 | ||
|  | db193a46e8 | ||
|  | 808bb9a958 | ||
|  | eca8ea1eb6 | ||
|  | d9681e1791 | ||
|  | 7f96363ecb | ||
|  | 04c340627d | ||
|  | c1c6c1cf30 | ||
|  | b47a38d9d8 | ||
|  | 5bb7b0dda5 | ||
|  | 61edd5588e | ||
|  | e1c993c277 | ||
|  | 15abd4d053 | ||
|  | a7376b36f8 | ||
|  | d2b61762b7 | ||
|  | a5e38f6f99 | ||
|  | 4988b585f8 | ||
|  | b35f708c07 | 
							
								
								
									
										1
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							| @@ -29,7 +29,6 @@ target/ | ||||
| nbproject/private/ | ||||
| build/* | ||||
| nbbuild/ | ||||
| dist/ | ||||
| nbdist/ | ||||
| .nb-gradle/ | ||||
|  | ||||
|   | ||||
							
								
								
									
										155
									
								
								README.md
									
									
									
									
									
								
							
							
						
						
									
										155
									
								
								README.md
									
									
									
									
									
								
							| @@ -4,39 +4,49 @@ | ||||
| [](https://gitee.com/JavaLionLi/RuoYi-Vue-Plus/blob/master/LICENSE) | ||||
| [](https://www.jetbrains.com/?from=RuoYi-Vue-Plus) | ||||
| <br> | ||||
| [](https://gitee.com/JavaLionLi/RuoYi-Vue-Plus) | ||||
| [](https://gitee.com/JavaLionLi/RuoYi-Vue-Plus) | ||||
| []() | ||||
| []() | ||||
| []() | ||||
| []() | ||||
|  | ||||
| RuoYi-Vue-Plus 是基于 RuoYi-Vue 针对 `分布式集群` 场景升级 定期与 RuoYi-Vue 同步 | ||||
| > RuoYi-Vue-Plus 是重写 RuoYi-Vue 针对 `分布式集群` 场景全方位升级(不兼容原框架) | ||||
|  | ||||
| 集成 Lock4j dynamic-datasource OSS存储 等分布式场景解决方案 | ||||
| > 系统演示: [传送门](https://gitee.com/JavaLionLi/RuoYi-Vue-Plus/wikis/系统演示?sort_id=4836388) | ||||
|  | ||||
| 集成 Mybatis-Plus Lombok Hutool 等便捷开发工具 适配重写相关业务 便于开发  | ||||
|  | ||||
| * 前端开发框架 Vue、Element UI | ||||
| * 后端开发框架 Spring Boot、Redis | ||||
| * 容器框架 Undertow 基于 Netty 的高性能容器 | ||||
| * 权限认证框架 Spring Security、Jwt,支持多终端认证系统 | ||||
| * 关系数据库 MySQL 适配 8.X  | ||||
| * 缓存数据库 Redis 适配 6.X | ||||
| * 数据库框架 Mybatis-Plus 快速 CRUD 增加开发效率 插件化支持各类需求 | ||||
| * 数据库框架 多数据源框架 dynamic-datasource 支持主从与多种类数据库异构 | ||||
| * 数据库框架 Redis客户端 采用 Redisson 性能更强 | ||||
| * 数据库框架 性能分析插件 p6spy 更强劲的 SQL 分析 | ||||
| * 序列化框架 统一使用 jackson 高效可靠 | ||||
| * 网络框架 Feign、OkHttp3 接口化管理 HTTP 请求 | ||||
| * 分布式锁 Lock4j 注解锁、工具锁 多种多样 | ||||
| * 文件存储 OSS 对象存储模块 支持(Minio、七牛、阿里、腾讯) | ||||
| * 监控框架 spring-boot-admin 全方位服务监控 | ||||
| * 校验框架 validation 增强接口安全性 严谨性 | ||||
| * Excel框架 Alibaba EasyExcel 性能优异 扩展性强 | ||||
| * 文档框架 knife4j 美化接口文档 | ||||
| * 工具类框架 Hutool、Lombok 减少代码冗余 增加安全性 | ||||
| * 代码生成器 一键生成前后端代码 | ||||
| * 部署方式 Docker 容器编排 一键部署业务集群 | ||||
| * 国际化 Spring 标准国际化方解决方案 | ||||
| | 功能介绍 | 使用技术 | 文档地址 | 特性注意事项 | | ||||
| |---|---|---|---| | ||||
| | 当前框架 | RuoYi-Vue-Plus | [RuoYi-Vue-Plus文档](https://gitee.com/JavaLionLi/RuoYi-Vue-Plus/wikis/pages) | 重写RuoYi-Vue全方位升级(不兼容原框架) | | ||||
| | satoken分支 | RuoYi-Vue-Plus-satoken | [satoken分支地址](https://gitee.com/JavaLionLi/RuoYi-Vue-Plus/tree/satoken/) | 高可读性 扩展性(推荐使用) | | ||||
| | 单体分支 | RuoYi-Vue-Plus-fast | [fast分支地址](https://gitee.com/JavaLionLi/RuoYi-Vue-Plus/tree/fast/) | 单体应用结构 | | ||||
| | Vue3分支 | RuoYi-Vue-Plus-UI | [UI地址](https://gitee.com/JavaLionLi/RuoYi-Vue-Plus-UI) | 由于组件还未完善 仅供学习 | | ||||
| | 原框架 | RuoYi-Vue | [RuoYi-Vue官网](http://ruoyi.vip/) | 定期同步需要的功能 | | ||||
| | 前端开发框架 | Vue、Element UI | [Element UI官网](https://element.eleme.cn/#/zh-CN) | | | ||||
| | 后端开发框架 | SpringBoot | [SpringBoot官网](https://spring.io/projects/spring-boot/#learn) | | | ||||
| | 容器框架 | Undertow | [Undertow官网](https://undertow.io/) | 基于 XNIO 的高性能容器 | | ||||
| | 权限认证框架 | Spring Security、Jwt | [SpringSecurity官网](https://spring.io/projects/spring-security#learn) | 支持多终端认证系统 | | ||||
| | 权限认证框架 | Sa-Token、Jwt | [Sa-Token官网](https://sa-token.dev33.cn/) | 强解耦、强扩展 | | ||||
| | 关系数据库 | MySQL | [MySQL官网](https://dev.mysql.com/) | 适配 8.X 最低 5.7 | | ||||
| | 缓存数据库 | Redis | [Redis官网](https://redis.io/) | 适配 6.X 最低 4.X | | ||||
| | 数据库框架 | Mybatis-Plus | [Mybatis-Plus文档](https://baomidou.com/guide/) | 快速 CRUD 增加开发效率 | | ||||
| | 数据库框架 | p6spy | [p6spy官网](https://p6spy.readthedocs.io/) | 更强劲的 SQL 分析 | | ||||
| | 多数据源框架 | dynamic-datasource | [dynamic-ds文档](https://www.kancloud.cn/tracy5546/dynamic-datasource/content) | 支持主从与多种类数据库异构 | | ||||
| | 序列化框架 | Jackson | [Jackson官网](https://github.com/FasterXML/jackson) | 统一使用 jackson 高效可靠 | | ||||
| | Redis客户端 | Redisson | [Redisson文档](https://github.com/redisson/redisson/wiki/%E7%9B%AE%E5%BD%95) | 支持单机、集群配置 | | ||||
| | 分布式限流 | Redisson | [Redisson文档](https://github.com/redisson/redisson/wiki/%E7%9B%AE%E5%BD%95) | 全局、请求IP、集群ID 多种限流 | | ||||
| | 分布式锁 | Lock4j | [Lock4j官网](https://gitee.com/baomidou/lock4j) | 注解锁、工具锁 多种多样 | | ||||
| | 分布式幂等 | Redisson | [Lock4j文档](https://gitee.com/baomidou/lock4j) | 拦截重复提交 | | ||||
| | 分布式日志 | TLog | [TLog文档](https://yomahub.com/tlog/docs) | 支持跟踪链路日志记录、性能分析、链路排查 | | ||||
| | 分布式任务调度 | Xxl-Job | [Xxl-Job官网](https://www.xuxueli.com/xxl-job/) | 高性能 高可靠 易扩展 | | ||||
| | 文件存储 | Minio | [Minio文档](https://docs.min.io/) | 本地存储 | | ||||
| | 文件存储 | 七牛、阿里、腾讯 | [OSS使用文档](https://gitee.com/JavaLionLi/RuoYi-Vue-Plus/wikis/pages?sort_id=4359146&doc_id=1469725) | 云存储 | | ||||
| | 监控框架 | SpringBoot-Admin | [SpringBoot-Admin文档](https://codecentric.github.io/spring-boot-admin/current/) | 全方位服务监控 | | ||||
| | 校验框架 | Validation | [Validation文档](https://docs.jboss.org/hibernate/stable/validator/reference/en-US/html_single/) | 增强接口安全性、严谨性 支持国际化 | | ||||
| | Excel框架 | Alibaba EasyExcel | [EasyExcel文档](https://www.yuque.com/easyexcel/doc/easyexcel) | 性能优异 扩展性强 | | ||||
| | 文档框架 | Knife4j | [Knife4j文档](https://doc.xiaominfo.com/knife4j/documentation/) | 美化接口文档 | | ||||
| | 工具类框架 | Hutool、Lombok | [Hutool文档](https://www.hutool.cn/docs/) | 减少代码冗余 增加安全性 | | ||||
| | 代码生成器 | 适配MP、Knife4j规范化代码 | [Hutool文档](https://www.hutool.cn/docs/) | 一键生成前后端代码 | | ||||
| | 部署方式 | Docker | [Docker文档](https://docs.docker.com/) | 容器编排 一键部署业务集群 | | ||||
| | 国际化 | SpringMessage | [SpringMVC文档](https://docs.spring.io/spring-framework/docs/current/reference/html/web.html#mvc) | Spring标准国际化方案 | | ||||
|  | ||||
| ## 参考文档 | ||||
|  | ||||
| @@ -53,54 +63,20 @@ RuoYi-Vue-Plus 是基于 RuoYi-Vue 针对 `分布式集群` 场景升级 定期 | ||||
|  | ||||
| ## 软件架构图 | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
| ## 贡献代码 | ||||
|  | ||||
| 欢迎各路英雄豪杰 `PR` 代码 请提交到 `dev` 开发分支 统一测试发版 | ||||
|  | ||||
| 框架定位为 `通用后台管理系统(分布式集群强化)` 原则上不接受业务 `PR` | ||||
|  | ||||
| ## 修改RuoYi功能 | ||||
| ### 依赖改动 | ||||
|  | ||||
| * ORM框架 使用 Mybatis-Plus 简化CRUD (不支持主子表) | ||||
| * Bean简化 使用 Lombok 简化 get set toString 等等 | ||||
| * 容器改动 Tomcat 改为 并发性能更好的 undertow | ||||
| * 移除 pagehelper 改为 Mybatis-Plus 分页 | ||||
| * 集成 p6spy 更强劲的 SQL 分析 | ||||
| * 升级 swagger 为 knife4j | ||||
| * 集成 Hutool 5.X 并重写RuoYi部分功能 | ||||
| * 集成 Feign 接口化管理 Http 请求(如三方请求 支付,短信,推送等) | ||||
| * 移除 自带服务监控 改为 spring-boot-admin 全方位监控 | ||||
| * 增加 demo 模块示例(给不会增加模块的小伙伴做参考) | ||||
| * 增加 redisson 高性能 Redis 客户端 | ||||
| * 移除 fastjson 统一使用 jackson 序列化 | ||||
| * 集成 dynamic-datasource 多数据源(默认支持MySQL,其他种类需自行适配) | ||||
| * 集成 Lock4j 实现分布式 注解锁、工具锁 多种多样 | ||||
| * 增加 Docker 容器编排 打包插件与部署脚本 | ||||
| * 移除 通用上传下载 改为 OSS对象存储 支持(Minio、七牛、阿里、腾讯) | ||||
| * 移除 RuoYi自带 Excel 工具 改为 EasyExcel 工具 | ||||
|  | ||||
| ### 代码改动 | ||||
|  | ||||
| * 所有原生功能使用 Mybatis-Plus 与 Lombok 重写 | ||||
| * 增加 IServicePlus 与 BaseMapperPlus 可自定义通用方法 | ||||
| * 代码生成模板 改为适配 Mybatis-Plus 的代码 | ||||
| * 代码生成模板 根据 Alibaba 代码规约 拆分出 VO、BO 等领域对象 | ||||
| * 代码生成模板 增加 文档注解 与 校验注解 简化通用操作 | ||||
| * 项目修改为 maven多环境配置 | ||||
| * 项目配置修改为 application.yml 统一管理 | ||||
| * 数据权限修改为 适配支持单表、多表 | ||||
| * 使用 redisson 实现 spring-cache 整合 | ||||
| * 增加 mybatis-plus 二级缓存 redis 存储 | ||||
|  | ||||
| ### 其他 | ||||
|  | ||||
| * 同步升级 RuoYi-Vue | ||||
| * GitHub 地址 [RuoYi-Vue-Plus-github](https://github.com/JavaLionLi/RuoYi-Vue-Plus) | ||||
| * 单模块 fast 分支 [RuoYi-Vue-Plus-fast](https://gitee.com/JavaLionLi/RuoYi-Vue-Plus/tree/fast/) | ||||
| * Oracle 模块 oracle 分支 [RuoYi-Vue-Plus-oracle](https://gitee.com/JavaLionLi/RuoYi-Vue-Plus/tree/oracle/) | ||||
| * satoken 分支 [RuoYi-Vue-Plus-satoken](https://gitee.com/JavaLionLi/RuoYi-Vue-Plus/tree/satoken/) | ||||
| * 用户扩展项目 [扩展项目列表](https://gitee.com/JavaLionLi/RuoYi-Vue-Plus/wikis/pages?sort_id=4478302&doc_id=1469725) | ||||
|  | ||||
| ## 加群与捐献 | ||||
| >[加群与捐献](https://gitee.com/JavaLionLi/RuoYi-Vue-Plus/wikis/加群与捐献?sort_id=4104598) | ||||
| @@ -111,26 +87,29 @@ RuoYi-Vue-Plus 是基于 RuoYi-Vue 针对 `分布式集群` 场景升级 定期 | ||||
| <img src="https://images.gitee.com/uploads/images/2021/0525/101654_451e4523_1766278.jpeg" width="300px" height="450px" /> | ||||
| <img src="https://images.gitee.com/uploads/images/2021/0525/101713_3d18b119_1766278.jpeg" width="300px" height="450px" /> | ||||
|  | ||||
| ## 内置功能 | ||||
| ## 业务功能 | ||||
|  | ||||
| 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找出系统性能瓶颈。 | ||||
| | 功能 | 介绍 | | ||||
| |---|---| | ||||
| | 用户管理 | 用户是系统操作者,该功能主要完成系统用户配置。 | | ||||
| | 部门管理 | 配置系统组织机构(公司、部门、小组),树结构展现支持数据权限。 | | ||||
| | 岗位管理 | 配置系统用户所属担任职务。 | | ||||
| | 菜单管理 | 配置系统菜单,操作权限,按钮权限标识等。 | | ||||
| | 角色管理 | 角色菜单权限分配、设置角色按机构进行数据范围权限划分。 | | ||||
| | 字典管理 | 对系统中经常使用的一些较为固定的数据进行维护。 | | ||||
| | 参数管理 | 对系统动态配置常用参数。 | | ||||
| | 通知公告 | 系统通知公告信息发布维护。 | | ||||
| | 操作日志 | 系统正常操作日志记录和查询;系统异常信息日志记录和查询。 | | ||||
| | 登录日志 | 系统登录日志记录查询包含登录异常。 | | ||||
| | 文件管理 | 系统文件上传、下载等管理。 | | ||||
| | 定时任务 | 在线(添加、修改、删除)任务调度包含执行结果日志。 | | ||||
| | 代码生成 | 前后端代码的生成(java、html、xml、sql)支持CRUD下载 。 | | ||||
| | 系统接口 | 根据业务代码自动生成相关的api接口文档。 | | ||||
| | 服务监控 | 监视集群系统CPU、内存、磁盘、堆栈、在线日志、Spring相关配置等。 | | ||||
| | 缓存监控 | 对系统的缓存信息查询,命令统计等。 | | ||||
| | 在线构建器 | 拖动表单元素生成相应的HTML代码。 | | ||||
| | 连接池监视 | 监视当前系统数据库连接池状态,可进行分析SQL找出系统性能瓶颈。 | | ||||
| | 使用案例 | 系统的一些功能案例 | | ||||
|  | ||||
| ## 演示图例 | ||||
|  | ||||
| @@ -172,11 +151,3 @@ RuoYi-Vue-Plus 是基于 RuoYi-Vue 针对 `分布式集群` 场景升级 定期 | ||||
| 		</tr> | ||||
| 	</tbody> | ||||
| </table> | ||||
|  | ||||
| ## 在线体验 | ||||
|  | ||||
| - admin/admin123   | ||||
| - 陆陆续续收到一些打赏,为了更好的体验已用于演示服务器升级。谢谢各位小伙伴。 | ||||
|  | ||||
| 演示地址:http://vue.ruoyi.vip   | ||||
| 文档地址:http://doc.ruoyi.vip | ||||
|   | ||||
| @@ -1,2 +0,0 @@ | ||||
| # redis 密码 | ||||
| # requirepass 123456 | ||||
							
								
								
									
										182
									
								
								pom.xml
									
									
									
									
									
								
							
							
						
						
									
										182
									
								
								pom.xml
									
									
									
									
									
								
							| @@ -6,47 +6,52 @@ | ||||
|  | ||||
|     <groupId>com.ruoyi</groupId> | ||||
|     <artifactId>ruoyi-vue-plus</artifactId> | ||||
|     <version>3.1.0</version> | ||||
|     <version>3.5.0</version> | ||||
|  | ||||
|     <name>RuoYi-Vue-Plus</name> | ||||
|     <url>https://gitee.com/JavaLionLi/RuoYi-Vue-Plus</url> | ||||
|     <description>RuoYi-Vue-Plus后台管理系统</description> | ||||
|  | ||||
|     <properties> | ||||
|         <ruoyi-vue-plus.version>3.1.0</ruoyi-vue-plus.version> | ||||
|         <spring-boot.version>2.5.4</spring-boot.version> | ||||
|         <ruoyi-vue-plus.version>3.5.0</ruoyi-vue-plus.version> | ||||
|         <spring-boot.version>2.5.8</spring-boot.version> | ||||
|         <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding> | ||||
|         <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding> | ||||
|         <java.version>1.8</java.version> | ||||
|         <maven-jar-plugin.version>3.2.0</maven-jar-plugin.version> | ||||
|         <druid.version>1.2.6</druid.version> | ||||
|         <druid.version>1.2.8</druid.version> | ||||
|         <knife4j.version>3.0.3</knife4j.version> | ||||
|         <swagger-annotations.version>1.5.22</swagger-annotations.version> | ||||
|         <poi.version>4.1.2</poi.version> | ||||
|         <easyexcel.version>2.2.10</easyexcel.version> | ||||
|         <velocity.version>1.7</velocity.version> | ||||
|         <jwt.version>0.9.1</jwt.version> | ||||
|         <mybatis-plus.version>3.4.3.3</mybatis-plus.version> | ||||
|         <easyexcel.version>2.2.11</easyexcel.version> | ||||
|         <cglib.version>3.3.0</cglib.version> | ||||
|         <velocity.version>2.3</velocity.version> | ||||
|         <mybatis-plus.version>3.4.3.4</mybatis-plus.version> | ||||
|         <p6spy.version>3.9.1</p6spy.version> | ||||
|         <hutool.version>5.7.11</hutool.version> | ||||
|         <feign.version>3.0.3</feign.version> | ||||
|         <feign-okhttp.version>11.6</feign-okhttp.version> | ||||
|         <okhttp.version>4.9.1</okhttp.version> | ||||
|         <spring-boot-admin.version>2.5.1</spring-boot-admin.version> | ||||
|         <redisson.version>3.16.2</redisson.version> | ||||
|         <hutool.version>5.7.18</hutool.version> | ||||
|         <okhttp.version>4.9.2</okhttp.version> | ||||
|         <spring-boot-admin.version>2.5.5</spring-boot-admin.version> | ||||
|         <redisson.version>3.16.7</redisson.version> | ||||
|         <lock4j.version>2.2.1</lock4j.version> | ||||
|         <dynamic-ds.version>3.4.1</dynamic-ds.version> | ||||
|         <dynamic-ds.version>3.5.0</dynamic-ds.version> | ||||
|         <tlog.version>1.3.6</tlog.version> | ||||
|         <xxl-job.version>2.3.0</xxl-job.version> | ||||
|  | ||||
|         <!-- jdk11 缺失依赖 jaxb--> | ||||
|         <jaxb.version>3.0.1</jaxb.version> | ||||
|  | ||||
|         <!-- OSS 配置 --> | ||||
|         <qiniu.version>7.8.0</qiniu.version> | ||||
|         <qiniu.version>7.9.0</qiniu.version> | ||||
|         <aliyun.oss.version>3.13.1</aliyun.oss.version> | ||||
|         <qcloud.cos.version>5.6.51</qcloud.cos.version> | ||||
|         <minio.version>8.3.0</minio.version> | ||||
|         <qcloud.cos.version>5.6.58</qcloud.cos.version> | ||||
|         <minio.version>8.3.4</minio.version> | ||||
|  | ||||
|         <!-- docker 配置 --> | ||||
|         <docker.registry.url>localhost</docker.registry.url> | ||||
|         <docker.registry.host>http://${docker.registry.url}:2375</docker.registry.host> | ||||
|         <docker.namespace>ruoyi</docker.namespace> | ||||
|         <docker.plugin.version>1.2.2</docker.plugin.version> | ||||
|  | ||||
|     </properties> | ||||
|  | ||||
|     <!-- 依赖声明 --> | ||||
| @@ -73,6 +78,18 @@ | ||||
|                 <groupId>com.github.xiaoymin</groupId> | ||||
|                 <artifactId>knife4j-spring-boot-starter</artifactId> | ||||
|                 <version>${knife4j.version}</version> | ||||
|                 <exclusions> | ||||
|                     <exclusion> | ||||
|                         <artifactId>swagger-annotations</artifactId> | ||||
|                         <groupId>io.swagger</groupId> | ||||
|                     </exclusion> | ||||
|                 </exclusions> | ||||
|             </dependency> | ||||
|  | ||||
|             <dependency> | ||||
|                 <groupId>io.swagger</groupId> | ||||
|                 <artifactId>swagger-annotations</artifactId> | ||||
|                 <version>${swagger-annotations.version}</version> | ||||
|             </dependency> | ||||
|  | ||||
|             <!-- excel工具 --> | ||||
| @@ -86,20 +103,36 @@ | ||||
|                 <groupId>com.alibaba</groupId> | ||||
|                 <artifactId>easyexcel</artifactId> | ||||
|                 <version>${easyexcel.version}</version> | ||||
|                 <exclusions> | ||||
|                     <exclusion> | ||||
|                         <groupId>org.apache.poi</groupId> | ||||
|                         <artifactId>poi</artifactId> | ||||
|                     </exclusion> | ||||
|                     <exclusion> | ||||
|                         <groupId>org.apache.poi</groupId> | ||||
|                         <artifactId>poi-ooxml-schemas</artifactId> | ||||
|                     </exclusion> | ||||
|                 </exclusions> | ||||
|             </dependency> | ||||
|  | ||||
|             <dependency> | ||||
|                 <groupId>cglib</groupId> | ||||
|                 <artifactId>cglib</artifactId> | ||||
|                 <version>${cglib.version}</version> | ||||
|             </dependency> | ||||
|  | ||||
|             <!-- velocity代码生成使用模板 --> | ||||
|             <dependency> | ||||
|                 <groupId>org.apache.velocity</groupId> | ||||
|                 <artifactId>velocity</artifactId> | ||||
|                 <artifactId>velocity-engine-core</artifactId> | ||||
|                 <version>${velocity.version}</version> | ||||
|             </dependency> | ||||
|  | ||||
|             <!-- Token生成与解析--> | ||||
|             <!-- jdk11 缺失依赖 jaxb--> | ||||
|             <dependency> | ||||
|                 <groupId>io.jsonwebtoken</groupId> | ||||
|                 <artifactId>jjwt</artifactId> | ||||
|                 <version>${jwt.version}</version> | ||||
|                 <groupId>com.sun.xml.bind</groupId> | ||||
|                 <artifactId>jaxb-impl</artifactId> | ||||
|                 <version>${jaxb.version}</version> | ||||
|             </dependency> | ||||
|  | ||||
|             <!-- dynamic-datasource 多数据源--> | ||||
| @@ -128,20 +161,32 @@ | ||||
|  | ||||
|             <dependency> | ||||
|                 <groupId>cn.hutool</groupId> | ||||
|                 <artifactId>hutool-all</artifactId> | ||||
|                 <artifactId>hutool-core</artifactId> | ||||
|                 <version>${hutool.version}</version> | ||||
|             </dependency> | ||||
|  | ||||
|             <dependency> | ||||
|                 <groupId>org.springframework.cloud</groupId> | ||||
|                 <artifactId>spring-cloud-starter-openfeign</artifactId> | ||||
|                 <version>${feign.version}</version> | ||||
|                 <groupId>cn.hutool</groupId> | ||||
|                 <artifactId>hutool-http</artifactId> | ||||
|                 <version>${hutool.version}</version> | ||||
|             </dependency> | ||||
|  | ||||
|             <dependency> | ||||
|                 <groupId>io.github.openfeign</groupId> | ||||
|                 <artifactId>feign-okhttp</artifactId> | ||||
|                 <version>${feign-okhttp.version}</version> | ||||
|                 <groupId>cn.hutool</groupId> | ||||
|                 <artifactId>hutool-captcha</artifactId> | ||||
|                 <version>${hutool.version}</version> | ||||
|             </dependency> | ||||
|  | ||||
|             <dependency> | ||||
|                 <groupId>cn.hutool</groupId> | ||||
|                 <artifactId>hutool-extra</artifactId> | ||||
|                 <version>${hutool.version}</version> | ||||
|             </dependency> | ||||
|  | ||||
|             <dependency> | ||||
|                 <groupId>cn.hutool</groupId> | ||||
|                 <artifactId>hutool-jwt</artifactId> | ||||
|                 <version>${hutool.version}</version> | ||||
|             </dependency> | ||||
|  | ||||
|             <dependency> | ||||
| @@ -172,10 +217,30 @@ | ||||
|                 <artifactId>lock4j-redisson-spring-boot-starter</artifactId> | ||||
|                 <version>${lock4j.version}</version> | ||||
|             </dependency> | ||||
|             <!-- 定时任务--> | ||||
|  | ||||
|             <!-- xxl-job-core --> | ||||
|             <dependency> | ||||
|                 <groupId>com.xuxueli</groupId> | ||||
|                 <artifactId>xxl-job-core</artifactId> | ||||
|                 <version>${xxl-job.version}</version> | ||||
|             </dependency> | ||||
|  | ||||
|             <dependency> | ||||
|                 <groupId>com.yomahub</groupId> | ||||
|                 <artifactId>tlog-web-spring-boot-starter</artifactId> | ||||
|                 <version>${tlog.version}</version> | ||||
|             </dependency> | ||||
|  | ||||
|             <dependency> | ||||
|                 <groupId>com.yomahub</groupId> | ||||
|                 <artifactId>tlog-xxljob-spring-boot-starter</artifactId> | ||||
|                 <version>${tlog.version}</version> | ||||
|             </dependency> | ||||
|  | ||||
|             <!-- 定时任务 --> | ||||
|             <dependency> | ||||
|                 <groupId>com.ruoyi</groupId> | ||||
|                 <artifactId>ruoyi-quartz</artifactId> | ||||
|                 <artifactId>ruoyi-job</artifactId> | ||||
|                 <version>${ruoyi-vue-plus.version}</version> | ||||
|             </dependency> | ||||
|  | ||||
| @@ -207,7 +272,7 @@ | ||||
|                 <version>${ruoyi-vue-plus.version}</version> | ||||
|             </dependency> | ||||
|  | ||||
|             <!-- demo模块 --> | ||||
|             <!-- OSS对象存储模块 --> | ||||
|             <dependency> | ||||
|                 <groupId>com.ruoyi</groupId> | ||||
|                 <artifactId>ruoyi-oss</artifactId> | ||||
| @@ -228,7 +293,7 @@ | ||||
|         <module>ruoyi-admin</module> | ||||
|         <module>ruoyi-framework</module> | ||||
|         <module>ruoyi-system</module> | ||||
|         <module>ruoyi-quartz</module> | ||||
|         <module>ruoyi-job</module> | ||||
|         <module>ruoyi-generator</module> | ||||
|         <module>ruoyi-common</module> | ||||
|         <module>ruoyi-demo</module> | ||||
| @@ -237,11 +302,6 @@ | ||||
|     </modules> | ||||
|     <packaging>pom</packaging> | ||||
|  | ||||
|  | ||||
|     <dependencies> | ||||
|  | ||||
|     </dependencies> | ||||
|  | ||||
|     <build> | ||||
|         <plugins> | ||||
|             <plugin> | ||||
| @@ -297,6 +357,7 @@ | ||||
|                 <!-- 环境标识,需要与配置文件的名称相对应 --> | ||||
|                 <profiles.active>local</profiles.active> | ||||
|                 <logging.level>debug</logging.level> | ||||
|                 <knife4j.production>false</knife4j.production> | ||||
|                 <endpoints.include>'*'</endpoints.include> | ||||
|             </properties> | ||||
|         </profile> | ||||
| @@ -306,6 +367,7 @@ | ||||
|                 <!-- 环境标识,需要与配置文件的名称相对应 --> | ||||
|                 <profiles.active>dev</profiles.active> | ||||
|                 <logging.level>debug</logging.level> | ||||
|                 <knife4j.production>false</knife4j.production> | ||||
|                 <endpoints.include>'*'</endpoints.include> | ||||
|             </properties> | ||||
|             <activation> | ||||
| @@ -318,48 +380,10 @@ | ||||
|             <properties> | ||||
|                 <profiles.active>prod</profiles.active> | ||||
|                 <logging.level>warn</logging.level> | ||||
|                 <endpoints.include>health,info</endpoints.include> | ||||
|                 <knife4j.production>true</knife4j.production> | ||||
|                 <endpoints.include>health, info, logfile</endpoints.include> | ||||
|             </properties> | ||||
|         </profile> | ||||
|  | ||||
|         <!-- jdk多版本配置 --> | ||||
|         <profile> | ||||
|             <id>jdk8</id> | ||||
|             <activation> | ||||
|                 <activeByDefault>true</activeByDefault> | ||||
|                 <jdk>1.8</jdk> | ||||
|             </activation> | ||||
|             <properties> | ||||
|                 <java.version>1.8</java.version> | ||||
|             </properties> | ||||
|         </profile> | ||||
|         <profile> | ||||
|             <id>jdk11</id> | ||||
|             <activation> | ||||
|                 <jdk>11</jdk> | ||||
|             </activation> | ||||
|             <properties> | ||||
|                 <java.version>11</java.version> | ||||
|                 <jaxb.version>3.0.1</jaxb.version> | ||||
|             </properties> | ||||
|             <dependencyManagement> | ||||
|                 <dependencies> | ||||
|                     <!-- jdk11 缺失依赖 jaxb--> | ||||
|                     <dependency> | ||||
|                         <groupId>com.sun.xml.bind</groupId> | ||||
|                         <artifactId>jaxb-impl</artifactId> | ||||
|                         <version>${jaxb.version}</version> | ||||
|                     </dependency> | ||||
|                 </dependencies> | ||||
|             </dependencyManagement> | ||||
|             <dependencies> | ||||
|                 <!--jaxb--> | ||||
|                 <dependency> | ||||
|                     <groupId>com.sun.xml.bind</groupId> | ||||
|                     <artifactId>jaxb-impl</artifactId> | ||||
|                 </dependency> | ||||
|             </dependencies> | ||||
|         </profile> | ||||
|     </profiles> | ||||
|  | ||||
| </project> | ||||
|   | ||||
| @@ -4,6 +4,7 @@ MAINTAINER Lion Li | ||||
|  | ||||
| RUN mkdir -p /ruoyi/server | ||||
| RUN mkdir -p /ruoyi/server/logs | ||||
| RUN mkdir -p /ruoyi/server/temp | ||||
|  | ||||
| WORKDIR /ruoyi/server | ||||
|  | ||||
|   | ||||
| @@ -5,7 +5,7 @@ | ||||
|     <parent> | ||||
|         <artifactId>ruoyi-vue-plus</artifactId> | ||||
|         <groupId>com.ruoyi</groupId> | ||||
|         <version>3.1.0</version> | ||||
|         <version>3.5.0</version> | ||||
|     </parent> | ||||
|     <modelVersion>4.0.0</modelVersion> | ||||
|     <packaging>jar</packaging> | ||||
| @@ -36,10 +36,14 @@ | ||||
|             <artifactId>ruoyi-framework</artifactId> | ||||
|         </dependency> | ||||
|  | ||||
|         <!-- 定时任务--> | ||||
|         <dependency> | ||||
|             <groupId>com.ruoyi</groupId> | ||||
|             <artifactId>ruoyi-quartz</artifactId> | ||||
|             <artifactId>ruoyi-system</artifactId> | ||||
|         </dependency> | ||||
|  | ||||
|         <dependency> | ||||
|             <groupId>com.ruoyi</groupId> | ||||
|             <artifactId>ruoyi-job</artifactId> | ||||
|         </dependency> | ||||
|  | ||||
|         <dependency> | ||||
| @@ -82,7 +86,7 @@ | ||||
|             <plugin> | ||||
|                 <groupId>org.apache.maven.plugins</groupId> | ||||
|                 <artifactId>maven-war-plugin</artifactId> | ||||
|                 <version>3.1.0</version> | ||||
|                 <version>3.2.0</version> | ||||
|                 <configuration> | ||||
|                     <failOnMissingWebXml>false</failOnMissingWebXml> | ||||
|                     <warName>${project.artifactId}</warName> | ||||
|   | ||||
| @@ -2,6 +2,7 @@ package com.ruoyi; | ||||
|  | ||||
| import org.springframework.boot.SpringApplication; | ||||
| import org.springframework.boot.autoconfigure.SpringBootApplication; | ||||
| import org.springframework.boot.context.metrics.buffering.BufferingApplicationStartup; | ||||
|  | ||||
| /** | ||||
|  * 启动程序 | ||||
| @@ -10,12 +11,14 @@ import org.springframework.boot.autoconfigure.SpringBootApplication; | ||||
|  */ | ||||
|  | ||||
| @SpringBootApplication | ||||
| public class RuoYiApplication | ||||
| { | ||||
|     public static void main(String[] args) | ||||
|     { | ||||
| public class RuoYiApplication { | ||||
|  | ||||
|     public static void main(String[] args) { | ||||
|         System.setProperty("spring.devtools.restart.enabled", "false"); | ||||
|         SpringApplication.run(RuoYiApplication.class, args); | ||||
|         SpringApplication application = new SpringApplication(RuoYiApplication.class); | ||||
|         application.setApplicationStartup(new BufferingApplicationStartup(2048)); | ||||
|         application.run(args); | ||||
|         System.out.println("(♥◠‿◠)ノ゙  RuoYi-Vue-Plus启动成功   ლ(´ڡ`ლ)゙"); | ||||
|     } | ||||
|  | ||||
| } | ||||
|   | ||||
| @@ -8,11 +8,11 @@ import org.springframework.boot.web.servlet.support.SpringBootServletInitializer | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| public class RuoYiServletInitializer extends SpringBootServletInitializer | ||||
| { | ||||
| public class RuoYiServletInitializer extends SpringBootServletInitializer { | ||||
|  | ||||
|     @Override | ||||
|     protected SpringApplicationBuilder configure(SpringApplicationBuilder application) | ||||
|     { | ||||
|     protected SpringApplicationBuilder configure(SpringApplicationBuilder application) { | ||||
|         return application.sources(RuoYiApplication.class); | ||||
|     } | ||||
|  | ||||
| } | ||||
|   | ||||
| @@ -13,6 +13,9 @@ import com.ruoyi.common.utils.reflect.ReflectUtils; | ||||
| import com.ruoyi.common.utils.spring.SpringUtils; | ||||
| import com.ruoyi.framework.config.properties.CaptchaProperties; | ||||
| import com.ruoyi.system.service.ISysConfigService; | ||||
| import io.swagger.annotations.Api; | ||||
| import io.swagger.annotations.ApiOperation; | ||||
| import lombok.RequiredArgsConstructor; | ||||
| import org.springframework.beans.factory.annotation.Autowired; | ||||
| import org.springframework.web.bind.annotation.GetMapping; | ||||
| import org.springframework.web.bind.annotation.RestController; | ||||
| @@ -24,61 +27,61 @@ import java.util.concurrent.TimeUnit; | ||||
| /** | ||||
|  * 验证码操作处理 | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  * @author Lion Li | ||||
|  */ | ||||
| @Api(value = "验证码操作处理", tags = {"验证码管理"}) | ||||
| @RequiredArgsConstructor(onConstructor_ = @Autowired) | ||||
| @RestController | ||||
| public class CaptchaController { | ||||
|  | ||||
| 	@Autowired | ||||
| 	private CaptchaProperties captchaProperties; | ||||
|     private final CaptchaProperties captchaProperties; | ||||
|     private final ISysConfigService configService; | ||||
|  | ||||
| 	@Autowired | ||||
| 	private ISysConfigService configService; | ||||
|     /** | ||||
|      * 生成验证码 | ||||
|      */ | ||||
|     @ApiOperation("生成验证码") | ||||
|     @GetMapping("/captchaImage") | ||||
|     public AjaxResult<Map<String, Object>> getCode() { | ||||
|         Map<String, Object> ajax = new HashMap<>(); | ||||
|         boolean captchaOnOff = configService.selectCaptchaOnOff(); | ||||
|         ajax.put("captchaOnOff", captchaOnOff); | ||||
|         if (!captchaOnOff) { | ||||
|             return AjaxResult.success(ajax); | ||||
|         } | ||||
|         // 保存验证码信息 | ||||
|         String uuid = IdUtil.simpleUUID(); | ||||
|         String verifyKey = Constants.CAPTCHA_CODE_KEY + uuid; | ||||
|         // 生成验证码 | ||||
|         CaptchaType captchaType = captchaProperties.getType(); | ||||
|         boolean isMath = CaptchaType.MATH == captchaType; | ||||
|         Integer length = isMath ? captchaProperties.getNumberLength() : captchaProperties.getCharLength(); | ||||
|         CodeGenerator codeGenerator = ReflectUtils.newInstance(captchaType.getClazz(), length); | ||||
|         AbstractCaptcha captcha = SpringUtils.getBean(captchaProperties.getCategory().getClazz()); | ||||
|         captcha.setGenerator(codeGenerator); | ||||
|         captcha.createCode(); | ||||
|         String code = isMath ? getCodeResult(captcha.getCode()) : captcha.getCode(); | ||||
|         RedisUtils.setCacheObject(verifyKey, code, Constants.CAPTCHA_EXPIRATION, TimeUnit.MINUTES); | ||||
|         ajax.put("uuid", uuid); | ||||
|         ajax.put("img", captcha.getImageBase64()); | ||||
|         return AjaxResult.success(ajax); | ||||
|     } | ||||
|  | ||||
| 	/** | ||||
| 	 * 生成验证码 | ||||
| 	 */ | ||||
| 	@GetMapping("/captchaImage") | ||||
| 	public AjaxResult getCode() { | ||||
| 		Map<String, Object> ajax = new HashMap<>(); | ||||
| 		boolean captchaOnOff = configService.selectCaptchaOnOff(); | ||||
| 		ajax.put("captchaOnOff", captchaOnOff); | ||||
| 		if (!captchaOnOff) { | ||||
| 			return AjaxResult.success(ajax); | ||||
| 		} | ||||
| 		// 保存验证码信息 | ||||
| 		String uuid = IdUtil.simpleUUID(); | ||||
| 		String verifyKey = Constants.CAPTCHA_CODE_KEY + uuid; | ||||
| 		// 生成验证码 | ||||
| 		CaptchaType captchaType = captchaProperties.getType(); | ||||
| 		boolean isMath = CaptchaType.MATH == captchaType; | ||||
| 		Integer length = isMath ? captchaProperties.getNumberLength() : captchaProperties.getCharLength(); | ||||
| 		CodeGenerator codeGenerator = ReflectUtils.newInstance(captchaType.getClazz(), length); | ||||
| 		AbstractCaptcha captcha = SpringUtils.getBean(captchaProperties.getCategory().getClazz()); | ||||
| 		captcha.setGenerator(codeGenerator); | ||||
| 		captcha.createCode(); | ||||
| 		String code = isMath ? getCodeResult(captcha.getCode()) : captcha.getCode(); | ||||
| 		RedisUtils.setCacheObject(verifyKey, code, Constants.CAPTCHA_EXPIRATION, TimeUnit.MINUTES); | ||||
| 		ajax.put("uuid", uuid); | ||||
| 		ajax.put("img", captcha.getImageBase64()); | ||||
| 		return AjaxResult.success(ajax); | ||||
| 	} | ||||
|  | ||||
| 	private String getCodeResult(String capStr) { | ||||
| 		int numberLength = captchaProperties.getNumberLength(); | ||||
| 		int a = Convert.toInt(StringUtils.substring(capStr, 0, numberLength).trim()); | ||||
| 		char operator = capStr.charAt(numberLength); | ||||
| 		int b = Convert.toInt(StringUtils.substring(capStr, numberLength + 1, numberLength + 1 + numberLength).trim()); | ||||
| 		switch (operator) { | ||||
| 			case '*': | ||||
| 				return Convert.toStr(a * b); | ||||
| 			case '+': | ||||
| 				return Convert.toStr(a + b); | ||||
| 			case '-': | ||||
| 				return Convert.toStr(a - b); | ||||
| 			default: | ||||
| 				return StringUtils.EMPTY; | ||||
| 		} | ||||
| 	} | ||||
|     private String getCodeResult(String capStr) { | ||||
|         int numberLength = captchaProperties.getNumberLength(); | ||||
|         int a = Convert.toInt(StringUtils.substring(capStr, 0, numberLength).trim()); | ||||
|         char operator = capStr.charAt(numberLength); | ||||
|         int b = Convert.toInt(StringUtils.substring(capStr, numberLength + 1, numberLength + 1 + numberLength).trim()); | ||||
|         switch (operator) { | ||||
|             case '*': | ||||
|                 return Convert.toStr(a * b); | ||||
|             case '+': | ||||
|                 return Convert.toStr(a + b); | ||||
|             case '-': | ||||
|                 return Convert.toStr(a - b); | ||||
|             default: | ||||
|                 return StringUtils.EMPTY; | ||||
|         } | ||||
|     } | ||||
|  | ||||
| } | ||||
|   | ||||
| @@ -1,8 +1,12 @@ | ||||
| package com.ruoyi.web.controller.monitor; | ||||
|  | ||||
| import com.ruoyi.common.utils.StringUtils; | ||||
| import com.ruoyi.common.core.domain.AjaxResult; | ||||
| import com.ruoyi.common.utils.StringUtils; | ||||
| import io.swagger.annotations.Api; | ||||
| import io.swagger.annotations.ApiOperation; | ||||
| import lombok.RequiredArgsConstructor; | ||||
| import org.springframework.beans.factory.annotation.Autowired; | ||||
| import org.springframework.data.redis.connection.RedisServerCommands; | ||||
| import org.springframework.data.redis.core.RedisCallback; | ||||
| import org.springframework.data.redis.core.RedisTemplate; | ||||
| import org.springframework.security.access.prepost.PreAuthorize; | ||||
| @@ -15,35 +19,38 @@ import java.util.*; | ||||
| /** | ||||
|  * 缓存监控 | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  * @author Lion Li | ||||
|  */ | ||||
| @Api(value = "缓存监控", tags = {"缓存监控管理"}) | ||||
| @RequiredArgsConstructor(onConstructor_ = @Autowired) | ||||
| @RestController | ||||
| @RequestMapping("/monitor/cache") | ||||
| public class CacheController | ||||
| { | ||||
|     @Autowired | ||||
|     private RedisTemplate<String, String> redisTemplate; | ||||
| public class CacheController { | ||||
|  | ||||
|     private final RedisTemplate<String, String> redisTemplate; | ||||
|  | ||||
|     @ApiOperation("获取缓存监控详细信息") | ||||
|     @PreAuthorize("@ss.hasPermi('monitor:cache:list')") | ||||
|     @GetMapping() | ||||
|     public AjaxResult getInfo() throws Exception | ||||
|     { | ||||
|         Properties info = (Properties) redisTemplate.execute((RedisCallback<Object>) connection -> connection.info()); | ||||
|     public AjaxResult<Map<String, Object>> getInfo() throws Exception { | ||||
|         Properties info = (Properties) redisTemplate.execute((RedisCallback<Object>) RedisServerCommands::info); | ||||
|         Properties commandStats = (Properties) redisTemplate.execute((RedisCallback<Object>) connection -> connection.info("commandstats")); | ||||
|         Object dbSize = redisTemplate.execute((RedisCallback<Object>) connection -> connection.dbSize()); | ||||
|         Object dbSize = redisTemplate.execute((RedisCallback<Object>) RedisServerCommands::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); | ||||
|         }); | ||||
|         if (commandStats != null) { | ||||
|             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); | ||||
|     } | ||||
|   | ||||
| @@ -3,13 +3,18 @@ package com.ruoyi.web.controller.monitor; | ||||
| import com.ruoyi.common.annotation.Log; | ||||
| import com.ruoyi.common.core.controller.BaseController; | ||||
| import com.ruoyi.common.core.domain.AjaxResult; | ||||
| import com.ruoyi.common.core.domain.PageQuery; | ||||
| import com.ruoyi.common.core.page.TableDataInfo; | ||||
| import com.ruoyi.common.enums.BusinessType; | ||||
| import com.ruoyi.common.utils.poi.ExcelUtil; | ||||
| import com.ruoyi.system.domain.SysLogininfor; | ||||
| import com.ruoyi.system.service.ISysLogininforService; | ||||
| import io.swagger.annotations.Api; | ||||
| import io.swagger.annotations.ApiOperation; | ||||
| import lombok.RequiredArgsConstructor; | ||||
| import org.springframework.beans.factory.annotation.Autowired; | ||||
| import org.springframework.security.access.prepost.PreAuthorize; | ||||
| import org.springframework.validation.annotation.Validated; | ||||
| import org.springframework.web.bind.annotation.*; | ||||
|  | ||||
| import javax.servlet.http.HttpServletResponse; | ||||
| @@ -18,44 +23,46 @@ import java.util.List; | ||||
| /** | ||||
|  * 系统访问记录 | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  * @author Lion Li | ||||
|  */ | ||||
| @Validated | ||||
| @Api(value = "系统访问记录", tags = {"系统访问记录管理"}) | ||||
| @RequiredArgsConstructor(onConstructor_ = @Autowired) | ||||
| @RestController | ||||
| @RequestMapping("/monitor/logininfor") | ||||
| public class SysLogininforController extends BaseController | ||||
| { | ||||
|     @Autowired | ||||
|     private ISysLogininforService logininforService; | ||||
| public class SysLogininforController extends BaseController { | ||||
|  | ||||
|     private final ISysLogininforService logininforService; | ||||
|  | ||||
|     @ApiOperation("查询系统访问记录列表") | ||||
|     @PreAuthorize("@ss.hasPermi('monitor:logininfor:list')") | ||||
|     @GetMapping("/list") | ||||
|     public TableDataInfo list(SysLogininfor logininfor) | ||||
|     { | ||||
|         return logininforService.selectPageLogininforList(logininfor); | ||||
|     public TableDataInfo<SysLogininfor> list(SysLogininfor logininfor, PageQuery pageQuery) { | ||||
|         return logininforService.selectPageLogininforList(logininfor, pageQuery); | ||||
|     } | ||||
|  | ||||
|     @ApiOperation("导出系统访问记录列表") | ||||
|     @Log(title = "登录日志", businessType = BusinessType.EXPORT) | ||||
|     @PreAuthorize("@ss.hasPermi('monitor:logininfor:export')") | ||||
|     @GetMapping("/export") | ||||
|     public void export(SysLogininfor logininfor, HttpServletResponse response) | ||||
|     { | ||||
|     @PostMapping("/export") | ||||
|     public void export(SysLogininfor logininfor, HttpServletResponse response) { | ||||
|         List<SysLogininfor> list = logininforService.selectLogininforList(logininfor); | ||||
| 		ExcelUtil.exportExcel(list, "登录日志", SysLogininfor.class, response); | ||||
|         ExcelUtil.exportExcel(list, "登录日志", SysLogininfor.class, response); | ||||
|     } | ||||
|  | ||||
|     @ApiOperation("删除系统访问记录") | ||||
|     @PreAuthorize("@ss.hasPermi('monitor:logininfor:remove')") | ||||
|     @Log(title = "登录日志", businessType = BusinessType.DELETE) | ||||
|     @DeleteMapping("/{infoIds}") | ||||
|     public AjaxResult remove(@PathVariable Long[] infoIds) | ||||
|     { | ||||
|     public AjaxResult<Void> remove(@PathVariable Long[] infoIds) { | ||||
|         return toAjax(logininforService.deleteLogininforByIds(infoIds)); | ||||
|     } | ||||
|  | ||||
|     @ApiOperation("清空系统访问记录") | ||||
|     @PreAuthorize("@ss.hasPermi('monitor:logininfor:remove')") | ||||
|     @Log(title = "登录日志", businessType = BusinessType.CLEAN) | ||||
|     @DeleteMapping("/clean") | ||||
|     public AjaxResult clean() | ||||
|     { | ||||
|     public AjaxResult<Void> clean() { | ||||
|         logininforService.cleanLogininfor(); | ||||
|         return AjaxResult.success(); | ||||
|     } | ||||
|   | ||||
| @@ -3,13 +3,18 @@ package com.ruoyi.web.controller.monitor; | ||||
| import com.ruoyi.common.annotation.Log; | ||||
| import com.ruoyi.common.core.controller.BaseController; | ||||
| import com.ruoyi.common.core.domain.AjaxResult; | ||||
| import com.ruoyi.common.core.domain.PageQuery; | ||||
| import com.ruoyi.common.core.page.TableDataInfo; | ||||
| import com.ruoyi.common.enums.BusinessType; | ||||
| import com.ruoyi.common.utils.poi.ExcelUtil; | ||||
| import com.ruoyi.system.domain.SysOperLog; | ||||
| import com.ruoyi.system.service.ISysOperLogService; | ||||
| import io.swagger.annotations.Api; | ||||
| import io.swagger.annotations.ApiOperation; | ||||
| import lombok.RequiredArgsConstructor; | ||||
| import org.springframework.beans.factory.annotation.Autowired; | ||||
| import org.springframework.security.access.prepost.PreAuthorize; | ||||
| import org.springframework.validation.annotation.Validated; | ||||
| import org.springframework.web.bind.annotation.*; | ||||
|  | ||||
| import javax.servlet.http.HttpServletResponse; | ||||
| @@ -18,44 +23,46 @@ import java.util.List; | ||||
| /** | ||||
|  * 操作日志记录 | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  * @author Lion Li | ||||
|  */ | ||||
| @Validated | ||||
| @Api(value = "操作日志记录", tags = {"操作日志记录管理"}) | ||||
| @RequiredArgsConstructor(onConstructor_ = @Autowired) | ||||
| @RestController | ||||
| @RequestMapping("/monitor/operlog") | ||||
| public class SysOperlogController extends BaseController | ||||
| { | ||||
|     @Autowired | ||||
|     private ISysOperLogService operLogService; | ||||
| public class SysOperlogController extends BaseController { | ||||
|  | ||||
|     private final ISysOperLogService operLogService; | ||||
|  | ||||
|     @ApiOperation("查询操作日志记录列表") | ||||
|     @PreAuthorize("@ss.hasPermi('monitor:operlog:list')") | ||||
|     @GetMapping("/list") | ||||
|     public TableDataInfo list(SysOperLog operLog) | ||||
|     { | ||||
|         return operLogService.selectPageOperLogList(operLog); | ||||
|     public TableDataInfo<SysOperLog> list(SysOperLog operLog, PageQuery pageQuery) { | ||||
|         return operLogService.selectPageOperLogList(operLog, pageQuery); | ||||
|     } | ||||
|  | ||||
|     @ApiOperation("导出操作日志记录列表") | ||||
|     @Log(title = "操作日志", businessType = BusinessType.EXPORT) | ||||
|     @PreAuthorize("@ss.hasPermi('monitor:operlog:export')") | ||||
|     @GetMapping("/export") | ||||
|     public void export(SysOperLog operLog, HttpServletResponse response) | ||||
|     { | ||||
|     @PostMapping("/export") | ||||
|     public void export(SysOperLog operLog, HttpServletResponse response) { | ||||
|         List<SysOperLog> list = operLogService.selectOperLogList(operLog); | ||||
| 		ExcelUtil.exportExcel(list, "操作日志", SysOperLog.class, response); | ||||
|         ExcelUtil.exportExcel(list, "操作日志", SysOperLog.class, response); | ||||
|     } | ||||
|  | ||||
|     @ApiOperation("删除操作日志记录") | ||||
|     @Log(title = "操作日志", businessType = BusinessType.DELETE) | ||||
|     @PreAuthorize("@ss.hasPermi('monitor:operlog:remove')") | ||||
|     @DeleteMapping("/{operIds}") | ||||
|     public AjaxResult remove(@PathVariable Long[] operIds) | ||||
|     { | ||||
|     public AjaxResult<Void> remove(@PathVariable Long[] operIds) { | ||||
|         return toAjax(operLogService.deleteOperLogByIds(operIds)); | ||||
|     } | ||||
|  | ||||
|     @ApiOperation("清空操作日志记录") | ||||
|     @Log(title = "操作日志", businessType = BusinessType.CLEAN) | ||||
|     @PreAuthorize("@ss.hasPermi('monitor:operlog:remove')") | ||||
|     @DeleteMapping("/clean") | ||||
|     public AjaxResult clean() | ||||
|     { | ||||
|     public AjaxResult<Void> clean() { | ||||
|         operLogService.cleanOperLog(); | ||||
|         return AjaxResult.success(); | ||||
|     } | ||||
|   | ||||
| @@ -7,11 +7,13 @@ import com.ruoyi.common.core.domain.AjaxResult; | ||||
| import com.ruoyi.common.core.domain.model.LoginUser; | ||||
| import com.ruoyi.common.core.page.TableDataInfo; | ||||
| import com.ruoyi.common.enums.BusinessType; | ||||
| import com.ruoyi.common.utils.PageUtils; | ||||
| import com.ruoyi.common.utils.RedisUtils; | ||||
| import com.ruoyi.common.utils.StringUtils; | ||||
| import com.ruoyi.system.domain.SysUserOnline; | ||||
| import com.ruoyi.system.service.ISysUserOnlineService; | ||||
| import io.swagger.annotations.Api; | ||||
| import io.swagger.annotations.ApiOperation; | ||||
| import lombok.RequiredArgsConstructor; | ||||
| import org.springframework.beans.factory.annotation.Autowired; | ||||
| import org.springframework.security.access.prepost.PreAuthorize; | ||||
| import org.springframework.web.bind.annotation.*; | ||||
| @@ -24,63 +26,53 @@ import java.util.List; | ||||
| /** | ||||
|  * 在线用户监控 | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  * @author Lion Li | ||||
|  */ | ||||
| @Api(value = "在线用户监控", tags = {"在线用户监控管理"}) | ||||
| @RequiredArgsConstructor(onConstructor_ = @Autowired) | ||||
| @RestController | ||||
| @RequestMapping("/monitor/online") | ||||
| public class SysUserOnlineController extends BaseController | ||||
| { | ||||
|     @Autowired | ||||
|     private ISysUserOnlineService userOnlineService; | ||||
| public class SysUserOnlineController extends BaseController { | ||||
|  | ||||
|     private final ISysUserOnlineService userOnlineService; | ||||
|  | ||||
|     @ApiOperation("在线用户列表") | ||||
|     @PreAuthorize("@ss.hasPermi('monitor:online:list')") | ||||
|     @GetMapping("/list") | ||||
|     public TableDataInfo list(String ipaddr, String userName) | ||||
|     { | ||||
|     public TableDataInfo<SysUserOnline> list(String ipaddr, String userName) { | ||||
|         Collection<String> keys = RedisUtils.keys(Constants.LOGIN_TOKEN_KEY + "*"); | ||||
|         List<SysUserOnline> userOnlineList = new ArrayList<SysUserOnline>(); | ||||
|         for (String key : keys) | ||||
|         { | ||||
|         for (String key : keys) { | ||||
|             LoginUser user = RedisUtils.getCacheObject(key); | ||||
|             if (StringUtils.isNotEmpty(ipaddr) && StringUtils.isNotEmpty(userName)) | ||||
|             { | ||||
|                 if (StringUtils.equals(ipaddr, user.getIpaddr()) && StringUtils.equals(userName, user.getUsername())) | ||||
|                 { | ||||
|             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())) | ||||
|                 { | ||||
|             } 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())) | ||||
|                 { | ||||
|             } else if (StringUtils.isNotEmpty(userName)) { | ||||
|                 if (StringUtils.equals(userName, user.getUsername())) { | ||||
|                     userOnlineList.add(userOnlineService.selectOnlineByUserName(userName, user)); | ||||
|                 } | ||||
|             } | ||||
|             else | ||||
|             { | ||||
|             } else { | ||||
|                 userOnlineList.add(userOnlineService.loginUserToUserOnline(user)); | ||||
|             } | ||||
|         } | ||||
|         Collections.reverse(userOnlineList); | ||||
|         userOnlineList.removeAll(Collections.singleton(null)); | ||||
|         return PageUtils.buildDataInfo(userOnlineList); | ||||
|         return TableDataInfo.build(userOnlineList); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 强退用户 | ||||
|      */ | ||||
|     @ApiOperation("强退用户") | ||||
|     @PreAuthorize("@ss.hasPermi('monitor:online:forceLogout')") | ||||
|     @Log(title = "在线用户", businessType = BusinessType.FORCE) | ||||
|     @DeleteMapping("/{tokenId}") | ||||
|     public AjaxResult forceLogout(@PathVariable String tokenId) | ||||
|     { | ||||
|     public AjaxResult<Void> forceLogout(@PathVariable String tokenId) { | ||||
|         RedisUtils.deleteObject(Constants.LOGIN_TOKEN_KEY + tokenId); | ||||
|         return AjaxResult.success(); | ||||
|     } | ||||
|   | ||||
| @@ -1,15 +1,19 @@ | ||||
| package com.ruoyi.web.controller.system; | ||||
|  | ||||
| import com.ruoyi.common.annotation.Log; | ||||
| import com.ruoyi.common.annotation.RepeatSubmit; | ||||
| import com.ruoyi.common.constant.UserConstants; | ||||
| import com.ruoyi.common.core.controller.BaseController; | ||||
| import com.ruoyi.common.core.domain.AjaxResult; | ||||
| import com.ruoyi.common.core.domain.PageQuery; | ||||
| import com.ruoyi.common.core.page.TableDataInfo; | ||||
| import com.ruoyi.common.enums.BusinessType; | ||||
| import com.ruoyi.common.utils.poi.ExcelUtil; | ||||
| import com.ruoyi.system.domain.SysConfig; | ||||
| import com.ruoyi.system.service.ISysConfigService; | ||||
| import io.swagger.annotations.Api; | ||||
| import io.swagger.annotations.ApiOperation; | ||||
| import io.swagger.annotations.ApiParam; | ||||
| import lombok.RequiredArgsConstructor; | ||||
| import org.springframework.beans.factory.annotation.Autowired; | ||||
| import org.springframework.security.access.prepost.PreAuthorize; | ||||
| import org.springframework.validation.annotation.Validated; | ||||
| @@ -21,94 +25,91 @@ import java.util.List; | ||||
| /** | ||||
|  * 参数配置 信息操作处理 | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  * @author Lion Li | ||||
|  */ | ||||
| @Validated | ||||
| @Api(value = "参数配置控制器", tags = {"参数配置管理"}) | ||||
| @RequiredArgsConstructor(onConstructor_ = @Autowired) | ||||
| @RestController | ||||
| @RequestMapping("/system/config") | ||||
| public class SysConfigController extends BaseController | ||||
| { | ||||
|     @Autowired | ||||
|     private ISysConfigService configService; | ||||
| public class SysConfigController extends BaseController { | ||||
|  | ||||
|     private final ISysConfigService configService; | ||||
|  | ||||
|     /** | ||||
|      * 获取参数配置列表 | ||||
|      */ | ||||
|     @ApiOperation("获取参数配置列表") | ||||
|     @PreAuthorize("@ss.hasPermi('system:config:list')") | ||||
|     @GetMapping("/list") | ||||
|     public TableDataInfo list(SysConfig config) | ||||
|     { | ||||
|         return configService.selectPageConfigList(config); | ||||
|     public TableDataInfo<SysConfig> list(SysConfig config, PageQuery pageQuery) { | ||||
|         return configService.selectPageConfigList(config, pageQuery); | ||||
|     } | ||||
|  | ||||
|     @ApiOperation("导出参数配置列表") | ||||
|     @Log(title = "参数管理", businessType = BusinessType.EXPORT) | ||||
|     @PreAuthorize("@ss.hasPermi('system:config:export')") | ||||
|     @GetMapping("/export") | ||||
|     public void export(SysConfig config, HttpServletResponse response) | ||||
|     { | ||||
|     @PostMapping("/export") | ||||
|     public void export(SysConfig config, HttpServletResponse response) { | ||||
|         List<SysConfig> list = configService.selectConfigList(config); | ||||
| 		ExcelUtil.exportExcel(list, "参数数据", SysConfig.class, response); | ||||
|         ExcelUtil.exportExcel(list, "参数数据", SysConfig.class, response); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 根据参数编号获取详细信息 | ||||
|      */ | ||||
|     @ApiOperation("根据参数编号获取详细信息") | ||||
|     @PreAuthorize("@ss.hasPermi('system:config:query')") | ||||
|     @GetMapping(value = "/{configId}") | ||||
|     public AjaxResult getInfo(@PathVariable Long configId) | ||||
|     { | ||||
|     public AjaxResult<SysConfig> getInfo(@ApiParam("参数ID") @PathVariable Long configId) { | ||||
|         return AjaxResult.success(configService.selectConfigById(configId)); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 根据参数键名查询参数值 | ||||
|      */ | ||||
|     @ApiOperation("根据参数键名查询参数值") | ||||
|     @GetMapping(value = "/configKey/{configKey}") | ||||
|     public AjaxResult getConfigKey(@PathVariable String configKey) | ||||
|     { | ||||
|     public AjaxResult<Void> getConfigKey(@ApiParam("参数Key") @PathVariable String configKey) { | ||||
|         return AjaxResult.success(configService.selectConfigByKey(configKey)); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 新增参数配置 | ||||
|      */ | ||||
|     @ApiOperation("新增参数配置") | ||||
|     @PreAuthorize("@ss.hasPermi('system:config:add')") | ||||
|     @Log(title = "参数管理", businessType = BusinessType.INSERT) | ||||
|     @PostMapping | ||||
|     @RepeatSubmit | ||||
|     public AjaxResult add(@Validated @RequestBody SysConfig config) | ||||
|     { | ||||
|         if (UserConstants.NOT_UNIQUE.equals(configService.checkConfigKeyUnique(config))) | ||||
|         { | ||||
|     public AjaxResult<Void> add(@Validated @RequestBody SysConfig config) { | ||||
|         if (UserConstants.NOT_UNIQUE.equals(configService.checkConfigKeyUnique(config))) { | ||||
|             return AjaxResult.error("新增参数'" + config.getConfigName() + "'失败,参数键名已存在"); | ||||
|         } | ||||
|         config.setCreateBy(getUsername()); | ||||
|         return toAjax(configService.insertConfig(config)); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 修改参数配置 | ||||
|      */ | ||||
|     @ApiOperation("修改参数配置") | ||||
|     @PreAuthorize("@ss.hasPermi('system:config:edit')") | ||||
|     @Log(title = "参数管理", businessType = BusinessType.UPDATE) | ||||
|     @PutMapping | ||||
|     public AjaxResult edit(@Validated @RequestBody SysConfig config) | ||||
|     { | ||||
|         if (UserConstants.NOT_UNIQUE.equals(configService.checkConfigKeyUnique(config))) | ||||
|         { | ||||
|     public AjaxResult<Void> edit(@Validated @RequestBody SysConfig config) { | ||||
|         if (UserConstants.NOT_UNIQUE.equals(configService.checkConfigKeyUnique(config))) { | ||||
|             return AjaxResult.error("修改参数'" + config.getConfigName() + "'失败,参数键名已存在"); | ||||
|         } | ||||
|         config.setUpdateBy(getUsername()); | ||||
|         return toAjax(configService.updateConfig(config)); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 删除参数配置 | ||||
|      */ | ||||
|     @ApiOperation("删除参数配置") | ||||
|     @PreAuthorize("@ss.hasPermi('system:config:remove')") | ||||
|     @Log(title = "参数管理", businessType = BusinessType.DELETE) | ||||
|     @DeleteMapping("/{configIds}") | ||||
|     public AjaxResult remove(@PathVariable Long[] configIds) | ||||
|     { | ||||
|     public AjaxResult<Void> remove(@ApiParam("参数ID串") @PathVariable Long[] configIds) { | ||||
|         configService.deleteConfigByIds(configIds); | ||||
|         return success(); | ||||
|     } | ||||
| @@ -116,11 +117,11 @@ public class SysConfigController extends BaseController | ||||
|     /** | ||||
|      * 刷新参数缓存 | ||||
|      */ | ||||
|     @ApiOperation("刷新参数缓存") | ||||
|     @PreAuthorize("@ss.hasPermi('system:config:remove')") | ||||
|     @Log(title = "参数管理", businessType = BusinessType.CLEAN) | ||||
|     @DeleteMapping("/refreshCache") | ||||
|     public AjaxResult refreshCache() | ||||
|     { | ||||
|     public AjaxResult<Void> refreshCache() { | ||||
|         configService.resetConfigCache(); | ||||
|         return AjaxResult.success(); | ||||
|     } | ||||
|   | ||||
| @@ -1,5 +1,6 @@ | ||||
| package com.ruoyi.web.controller.system; | ||||
|  | ||||
| import cn.hutool.core.lang.tree.Tree; | ||||
| import cn.hutool.core.util.ArrayUtil; | ||||
| import com.ruoyi.common.annotation.Log; | ||||
| import com.ruoyi.common.constant.UserConstants; | ||||
| @@ -9,35 +10,40 @@ import com.ruoyi.common.core.domain.entity.SysDept; | ||||
| import com.ruoyi.common.enums.BusinessType; | ||||
| import com.ruoyi.common.utils.StringUtils; | ||||
| import com.ruoyi.system.service.ISysDeptService; | ||||
| import io.swagger.annotations.Api; | ||||
| import io.swagger.annotations.ApiOperation; | ||||
| import io.swagger.annotations.ApiParam; | ||||
| import lombok.RequiredArgsConstructor; | ||||
| import org.springframework.beans.factory.annotation.Autowired; | ||||
| import org.springframework.security.access.prepost.PreAuthorize; | ||||
| import org.springframework.validation.annotation.Validated; | ||||
| import org.springframework.web.bind.annotation.*; | ||||
|  | ||||
| import java.util.HashMap; | ||||
| import java.util.Iterator; | ||||
| import java.util.List; | ||||
| import java.util.Map; | ||||
|  | ||||
| /** | ||||
|  * 部门信息 | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  * @author Lion Li | ||||
|  */ | ||||
| @Validated | ||||
| @Api(value = "部门控制器", tags = {"部门管理"}) | ||||
| @RequiredArgsConstructor(onConstructor_ = @Autowired) | ||||
| @RestController | ||||
| @RequestMapping("/system/dept") | ||||
| public class SysDeptController extends BaseController | ||||
| { | ||||
|     @Autowired | ||||
|     private ISysDeptService deptService; | ||||
| public class SysDeptController extends BaseController { | ||||
|  | ||||
|     private final ISysDeptService deptService; | ||||
|  | ||||
|     /** | ||||
|      * 获取部门列表 | ||||
|      */ | ||||
|     @ApiOperation("获取部门列表") | ||||
|     @PreAuthorize("@ss.hasPermi('system:dept:list')") | ||||
|     @GetMapping("/list") | ||||
|     public AjaxResult list(SysDept dept) | ||||
|     { | ||||
|     public AjaxResult<List<SysDept>> list(SysDept dept) { | ||||
|         List<SysDept> depts = deptService.selectDeptList(dept); | ||||
|         return AjaxResult.success(depts); | ||||
|     } | ||||
| @@ -45,31 +51,23 @@ public class SysDeptController extends BaseController | ||||
|     /** | ||||
|      * 查询部门列表(排除节点) | ||||
|      */ | ||||
|     @ApiOperation("查询部门列表(排除节点)") | ||||
|     @PreAuthorize("@ss.hasPermi('system:dept:list')") | ||||
|     @GetMapping("/list/exclude/{deptId}") | ||||
|     public AjaxResult excludeChild(@PathVariable(value = "deptId", required = false) Long deptId) | ||||
|     { | ||||
|     public AjaxResult<List<SysDept>> excludeChild(@ApiParam("部门ID") @PathVariable(value = "deptId", required = false) Long deptId) { | ||||
|         List<SysDept> depts = deptService.selectDeptList(new SysDept()); | ||||
|         Iterator<SysDept> it = depts.iterator(); | ||||
|         while (it.hasNext()) | ||||
|         { | ||||
|             SysDept d = (SysDept) it.next(); | ||||
|             if (d.getDeptId().intValue() == deptId | ||||
|                     || ArrayUtil.contains(StringUtils.split(d.getAncestors(), ","), deptId + "")) | ||||
|             { | ||||
|                 it.remove(); | ||||
|             } | ||||
|         } | ||||
|         depts.removeIf(d -> d.getDeptId().equals(deptId) | ||||
|                 || ArrayUtil.contains(StringUtils.split(d.getAncestors(), ","), deptId + "")); | ||||
|         return AjaxResult.success(depts); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 根据部门编号获取详细信息 | ||||
|      */ | ||||
|     @ApiOperation("根据部门编号获取详细信息") | ||||
|     @PreAuthorize("@ss.hasPermi('system:dept:query')") | ||||
|     @GetMapping(value = "/{deptId}") | ||||
|     public AjaxResult getInfo(@PathVariable Long deptId) | ||||
|     { | ||||
|     public AjaxResult<SysDept> getInfo(@ApiParam("部门ID") @PathVariable Long deptId) { | ||||
|         deptService.checkDeptDataScope(deptId); | ||||
|         return AjaxResult.success(deptService.selectDeptById(deptId)); | ||||
|     } | ||||
| @@ -77,9 +75,9 @@ public class SysDeptController extends BaseController | ||||
|     /** | ||||
|      * 获取部门下拉树列表 | ||||
|      */ | ||||
|     @ApiOperation("获取部门下拉树列表") | ||||
|     @GetMapping("/treeselect") | ||||
|     public AjaxResult treeselect(SysDept dept) | ||||
|     { | ||||
|     public AjaxResult<List<Tree<Long>>> treeselect(SysDept dept) { | ||||
|         List<SysDept> depts = deptService.selectDeptList(dept); | ||||
|         return AjaxResult.success(deptService.buildDeptTreeSelect(depts)); | ||||
|     } | ||||
| @@ -87,11 +85,11 @@ public class SysDeptController extends BaseController | ||||
|     /** | ||||
|      * 加载对应角色部门列表树 | ||||
|      */ | ||||
|     @ApiOperation("加载对应角色部门列表树") | ||||
|     @GetMapping(value = "/roleDeptTreeselect/{roleId}") | ||||
|     public AjaxResult roleDeptTreeselect(@PathVariable("roleId") Long roleId) | ||||
|     { | ||||
|     public AjaxResult<Map<String, Object>> roleDeptTreeselect(@ApiParam("角色ID") @PathVariable("roleId") Long roleId) { | ||||
|         List<SysDept> depts = deptService.selectDeptList(new SysDept()); | ||||
| 		Map<String,Object> ajax = new HashMap<>(); | ||||
|         Map<String, Object> ajax = new HashMap<>(); | ||||
|         ajax.put("checkedKeys", deptService.selectDeptListByRoleId(roleId)); | ||||
|         ajax.put("depts", deptService.buildDeptTreeSelect(depts)); | ||||
|         return AjaxResult.success(ajax); | ||||
| @@ -100,58 +98,48 @@ public class SysDeptController extends BaseController | ||||
|     /** | ||||
|      * 新增部门 | ||||
|      */ | ||||
|     @ApiOperation("新增部门") | ||||
|     @PreAuthorize("@ss.hasPermi('system:dept:add')") | ||||
|     @Log(title = "部门管理", businessType = BusinessType.INSERT) | ||||
|     @PostMapping | ||||
|     public AjaxResult add(@Validated @RequestBody SysDept dept) | ||||
|     { | ||||
|         if (UserConstants.NOT_UNIQUE.equals(deptService.checkDeptNameUnique(dept))) | ||||
|         { | ||||
|     public AjaxResult<Void> add(@Validated @RequestBody SysDept dept) { | ||||
|         if (UserConstants.NOT_UNIQUE.equals(deptService.checkDeptNameUnique(dept))) { | ||||
|             return AjaxResult.error("新增部门'" + dept.getDeptName() + "'失败,部门名称已存在"); | ||||
|         } | ||||
|         dept.setCreateBy(getUsername()); | ||||
|         return toAjax(deptService.insertDept(dept)); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 修改部门 | ||||
|      */ | ||||
|     @ApiOperation("修改部门") | ||||
|     @PreAuthorize("@ss.hasPermi('system:dept:edit')") | ||||
|     @Log(title = "部门管理", businessType = BusinessType.UPDATE) | ||||
|     @PutMapping | ||||
|     public AjaxResult edit(@Validated @RequestBody SysDept dept) | ||||
|     { | ||||
|         if (UserConstants.NOT_UNIQUE.equals(deptService.checkDeptNameUnique(dept))) | ||||
|         { | ||||
|     public AjaxResult<Void> edit(@Validated @RequestBody SysDept dept) { | ||||
|         if (UserConstants.NOT_UNIQUE.equals(deptService.checkDeptNameUnique(dept))) { | ||||
|             return AjaxResult.error("修改部门'" + dept.getDeptName() + "'失败,部门名称已存在"); | ||||
|         } | ||||
|         else if (dept.getParentId().equals(dept.getDeptId())) | ||||
|         { | ||||
|         } else if (dept.getParentId().equals(dept.getDeptId())) { | ||||
|             return AjaxResult.error("修改部门'" + dept.getDeptName() + "'失败,上级部门不能是自己"); | ||||
|         } | ||||
|         else if (StringUtils.equals(UserConstants.DEPT_DISABLE, dept.getStatus()) | ||||
|                 && deptService.selectNormalChildrenDeptById(dept.getDeptId()) > 0) | ||||
|         { | ||||
|         } else if (StringUtils.equals(UserConstants.DEPT_DISABLE, dept.getStatus()) | ||||
|                 && deptService.selectNormalChildrenDeptById(dept.getDeptId()) > 0) { | ||||
|             return AjaxResult.error("该部门包含未停用的子部门!"); | ||||
|         } | ||||
|         dept.setUpdateBy(getUsername()); | ||||
|         return toAjax(deptService.updateDept(dept)); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 删除部门 | ||||
|      */ | ||||
|     @ApiOperation("删除部门") | ||||
|     @PreAuthorize("@ss.hasPermi('system:dept:remove')") | ||||
|     @Log(title = "部门管理", businessType = BusinessType.DELETE) | ||||
|     @DeleteMapping("/{deptId}") | ||||
|     public AjaxResult remove(@PathVariable Long deptId) | ||||
|     { | ||||
|         if (deptService.hasChildByDeptId(deptId)) | ||||
|         { | ||||
|     public AjaxResult<Void> remove(@ApiParam("部门ID串") @PathVariable Long deptId) { | ||||
|         if (deptService.hasChildByDeptId(deptId)) { | ||||
|             return AjaxResult.error("存在下级部门,不允许删除"); | ||||
|         } | ||||
|         if (deptService.checkDeptExistUser(deptId)) | ||||
|         { | ||||
|         if (deptService.checkDeptExistUser(deptId)) { | ||||
|             return AjaxResult.error("部门存在用户,不允许删除"); | ||||
|         } | ||||
|         return toAjax(deptService.deleteDeptById(deptId)); | ||||
|   | ||||
| @@ -3,6 +3,7 @@ package com.ruoyi.web.controller.system; | ||||
| import com.ruoyi.common.annotation.Log; | ||||
| import com.ruoyi.common.core.controller.BaseController; | ||||
| import com.ruoyi.common.core.domain.AjaxResult; | ||||
| import com.ruoyi.common.core.domain.PageQuery; | ||||
| import com.ruoyi.common.core.domain.entity.SysDictData; | ||||
| import com.ruoyi.common.core.page.TableDataInfo; | ||||
| import com.ruoyi.common.enums.BusinessType; | ||||
| @@ -10,6 +11,10 @@ import com.ruoyi.common.utils.StringUtils; | ||||
| import com.ruoyi.common.utils.poi.ExcelUtil; | ||||
| import com.ruoyi.system.service.ISysDictDataService; | ||||
| import com.ruoyi.system.service.ISysDictTypeService; | ||||
| import io.swagger.annotations.Api; | ||||
| import io.swagger.annotations.ApiOperation; | ||||
| import io.swagger.annotations.ApiParam; | ||||
| import lombok.RequiredArgsConstructor; | ||||
| import org.springframework.beans.factory.annotation.Autowired; | ||||
| import org.springframework.security.access.prepost.PreAuthorize; | ||||
| import org.springframework.validation.annotation.Validated; | ||||
| @@ -22,54 +27,53 @@ import java.util.List; | ||||
| /** | ||||
|  * 数据字典信息 | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  * @author Lion Li | ||||
|  */ | ||||
| @Validated | ||||
| @Api(value = "数据字典信息控制器", tags = {"数据字典信息管理"}) | ||||
| @RequiredArgsConstructor(onConstructor_ = @Autowired) | ||||
| @RestController | ||||
| @RequestMapping("/system/dict/data") | ||||
| public class SysDictDataController extends BaseController | ||||
| { | ||||
|     @Autowired | ||||
|     private ISysDictDataService dictDataService; | ||||
| public class SysDictDataController extends BaseController { | ||||
|  | ||||
|     @Autowired | ||||
|     private ISysDictTypeService dictTypeService; | ||||
|     private final ISysDictDataService dictDataService; | ||||
|     private final ISysDictTypeService dictTypeService; | ||||
|  | ||||
|     @ApiOperation("查询字典数据列表") | ||||
|     @PreAuthorize("@ss.hasPermi('system:dict:list')") | ||||
|     @GetMapping("/list") | ||||
|     public TableDataInfo list(SysDictData dictData) | ||||
|     { | ||||
|         return dictDataService.selectPageDictDataList(dictData); | ||||
|     public TableDataInfo<SysDictData> list(SysDictData dictData, PageQuery pageQuery) { | ||||
|         return dictDataService.selectPageDictDataList(dictData, pageQuery); | ||||
|     } | ||||
|  | ||||
|     @ApiOperation("导出字典数据列表") | ||||
|     @Log(title = "字典数据", businessType = BusinessType.EXPORT) | ||||
|     @PreAuthorize("@ss.hasPermi('system:dict:export')") | ||||
|     @GetMapping("/export") | ||||
|     public void export(SysDictData dictData, HttpServletResponse response) | ||||
|     { | ||||
|     @PostMapping("/export") | ||||
|     public void export(SysDictData dictData, HttpServletResponse response) { | ||||
|         List<SysDictData> list = dictDataService.selectDictDataList(dictData); | ||||
| 		ExcelUtil.exportExcel(list, "字典数据", SysDictData.class, response); | ||||
|         ExcelUtil.exportExcel(list, "字典数据", SysDictData.class, response); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 查询字典数据详细 | ||||
|      */ | ||||
|     @ApiOperation("查询字典数据详细") | ||||
|     @PreAuthorize("@ss.hasPermi('system:dict:query')") | ||||
|     @GetMapping(value = "/{dictCode}") | ||||
|     public AjaxResult getInfo(@PathVariable Long dictCode) | ||||
|     { | ||||
|     public AjaxResult<SysDictData> getInfo(@ApiParam("字典code") @PathVariable Long dictCode) { | ||||
|         return AjaxResult.success(dictDataService.selectDictDataById(dictCode)); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 根据字典类型查询字典数据信息 | ||||
|      */ | ||||
|     @ApiOperation("根据字典类型查询字典数据信息") | ||||
|     @GetMapping(value = "/type/{dictType}") | ||||
|     public AjaxResult dictType(@PathVariable String dictType) | ||||
|     { | ||||
|     public AjaxResult<List<SysDictData>> dictType(@ApiParam("字典类型") @PathVariable String dictType) { | ||||
|         List<SysDictData> data = dictTypeService.selectDictDataByType(dictType); | ||||
|         if (StringUtils.isNull(data)) | ||||
|         { | ||||
|             data = new ArrayList<SysDictData>(); | ||||
|         if (StringUtils.isNull(data)) { | ||||
|             data = new ArrayList<>(); | ||||
|         } | ||||
|         return AjaxResult.success(data); | ||||
|     } | ||||
| @@ -77,35 +81,33 @@ public class SysDictDataController extends BaseController | ||||
|     /** | ||||
|      * 新增字典类型 | ||||
|      */ | ||||
|     @ApiOperation("新增字典类型") | ||||
|     @PreAuthorize("@ss.hasPermi('system:dict:add')") | ||||
|     @Log(title = "字典数据", businessType = BusinessType.INSERT) | ||||
|     @PostMapping | ||||
|     public AjaxResult add(@Validated @RequestBody SysDictData dict) | ||||
|     { | ||||
|         dict.setCreateBy(getUsername()); | ||||
|     public AjaxResult<Void> add(@Validated @RequestBody SysDictData dict) { | ||||
|         return toAjax(dictDataService.insertDictData(dict)); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 修改保存字典类型 | ||||
|      */ | ||||
|     @ApiOperation("修改保存字典类型") | ||||
|     @PreAuthorize("@ss.hasPermi('system:dict:edit')") | ||||
|     @Log(title = "字典数据", businessType = BusinessType.UPDATE) | ||||
|     @PutMapping | ||||
|     public AjaxResult edit(@Validated @RequestBody SysDictData dict) | ||||
|     { | ||||
|         dict.setUpdateBy(getUsername()); | ||||
|     public AjaxResult<Void> edit(@Validated @RequestBody SysDictData dict) { | ||||
|         return toAjax(dictDataService.updateDictData(dict)); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 删除字典类型 | ||||
|      */ | ||||
|     @ApiOperation("删除字典类型") | ||||
|     @PreAuthorize("@ss.hasPermi('system:dict:remove')") | ||||
|     @Log(title = "字典类型", businessType = BusinessType.DELETE) | ||||
|     @DeleteMapping("/{dictCodes}") | ||||
|     public AjaxResult remove(@PathVariable Long[] dictCodes) | ||||
|     { | ||||
|     public AjaxResult<Void> remove(@ApiParam("字典code串") @PathVariable Long[] dictCodes) { | ||||
|         dictDataService.deleteDictDataByIds(dictCodes); | ||||
|         return success(); | ||||
|     } | ||||
|   | ||||
| @@ -4,11 +4,16 @@ import com.ruoyi.common.annotation.Log; | ||||
| import com.ruoyi.common.constant.UserConstants; | ||||
| import com.ruoyi.common.core.controller.BaseController; | ||||
| import com.ruoyi.common.core.domain.AjaxResult; | ||||
| import com.ruoyi.common.core.domain.PageQuery; | ||||
| import com.ruoyi.common.core.domain.entity.SysDictType; | ||||
| import com.ruoyi.common.core.page.TableDataInfo; | ||||
| import com.ruoyi.common.enums.BusinessType; | ||||
| import com.ruoyi.common.utils.poi.ExcelUtil; | ||||
| import com.ruoyi.system.service.ISysDictTypeService; | ||||
| import io.swagger.annotations.Api; | ||||
| import io.swagger.annotations.ApiOperation; | ||||
| import io.swagger.annotations.ApiParam; | ||||
| import lombok.RequiredArgsConstructor; | ||||
| import org.springframework.beans.factory.annotation.Autowired; | ||||
| import org.springframework.security.access.prepost.PreAuthorize; | ||||
| import org.springframework.validation.annotation.Validated; | ||||
| @@ -20,81 +25,79 @@ import java.util.List; | ||||
| /** | ||||
|  * 数据字典信息 | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  * @author Lion Li | ||||
|  */ | ||||
| @Validated | ||||
| @Api(value = "数据字典信息控制器", tags = {"数据字典信息管理"}) | ||||
| @RequiredArgsConstructor(onConstructor_ = @Autowired) | ||||
| @RestController | ||||
| @RequestMapping("/system/dict/type") | ||||
| public class SysDictTypeController extends BaseController | ||||
| { | ||||
|     @Autowired | ||||
|     private ISysDictTypeService dictTypeService; | ||||
| public class SysDictTypeController extends BaseController { | ||||
|  | ||||
|     private final ISysDictTypeService dictTypeService; | ||||
|  | ||||
|     @ApiOperation("查询字典类型列表") | ||||
|     @PreAuthorize("@ss.hasPermi('system:dict:list')") | ||||
|     @GetMapping("/list") | ||||
|     public TableDataInfo list(SysDictType dictType) | ||||
|     { | ||||
|         return dictTypeService.selectPageDictTypeList(dictType); | ||||
|     public TableDataInfo<SysDictType> list(SysDictType dictType, PageQuery pageQuery) { | ||||
|         return dictTypeService.selectPageDictTypeList(dictType, pageQuery); | ||||
|     } | ||||
|  | ||||
|     @ApiOperation("导出字典类型列表") | ||||
|     @Log(title = "字典类型", businessType = BusinessType.EXPORT) | ||||
|     @PreAuthorize("@ss.hasPermi('system:dict:export')") | ||||
|     @GetMapping("/export") | ||||
|     public void export(SysDictType dictType, HttpServletResponse response) | ||||
|     { | ||||
|     @PostMapping("/export") | ||||
|     public void export(SysDictType dictType, HttpServletResponse response) { | ||||
|         List<SysDictType> list = dictTypeService.selectDictTypeList(dictType); | ||||
| 		ExcelUtil.exportExcel(list, "字典类型", SysDictType.class, response); | ||||
|         ExcelUtil.exportExcel(list, "字典类型", SysDictType.class, response); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 查询字典类型详细 | ||||
|      */ | ||||
|     @ApiOperation("查询字典类型详细") | ||||
|     @PreAuthorize("@ss.hasPermi('system:dict:query')") | ||||
|     @GetMapping(value = "/{dictId}") | ||||
|     public AjaxResult getInfo(@PathVariable Long dictId) | ||||
|     { | ||||
|     public AjaxResult<SysDictType> getInfo(@ApiParam("字典ID") @PathVariable Long dictId) { | ||||
|         return AjaxResult.success(dictTypeService.selectDictTypeById(dictId)); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 新增字典类型 | ||||
|      */ | ||||
|     @ApiOperation("新增字典类型") | ||||
|     @PreAuthorize("@ss.hasPermi('system:dict:add')") | ||||
|     @Log(title = "字典类型", businessType = BusinessType.INSERT) | ||||
|     @PostMapping | ||||
|     public AjaxResult add(@Validated @RequestBody SysDictType dict) | ||||
|     { | ||||
|         if (UserConstants.NOT_UNIQUE.equals(dictTypeService.checkDictTypeUnique(dict))) | ||||
|         { | ||||
|     public AjaxResult<Void> add(@Validated @RequestBody SysDictType dict) { | ||||
|         if (UserConstants.NOT_UNIQUE.equals(dictTypeService.checkDictTypeUnique(dict))) { | ||||
|             return AjaxResult.error("新增字典'" + dict.getDictName() + "'失败,字典类型已存在"); | ||||
|         } | ||||
|         dict.setCreateBy(getUsername()); | ||||
|         return toAjax(dictTypeService.insertDictType(dict)); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 修改字典类型 | ||||
|      */ | ||||
|     @ApiOperation("修改字典类型") | ||||
|     @PreAuthorize("@ss.hasPermi('system:dict:edit')") | ||||
|     @Log(title = "字典类型", businessType = BusinessType.UPDATE) | ||||
|     @PutMapping | ||||
|     public AjaxResult edit(@Validated @RequestBody SysDictType dict) | ||||
|     { | ||||
|         if (UserConstants.NOT_UNIQUE.equals(dictTypeService.checkDictTypeUnique(dict))) | ||||
|         { | ||||
|     public AjaxResult<Void> edit(@Validated @RequestBody SysDictType dict) { | ||||
|         if (UserConstants.NOT_UNIQUE.equals(dictTypeService.checkDictTypeUnique(dict))) { | ||||
|             return AjaxResult.error("修改字典'" + dict.getDictName() + "'失败,字典类型已存在"); | ||||
|         } | ||||
|         dict.setUpdateBy(getUsername()); | ||||
|         return toAjax(dictTypeService.updateDictType(dict)); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 删除字典类型 | ||||
|      */ | ||||
|     @ApiOperation("删除字典类型") | ||||
|     @PreAuthorize("@ss.hasPermi('system:dict:remove')") | ||||
|     @Log(title = "字典类型", businessType = BusinessType.DELETE) | ||||
|     @DeleteMapping("/{dictIds}") | ||||
|     public AjaxResult remove(@PathVariable Long[] dictIds) | ||||
|     { | ||||
|     public AjaxResult<Void> remove(@ApiParam("字典ID串") @PathVariable Long[] dictIds) { | ||||
|         dictTypeService.deleteDictTypeByIds(dictIds); | ||||
|         return success(); | ||||
|     } | ||||
| @@ -102,11 +105,11 @@ public class SysDictTypeController extends BaseController | ||||
|     /** | ||||
|      * 刷新字典缓存 | ||||
|      */ | ||||
|     @ApiOperation("刷新字典缓存") | ||||
|     @PreAuthorize("@ss.hasPermi('system:dict:remove')") | ||||
|     @Log(title = "字典类型", businessType = BusinessType.CLEAN) | ||||
|     @DeleteMapping("/refreshCache") | ||||
|     public AjaxResult refreshCache() | ||||
|     { | ||||
|     public AjaxResult<Void> refreshCache() { | ||||
|         dictTypeService.resetDictCache(); | ||||
|         return AjaxResult.success(); | ||||
|     } | ||||
| @@ -114,9 +117,9 @@ public class SysDictTypeController extends BaseController | ||||
|     /** | ||||
|      * 获取字典选择框列表 | ||||
|      */ | ||||
|     @ApiOperation("获取字典选择框列表") | ||||
|     @GetMapping("/optionselect") | ||||
|     public AjaxResult optionselect() | ||||
|     { | ||||
|     public AjaxResult<List<SysDictType>> optionselect() { | ||||
|         List<SysDictType> dictTypes = dictTypeService.selectDictTypeAll(); | ||||
|         return AjaxResult.success(dictTypes); | ||||
|     } | ||||
|   | ||||
| @@ -1,29 +1,35 @@ | ||||
| package com.ruoyi.web.controller.system; | ||||
|  | ||||
| import com.ruoyi.common.utils.StringUtils; | ||||
| import com.ruoyi.common.config.RuoYiConfig; | ||||
| import com.ruoyi.common.utils.StringUtils; | ||||
| import io.swagger.annotations.Api; | ||||
| import io.swagger.annotations.ApiOperation; | ||||
| import lombok.RequiredArgsConstructor; | ||||
| import org.springframework.beans.factory.annotation.Autowired; | ||||
| import org.springframework.web.bind.annotation.RequestMapping; | ||||
| import org.springframework.web.bind.annotation.GetMapping; | ||||
| import org.springframework.web.bind.annotation.RestController; | ||||
|  | ||||
| /** | ||||
|  * 首页 | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  * @author Lion Li | ||||
|  */ | ||||
| @Api(value = "首页控制器", tags = {"首页管理"}) | ||||
| @RequiredArgsConstructor(onConstructor_ = @Autowired) | ||||
| @RestController | ||||
| public class SysIndexController | ||||
| { | ||||
|     /** 系统基础配置 */ | ||||
|     @Autowired | ||||
|     private RuoYiConfig ruoyiConfig; | ||||
| public class SysIndexController { | ||||
|  | ||||
|     /** | ||||
|      * 系统基础配置 | ||||
|      */ | ||||
|     private final RuoYiConfig ruoyiConfig; | ||||
|  | ||||
|     /** | ||||
|      * 访问首页,提示语 | ||||
|      */ | ||||
|     @RequestMapping("/") | ||||
|     public String index() | ||||
|     { | ||||
|     @ApiOperation("访问首页,提示语") | ||||
|     @GetMapping("/") | ||||
|     public String index() { | ||||
|         return StringUtils.format("欢迎使用{}后台管理框架,当前版本:v{},请通过前端地址访问。", ruoyiConfig.getName(), ruoyiConfig.getVersion()); | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -6,10 +6,16 @@ import com.ruoyi.common.core.domain.entity.SysMenu; | ||||
| import com.ruoyi.common.core.domain.entity.SysUser; | ||||
| import com.ruoyi.common.core.domain.model.LoginBody; | ||||
| import com.ruoyi.common.utils.SecurityUtils; | ||||
| import com.ruoyi.framework.web.service.SysLoginService; | ||||
| import com.ruoyi.framework.web.service.SysPermissionService; | ||||
| import com.ruoyi.system.domain.vo.RouterVo; | ||||
| import com.ruoyi.system.service.ISysMenuService; | ||||
| import com.ruoyi.system.service.ISysUserService; | ||||
| import com.ruoyi.system.service.SysLoginService; | ||||
| import com.ruoyi.system.service.SysPermissionService; | ||||
| import io.swagger.annotations.Api; | ||||
| import io.swagger.annotations.ApiOperation; | ||||
| import lombok.RequiredArgsConstructor; | ||||
| import org.springframework.beans.factory.annotation.Autowired; | ||||
| import org.springframework.validation.annotation.Validated; | ||||
| import org.springframework.web.bind.annotation.GetMapping; | ||||
| import org.springframework.web.bind.annotation.PostMapping; | ||||
| import org.springframework.web.bind.annotation.RequestBody; | ||||
| @@ -23,19 +29,18 @@ import java.util.Set; | ||||
| /** | ||||
|  * 登录验证 | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  * @author Lion Li | ||||
|  */ | ||||
| @Validated | ||||
| @Api(value = "登录验证控制器", tags = {"登录验证管理"}) | ||||
| @RequiredArgsConstructor(onConstructor_ = @Autowired) | ||||
| @RestController | ||||
| public class SysLoginController | ||||
| { | ||||
|     @Autowired | ||||
|     private SysLoginService loginService; | ||||
| public class SysLoginController { | ||||
|  | ||||
|     @Autowired | ||||
|     private ISysMenuService menuService; | ||||
|  | ||||
|     @Autowired | ||||
|     private SysPermissionService permissionService; | ||||
|     private final SysLoginService loginService; | ||||
|     private final ISysMenuService menuService; | ||||
|     private final ISysUserService userService; | ||||
|     private final SysPermissionService permissionService; | ||||
|  | ||||
|     /** | ||||
|      * 登录方法 | ||||
| @@ -43,10 +48,10 @@ public class SysLoginController | ||||
|      * @param loginBody 登录信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @ApiOperation("登录方法") | ||||
|     @PostMapping("/login") | ||||
|     public AjaxResult login(@RequestBody LoginBody loginBody) | ||||
|     { | ||||
| 		Map<String,Object> ajax = new HashMap<>(); | ||||
|     public AjaxResult<Map<String, Object>> login(@RequestBody LoginBody loginBody) { | ||||
|         Map<String, Object> ajax = new HashMap<>(); | ||||
|         // 生成令牌 | ||||
|         String token = loginService.login(loginBody.getUsername(), loginBody.getPassword(), loginBody.getCode(), | ||||
|                 loginBody.getUuid()); | ||||
| @@ -59,15 +64,15 @@ public class SysLoginController | ||||
|      * | ||||
|      * @return 用户信息 | ||||
|      */ | ||||
|     @ApiOperation("获取用户信息") | ||||
|     @GetMapping("getInfo") | ||||
|     public AjaxResult getInfo() | ||||
|     { | ||||
|         SysUser user = SecurityUtils.getLoginUser().getUser(); | ||||
|     public AjaxResult<Map<String, Object>> getInfo() { | ||||
|         SysUser user = userService.selectUserById(SecurityUtils.getUserId()); | ||||
|         // 角色集合 | ||||
|         Set<String> roles = permissionService.getRolePermission(user); | ||||
|         // 权限集合 | ||||
|         Set<String> permissions = permissionService.getMenuPermission(user); | ||||
| 		Map<String,Object> ajax = new HashMap<>(); | ||||
|         Map<String, Object> ajax = new HashMap<>(); | ||||
|         ajax.put("user", user); | ||||
|         ajax.put("roles", roles); | ||||
|         ajax.put("permissions", permissions); | ||||
| @@ -79,9 +84,9 @@ public class SysLoginController | ||||
|      * | ||||
|      * @return 路由信息 | ||||
|      */ | ||||
|     @ApiOperation("获取路由信息") | ||||
|     @GetMapping("getRouters") | ||||
|     public AjaxResult getRouters() | ||||
|     { | ||||
|     public AjaxResult<List<RouterVo>> getRouters() { | ||||
|         Long userId = SecurityUtils.getUserId(); | ||||
|         List<SysMenu> menus = menuService.selectMenuTreeByUserId(userId); | ||||
|         return AjaxResult.success(menuService.buildMenus(menus)); | ||||
|   | ||||
| @@ -1,5 +1,6 @@ | ||||
| package com.ruoyi.web.controller.system; | ||||
|  | ||||
| import cn.hutool.core.lang.tree.Tree; | ||||
| import com.ruoyi.common.annotation.Log; | ||||
| import com.ruoyi.common.constant.UserConstants; | ||||
| import com.ruoyi.common.core.controller.BaseController; | ||||
| @@ -8,6 +9,10 @@ import com.ruoyi.common.core.domain.entity.SysMenu; | ||||
| import com.ruoyi.common.enums.BusinessType; | ||||
| import com.ruoyi.common.utils.StringUtils; | ||||
| import com.ruoyi.system.service.ISysMenuService; | ||||
| import io.swagger.annotations.Api; | ||||
| import io.swagger.annotations.ApiOperation; | ||||
| import io.swagger.annotations.ApiParam; | ||||
| import lombok.RequiredArgsConstructor; | ||||
| import org.springframework.beans.factory.annotation.Autowired; | ||||
| import org.springframework.security.access.prepost.PreAuthorize; | ||||
| import org.springframework.validation.annotation.Validated; | ||||
| @@ -20,22 +25,24 @@ import java.util.Map; | ||||
| /** | ||||
|  * 菜单信息 | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  * @author Lion Li | ||||
|  */ | ||||
| @Validated | ||||
| @Api(value = "菜单信息控制器", tags = {"菜单信息管理"}) | ||||
| @RequiredArgsConstructor(onConstructor_ = @Autowired) | ||||
| @RestController | ||||
| @RequestMapping("/system/menu") | ||||
| public class SysMenuController extends BaseController | ||||
| { | ||||
|     @Autowired | ||||
|     private ISysMenuService menuService; | ||||
| public class SysMenuController extends BaseController { | ||||
|  | ||||
|     private final ISysMenuService menuService; | ||||
|  | ||||
|     /** | ||||
|      * 获取菜单列表 | ||||
|      */ | ||||
|     @ApiOperation("获取菜单列表") | ||||
|     @PreAuthorize("@ss.hasPermi('system:menu:list')") | ||||
|     @GetMapping("/list") | ||||
|     public AjaxResult list(SysMenu menu) | ||||
|     { | ||||
|     public AjaxResult<List<SysMenu>> list(SysMenu menu) { | ||||
|         List<SysMenu> menus = menuService.selectMenuList(menu, getUserId()); | ||||
|         return AjaxResult.success(menus); | ||||
|     } | ||||
| @@ -43,19 +50,19 @@ public class SysMenuController extends BaseController | ||||
|     /** | ||||
|      * 根据菜单编号获取详细信息 | ||||
|      */ | ||||
|     @ApiOperation("根据菜单编号获取详细信息") | ||||
|     @PreAuthorize("@ss.hasPermi('system:menu:query')") | ||||
|     @GetMapping(value = "/{menuId}") | ||||
|     public AjaxResult getInfo(@PathVariable Long menuId) | ||||
|     { | ||||
|     public AjaxResult<SysMenu> getInfo(@ApiParam("菜单ID") @PathVariable Long menuId) { | ||||
|         return AjaxResult.success(menuService.selectMenuById(menuId)); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 获取菜单下拉树列表 | ||||
|      */ | ||||
|     @ApiOperation("获取菜单下拉树列表") | ||||
|     @GetMapping("/treeselect") | ||||
|     public AjaxResult treeselect(SysMenu menu) | ||||
|     { | ||||
|     public AjaxResult<List<Tree<Long>>> treeselect(SysMenu menu) { | ||||
|         List<SysMenu> menus = menuService.selectMenuList(menu, getUserId()); | ||||
|         return AjaxResult.success(menuService.buildMenuTreeSelect(menus)); | ||||
|     } | ||||
| @@ -63,11 +70,11 @@ public class SysMenuController extends BaseController | ||||
|     /** | ||||
|      * 加载对应角色菜单列表树 | ||||
|      */ | ||||
|     @ApiOperation("加载对应角色菜单列表树") | ||||
|     @GetMapping(value = "/roleMenuTreeselect/{roleId}") | ||||
|     public AjaxResult roleMenuTreeselect(@PathVariable("roleId") Long roleId) | ||||
|     { | ||||
| 		List<SysMenu> menus = menuService.selectMenuList(getUserId()); | ||||
| 		Map<String,Object> ajax = new HashMap<>(); | ||||
|     public AjaxResult<Map<String, Object>> roleMenuTreeselect(@ApiParam("角色ID") @PathVariable("roleId") Long roleId) { | ||||
|         List<SysMenu> menus = menuService.selectMenuList(getUserId()); | ||||
|         Map<String, Object> ajax = new HashMap<>(); | ||||
|         ajax.put("checkedKeys", menuService.selectMenuListByRoleId(roleId)); | ||||
|         ajax.put("menus", menuService.buildMenuTreeSelect(menus)); | ||||
|         return AjaxResult.success(ajax); | ||||
| @@ -76,61 +83,49 @@ public class SysMenuController extends BaseController | ||||
|     /** | ||||
|      * 新增菜单 | ||||
|      */ | ||||
|     @ApiOperation("新增菜单") | ||||
|     @PreAuthorize("@ss.hasPermi('system:menu:add')") | ||||
|     @Log(title = "菜单管理", businessType = BusinessType.INSERT) | ||||
|     @PostMapping | ||||
|     public AjaxResult add(@Validated @RequestBody SysMenu menu) | ||||
|     { | ||||
|         if (UserConstants.NOT_UNIQUE.equals(menuService.checkMenuNameUnique(menu))) | ||||
|         { | ||||
|     public AjaxResult<Void> add(@Validated @RequestBody SysMenu menu) { | ||||
|         if (UserConstants.NOT_UNIQUE.equals(menuService.checkMenuNameUnique(menu))) { | ||||
|             return AjaxResult.error("新增菜单'" + menu.getMenuName() + "'失败,菜单名称已存在"); | ||||
|         } | ||||
|         else if (UserConstants.YES_FRAME.equals(menu.getIsFrame()) && !StringUtils.ishttp(menu.getPath())) | ||||
|         { | ||||
|         } else if (UserConstants.YES_FRAME.equals(menu.getIsFrame()) && !StringUtils.ishttp(menu.getPath())) { | ||||
|             return AjaxResult.error("新增菜单'" + menu.getMenuName() + "'失败,地址必须以http(s)://开头"); | ||||
|         } | ||||
|         menu.setCreateBy(getUsername()); | ||||
|         return toAjax(menuService.insertMenu(menu)); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 修改菜单 | ||||
|      */ | ||||
|     @ApiOperation("修改菜单") | ||||
|     @PreAuthorize("@ss.hasPermi('system:menu:edit')") | ||||
|     @Log(title = "菜单管理", businessType = BusinessType.UPDATE) | ||||
|     @PutMapping | ||||
|     public AjaxResult edit(@Validated @RequestBody SysMenu menu) | ||||
|     { | ||||
|         if (UserConstants.NOT_UNIQUE.equals(menuService.checkMenuNameUnique(menu))) | ||||
|         { | ||||
|     public AjaxResult<Void> edit(@Validated @RequestBody SysMenu menu) { | ||||
|         if (UserConstants.NOT_UNIQUE.equals(menuService.checkMenuNameUnique(menu))) { | ||||
|             return AjaxResult.error("修改菜单'" + menu.getMenuName() + "'失败,菜单名称已存在"); | ||||
|         } | ||||
|         else if (UserConstants.YES_FRAME.equals(menu.getIsFrame()) && !StringUtils.ishttp(menu.getPath())) | ||||
|         { | ||||
|         } else if (UserConstants.YES_FRAME.equals(menu.getIsFrame()) && !StringUtils.ishttp(menu.getPath())) { | ||||
|             return AjaxResult.error("修改菜单'" + menu.getMenuName() + "'失败,地址必须以http(s)://开头"); | ||||
|         } | ||||
|         else if (menu.getMenuId().equals(menu.getParentId())) | ||||
|         { | ||||
|         } else if (menu.getMenuId().equals(menu.getParentId())) { | ||||
|             return AjaxResult.error("修改菜单'" + menu.getMenuName() + "'失败,上级菜单不能选择自己"); | ||||
|         } | ||||
|         menu.setUpdateBy(getUsername()); | ||||
|         return toAjax(menuService.updateMenu(menu)); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 删除菜单 | ||||
|      */ | ||||
|     @ApiOperation("删除菜单") | ||||
|     @PreAuthorize("@ss.hasPermi('system:menu:remove')") | ||||
|     @Log(title = "菜单管理", businessType = BusinessType.DELETE) | ||||
|     @DeleteMapping("/{menuId}") | ||||
|     public AjaxResult remove(@PathVariable("menuId") Long menuId) | ||||
|     { | ||||
|         if (menuService.hasChildByMenuId(menuId)) | ||||
|         { | ||||
|     public AjaxResult<Void> remove(@ApiParam("菜单ID") @PathVariable("menuId") Long menuId) { | ||||
|         if (menuService.hasChildByMenuId(menuId)) { | ||||
|             return AjaxResult.error("存在子菜单,不允许删除"); | ||||
|         } | ||||
|         if (menuService.checkMenuExistRole(menuId)) | ||||
|         { | ||||
|         if (menuService.checkMenuExistRole(menuId)) { | ||||
|             return AjaxResult.error("菜单已分配,不允许删除"); | ||||
|         } | ||||
|         return toAjax(menuService.deleteMenuById(menuId)); | ||||
|   | ||||
| @@ -1,89 +1,86 @@ | ||||
| package com.ruoyi.web.controller.system; | ||||
|  | ||||
| import java.util.List; | ||||
| import org.springframework.beans.factory.annotation.Autowired; | ||||
| import org.springframework.security.access.prepost.PreAuthorize; | ||||
| import org.springframework.validation.annotation.Validated; | ||||
| import org.springframework.web.bind.annotation.DeleteMapping; | ||||
| import org.springframework.web.bind.annotation.GetMapping; | ||||
| import org.springframework.web.bind.annotation.PathVariable; | ||||
| 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.RestController; | ||||
| import com.ruoyi.common.annotation.Log; | ||||
| import com.ruoyi.common.core.controller.BaseController; | ||||
| import com.ruoyi.common.core.domain.AjaxResult; | ||||
| import com.ruoyi.common.core.domain.PageQuery; | ||||
| import com.ruoyi.common.core.page.TableDataInfo; | ||||
| import com.ruoyi.common.enums.BusinessType; | ||||
| import com.ruoyi.system.domain.SysNotice; | ||||
| import com.ruoyi.system.service.ISysNoticeService; | ||||
| import io.swagger.annotations.Api; | ||||
| import io.swagger.annotations.ApiOperation; | ||||
| import io.swagger.annotations.ApiParam; | ||||
| import lombok.RequiredArgsConstructor; | ||||
| import org.springframework.beans.factory.annotation.Autowired; | ||||
| import org.springframework.security.access.prepost.PreAuthorize; | ||||
| import org.springframework.validation.annotation.Validated; | ||||
| import org.springframework.web.bind.annotation.*; | ||||
|  | ||||
| /** | ||||
|  * 公告 信息操作处理 | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  * @author Lion Li | ||||
|  */ | ||||
| @Validated | ||||
| @Api(value = "公告信息控制器", tags = {"公告信息管理"}) | ||||
| @RequiredArgsConstructor(onConstructor_ = @Autowired) | ||||
| @RestController | ||||
| @RequestMapping("/system/notice") | ||||
| public class SysNoticeController extends BaseController | ||||
| { | ||||
|     @Autowired | ||||
|     private ISysNoticeService noticeService; | ||||
| public class SysNoticeController extends BaseController { | ||||
|  | ||||
|     private final ISysNoticeService noticeService; | ||||
|  | ||||
|     /** | ||||
|      * 获取通知公告列表 | ||||
|      */ | ||||
|     @ApiOperation("获取通知公告列表") | ||||
|     @PreAuthorize("@ss.hasPermi('system:notice:list')") | ||||
|     @GetMapping("/list") | ||||
|     public TableDataInfo list(SysNotice notice) | ||||
|     { | ||||
|         return noticeService.selectPageNoticeList(notice); | ||||
|     public TableDataInfo<SysNotice> list(SysNotice notice, PageQuery pageQuery) { | ||||
|         return noticeService.selectPageNoticeList(notice, pageQuery); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 根据通知公告编号获取详细信息 | ||||
|      */ | ||||
|     @ApiOperation("根据通知公告编号获取详细信息") | ||||
|     @PreAuthorize("@ss.hasPermi('system:notice:query')") | ||||
|     @GetMapping(value = "/{noticeId}") | ||||
|     public AjaxResult getInfo(@PathVariable Long noticeId) | ||||
|     { | ||||
|     public AjaxResult<SysNotice> getInfo(@ApiParam("公告ID") @PathVariable Long noticeId) { | ||||
|         return AjaxResult.success(noticeService.selectNoticeById(noticeId)); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 新增通知公告 | ||||
|      */ | ||||
|     @ApiOperation("新增通知公告") | ||||
|     @PreAuthorize("@ss.hasPermi('system:notice:add')") | ||||
|     @Log(title = "通知公告", businessType = BusinessType.INSERT) | ||||
|     @PostMapping | ||||
|     public AjaxResult add(@Validated @RequestBody SysNotice notice) | ||||
|     { | ||||
|         notice.setCreateBy(getUsername()); | ||||
|     public AjaxResult<Void> add(@Validated @RequestBody SysNotice notice) { | ||||
|         return toAjax(noticeService.insertNotice(notice)); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 修改通知公告 | ||||
|      */ | ||||
|     @ApiOperation("修改通知公告") | ||||
|     @PreAuthorize("@ss.hasPermi('system:notice:edit')") | ||||
|     @Log(title = "通知公告", businessType = BusinessType.UPDATE) | ||||
|     @PutMapping | ||||
|     public AjaxResult edit(@Validated @RequestBody SysNotice notice) | ||||
|     { | ||||
|         notice.setUpdateBy(getUsername()); | ||||
|     public AjaxResult<Void> edit(@Validated @RequestBody SysNotice notice) { | ||||
|         return toAjax(noticeService.updateNotice(notice)); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 删除通知公告 | ||||
|      */ | ||||
|     @ApiOperation("删除通知公告") | ||||
|     @PreAuthorize("@ss.hasPermi('system:notice:remove')") | ||||
|     @Log(title = "通知公告", businessType = BusinessType.DELETE) | ||||
|     @DeleteMapping("/{noticeIds}") | ||||
|     public AjaxResult remove(@PathVariable Long[] noticeIds) | ||||
|     { | ||||
|     public AjaxResult<Void> remove(@ApiParam("公告ID串") @PathVariable Long[] noticeIds) { | ||||
|         return toAjax(noticeService.deleteNoticeByIds(noticeIds)); | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -4,6 +4,7 @@ import com.ruoyi.common.annotation.Log; | ||||
| import com.ruoyi.common.annotation.RepeatSubmit; | ||||
| import com.ruoyi.common.core.controller.BaseController; | ||||
| import com.ruoyi.common.core.domain.AjaxResult; | ||||
| import com.ruoyi.common.core.domain.PageQuery; | ||||
| import com.ruoyi.common.core.page.TableDataInfo; | ||||
| import com.ruoyi.common.core.validate.AddGroup; | ||||
| import com.ruoyi.common.core.validate.EditGroup; | ||||
| @@ -14,6 +15,7 @@ import com.ruoyi.system.domain.vo.SysOssConfigVo; | ||||
| import com.ruoyi.system.service.ISysOssConfigService; | ||||
| import io.swagger.annotations.Api; | ||||
| import io.swagger.annotations.ApiOperation; | ||||
| import io.swagger.annotations.ApiParam; | ||||
| import lombok.RequiredArgsConstructor; | ||||
| import org.springframework.beans.factory.annotation.Autowired; | ||||
| import org.springframework.security.access.prepost.PreAuthorize; | ||||
| @@ -25,85 +27,88 @@ import javax.validation.constraints.NotNull; | ||||
| import java.util.Arrays; | ||||
|  | ||||
| /** | ||||
|  * 云存储配置Controller | ||||
|  * 对象存储配置Controller | ||||
|  * | ||||
|  * @author Lion Li | ||||
|  * @author 孤舟烟雨 | ||||
|  * @date 2021-08-13 | ||||
|  */ | ||||
| @Validated | ||||
| @Api(value = "云存储配置控制器", tags = {"云存储配置管理"}) | ||||
| @Api(value = "对象存储配置控制器", tags = {"对象存储配置管理"}) | ||||
| @RequiredArgsConstructor(onConstructor_ = @Autowired) | ||||
| @RestController | ||||
| @RequestMapping("/system/oss/config") | ||||
| public class SysOssConfigController extends BaseController { | ||||
|  | ||||
| 	private final ISysOssConfigService iSysOssConfigService; | ||||
|     private final ISysOssConfigService iSysOssConfigService; | ||||
|  | ||||
| 	/** | ||||
| 	 * 查询云存储配置列表 | ||||
| 	 */ | ||||
| 	@ApiOperation("查询云存储配置列表") | ||||
| 	@PreAuthorize("@ss.hasPermi('system:oss:list')") | ||||
| 	@GetMapping("/list") | ||||
| 	public TableDataInfo<SysOssConfigVo> list(@Validated(QueryGroup.class) SysOssConfigBo bo) { | ||||
| 		return iSysOssConfigService.queryPageList(bo); | ||||
| 	} | ||||
|     /** | ||||
|      * 查询对象存储配置列表 | ||||
|      */ | ||||
|     @ApiOperation("查询对象存储配置列表") | ||||
|     @PreAuthorize("@ss.hasPermi('system:oss:list')") | ||||
|     @GetMapping("/list") | ||||
|     public TableDataInfo<SysOssConfigVo> list(@Validated(QueryGroup.class) SysOssConfigBo bo, PageQuery pageQuery) { | ||||
|         return iSysOssConfigService.queryPageList(bo, pageQuery); | ||||
|     } | ||||
|  | ||||
| 	/** | ||||
| 	 * 获取云存储配置详细信息 | ||||
| 	 */ | ||||
| 	@ApiOperation("获取云存储配置详细信息") | ||||
| 	@PreAuthorize("@ss.hasPermi('system:oss:query')") | ||||
| 	@GetMapping("/{ossConfigId}") | ||||
| 	public AjaxResult<SysOssConfigVo> getInfo(@NotNull(message = "主键不能为空") | ||||
| 											  @PathVariable("ossConfigId") Integer ossConfigId) { | ||||
| 		return AjaxResult.success(iSysOssConfigService.queryById(ossConfigId)); | ||||
| 	} | ||||
|     /** | ||||
|      * 获取对象存储配置详细信息 | ||||
|      */ | ||||
|     @ApiOperation("获取对象存储配置详细信息") | ||||
|     @PreAuthorize("@ss.hasPermi('system:oss:query')") | ||||
|     @GetMapping("/{ossConfigId}") | ||||
|     public AjaxResult<SysOssConfigVo> getInfo(@ApiParam("OSS配置ID") | ||||
|                                               @NotNull(message = "主键不能为空") | ||||
|                                               @PathVariable("ossConfigId") Integer ossConfigId) { | ||||
|         return AjaxResult.success(iSysOssConfigService.queryById(ossConfigId)); | ||||
|     } | ||||
|  | ||||
| 	/** | ||||
| 	 * 新增云存储配置 | ||||
| 	 */ | ||||
| 	@ApiOperation("新增云存储配置") | ||||
| 	@PreAuthorize("@ss.hasPermi('system:oss:add')") | ||||
| 	@Log(title = "云存储配置", businessType = BusinessType.INSERT) | ||||
| 	@RepeatSubmit() | ||||
| 	@PostMapping() | ||||
| 	public AjaxResult<Void> add(@Validated(AddGroup.class) @RequestBody SysOssConfigBo bo) { | ||||
| 		return toAjax(iSysOssConfigService.insertByBo(bo) ? 1 : 0); | ||||
| 	} | ||||
|     /** | ||||
|      * 新增对象存储配置 | ||||
|      */ | ||||
|     @ApiOperation("新增对象存储配置") | ||||
|     @PreAuthorize("@ss.hasPermi('system:oss:add')") | ||||
|     @Log(title = "对象存储配置", businessType = BusinessType.INSERT) | ||||
|     @RepeatSubmit() | ||||
|     @PostMapping() | ||||
|     public AjaxResult<Void> add(@Validated(AddGroup.class) @RequestBody SysOssConfigBo bo) { | ||||
|         return toAjax(iSysOssConfigService.insertByBo(bo) ? 1 : 0); | ||||
|     } | ||||
|  | ||||
| 	/** | ||||
| 	 * 修改云存储配置 | ||||
| 	 */ | ||||
| 	@ApiOperation("修改云存储配置") | ||||
| 	@PreAuthorize("@ss.hasPermi('system:oss:edit')") | ||||
| 	@Log(title = "云存储配置", businessType = BusinessType.UPDATE) | ||||
| 	@RepeatSubmit() | ||||
| 	@PutMapping() | ||||
| 	public AjaxResult<Void> edit(@Validated(EditGroup.class) @RequestBody SysOssConfigBo bo) { | ||||
| 		return toAjax(iSysOssConfigService.updateByBo(bo) ? 1 : 0); | ||||
| 	} | ||||
|     /** | ||||
|      * 修改对象存储配置 | ||||
|      */ | ||||
|     @ApiOperation("修改对象存储配置") | ||||
|     @PreAuthorize("@ss.hasPermi('system:oss:edit')") | ||||
|     @Log(title = "对象存储配置", businessType = BusinessType.UPDATE) | ||||
|     @RepeatSubmit() | ||||
|     @PutMapping() | ||||
|     public AjaxResult<Void> edit(@Validated(EditGroup.class) @RequestBody SysOssConfigBo bo) { | ||||
|         return toAjax(iSysOssConfigService.updateByBo(bo) ? 1 : 0); | ||||
|     } | ||||
|  | ||||
| 	/** | ||||
| 	 * 删除云存储配置 | ||||
| 	 */ | ||||
| 	@ApiOperation("删除云存储配置") | ||||
| 	@PreAuthorize("@ss.hasPermi('system:oss:remove')") | ||||
| 	@Log(title = "云存储配置", businessType = BusinessType.DELETE) | ||||
| 	@DeleteMapping("/{ossConfigIds}") | ||||
| 	public AjaxResult<Void> remove(@NotEmpty(message = "主键不能为空") | ||||
| 								   @PathVariable Long[] ossConfigIds) { | ||||
| 		return toAjax(iSysOssConfigService.deleteWithValidByIds(Arrays.asList(ossConfigIds), true) ? 1 : 0); | ||||
| 	} | ||||
|     /** | ||||
|      * 删除对象存储配置 | ||||
|      */ | ||||
|     @ApiOperation("删除对象存储配置") | ||||
|     @PreAuthorize("@ss.hasPermi('system:oss:remove')") | ||||
|     @Log(title = "对象存储配置", businessType = BusinessType.DELETE) | ||||
|     @DeleteMapping("/{ossConfigIds}") | ||||
|     public AjaxResult<Void> remove(@ApiParam("OSS配置ID串") | ||||
|                                    @NotEmpty(message = "主键不能为空") | ||||
|                                    @PathVariable Long[] ossConfigIds) { | ||||
|         return toAjax(iSysOssConfigService.deleteWithValidByIds(Arrays.asList(ossConfigIds), true) ? 1 : 0); | ||||
|     } | ||||
|  | ||||
| 	/** | ||||
| 	 * 状态修改 | ||||
| 	 */ | ||||
| 	@PreAuthorize("@ss.hasPermi('system:oss:edit')") | ||||
| 	@Log(title = "云存储状态修改", businessType = BusinessType.UPDATE) | ||||
| 	@PutMapping("/changeStatus") | ||||
| 	public AjaxResult changeStatus(@RequestBody SysOssConfigBo bo) { | ||||
| 		return toAjax(iSysOssConfigService.updateOssConfigStatus(bo)); | ||||
| 	} | ||||
|     /** | ||||
|      * 状态修改 | ||||
|      */ | ||||
|     @ApiOperation("状态修改") | ||||
|     @PreAuthorize("@ss.hasPermi('system:oss:edit')") | ||||
|     @Log(title = "对象存储状态修改", businessType = BusinessType.UPDATE) | ||||
|     @PutMapping("/changeStatus") | ||||
|     public AjaxResult<Void> changeStatus(@RequestBody SysOssConfigBo bo) { | ||||
|         return toAjax(iSysOssConfigService.updateOssConfigStatus(bo)); | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -3,29 +3,28 @@ package com.ruoyi.web.controller.system; | ||||
|  | ||||
| import cn.hutool.core.convert.Convert; | ||||
| import cn.hutool.core.util.ObjectUtil; | ||||
| import cn.hutool.http.HttpException; | ||||
| import cn.hutool.http.HttpUtil; | ||||
| import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; | ||||
| import com.ruoyi.common.annotation.Log; | ||||
| import com.ruoyi.common.annotation.RepeatSubmit; | ||||
| import com.ruoyi.common.core.controller.BaseController; | ||||
| import com.ruoyi.common.core.domain.AjaxResult; | ||||
| import com.ruoyi.common.core.domain.PageQuery; | ||||
| import com.ruoyi.common.core.page.TableDataInfo; | ||||
| import com.ruoyi.common.core.validate.QueryGroup; | ||||
| import com.ruoyi.common.enums.BusinessType; | ||||
| import com.ruoyi.common.exception.ServiceException; | ||||
| import com.ruoyi.common.utils.JsonUtils; | ||||
| import com.ruoyi.common.utils.file.FileUtils; | ||||
| import com.ruoyi.oss.constant.CloudConstant; | ||||
| import com.ruoyi.oss.constant.OssConstant; | ||||
| import com.ruoyi.system.domain.SysConfig; | ||||
| import com.ruoyi.system.domain.SysOss; | ||||
| import com.ruoyi.system.domain.bo.SysOssBo; | ||||
| import com.ruoyi.system.domain.vo.SysOssVo; | ||||
| import com.ruoyi.system.service.ISysConfigService; | ||||
| import com.ruoyi.system.service.ISysOssService; | ||||
| import io.swagger.annotations.Api; | ||||
| import io.swagger.annotations.ApiImplicitParam; | ||||
| import io.swagger.annotations.ApiImplicitParams; | ||||
| import io.swagger.annotations.ApiOperation; | ||||
| import io.swagger.annotations.*; | ||||
| import lombok.RequiredArgsConstructor; | ||||
| import org.springframework.beans.factory.annotation.Autowired; | ||||
| import org.springframework.http.MediaType; | ||||
| @@ -36,9 +35,8 @@ import org.springframework.web.multipart.MultipartFile; | ||||
|  | ||||
| import javax.servlet.http.HttpServletResponse; | ||||
| import javax.validation.constraints.NotEmpty; | ||||
| import java.io.File; | ||||
| import java.io.IOException; | ||||
| import java.net.URLEncoder; | ||||
| import java.nio.charset.StandardCharsets; | ||||
| import java.util.Arrays; | ||||
| import java.util.HashMap; | ||||
| import java.util.Map; | ||||
| @@ -49,89 +47,97 @@ import java.util.Map; | ||||
|  * @author Lion Li | ||||
|  */ | ||||
| @Validated | ||||
| @Api(value = "OSS云存储控制器", tags = {"OSS云存储管理"}) | ||||
| @Api(value = "OSS对象存储控制器", tags = {"OSS对象存储管理"}) | ||||
| @RequiredArgsConstructor(onConstructor_ = @Autowired) | ||||
| @RestController | ||||
| @RequestMapping("/system/oss") | ||||
| public class SysOssController extends BaseController { | ||||
|  | ||||
| 	private final ISysOssService iSysOssService; | ||||
| 	private final ISysConfigService iSysConfigService; | ||||
|     private final ISysOssService iSysOssService; | ||||
|     private final ISysConfigService iSysConfigService; | ||||
|  | ||||
| 	/** | ||||
| 	 * 查询OSS云存储列表 | ||||
| 	 */ | ||||
| 	@ApiOperation("查询OSS云存储列表") | ||||
| 	@PreAuthorize("@ss.hasPermi('system:oss:list')") | ||||
| 	@GetMapping("/list") | ||||
| 	public TableDataInfo<SysOssVo> list(@Validated(QueryGroup.class) SysOssBo bo) { | ||||
| 		return iSysOssService.queryPageList(bo); | ||||
| 	} | ||||
|     /** | ||||
|      * 查询OSS对象存储列表 | ||||
|      */ | ||||
|     @ApiOperation("查询OSS对象存储列表") | ||||
|     @PreAuthorize("@ss.hasPermi('system:oss:list')") | ||||
|     @GetMapping("/list") | ||||
|     public TableDataInfo<SysOssVo> list(@Validated(QueryGroup.class) SysOssBo bo, PageQuery pageQuery) { | ||||
|         return iSysOssService.queryPageList(bo, pageQuery); | ||||
|     } | ||||
|  | ||||
| 	/** | ||||
| 	 * 上传OSS云存储 | ||||
| 	 */ | ||||
| 	@ApiOperation("上传OSS云存储") | ||||
| 	@ApiImplicitParams({ | ||||
| 		@ApiImplicitParam(name = "file", value = "文件", dataType = "java.io.File", required = true), | ||||
| 	}) | ||||
| 	@PreAuthorize("@ss.hasPermi('system:oss:upload')") | ||||
| 	@Log(title = "OSS云存储", businessType = BusinessType.INSERT) | ||||
| 	@RepeatSubmit | ||||
| 	@PostMapping("/upload") | ||||
| 	public AjaxResult<Map<String, String>> upload(@RequestPart("file") MultipartFile file) { | ||||
| 		if (ObjectUtil.isNull(file)) { | ||||
| 			throw new ServiceException("上传文件不能为空"); | ||||
| 		} | ||||
| 		SysOss oss = iSysOssService.upload(file); | ||||
| 		Map<String, String> map = new HashMap<>(2); | ||||
| 		map.put("url", oss.getUrl()); | ||||
| 		map.put("fileName", oss.getFileName()); | ||||
| 		return AjaxResult.success(map); | ||||
| 	} | ||||
|     /** | ||||
|      * 上传OSS对象存储 | ||||
|      */ | ||||
|     @ApiOperation("上传OSS对象存储") | ||||
|     @ApiImplicitParams({ | ||||
|         @ApiImplicitParam(name = "file", value = "文件", dataTypeClass = File.class, required = true), | ||||
|     }) | ||||
|     @PreAuthorize("@ss.hasPermi('system:oss:upload')") | ||||
|     @Log(title = "OSS对象存储", businessType = BusinessType.INSERT) | ||||
|     @RepeatSubmit | ||||
|     @PostMapping("/upload") | ||||
|     public AjaxResult<Map<String, String>> upload(@RequestPart("file") MultipartFile file) { | ||||
|         if (ObjectUtil.isNull(file)) { | ||||
|             throw new ServiceException("上传文件不能为空"); | ||||
|         } | ||||
|         SysOss oss = iSysOssService.upload(file); | ||||
|         Map<String, String> map = new HashMap<>(2); | ||||
|         map.put("url", oss.getUrl()); | ||||
|         map.put("fileName", oss.getFileName()); | ||||
|         return AjaxResult.success(map); | ||||
|     } | ||||
|  | ||||
| 	@ApiOperation("下载OSS云存储") | ||||
| 	@PreAuthorize("@ss.hasPermi('system:oss:download')") | ||||
| 	@GetMapping("/download/{ossId}") | ||||
| 	public void download(@PathVariable Long ossId, HttpServletResponse response) throws IOException { | ||||
| 		SysOss sysOss = iSysOssService.getById(ossId); | ||||
| 		if (ObjectUtil.isNull(sysOss)) { | ||||
| 			throw new ServiceException("文件数据不存在!"); | ||||
| 		} | ||||
| 		response.reset(); | ||||
| 		response.addHeader("Access-Control-Allow-Origin", "*"); | ||||
| 		response.addHeader("Access-Control-Expose-Headers", "Content-Disposition"); | ||||
| 		FileUtils.setAttachmentResponseHeader(response, URLEncoder.encode(sysOss.getOriginalName(), StandardCharsets.UTF_8.toString())); | ||||
| 		response.setContentType(MediaType.APPLICATION_OCTET_STREAM_VALUE + "; charset=UTF-8"); | ||||
| 		long data = HttpUtil.download(sysOss.getUrl(), response.getOutputStream(), false); | ||||
| 		response.setContentLength(Convert.toInt(data)); | ||||
| 	} | ||||
|     @ApiOperation("下载OSS对象存储") | ||||
|     @PreAuthorize("@ss.hasPermi('system:oss:download')") | ||||
|     @GetMapping("/download/{ossId}") | ||||
|     public void download(@ApiParam("OSS对象ID") @PathVariable Long ossId, HttpServletResponse response) throws IOException { | ||||
|         SysOss sysOss = iSysOssService.getById(ossId); | ||||
|         if (ObjectUtil.isNull(sysOss)) { | ||||
|             throw new ServiceException("文件数据不存在!"); | ||||
|         } | ||||
|         response.reset(); | ||||
|         FileUtils.setAttachmentResponseHeader(response, sysOss.getOriginalName()); | ||||
|         response.setContentType(MediaType.APPLICATION_OCTET_STREAM_VALUE + "; charset=UTF-8"); | ||||
|         long data; | ||||
|         try { | ||||
|             data = HttpUtil.download(sysOss.getUrl(), response.getOutputStream(), false); | ||||
|         } catch (HttpException e) { | ||||
|             if (e.getMessage().contains("403")) { | ||||
|                 throw new ServiceException("无读取权限, 请在对应的OSS开启'公有读'权限!"); | ||||
|             } else { | ||||
|                 throw new ServiceException(e.getMessage()); | ||||
|             } | ||||
|         } | ||||
|         response.setContentLength(Convert.toInt(data)); | ||||
|     } | ||||
|  | ||||
| 	/** | ||||
| 	 * 删除OSS云存储 | ||||
| 	 */ | ||||
| 	@ApiOperation("删除OSS云存储") | ||||
| 	@PreAuthorize("@ss.hasPermi('system:oss:remove')") | ||||
| 	@Log(title = "OSS云存储" , businessType = BusinessType.DELETE) | ||||
| 	@DeleteMapping("/{ossIds}") | ||||
| 	public AjaxResult<Void> remove(@NotEmpty(message = "主键不能为空") | ||||
| 								   @PathVariable Long[] ossIds) { | ||||
| 		return toAjax(iSysOssService.deleteWithValidByIds(Arrays.asList(ossIds), true) ? 1 : 0); | ||||
| 	} | ||||
|     /** | ||||
|      * 删除OSS对象存储 | ||||
|      */ | ||||
|     @ApiOperation("删除OSS对象存储") | ||||
|     @PreAuthorize("@ss.hasPermi('system:oss:remove')") | ||||
|     @Log(title = "OSS对象存储", businessType = BusinessType.DELETE) | ||||
|     @DeleteMapping("/{ossIds}") | ||||
|     public AjaxResult<Void> remove(@ApiParam("OSS对象ID串") | ||||
|                                    @NotEmpty(message = "主键不能为空") | ||||
|                                    @PathVariable Long[] ossIds) { | ||||
|         return toAjax(iSysOssService.deleteWithValidByIds(Arrays.asList(ossIds), true) ? 1 : 0); | ||||
|     } | ||||
|  | ||||
| 	/** | ||||
| 	 * 变更图片列表预览状态 | ||||
| 	 */ | ||||
| 	@ApiOperation("变更图片列表预览状态") | ||||
| 	@PreAuthorize("@ss.hasPermi('system:oss:edit')") | ||||
| 	@Log(title = "OSS云存储" , businessType = BusinessType.UPDATE) | ||||
| 	@PutMapping("/changePreviewListResource") | ||||
| 	public AjaxResult<Void> changePreviewListResource(@RequestBody String body) { | ||||
| 		Map<String, Boolean> map = JsonUtils.parseMap(body); | ||||
| 		SysConfig config = iSysConfigService.getOne(new LambdaQueryWrapper<SysConfig>() | ||||
| 			.eq(SysConfig::getConfigKey, CloudConstant.PEREVIEW_LIST_RESOURCE_KEY)); | ||||
| 		config.setConfigValue(map.get("previewListResource").toString()); | ||||
| 		return toAjax(iSysConfigService.updateConfig(config)); | ||||
| 	} | ||||
|     /** | ||||
|      * 变更图片列表预览状态 | ||||
|      */ | ||||
|     @ApiOperation("变更图片列表预览状态") | ||||
|     @PreAuthorize("@ss.hasPermi('system:oss:edit')") | ||||
|     @Log(title = "OSS对象存储", businessType = BusinessType.UPDATE) | ||||
|     @PutMapping("/changePreviewListResource") | ||||
|     public AjaxResult<Void> changePreviewListResource(@RequestBody String body) { | ||||
|         Map<String, Boolean> map = JsonUtils.parseMap(body); | ||||
|         SysConfig config = iSysConfigService.getOne(new LambdaQueryWrapper<SysConfig>() | ||||
|             .eq(SysConfig::getConfigKey, OssConstant.PEREVIEW_LIST_RESOURCE_KEY)); | ||||
|         config.setConfigValue(map.get("previewListResource").toString()); | ||||
|         return toAjax(iSysConfigService.updateConfig(config)); | ||||
|     } | ||||
|  | ||||
| } | ||||
|   | ||||
| @@ -4,11 +4,16 @@ import com.ruoyi.common.annotation.Log; | ||||
| import com.ruoyi.common.constant.UserConstants; | ||||
| import com.ruoyi.common.core.controller.BaseController; | ||||
| import com.ruoyi.common.core.domain.AjaxResult; | ||||
| import com.ruoyi.common.core.domain.PageQuery; | ||||
| import com.ruoyi.common.core.page.TableDataInfo; | ||||
| import com.ruoyi.common.enums.BusinessType; | ||||
| import com.ruoyi.common.utils.poi.ExcelUtil; | ||||
| import com.ruoyi.system.domain.SysPost; | ||||
| import com.ruoyi.system.service.ISysPostService; | ||||
| import io.swagger.annotations.Api; | ||||
| import io.swagger.annotations.ApiOperation; | ||||
| import io.swagger.annotations.ApiParam; | ||||
| import lombok.RequiredArgsConstructor; | ||||
| import org.springframework.beans.factory.annotation.Autowired; | ||||
| import org.springframework.security.access.prepost.PreAuthorize; | ||||
| import org.springframework.validation.annotation.Validated; | ||||
| @@ -20,101 +25,95 @@ import java.util.List; | ||||
| /** | ||||
|  * 岗位信息操作处理 | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  * @author Lion Li | ||||
|  */ | ||||
| @Validated | ||||
| @Api(value = "岗位信息控制器", tags = {"岗位信息管理"}) | ||||
| @RequiredArgsConstructor(onConstructor_ = @Autowired) | ||||
| @RestController | ||||
| @RequestMapping("/system/post") | ||||
| public class SysPostController extends BaseController | ||||
| { | ||||
|     @Autowired | ||||
|     private ISysPostService postService; | ||||
| public class SysPostController extends BaseController { | ||||
|  | ||||
|     private final ISysPostService postService; | ||||
|  | ||||
|     /** | ||||
|      * 获取岗位列表 | ||||
|      */ | ||||
|     @ApiOperation("获取岗位列表") | ||||
|     @PreAuthorize("@ss.hasPermi('system:post:list')") | ||||
|     @GetMapping("/list") | ||||
|     public TableDataInfo list(SysPost post) | ||||
|     { | ||||
|         return postService.selectPagePostList(post); | ||||
|     public TableDataInfo<SysPost> list(SysPost post, PageQuery pageQuery) { | ||||
|         return postService.selectPagePostList(post, pageQuery); | ||||
|     } | ||||
|  | ||||
|     @ApiOperation("导出岗位列表") | ||||
|     @Log(title = "岗位管理", businessType = BusinessType.EXPORT) | ||||
|     @PreAuthorize("@ss.hasPermi('system:post:export')") | ||||
|     @GetMapping("/export") | ||||
|     public void export(SysPost post, HttpServletResponse response) | ||||
|     { | ||||
|     @PostMapping("/export") | ||||
|     public void export(SysPost post, HttpServletResponse response) { | ||||
|         List<SysPost> list = postService.selectPostList(post); | ||||
| 		ExcelUtil.exportExcel(list, "岗位数据", SysPost.class, response); | ||||
|         ExcelUtil.exportExcel(list, "岗位数据", SysPost.class, response); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 根据岗位编号获取详细信息 | ||||
|      */ | ||||
|     @ApiOperation("根据岗位编号获取详细信息") | ||||
|     @PreAuthorize("@ss.hasPermi('system:post:query')") | ||||
|     @GetMapping(value = "/{postId}") | ||||
|     public AjaxResult getInfo(@PathVariable Long postId) | ||||
|     { | ||||
|     public AjaxResult<SysPost> getInfo(@ApiParam("岗位ID") @PathVariable Long postId) { | ||||
|         return AjaxResult.success(postService.selectPostById(postId)); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 新增岗位 | ||||
|      */ | ||||
|     @ApiOperation("新增岗位") | ||||
|     @PreAuthorize("@ss.hasPermi('system:post:add')") | ||||
|     @Log(title = "岗位管理", businessType = BusinessType.INSERT) | ||||
|     @PostMapping | ||||
|     public AjaxResult add(@Validated @RequestBody SysPost post) | ||||
|     { | ||||
|         if (UserConstants.NOT_UNIQUE.equals(postService.checkPostNameUnique(post))) | ||||
|         { | ||||
|     public AjaxResult<Void> add(@Validated @RequestBody SysPost post) { | ||||
|         if (UserConstants.NOT_UNIQUE.equals(postService.checkPostNameUnique(post))) { | ||||
|             return AjaxResult.error("新增岗位'" + post.getPostName() + "'失败,岗位名称已存在"); | ||||
|         } | ||||
|         else if (UserConstants.NOT_UNIQUE.equals(postService.checkPostCodeUnique(post))) | ||||
|         { | ||||
|         } else if (UserConstants.NOT_UNIQUE.equals(postService.checkPostCodeUnique(post))) { | ||||
|             return AjaxResult.error("新增岗位'" + post.getPostName() + "'失败,岗位编码已存在"); | ||||
|         } | ||||
|         post.setCreateBy(getUsername()); | ||||
|         return toAjax(postService.insertPost(post)); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 修改岗位 | ||||
|      */ | ||||
|     @ApiOperation("修改岗位") | ||||
|     @PreAuthorize("@ss.hasPermi('system:post:edit')") | ||||
|     @Log(title = "岗位管理", businessType = BusinessType.UPDATE) | ||||
|     @PutMapping | ||||
|     public AjaxResult edit(@Validated @RequestBody SysPost post) | ||||
|     { | ||||
|         if (UserConstants.NOT_UNIQUE.equals(postService.checkPostNameUnique(post))) | ||||
|         { | ||||
|     public AjaxResult<Void> edit(@Validated @RequestBody SysPost post) { | ||||
|         if (UserConstants.NOT_UNIQUE.equals(postService.checkPostNameUnique(post))) { | ||||
|             return AjaxResult.error("修改岗位'" + post.getPostName() + "'失败,岗位名称已存在"); | ||||
|         } | ||||
|         else if (UserConstants.NOT_UNIQUE.equals(postService.checkPostCodeUnique(post))) | ||||
|         { | ||||
|         } else if (UserConstants.NOT_UNIQUE.equals(postService.checkPostCodeUnique(post))) { | ||||
|             return AjaxResult.error("修改岗位'" + post.getPostName() + "'失败,岗位编码已存在"); | ||||
|         } | ||||
|         post.setUpdateBy(getUsername()); | ||||
|         return toAjax(postService.updatePost(post)); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 删除岗位 | ||||
|      */ | ||||
|     @ApiOperation("删除岗位") | ||||
|     @PreAuthorize("@ss.hasPermi('system:post:remove')") | ||||
|     @Log(title = "岗位管理", businessType = BusinessType.DELETE) | ||||
|     @DeleteMapping("/{postIds}") | ||||
|     public AjaxResult remove(@PathVariable Long[] postIds) | ||||
|     { | ||||
|     public AjaxResult<Void> remove(@ApiParam("岗位ID串") @PathVariable Long[] postIds) { | ||||
|         return toAjax(postService.deletePostByIds(postIds)); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 获取岗位选择框列表 | ||||
|      */ | ||||
|     @ApiOperation("获取岗位选择框列表") | ||||
|     @GetMapping("/optionselect") | ||||
|     public AjaxResult optionselect() | ||||
|     { | ||||
|     public AjaxResult<List<SysPost>> optionselect() { | ||||
|         List<SysPost> posts = postService.selectPostAll(); | ||||
|         return AjaxResult.success(posts); | ||||
|     } | ||||
|   | ||||
| @@ -6,49 +6,53 @@ import com.ruoyi.common.core.controller.BaseController; | ||||
| import com.ruoyi.common.core.domain.AjaxResult; | ||||
| import com.ruoyi.common.core.domain.entity.SysUser; | ||||
| import com.ruoyi.common.core.domain.model.LoginUser; | ||||
| import com.ruoyi.common.core.service.TokenService; | ||||
| import com.ruoyi.common.enums.BusinessType; | ||||
| import com.ruoyi.common.utils.SecurityUtils; | ||||
| import com.ruoyi.common.utils.StringUtils; | ||||
| import com.ruoyi.framework.web.service.TokenService; | ||||
| import com.ruoyi.system.domain.SysOss; | ||||
| import com.ruoyi.system.service.ISysOssService; | ||||
| import com.ruoyi.system.service.ISysUserService; | ||||
| import io.swagger.annotations.Api; | ||||
| import io.swagger.annotations.ApiImplicitParam; | ||||
| import io.swagger.annotations.ApiImplicitParams; | ||||
| import io.swagger.annotations.ApiOperation; | ||||
| import lombok.RequiredArgsConstructor; | ||||
| 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 java.io.IOException; | ||||
| import java.io.File; | ||||
| import java.util.HashMap; | ||||
| import java.util.Map; | ||||
|  | ||||
| /** | ||||
|  * 个人信息 业务处理 | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  * @author Lion Li | ||||
|  */ | ||||
| @Validated | ||||
| @Api(value = "个人信息控制器", tags = {"个人信息管理"}) | ||||
| @RequiredArgsConstructor(onConstructor_ = @Autowired) | ||||
| @RestController | ||||
| @RequestMapping("/system/user/profile") | ||||
| public class SysProfileController extends BaseController | ||||
| { | ||||
|     @Autowired | ||||
|     private ISysUserService userService; | ||||
| public class SysProfileController extends BaseController { | ||||
|  | ||||
|     @Autowired | ||||
|     private TokenService tokenService; | ||||
|  | ||||
|     @Autowired | ||||
| 	private ISysOssService iSysOssService; | ||||
|     private final ISysUserService userService; | ||||
|     private final TokenService tokenService; | ||||
|     private final ISysOssService iSysOssService; | ||||
|  | ||||
|     /** | ||||
|      * 个人信息 | ||||
|      */ | ||||
|     @ApiOperation("个人信息") | ||||
|     @GetMapping | ||||
|     public AjaxResult profile() | ||||
|     { | ||||
|     public AjaxResult<Map<String, Object>> profile() { | ||||
|         LoginUser loginUser = getLoginUser(); | ||||
|         SysUser user = loginUser.getUser(); | ||||
| 		Map<String,Object> ajax = new HashMap<>(); | ||||
| 		ajax.put("user", user); | ||||
|         SysUser user = userService.selectUserById(loginUser.getUserId()); | ||||
|         Map<String, Object> ajax = new HashMap<>(); | ||||
|         ajax.put("user", user); | ||||
|         ajax.put("roleGroup", userService.selectUserRoleGroup(loginUser.getUsername())); | ||||
|         ajax.put("postGroup", userService.selectUserPostGroup(loginUser.getUsername())); | ||||
|         return AjaxResult.success(ajax); | ||||
| @@ -57,32 +61,24 @@ public class SysProfileController extends BaseController | ||||
|     /** | ||||
|      * 修改用户 | ||||
|      */ | ||||
|     @ApiOperation("修改用户") | ||||
|     @Log(title = "个人信息", businessType = BusinessType.UPDATE) | ||||
|     @PutMapping | ||||
|     public AjaxResult updateProfile(@RequestBody SysUser user) | ||||
|     { | ||||
|     public AjaxResult<Void> updateProfile(@RequestBody SysUser user) { | ||||
|         if (StringUtils.isNotEmpty(user.getPhonenumber()) | ||||
|                 && UserConstants.NOT_UNIQUE.equals(userService.checkPhoneUnique(user))) | ||||
|         { | ||||
|                 && UserConstants.NOT_UNIQUE.equals(userService.checkPhoneUnique(user))) { | ||||
|             return AjaxResult.error("修改用户'" + user.getUserName() + "'失败,手机号码已存在"); | ||||
|         } | ||||
|         if (StringUtils.isNotEmpty(user.getEmail()) | ||||
|                 && UserConstants.NOT_UNIQUE.equals(userService.checkEmailUnique(user))) | ||||
|         { | ||||
|                 && UserConstants.NOT_UNIQUE.equals(userService.checkEmailUnique(user))) { | ||||
|             return AjaxResult.error("修改用户'" + user.getUserName() + "'失败,邮箱账号已存在"); | ||||
|         } | ||||
|         LoginUser loginUser = getLoginUser(); | ||||
|         SysUser sysUser = loginUser.getUser(); | ||||
|         SysUser sysUser = userService.selectUserById(loginUser.getUserId()); | ||||
|         user.setUserId(sysUser.getUserId()); | ||||
|         user.setUserName(null); | ||||
|         user.setPassword(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); | ||||
|         if (userService.updateUserProfile(user) > 0) { | ||||
|             return AjaxResult.success(); | ||||
|         } | ||||
|         return AjaxResult.error("修改个人信息异常,请联系管理员"); | ||||
| @@ -91,26 +87,24 @@ public class SysProfileController extends BaseController | ||||
|     /** | ||||
|      * 重置密码 | ||||
|      */ | ||||
|     @ApiOperation("重置密码") | ||||
|     @ApiImplicitParams({ | ||||
|         @ApiImplicitParam(name = "oldPassword", value = "旧密码", paramType = "query", dataTypeClass = String.class), | ||||
|         @ApiImplicitParam(name = "newPassword", value = "新密码", paramType = "query", dataTypeClass = String.class) | ||||
|     }) | ||||
|     @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)) | ||||
|         { | ||||
|     public AjaxResult<Void> updatePwd(String oldPassword, String newPassword) { | ||||
|         SysUser user = userService.selectUserById(SecurityUtils.getUserId()); | ||||
|         String userName = user.getUserName(); | ||||
|         String password = user.getPassword(); | ||||
|         if (!SecurityUtils.matchesPassword(oldPassword, password)) { | ||||
|             return AjaxResult.error("修改密码失败,旧密码错误"); | ||||
|         } | ||||
|         if (SecurityUtils.matchesPassword(newPassword, password)) | ||||
|         { | ||||
|         if (SecurityUtils.matchesPassword(newPassword, password)) { | ||||
|             return AjaxResult.error("新密码不能与旧密码相同"); | ||||
|         } | ||||
|         if (userService.resetUserPwd(userName, SecurityUtils.encryptPassword(newPassword)) > 0) | ||||
|         { | ||||
|             // 更新缓存用户密码 | ||||
|             loginUser.getUser().setPassword(SecurityUtils.encryptPassword(newPassword)); | ||||
|             tokenService.setLoginUser(loginUser); | ||||
|         if (userService.resetUserPwd(userName, SecurityUtils.encryptPassword(newPassword)) > 0) { | ||||
|             return AjaxResult.success(); | ||||
|         } | ||||
|         return AjaxResult.error("修改密码异常,请联系管理员"); | ||||
| @@ -119,25 +113,23 @@ public class SysProfileController extends BaseController | ||||
|     /** | ||||
|      * 头像上传 | ||||
|      */ | ||||
|     @ApiOperation("头像上传") | ||||
|     @ApiImplicitParams({ | ||||
|         @ApiImplicitParam(name = "avatarfile", value = "用户头像", dataTypeClass = File.class, required = true), | ||||
|     }) | ||||
|     @Log(title = "用户头像", businessType = BusinessType.UPDATE) | ||||
|     @PostMapping("/avatar") | ||||
|     public AjaxResult avatar(@RequestParam("avatarfile") MultipartFile file) throws IOException | ||||
|     { | ||||
|         if (!file.isEmpty()) | ||||
|         { | ||||
|     public AjaxResult<Map<String, Object>> avatar(@RequestPart("avatarfile") MultipartFile file) { | ||||
|         Map<String, Object> ajax = new HashMap<>(); | ||||
|         if (!file.isEmpty()) { | ||||
|             LoginUser loginUser = getLoginUser(); | ||||
| 			SysOss oss = iSysOssService.upload(file); | ||||
| 			String avatar = oss.getUrl(); | ||||
|             if (userService.updateUserAvatar(loginUser.getUsername(), avatar)) | ||||
|             { | ||||
| 				Map<String,Object> ajax = new HashMap<>(); | ||||
|             SysOss oss = iSysOssService.upload(file); | ||||
|             String avatar = oss.getUrl(); | ||||
|             if (userService.updateUserAvatar(loginUser.getUsername(), avatar)) { | ||||
|                 ajax.put("imgUrl", avatar); | ||||
|                 // 更新缓存用户头像 | ||||
|                 loginUser.getUser().setAvatar(avatar); | ||||
|                 tokenService.setLoginUser(loginUser); | ||||
|                 return AjaxResult.success(ajax); | ||||
|             } | ||||
|         } | ||||
|         return AjaxResult.error("上传图片异常,请联系管理员"); | ||||
|         return AjaxResult.error("上传图片异常,请联系管理员", ajax); | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -4,9 +4,13 @@ import com.ruoyi.common.core.controller.BaseController; | ||||
| import com.ruoyi.common.core.domain.AjaxResult; | ||||
| import com.ruoyi.common.core.domain.model.RegisterBody; | ||||
| import com.ruoyi.common.utils.StringUtils; | ||||
| import com.ruoyi.framework.web.service.SysRegisterService; | ||||
| import com.ruoyi.system.service.ISysConfigService; | ||||
| import com.ruoyi.system.service.SysRegisterService; | ||||
| import io.swagger.annotations.Api; | ||||
| import io.swagger.annotations.ApiOperation; | ||||
| import lombok.RequiredArgsConstructor; | ||||
| import org.springframework.beans.factory.annotation.Autowired; | ||||
| import org.springframework.validation.annotation.Validated; | ||||
| import org.springframework.web.bind.annotation.PostMapping; | ||||
| import org.springframework.web.bind.annotation.RequestBody; | ||||
| import org.springframework.web.bind.annotation.RestController; | ||||
| @@ -14,22 +18,21 @@ import org.springframework.web.bind.annotation.RestController; | ||||
| /** | ||||
|  * 注册验证 | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  * @author Lion Li | ||||
|  */ | ||||
| @Validated | ||||
| @Api(value = "注册验证控制器", tags = {"注册验证管理"}) | ||||
| @RequiredArgsConstructor(onConstructor_ = @Autowired) | ||||
| @RestController | ||||
| public class SysRegisterController extends BaseController | ||||
| { | ||||
|     @Autowired | ||||
|     private SysRegisterService registerService; | ||||
| public class SysRegisterController extends BaseController { | ||||
|  | ||||
|     @Autowired | ||||
|     private ISysConfigService configService; | ||||
|     private final SysRegisterService registerService; | ||||
|     private final ISysConfigService configService; | ||||
|  | ||||
|     @ApiOperation("用户注册") | ||||
|     @PostMapping("/register") | ||||
|     public AjaxResult register(@RequestBody RegisterBody user) | ||||
|     { | ||||
|         if (!("true".equals(configService.selectConfigByKey("sys.account.registerUser")))) | ||||
|         { | ||||
|     public AjaxResult<Void> register(@RequestBody RegisterBody user) { | ||||
|         if (!("true".equals(configService.selectConfigByKey("sys.account.registerUser")))) { | ||||
|             return error("当前系统没有开启注册功能!"); | ||||
|         } | ||||
|         String msg = registerService.register(user); | ||||
|   | ||||
| @@ -4,18 +4,21 @@ import com.ruoyi.common.annotation.Log; | ||||
| import com.ruoyi.common.constant.UserConstants; | ||||
| import com.ruoyi.common.core.controller.BaseController; | ||||
| import com.ruoyi.common.core.domain.AjaxResult; | ||||
| import com.ruoyi.common.core.domain.PageQuery; | ||||
| import com.ruoyi.common.core.domain.entity.SysRole; | ||||
| import com.ruoyi.common.core.domain.entity.SysUser; | ||||
| import com.ruoyi.common.core.domain.model.LoginUser; | ||||
| import com.ruoyi.common.core.page.TableDataInfo; | ||||
| import com.ruoyi.common.core.service.TokenService; | ||||
| import com.ruoyi.common.enums.BusinessType; | ||||
| import com.ruoyi.common.utils.StringUtils; | ||||
| import com.ruoyi.common.utils.poi.ExcelUtil; | ||||
| import com.ruoyi.framework.web.service.SysPermissionService; | ||||
| import com.ruoyi.framework.web.service.TokenService; | ||||
| import com.ruoyi.system.domain.SysUserRole; | ||||
| import com.ruoyi.system.service.ISysRoleService; | ||||
| import com.ruoyi.system.service.ISysUserService; | ||||
| import com.ruoyi.system.service.SysPermissionService; | ||||
| import io.swagger.annotations.*; | ||||
| import lombok.RequiredArgsConstructor; | ||||
| import org.springframework.beans.factory.annotation.Autowired; | ||||
| import org.springframework.security.access.prepost.PreAuthorize; | ||||
| import org.springframework.validation.annotation.Validated; | ||||
| @@ -27,47 +30,43 @@ import java.util.List; | ||||
| /** | ||||
|  * 角色信息 | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  * @author Lion Li | ||||
|  */ | ||||
| @Validated | ||||
| @Api(value = "角色信息控制器", tags = {"角色信息管理"}) | ||||
| @RequiredArgsConstructor(onConstructor_ = @Autowired) | ||||
| @RestController | ||||
| @RequestMapping("/system/role") | ||||
| public class SysRoleController extends BaseController | ||||
| { | ||||
|     @Autowired | ||||
|     private ISysRoleService roleService; | ||||
| public class SysRoleController extends BaseController { | ||||
|  | ||||
|     @Autowired | ||||
|     private TokenService tokenService; | ||||
|  | ||||
|     @Autowired | ||||
|     private SysPermissionService permissionService; | ||||
|  | ||||
|     @Autowired | ||||
|     private ISysUserService userService; | ||||
|     private final ISysRoleService roleService; | ||||
|     private final TokenService tokenService; | ||||
|     private final ISysUserService userService; | ||||
|     private final SysPermissionService permissionService; | ||||
|  | ||||
|     @ApiOperation("查询角色信息列表") | ||||
|     @PreAuthorize("@ss.hasPermi('system:role:list')") | ||||
|     @GetMapping("/list") | ||||
|     public TableDataInfo list(SysRole role) | ||||
|     { | ||||
|         return roleService.selectPageRoleList(role); | ||||
|     public TableDataInfo<SysRole> list(SysRole role, PageQuery pageQuery) { | ||||
|         return roleService.selectPageRoleList(role, pageQuery); | ||||
|     } | ||||
|  | ||||
|     @ApiOperation("导出角色信息列表") | ||||
|     @Log(title = "角色管理", businessType = BusinessType.EXPORT) | ||||
|     @PreAuthorize("@ss.hasPermi('system:role:export')") | ||||
|     @GetMapping("/export") | ||||
|     public void export(SysRole role, HttpServletResponse response) | ||||
|     { | ||||
|     @PostMapping("/export") | ||||
|     public void export(SysRole role, HttpServletResponse response) { | ||||
|         List<SysRole> list = roleService.selectRoleList(role); | ||||
| 		ExcelUtil.exportExcel(list, "角色数据", SysRole.class, response); | ||||
|         ExcelUtil.exportExcel(list, "角色数据", SysRole.class, response); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 根据角色编号获取详细信息 | ||||
|      */ | ||||
|     @ApiOperation("根据角色编号获取详细信息") | ||||
|     @PreAuthorize("@ss.hasPermi('system:role:query')") | ||||
|     @GetMapping(value = "/{roleId}") | ||||
|     public AjaxResult getInfo(@PathVariable Long roleId) | ||||
|     { | ||||
|     public AjaxResult<SysRole> getInfo(@ApiParam("角色ID") @PathVariable Long roleId) { | ||||
|         roleService.checkRoleDataScope(roleId); | ||||
|         return AjaxResult.success(roleService.selectRoleById(roleId)); | ||||
|     } | ||||
| @@ -75,20 +74,16 @@ public class SysRoleController extends BaseController | ||||
|     /** | ||||
|      * 新增角色 | ||||
|      */ | ||||
|     @ApiOperation("新增角色") | ||||
|     @PreAuthorize("@ss.hasPermi('system:role:add')") | ||||
|     @Log(title = "角色管理", businessType = BusinessType.INSERT) | ||||
|     @PostMapping | ||||
|     public AjaxResult add(@Validated @RequestBody SysRole role) | ||||
|     { | ||||
|         if (UserConstants.NOT_UNIQUE.equals(roleService.checkRoleNameUnique(role))) | ||||
|         { | ||||
|     public AjaxResult<Void> add(@Validated @RequestBody SysRole role) { | ||||
|         if (UserConstants.NOT_UNIQUE.equals(roleService.checkRoleNameUnique(role))) { | ||||
|             return AjaxResult.error("新增角色'" + role.getRoleName() + "'失败,角色名称已存在"); | ||||
|         } | ||||
|         else if (UserConstants.NOT_UNIQUE.equals(roleService.checkRoleKeyUnique(role))) | ||||
|         { | ||||
|         } else if (UserConstants.NOT_UNIQUE.equals(roleService.checkRoleKeyUnique(role))) { | ||||
|             return AjaxResult.error("新增角色'" + role.getRoleName() + "'失败,角色权限已存在"); | ||||
|         } | ||||
|         role.setCreateBy(getUsername()); | ||||
|         return toAjax(roleService.insertRole(role)); | ||||
|  | ||||
|     } | ||||
| @@ -96,30 +91,24 @@ public class SysRoleController extends BaseController | ||||
|     /** | ||||
|      * 修改保存角色 | ||||
|      */ | ||||
|     @ApiOperation("修改保存角色") | ||||
|     @PreAuthorize("@ss.hasPermi('system:role:edit')") | ||||
|     @Log(title = "角色管理", businessType = BusinessType.UPDATE) | ||||
|     @PutMapping | ||||
|     public AjaxResult edit(@Validated @RequestBody SysRole role) | ||||
|     { | ||||
|     public AjaxResult<Void> edit(@Validated @RequestBody SysRole role) { | ||||
|         roleService.checkRoleAllowed(role); | ||||
|         if (UserConstants.NOT_UNIQUE.equals(roleService.checkRoleNameUnique(role))) | ||||
|         { | ||||
|         if (UserConstants.NOT_UNIQUE.equals(roleService.checkRoleNameUnique(role))) { | ||||
|             return AjaxResult.error("修改角色'" + role.getRoleName() + "'失败,角色名称已存在"); | ||||
|         } | ||||
|         else if (UserConstants.NOT_UNIQUE.equals(roleService.checkRoleKeyUnique(role))) | ||||
|         { | ||||
|         } else if (UserConstants.NOT_UNIQUE.equals(roleService.checkRoleKeyUnique(role))) { | ||||
|             return AjaxResult.error("修改角色'" + role.getRoleName() + "'失败,角色权限已存在"); | ||||
|         } | ||||
|         role.setUpdateBy(getUsername()); | ||||
|  | ||||
|         if (roleService.updateRole(role) > 0) | ||||
|         { | ||||
|         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())); | ||||
|             SysUser sysUser = userService.selectUserById(loginUser.getUserId()); | ||||
|             if (StringUtils.isNotNull(sysUser) && !sysUser.isAdmin()) { | ||||
|                 loginUser.setMenuPermissions(permissionService.getMenuPermission(sysUser)); | ||||
|                 tokenService.setLoginUser(loginUser); | ||||
|             } | ||||
|             return AjaxResult.success(); | ||||
| @@ -130,11 +119,11 @@ public class SysRoleController extends BaseController | ||||
|     /** | ||||
|      * 修改保存数据权限 | ||||
|      */ | ||||
|     @ApiOperation("修改保存数据权限") | ||||
|     @PreAuthorize("@ss.hasPermi('system:role:edit')") | ||||
|     @Log(title = "角色管理", businessType = BusinessType.UPDATE) | ||||
|     @PutMapping("/dataScope") | ||||
|     public AjaxResult dataScope(@RequestBody SysRole role) | ||||
|     { | ||||
|     public AjaxResult<Void> dataScope(@RequestBody SysRole role) { | ||||
|         roleService.checkRoleAllowed(role); | ||||
|         return toAjax(roleService.authDataScope(role)); | ||||
|     } | ||||
| @@ -142,87 +131,94 @@ public class SysRoleController extends BaseController | ||||
|     /** | ||||
|      * 状态修改 | ||||
|      */ | ||||
|     @ApiOperation("状态修改") | ||||
|     @PreAuthorize("@ss.hasPermi('system:role:edit')") | ||||
|     @Log(title = "角色管理", businessType = BusinessType.UPDATE) | ||||
|     @PutMapping("/changeStatus") | ||||
|     public AjaxResult changeStatus(@RequestBody SysRole role) | ||||
|     { | ||||
|     public AjaxResult<Void> changeStatus(@RequestBody SysRole role) { | ||||
|         roleService.checkRoleAllowed(role); | ||||
|         role.setUpdateBy(getUsername()); | ||||
|         return toAjax(roleService.updateRoleStatus(role)); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 删除角色 | ||||
|      */ | ||||
|     @ApiOperation("删除角色") | ||||
|     @PreAuthorize("@ss.hasPermi('system:role:remove')") | ||||
|     @Log(title = "角色管理", businessType = BusinessType.DELETE) | ||||
|     @DeleteMapping("/{roleIds}") | ||||
|     public AjaxResult remove(@PathVariable Long[] roleIds) | ||||
|     { | ||||
|     public AjaxResult<Void> remove(@ApiParam("岗位ID串") @PathVariable Long[] roleIds) { | ||||
|         return toAjax(roleService.deleteRoleByIds(roleIds)); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 获取角色选择框列表 | ||||
|      */ | ||||
|     @ApiOperation("获取角色选择框列表") | ||||
|     @PreAuthorize("@ss.hasPermi('system:role:query')") | ||||
|     @GetMapping("/optionselect") | ||||
|     public AjaxResult optionselect() | ||||
|     { | ||||
|     public AjaxResult<List<SysRole>> optionselect() { | ||||
|         return AjaxResult.success(roleService.selectRoleAll()); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 查询已分配用户角色列表 | ||||
|      */ | ||||
|     @ApiOperation("查询已分配用户角色列表") | ||||
|     @PreAuthorize("@ss.hasPermi('system:role:list')") | ||||
|     @GetMapping("/authUser/allocatedList") | ||||
|     public TableDataInfo allocatedList(SysUser user) | ||||
|     { | ||||
| 		return userService.selectAllocatedList(user); | ||||
|     public TableDataInfo<SysUser> allocatedList(SysUser user, PageQuery pageQuery) { | ||||
|         return userService.selectAllocatedList(user, pageQuery); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 查询未分配用户角色列表 | ||||
|      */ | ||||
|     @ApiOperation("查询未分配用户角色列表") | ||||
|     @PreAuthorize("@ss.hasPermi('system:role:list')") | ||||
|     @GetMapping("/authUser/unallocatedList") | ||||
|     public TableDataInfo unallocatedList(SysUser user) | ||||
|     { | ||||
|         return userService.selectUnallocatedList(user); | ||||
|     public TableDataInfo<SysUser> unallocatedList(SysUser user, PageQuery pageQuery) { | ||||
|         return userService.selectUnallocatedList(user, pageQuery); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 取消授权用户 | ||||
|      */ | ||||
|     @ApiOperation("取消授权用户") | ||||
|     @PreAuthorize("@ss.hasPermi('system:role:edit')") | ||||
|     @Log(title = "角色管理", businessType = BusinessType.GRANT) | ||||
|     @PutMapping("/authUser/cancel") | ||||
|     public AjaxResult cancelAuthUser(@RequestBody SysUserRole userRole) | ||||
|     { | ||||
|     public AjaxResult<Void> cancelAuthUser(@RequestBody SysUserRole userRole) { | ||||
|         return toAjax(roleService.deleteAuthUser(userRole)); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 批量取消授权用户 | ||||
|      */ | ||||
|     @ApiOperation("批量取消授权用户") | ||||
|     @ApiImplicitParams({ | ||||
|         @ApiImplicitParam(name = "roleId", value = "角色ID", paramType = "query", dataTypeClass = String.class), | ||||
|         @ApiImplicitParam(name = "userIds", value = "用户ID串", paramType = "query", dataTypeClass = String.class) | ||||
|     }) | ||||
|     @PreAuthorize("@ss.hasPermi('system:role:edit')") | ||||
|     @Log(title = "角色管理", businessType = BusinessType.GRANT) | ||||
|     @PutMapping("/authUser/cancelAll") | ||||
|     public AjaxResult cancelAuthUserAll(Long roleId, Long[] userIds) | ||||
|     { | ||||
|     public AjaxResult<Void> cancelAuthUserAll(Long roleId, Long[] userIds) { | ||||
|         return toAjax(roleService.deleteAuthUsers(roleId, userIds)); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 批量选择用户授权 | ||||
|      */ | ||||
|     @ApiOperation("批量选择用户授权") | ||||
|     @ApiImplicitParams({ | ||||
|         @ApiImplicitParam(name = "roleId", value = "角色ID", paramType = "query", dataTypeClass = String.class), | ||||
|         @ApiImplicitParam(name = "userIds", value = "用户ID串", paramType = "query", dataTypeClass = String.class) | ||||
|     }) | ||||
|     @PreAuthorize("@ss.hasPermi('system:role:edit')") | ||||
|     @Log(title = "角色管理", businessType = BusinessType.GRANT) | ||||
|     @PutMapping("/authUser/selectAll") | ||||
|     public AjaxResult selectAuthUserAll(Long roleId, Long[] userIds) | ||||
|     { | ||||
|     public AjaxResult<Void> selectAuthUserAll(Long roleId, Long[] userIds) { | ||||
|         return toAjax(roleService.insertAuthUsers(roleId, userIds)); | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -7,19 +7,24 @@ import com.ruoyi.common.annotation.Log; | ||||
| import com.ruoyi.common.constant.UserConstants; | ||||
| import com.ruoyi.common.core.controller.BaseController; | ||||
| import com.ruoyi.common.core.domain.AjaxResult; | ||||
| import com.ruoyi.common.core.domain.PageQuery; | ||||
| import com.ruoyi.common.core.domain.entity.SysDept; | ||||
| import com.ruoyi.common.core.domain.entity.SysRole; | ||||
| import com.ruoyi.common.core.domain.entity.SysUser; | ||||
| import com.ruoyi.common.core.page.TableDataInfo; | ||||
| import com.ruoyi.common.enums.BusinessType; | ||||
| import com.ruoyi.common.excel.ExcelResult; | ||||
| import com.ruoyi.common.utils.SecurityUtils; | ||||
| import com.ruoyi.common.utils.StringUtils; | ||||
| import com.ruoyi.common.utils.poi.ExcelUtil; | ||||
| import com.ruoyi.system.domain.vo.SysUserExportVo; | ||||
| import com.ruoyi.system.domain.vo.SysUserImportVo; | ||||
| import com.ruoyi.system.listener.SysUserImportListener; | ||||
| import com.ruoyi.system.service.ISysPostService; | ||||
| import com.ruoyi.system.service.ISysRoleService; | ||||
| import com.ruoyi.system.service.ISysUserService; | ||||
| import io.swagger.annotations.*; | ||||
| import lombok.RequiredArgsConstructor; | ||||
| import org.springframework.beans.factory.annotation.Autowired; | ||||
| import org.springframework.security.access.prepost.PreAuthorize; | ||||
| import org.springframework.validation.annotation.Validated; | ||||
| @@ -36,81 +41,78 @@ import java.util.stream.Collectors; | ||||
| /** | ||||
|  * 用户信息 | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  * @author Lion Li | ||||
|  */ | ||||
| @Validated | ||||
| @Api(value = "用户信息控制器", tags = {"用户信息管理"}) | ||||
| @RequiredArgsConstructor(onConstructor_ = @Autowired) | ||||
| @RestController | ||||
| @RequestMapping("/system/user") | ||||
| public class SysUserController extends BaseController | ||||
| { | ||||
|     @Autowired | ||||
|     private ISysUserService userService; | ||||
| public class SysUserController extends BaseController { | ||||
|  | ||||
|     @Autowired | ||||
|     private ISysRoleService roleService; | ||||
|  | ||||
|     @Autowired | ||||
|     private ISysPostService postService; | ||||
|     private final ISysUserService userService; | ||||
|     private final ISysRoleService roleService; | ||||
|     private final ISysPostService postService; | ||||
|  | ||||
|     /** | ||||
|      * 获取用户列表 | ||||
|      */ | ||||
|     @ApiOperation("获取用户列表") | ||||
|     @PreAuthorize("@ss.hasPermi('system:user:list')") | ||||
|     @GetMapping("/list") | ||||
|     public TableDataInfo list(SysUser user) | ||||
|     { | ||||
|         return userService.selectPageUserList(user); | ||||
|     public TableDataInfo<SysUser> list(SysUser user, PageQuery pageQuery) { | ||||
|         return userService.selectPageUserList(user, pageQuery); | ||||
|     } | ||||
|  | ||||
|     @ApiOperation("导出用户列表") | ||||
|     @Log(title = "用户管理", businessType = BusinessType.EXPORT) | ||||
|     @PreAuthorize("@ss.hasPermi('system:user:export')") | ||||
|     @GetMapping("/export") | ||||
|     public void export(SysUser user, HttpServletResponse response) | ||||
|     { | ||||
|     @PostMapping("/export") | ||||
|     public void export(SysUser user, HttpServletResponse response) { | ||||
|         List<SysUser> list = userService.selectUserList(user); | ||||
| 		List<SysUserExportVo> listVo = BeanUtil.copyToList(list, SysUserExportVo.class); | ||||
| 		for (int i = 0; i < list.size(); i++) { | ||||
| 			SysDept dept = list.get(i).getDept(); | ||||
| 			SysUserExportVo vo = listVo.get(i); | ||||
| 			if (ObjectUtil.isNotEmpty(dept)) { | ||||
| 				vo.setDeptName(dept.getDeptName()); | ||||
| 				vo.setLeader(dept.getLeader()); | ||||
| 			} | ||||
| 		} | ||||
| 		ExcelUtil.exportExcel(listVo, "用户数据", SysUserExportVo.class, response); | ||||
|         List<SysUserExportVo> listVo = BeanUtil.copyToList(list, SysUserExportVo.class); | ||||
|         for (int i = 0; i < list.size(); i++) { | ||||
|             SysDept dept = list.get(i).getDept(); | ||||
|             SysUserExportVo vo = listVo.get(i); | ||||
|             if (ObjectUtil.isNotEmpty(dept)) { | ||||
|                 vo.setDeptName(dept.getDeptName()); | ||||
|                 vo.setLeader(dept.getLeader()); | ||||
|             } | ||||
|         } | ||||
|         ExcelUtil.exportExcel(listVo, "用户数据", SysUserExportVo.class, response); | ||||
|     } | ||||
|  | ||||
|     @ApiOperation("导入用户列表") | ||||
|     @ApiImplicitParams({ | ||||
|             @ApiImplicitParam(name = "file", value = "导入文件", dataType = "java.io.File", required = true), | ||||
|     }) | ||||
|     @Log(title = "用户管理", businessType = BusinessType.IMPORT) | ||||
|     @PreAuthorize("@ss.hasPermi('system:user:import')") | ||||
|     @PostMapping("/importData") | ||||
|     public AjaxResult importData(MultipartFile file, boolean updateSupport) throws Exception | ||||
|     { | ||||
| 		List<SysUserImportVo> userListVo = ExcelUtil.importExcel(file.getInputStream(), SysUserImportVo.class); | ||||
| 		List<SysUser> userList = BeanUtil.copyToList(userListVo, SysUser.class); | ||||
|         String operName = getUsername(); | ||||
|         String message = userService.importUser(userList, updateSupport, operName); | ||||
|         return AjaxResult.success(message); | ||||
|     public AjaxResult<Void> importData(@RequestPart("file") MultipartFile file, boolean updateSupport) throws Exception { | ||||
|         ExcelResult<SysUserImportVo> result = ExcelUtil.importExcel(file.getInputStream(), SysUserImportVo.class, new SysUserImportListener(updateSupport)); | ||||
|         return AjaxResult.success(result.getAnalysis()); | ||||
|     } | ||||
|  | ||||
|     @GetMapping("/importTemplate") | ||||
|     public void importTemplate(HttpServletResponse response) | ||||
|     { | ||||
| 		ExcelUtil.exportExcel(new ArrayList<>(), "用户数据", SysUserImportVo.class, response); | ||||
|     @ApiOperation("下载导入模板") | ||||
|     @PostMapping("/importTemplate") | ||||
|     public void importTemplate(HttpServletResponse response) { | ||||
|         ExcelUtil.exportExcel(new ArrayList<>(), "用户数据", SysUserImportVo.class, response); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 根据用户编号获取详细信息 | ||||
|      */ | ||||
|     @ApiOperation("根据用户编号获取详细信息") | ||||
|     @PreAuthorize("@ss.hasPermi('system:user:query')") | ||||
|     @GetMapping(value = { "/", "/{userId}" }) | ||||
|     public AjaxResult getInfo(@PathVariable(value = "userId", required = false) Long userId) | ||||
|     { | ||||
| 		userService.checkUserDataScope(userId); | ||||
|     @GetMapping(value = {"/", "/{userId}"}) | ||||
|     public AjaxResult<Map<String, Object>> getInfo(@ApiParam("用户ID") @PathVariable(value = "userId", required = false) Long userId) { | ||||
|         userService.checkUserDataScope(userId); | ||||
|         Map<String, Object> ajax = new HashMap<>(); | ||||
|         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)) | ||||
|         { | ||||
|         if (StringUtils.isNotNull(userId)) { | ||||
|             ajax.put("user", userService.selectUserById(userId)); | ||||
|             ajax.put("postIds", postService.selectPostListByUserId(userId)); | ||||
|             ajax.put("roleIds", roleService.selectRoleListByUserId(userId)); | ||||
| @@ -121,26 +123,20 @@ public class SysUserController extends BaseController | ||||
|     /** | ||||
|      * 新增用户 | ||||
|      */ | ||||
|     @ApiOperation("新增用户") | ||||
|     @PreAuthorize("@ss.hasPermi('system:user:add')") | ||||
|     @Log(title = "用户管理", businessType = BusinessType.INSERT) | ||||
|     @PostMapping | ||||
|     public AjaxResult add(@Validated @RequestBody SysUser user) | ||||
|     { | ||||
|         if (UserConstants.NOT_UNIQUE.equals(userService.checkUserNameUnique(user.getUserName()))) | ||||
|         { | ||||
|     public AjaxResult<Void> add(@Validated @RequestBody SysUser user) { | ||||
|         if (UserConstants.NOT_UNIQUE.equals(userService.checkUserNameUnique(user.getUserName()))) { | ||||
|             return AjaxResult.error("新增用户'" + user.getUserName() + "'失败,登录账号已存在"); | ||||
|         } | ||||
|         else if (StringUtils.isNotEmpty(user.getPhonenumber()) | ||||
|                 && UserConstants.NOT_UNIQUE.equals(userService.checkPhoneUnique(user))) | ||||
|         { | ||||
|         } else if (StringUtils.isNotEmpty(user.getPhonenumber()) | ||||
|                 && UserConstants.NOT_UNIQUE.equals(userService.checkPhoneUnique(user))) { | ||||
|             return AjaxResult.error("新增用户'" + user.getUserName() + "'失败,手机号码已存在"); | ||||
|         } | ||||
|         else if (StringUtils.isNotEmpty(user.getEmail()) | ||||
|                 && UserConstants.NOT_UNIQUE.equals(userService.checkEmailUnique(user))) | ||||
|         { | ||||
|         } else if (StringUtils.isNotEmpty(user.getEmail()) | ||||
|                 && UserConstants.NOT_UNIQUE.equals(userService.checkEmailUnique(user))) { | ||||
|             return AjaxResult.error("新增用户'" + user.getUserName() + "'失败,邮箱账号已存在"); | ||||
|         } | ||||
|         user.setCreateBy(getUsername()); | ||||
|         user.setPassword(SecurityUtils.encryptPassword(user.getPassword())); | ||||
|         return toAjax(userService.insertUser(user)); | ||||
|     } | ||||
| @@ -148,36 +144,31 @@ public class SysUserController extends BaseController | ||||
|     /** | ||||
|      * 修改用户 | ||||
|      */ | ||||
|     @ApiOperation("修改用户") | ||||
|     @PreAuthorize("@ss.hasPermi('system:user:edit')") | ||||
|     @Log(title = "用户管理", businessType = BusinessType.UPDATE) | ||||
|     @PutMapping | ||||
|     public AjaxResult edit(@Validated @RequestBody SysUser user) | ||||
|     { | ||||
|     public AjaxResult<Void> edit(@Validated @RequestBody SysUser user) { | ||||
|         userService.checkUserAllowed(user); | ||||
|         if (StringUtils.isNotEmpty(user.getPhonenumber()) | ||||
|                 && UserConstants.NOT_UNIQUE.equals(userService.checkPhoneUnique(user))) | ||||
|         { | ||||
|                 && UserConstants.NOT_UNIQUE.equals(userService.checkPhoneUnique(user))) { | ||||
|             return AjaxResult.error("修改用户'" + user.getUserName() + "'失败,手机号码已存在"); | ||||
|         } | ||||
|         else if (StringUtils.isNotEmpty(user.getEmail()) | ||||
|                 && UserConstants.NOT_UNIQUE.equals(userService.checkEmailUnique(user))) | ||||
|         { | ||||
|         } else if (StringUtils.isNotEmpty(user.getEmail()) | ||||
|                 && UserConstants.NOT_UNIQUE.equals(userService.checkEmailUnique(user))) { | ||||
|             return AjaxResult.error("修改用户'" + user.getUserName() + "'失败,邮箱账号已存在"); | ||||
|         } | ||||
|         user.setUpdateBy(getUsername()); | ||||
|         return toAjax(userService.updateUser(user)); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 删除用户 | ||||
|      */ | ||||
|     @ApiOperation("删除用户") | ||||
|     @PreAuthorize("@ss.hasPermi('system:user:remove')") | ||||
|     @Log(title = "用户管理", businessType = BusinessType.DELETE) | ||||
|     @DeleteMapping("/{userIds}") | ||||
|     public AjaxResult remove(@PathVariable Long[] userIds) | ||||
|     { | ||||
|         if (ArrayUtil.contains(userIds, getUserId())) | ||||
|         { | ||||
|     public AjaxResult<Void> remove(@ApiParam("角色ID串") @PathVariable Long[] userIds) { | ||||
|         if (ArrayUtil.contains(userIds, getUserId())) { | ||||
|             return error("当前用户不能删除"); | ||||
|         } | ||||
|         return toAjax(userService.deleteUserByIds(userIds)); | ||||
| @@ -186,40 +177,38 @@ public class SysUserController extends BaseController | ||||
|     /** | ||||
|      * 重置密码 | ||||
|      */ | ||||
|     @ApiOperation("重置密码") | ||||
|     @PreAuthorize("@ss.hasPermi('system:user:resetPwd')") | ||||
|     @Log(title = "用户管理", businessType = BusinessType.UPDATE) | ||||
|     @PutMapping("/resetPwd") | ||||
|     public AjaxResult resetPwd(@RequestBody SysUser user) | ||||
|     { | ||||
|     public AjaxResult<Void> resetPwd(@RequestBody SysUser user) { | ||||
|         userService.checkUserAllowed(user); | ||||
|         user.setPassword(SecurityUtils.encryptPassword(user.getPassword())); | ||||
|         user.setUpdateBy(getUsername()); | ||||
|         return toAjax(userService.resetPwd(user)); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 状态修改 | ||||
|      */ | ||||
|     @ApiOperation("状态修改") | ||||
|     @PreAuthorize("@ss.hasPermi('system:user:edit')") | ||||
|     @Log(title = "用户管理", businessType = BusinessType.UPDATE) | ||||
|     @PutMapping("/changeStatus") | ||||
|     public AjaxResult changeStatus(@RequestBody SysUser user) | ||||
|     { | ||||
|     public AjaxResult<Void> changeStatus(@RequestBody SysUser user) { | ||||
|         userService.checkUserAllowed(user); | ||||
|         user.setUpdateBy(getUsername()); | ||||
|         return toAjax(userService.updateUserStatus(user)); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 根据用户编号获取授权角色 | ||||
|      */ | ||||
|     @ApiOperation("根据用户编号获取授权角色") | ||||
|     @PreAuthorize("@ss.hasPermi('system:user:query')") | ||||
|     @GetMapping("/authRole/{userId}") | ||||
|     public AjaxResult authRole(@PathVariable("userId") Long userId) | ||||
|     { | ||||
|     public AjaxResult<Map<String, Object>> authRole(@ApiParam("用户ID") @PathVariable("userId") Long userId) { | ||||
|         SysUser user = userService.selectUserById(userId); | ||||
|         List<SysRole> roles = roleService.selectRolesByUserId(userId); | ||||
| 		Map<String, Object> ajax = new HashMap<>(); | ||||
|         Map<String, Object> ajax = new HashMap<>(); | ||||
|         ajax.put("user", user); | ||||
|         ajax.put("roles", SysUser.isAdmin(userId) ? roles : roles.stream().filter(r -> !r.isAdmin()).collect(Collectors.toList())); | ||||
|         return AjaxResult.success(ajax); | ||||
| @@ -228,11 +217,15 @@ public class SysUserController extends BaseController | ||||
|     /** | ||||
|      * 用户授权角色 | ||||
|      */ | ||||
|     @ApiOperation("用户授权角色") | ||||
|     @ApiImplicitParams({ | ||||
|         @ApiImplicitParam(name = "userId", value = "用户Id", paramType = "query", dataTypeClass = String.class), | ||||
|         @ApiImplicitParam(name = "roleIds", value = "角色ID串", paramType = "query", dataTypeClass = String.class) | ||||
|     }) | ||||
|     @PreAuthorize("@ss.hasPermi('system:user:edit')") | ||||
|     @Log(title = "用户管理", businessType = BusinessType.GRANT) | ||||
|     @PutMapping("/authRole") | ||||
|     public AjaxResult insertAuthRole(Long userId, Long[] roleIds) | ||||
|     { | ||||
|     public AjaxResult<Void> insertAuthRole(Long userId, Long[] roleIds) { | ||||
|         userService.insertUserAuth(userId, roleIds); | ||||
|         return success(); | ||||
|     } | ||||
|   | ||||
| @@ -1,4 +1,43 @@ | ||||
| # 数据源配置 | ||||
| --- # 监控配置 | ||||
| spring: | ||||
|   boot: | ||||
|     admin: | ||||
|       # Spring Boot Admin Client 客户端的相关配置 | ||||
|       client: | ||||
|         # 增加客户端开关 | ||||
|         enabled: true | ||||
|         # 设置 Spring Boot Admin Server 地址 | ||||
|         url: http://localhost:9090/admin | ||||
|         instance: | ||||
|           prefer-ip: true # 注册实例时,优先使用 IP | ||||
|         username: ruoyi | ||||
|         password: 123456 | ||||
|  | ||||
| --- # xxl-job 配置 | ||||
| xxl: | ||||
|   job: | ||||
|     # 执行器开关 | ||||
|     enabled: true | ||||
|     # 调度中心地址:如调度中心集群部署存在多个地址则用逗号分隔。 | ||||
|     admin-addresses: http://localhost:9100/xxl-job-admin | ||||
|     # 执行器通讯TOKEN:非空时启用 | ||||
|     access-token: xxl-job | ||||
|     # 执行器配置 | ||||
|     executor: | ||||
|       # 执行器AppName:执行器心跳注册分组依据;为空则关闭自动注册 | ||||
|       appname: xxl-job-executor | ||||
|       # 执行器端口号 执行器从9101开始往后写 | ||||
|       port: 9101 | ||||
|       # 执行器注册:默认IP:PORT | ||||
|       address: | ||||
|       # 执行器IP:默认自动获取IP | ||||
|       ip: | ||||
|       # 执行器运行日志文件存储磁盘路径 | ||||
|       logpath: ./logs/xxl-job | ||||
|       # 执行器日志文件保存天数:大于3生效 | ||||
|       logretentiondays: 30 | ||||
|  | ||||
| --- # 数据源配置 | ||||
| spring: | ||||
|   datasource: | ||||
|     type: com.alibaba.druid.pool.DruidDataSource | ||||
| @@ -12,7 +51,9 @@ spring: | ||||
|         # 主库数据源 | ||||
|         master: | ||||
|           driverClassName: com.mysql.cj.jdbc.Driver | ||||
|           url: jdbc:mysql://localhost:3306/ry-vue?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8&autoReconnect=true | ||||
|           # jdbc 所有参数配置参考 https://lionli.blog.csdn.net/article/details/122018562 | ||||
|           # rewriteBatchedStatements=true 批处理优化 大幅提升批量插入更新删除性能(对数据库有性能损耗 使用批量操作应考虑性能问题) | ||||
|           url: jdbc:mysql://localhost:3306/ry-vue?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8&autoReconnect=true&rewriteBatchedStatements=true | ||||
|           username: root | ||||
|           password: root | ||||
|         # 从库数据源 | ||||
| @@ -38,7 +79,7 @@ spring: | ||||
|         # 配置一个连接在池中最大生存的时间,单位是毫秒 | ||||
|         maxEvictableIdleTimeMillis: 900000 | ||||
|         # 配置检测连接是否有效 | ||||
|         validationQuery: SELECT 1 | ||||
|         validationQuery: SELECT 1 FROM DUAL | ||||
|         testWhileIdle: true | ||||
|         testOnBorrow: false | ||||
|         testOnReturn: false | ||||
| @@ -70,7 +111,7 @@ spring: | ||||
|           config: | ||||
|             multi-statement-allow: true | ||||
|  | ||||
| --- # redis 配置 | ||||
| --- # redis 单机配置(单机与集群只能开启一个另一个需要注释掉) | ||||
| spring: | ||||
|   redis: | ||||
|     # 地址 | ||||
| @@ -117,18 +158,3 @@ redisson: | ||||
|     subscriptionsPerConnection: 5 | ||||
|     # DNS监测时间间隔,单位:毫秒 | ||||
|     dnsMonitoringInterval: 5000 | ||||
|  | ||||
| --- # 监控配置 | ||||
| spring: | ||||
|   boot: | ||||
|     admin: | ||||
|       # Spring Boot Admin Client 客户端的相关配置 | ||||
|       client: | ||||
|         # 增加客户端开关 | ||||
|         enabled: true | ||||
|         # 设置 Spring Boot Admin Server 地址 | ||||
|         url: http://localhost:9090/admin | ||||
|         instance: | ||||
|           prefer-ip: true # 注册实例时,优先使用 IP | ||||
|         username: ruoyi | ||||
|         password: 123456 | ||||
|   | ||||
| @@ -1,4 +1,50 @@ | ||||
| # 数据源配置 | ||||
| --- # 配置临时路径存储 | ||||
| spring: | ||||
|   servlet: | ||||
|     multipart: | ||||
|       # 临时文件存储位置 避免临时文件被系统清理报错 | ||||
|       location: /ruoyi/server/temp | ||||
|  | ||||
| --- # 监控配置 | ||||
| spring: | ||||
|   boot: | ||||
|     admin: | ||||
|       # Spring Boot Admin Client 客户端的相关配置 | ||||
|       client: | ||||
|         # 增加客户端开关 | ||||
|         enabled: true | ||||
|         # 设置 Spring Boot Admin Server 地址 | ||||
|         url: http://172.30.0.90:9090/admin | ||||
|         instance: | ||||
|           prefer-ip: true # 注册实例时,优先使用 IP | ||||
|         username: ruoyi | ||||
|         password: 123456 | ||||
|  | ||||
| --- # xxl-job 配置 | ||||
| xxl: | ||||
|   job: | ||||
|     # 执行器开关 | ||||
|     enabled: true | ||||
|     # 调度中心地址:如调度中心集群部署存在多个地址则用逗号分隔。 | ||||
|     admin-addresses: http://172.30.0.92:9100/xxl-job-admin | ||||
|     # 执行器通讯TOKEN:非空时启用 | ||||
|     access-token: xxl-job | ||||
|     # 执行器配置 | ||||
|     executor: | ||||
|       # 执行器AppName:执行器心跳注册分组依据;为空则关闭自动注册 | ||||
|       appname: xxl-job-executor | ||||
|       # 执行器端口号 执行器从9101开始往后写 | ||||
|       port: 9101 | ||||
|       # 执行器注册:默认IP:PORT | ||||
|       address: | ||||
|       # 执行器IP:默认自动获取IP | ||||
|       ip: | ||||
|       # 执行器运行日志文件存储磁盘路径 | ||||
|       logpath: ./logs/xxl-job | ||||
|       # 执行器日志文件保存天数:大于3生效 | ||||
|       logretentiondays: 30 | ||||
|  | ||||
| --- # 数据源配置 | ||||
| spring: | ||||
|   datasource: | ||||
|     type: com.alibaba.druid.pool.DruidDataSource | ||||
| @@ -12,7 +58,9 @@ spring: | ||||
|         # 主库数据源 | ||||
|         master: | ||||
|           driverClassName: com.mysql.cj.jdbc.Driver | ||||
|           url: jdbc:mysql://172.30.0.36:3306/ry-vue?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8&autoReconnect=true | ||||
|           # jdbc 所有参数配置参考 https://lionli.blog.csdn.net/article/details/122018562 | ||||
|           # rewriteBatchedStatements=true 批处理优化 大幅提升批量插入更新删除性能(对数据库有性能损耗 使用批量操作应考虑性能问题) | ||||
|           url: jdbc:mysql://172.30.0.36:3306/ry-vue?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8&autoReconnect=true&rewriteBatchedStatements=true | ||||
|           username: root | ||||
|           password: root | ||||
|         # 从库数据源 | ||||
| @@ -38,7 +86,7 @@ spring: | ||||
|         # 配置一个连接在池中最大生存的时间,单位是毫秒 | ||||
|         maxEvictableIdleTimeMillis: 900000 | ||||
|         # 配置检测连接是否有效 | ||||
|         validationQuery: SELECT 1 | ||||
|         validationQuery: SELECT 1 FROM DUAL | ||||
|         testWhileIdle: true | ||||
|         testOnBorrow: false | ||||
|         testOnReturn: false | ||||
| @@ -70,7 +118,7 @@ spring: | ||||
|           config: | ||||
|             multi-statement-allow: true | ||||
|  | ||||
| --- # redis 配置 | ||||
| --- # redis 单机配置(单机与集群只能开启一个另一个需要注释掉) | ||||
| spring: | ||||
|   redis: | ||||
|     # 地址 | ||||
| @@ -117,18 +165,3 @@ redisson: | ||||
|     subscriptionsPerConnection: 5 | ||||
|     # DNS监测时间间隔,单位:毫秒 | ||||
|     dnsMonitoringInterval: 5000 | ||||
|  | ||||
| --- # 监控配置 | ||||
| spring: | ||||
|   boot: | ||||
|     admin: | ||||
|       # Spring Boot Admin Client 客户端的相关配置 | ||||
|       client: | ||||
|         # 增加客户端开关 | ||||
|         enabled: true | ||||
|         # 设置 Spring Boot Admin Server 地址 | ||||
|         url: http://172.30.0.90:9090/admin | ||||
|         instance: | ||||
|           prefer-ip: true # 注册实例时,优先使用 IP | ||||
|         username: ruoyi | ||||
|         password: 123456 | ||||
|   | ||||
| @@ -10,6 +10,8 @@ ruoyi: | ||||
|   demoEnabled: true | ||||
|   # 获取ip地址开关 | ||||
|   addressEnabled: true | ||||
|   # 缓存懒加载 | ||||
|   cacheLazy: false | ||||
|  | ||||
| captcha: | ||||
|   # 页面 <参数设置> 可开启关闭 验证码校验 | ||||
| @@ -43,14 +45,6 @@ server: | ||||
|       io: 8 | ||||
|       # 阻塞任务线程池, 当执行类似servlet请求阻塞操作, undertow会从这个线程池中取得线程,它的值设置取决于系统的负载 | ||||
|       worker: 256 | ||||
| #  # tomcat 配置 | ||||
| #  tomcat: | ||||
| #    # tomcat的URI编码 | ||||
| #    uri-encoding: UTF-8 | ||||
| #    # tomcat最大线程数,默认为200 | ||||
| #    max-threads: 500 | ||||
| #    # Tomcat启动初始化的线程数,默认值25 | ||||
| #    min-spare-threads: 30 | ||||
|  | ||||
| # 日志配置 | ||||
| logging: | ||||
| @@ -106,10 +100,32 @@ token: | ||||
|   # 令牌有效期(默认30分钟) | ||||
|   expireTime: 30 | ||||
|  | ||||
| # security配置 | ||||
| security: | ||||
|   # 登出路径 | ||||
|   logout-url: /logout | ||||
|   # 匿名路径 | ||||
|   anonymous: | ||||
|     - /login | ||||
|     - /register | ||||
|     - /captchaImage | ||||
|     # swagger 文档配置 | ||||
|     - /doc.html | ||||
|     - /swagger-resources/** | ||||
|     - /webjars/** | ||||
|     - /*/api-docs | ||||
|     # druid 监控配置 | ||||
|     - /druid/** | ||||
|   # 用户放行 | ||||
|   permit-all: | ||||
|     # actuator 监控配置 | ||||
|     - /actuator | ||||
|     - /actuator/** | ||||
|  | ||||
| # 重复提交 | ||||
| repeat-submit: | ||||
|   # 全局间隔时间(毫秒) | ||||
|   intervalTime: 1000 | ||||
|   interval: 5000 | ||||
|  | ||||
| # MyBatisPlus配置 | ||||
| # https://baomidou.com/config/ | ||||
| @@ -121,43 +137,24 @@ mybatis-plus: | ||||
|   mapperLocations: classpath*:mapper/**/*Mapper.xml | ||||
|   # 实体扫描,多个package用逗号或者分号分隔 | ||||
|   typeAliasesPackage: com.ruoyi.**.domain | ||||
|   # 针对 typeAliasesPackage,如果配置了该属性,则仅仅会扫描路径下以该类作为父类的域对象 | ||||
|   #typeAliasesSuperType: Class<?> | ||||
|   # 如果配置了该属性,SqlSessionFactoryBean 会把该包下面的类注册为对应的 TypeHandler | ||||
|   #typeHandlersPackage: null | ||||
|   # 如果配置了该属性,会将路径下的枚举类进行注入,让实体类字段能够简单快捷的使用枚举属性 | ||||
|   #typeEnumsPackage: null | ||||
|   # 启动时是否检查 MyBatis XML 文件的存在,默认不检查 | ||||
|   checkConfigLocation: false | ||||
|   # 通过该属性可指定 MyBatis 的执行器,MyBatis 的执行器总共有三种: | ||||
|   # SIMPLE:该执行器类型不做特殊的事情,为每个语句的执行创建一个新的预处理语句(PreparedStatement) | ||||
|   # REUSE:该执行器类型会复用预处理语句(PreparedStatement) | ||||
|   # BATCH:该执行器类型会批量执行所有的更新语句 | ||||
|   # SIMPLE:每个语句创建新的预处理器 REUSE:会复用预处理器 BATCH:批量执行所有的更新 | ||||
|   executorType: SIMPLE | ||||
|   configuration: | ||||
|     # 自动驼峰命名规则(camel case)映射 | ||||
|     # 如果您的数据库命名符合规则无需使用 @TableField 注解指定数据库字段名 | ||||
|     mapUnderscoreToCamelCase: true | ||||
|     # 默认枚举处理类,如果配置了该属性,枚举将统一使用指定处理器进行处理 | ||||
|     # org.apache.ibatis.type.EnumTypeHandler : 存储枚举的名称 | ||||
|     # org.apache.ibatis.type.EnumOrdinalTypeHandler : 存储枚举的索引 | ||||
|     # com.baomidou.mybatisplus.extension.handlers.MybatisEnumTypeHandler : 枚举类需要实现IEnum接口或字段标记@EnumValue注解. | ||||
|     defaultEnumTypeHandler: org.apache.ibatis.type.EnumTypeHandler | ||||
|     # 当设置为 true 的时候,懒加载的对象可能被任何懒属性全部加载,否则,每个属性都按需加载。需要和 lazyLoadingEnabled 一起使用。 | ||||
|     aggressiveLazyLoading: true | ||||
|     # MyBatis 自动映射策略 | ||||
|     # NONE:不启用自动映射 | ||||
|     # PARTIAL:只对非嵌套的 resultMap 进行自动映射 | ||||
|     # FULL:对所有的 resultMap 都进行自动映射 | ||||
|     # NONE:不启用 PARTIAL:只对非嵌套 resultMap 自动映射 FULL:对所有 resultMap 自动映射 | ||||
|     autoMappingBehavior: PARTIAL | ||||
|     # MyBatis 自动映射时未知列或未知属性处理策 | ||||
|     # NONE:不做任何处理 (默认值) | ||||
|     # WARNING:以日志的形式打印相关警告信息 | ||||
|     # FAILING:当作映射失败处理,并抛出异常和详细信息 | ||||
|     # NONE:不做处理 WARNING:打印相关警告 FAILING:抛出异常和详细信息 | ||||
|     autoMappingUnknownColumnBehavior: NONE | ||||
|     # Mybatis一级缓存,默认为 SESSION | ||||
|     # SESSION session级别缓存,同一个session相同查询语句不会再次查询数据库 | ||||
|     # STATEMENT 关闭一级缓存 | ||||
|     # SESSION session级别缓存 STATEMENT 关闭一级缓存 | ||||
|     localCacheScope: SESSION | ||||
|     # 开启Mybatis二级缓存,默认为 true | ||||
|     cacheEnabled: false | ||||
| @@ -172,32 +169,18 @@ mybatis-plus: | ||||
|     enableSqlRunner: false | ||||
|     dbConfig: | ||||
|       # 主键类型 | ||||
|       # AUTO 数据库ID自增 | ||||
|       # NONE 空 | ||||
|       # INPUT 用户输入ID | ||||
|       # ASSIGN_ID 全局唯一ID | ||||
|       # ASSIGN_UUID 全局唯一ID UUID | ||||
|       # AUTO 自增 NONE 空 INPUT 用户输入 ASSIGN_ID 雪花 ASSIGN_UUID 唯一 UUID | ||||
|       idType: AUTO | ||||
|       # 表名前缀 | ||||
|       tablePrefix: null | ||||
|       # 字段 format,例: %s,(对主键无效) | ||||
|       columnFormat: null | ||||
|       # 表名是否使用驼峰转下划线命名,只对表名生效 | ||||
|       tableUnderline: true | ||||
|       # 大写命名,对表名和字段名均生效 | ||||
|       capitalMode: false | ||||
|       # 全局的entity的逻辑删除字段属性名 | ||||
|       logicDeleteField: null | ||||
|       # 逻辑已删除值 | ||||
|       logicDeleteValue: 2 | ||||
|       # 逻辑未删除值 | ||||
|       logicNotDeleteValue: 0 | ||||
|       # 字段验证策略之 insert,在 insert 的时候的字段验证策略 | ||||
|       # IGNORED 忽略判断 | ||||
|       # NOT_NULL 非NULL判断 | ||||
|       # NOT_EMPTY 非空判断(只对字符串类型字段,其他类型字段依然为非NULL判断) | ||||
|       # DEFAULT 默认的,一般只用于注解里 | ||||
|       # NEVER 不加入 SQL | ||||
|       # IGNORED 忽略 NOT_NULL 非NULL NOT_EMPTY 非空 DEFAULT 默认 NEVER 不加入 SQL | ||||
|       insertStrategy: NOT_NULL | ||||
|       # 字段验证策略之 update,在 update 的时候的字段验证策略 | ||||
|       updateStrategy: NOT_NULL | ||||
| @@ -221,6 +204,29 @@ swagger: | ||||
|     name: Lion Li | ||||
|     email: crazylionli@163.com | ||||
|     url: https://gitee.com/JavaLionLi/RuoYi-Vue-Plus | ||||
|   groups: | ||||
|     - name: 1.演示案例 | ||||
|       basePackage: com.ruoyi.demo | ||||
|     - name: 2.系统模块 | ||||
|       basePackage: com.ruoyi.web | ||||
|     - name: 3.代码生成模块 | ||||
|       basePackage: com.ruoyi.generator | ||||
|  | ||||
| knife4j: | ||||
|   # 是否开启Knife4j增强模式 | ||||
|   enable: true | ||||
|   # 是否开启生产环境保护策略 | ||||
|   production: @knife4j.production@ | ||||
|   # 前端Ui的个性化配置属性 | ||||
|   setting: | ||||
|     # 默认语言 | ||||
|     language: zh-CN | ||||
|     # 是否显示Footer | ||||
|     enableFooter: false | ||||
|     # 是否开启动态参数调试功能 | ||||
|     enableDynamicParameter: true | ||||
|     # 是否在每个Debug调试栏后显示刷新变量按钮 | ||||
|     enableReloadCacheParameter: true | ||||
|  | ||||
| # 防止XSS攻击 | ||||
| xss: | ||||
| @@ -244,28 +250,12 @@ thread-pool: | ||||
|   # 线程池维护线程所允许的空闲时间 | ||||
|   keepAliveSeconds: 300 | ||||
|   # 线程池对拒绝任务(无线程可用)的处理策略 | ||||
|   # CALLER_RUNS_POLICY 等待 | ||||
|   # CALLER_RUNS_POLICY 调用方执行 | ||||
|   # DISCARD_OLDEST_POLICY 放弃最旧的 | ||||
|   # DISCARD_POLICY 丢弃 | ||||
|   # ABORT_POLICY 中止 | ||||
|   rejectedExecutionHandler: CALLER_RUNS_POLICY | ||||
|  | ||||
| # feign 相关配置 | ||||
| feign: | ||||
|   # 不支持多包, 如有需要可在注解配置 或 提升扫包等级 | ||||
|   # 例如 com.**.**.feign | ||||
|   package: com.ruoyi.**.feign | ||||
|   # 开启压缩 | ||||
|   compression: | ||||
|     request: | ||||
|       enabled: true | ||||
|     response: | ||||
|       enabled: true | ||||
|   okhttp: | ||||
|     enabled: true | ||||
|   circuitbreaker: | ||||
|     enabled: true | ||||
|  | ||||
| --- # redisson 缓存配置 | ||||
| redisson: | ||||
|   cacheGroup: | ||||
| @@ -301,34 +291,3 @@ management: | ||||
|   endpoint: | ||||
|     logfile: | ||||
|       external-file: ./logs/sys-console.log | ||||
|  | ||||
| --- # 定时任务配置 | ||||
| spring: | ||||
|   quartz: | ||||
|     scheduler-name: RuoyiScheduler | ||||
|     startup-delay: 1s | ||||
|     overwrite-existing-jobs: true | ||||
|     auto-startup: true | ||||
|     job-store-type: jdbc | ||||
|     properties: | ||||
|       org: | ||||
|         quartz: | ||||
|           # Scheduler 相关配置 | ||||
|           scheduler: | ||||
|             instanceName: RuoyiScheduler | ||||
|             instanceId: AUTO | ||||
|           # 线程池相关配置 | ||||
|           threadPool: | ||||
|             class: org.quartz.simpl.SimpleThreadPool | ||||
|             threadCount: 20 | ||||
|             threadPriority: 5 | ||||
|           # JobStore 集群配置 | ||||
|           jobStore: | ||||
|             class: org.quartz.impl.jdbcjobstore.JobStoreTX | ||||
|             isClustered: true | ||||
|             clusterCheckinInterval: 15000 | ||||
|             txIsolationLevelSerializable: true | ||||
|             misfireThreshold: 60000 | ||||
|             tablePrefix: QRTZ_ | ||||
|             # sqlserver 启用 | ||||
|             # selectWithLockSQL: SELECT * FROM {0}LOCKS UPDLOCK WHERE LOCK_NAME = ? | ||||
|   | ||||
| @@ -2,20 +2,17 @@ | ||||
| not.null=* 必须填写 | ||||
| user.jcaptcha.error=验证码错误 | ||||
| user.jcaptcha.expire=验证码已失效 | ||||
| user.not.exists=用户不存在/密码错误 | ||||
| user.not.exists=对不起, 您的账号:{0} 不存在. | ||||
| user.password.not.match=用户不存在/密码错误 | ||||
| user.password.retry.limit.count=密码输入错误{0}次 | ||||
| user.password.retry.limit.exceed=密码输入错误{0}次,帐户锁定10分钟 | ||||
| user.password.delete=对不起,您的账号已被删除 | ||||
| user.blocked=用户已封禁,请联系管理员 | ||||
| user.password.retry.limit.exceed=密码错误次数过多,帐户锁定{0}分钟 | ||||
| user.password.delete=对不起,您的账号:{0} 已被删除 | ||||
| user.blocked=对不起,您的账号:{0} 已禁用,请联系管理员 | ||||
| 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=登录成功 | ||||
| @@ -23,11 +20,9 @@ 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}] | ||||
|   | ||||
| @@ -1,33 +1,32 @@ | ||||
| #错误消息 | ||||
| not.null= | ||||
| user.jcaptcha.error= | ||||
| user.jcaptcha.expire= | ||||
| user.not.exists= | ||||
| user.password.not.match= | ||||
| user.password.retry.limit.count= | ||||
| user.password.retry.limit.exceed= | ||||
| user.password.delete= | ||||
| user.blocked= | ||||
| role.blocked= | ||||
| user.logout.success= | ||||
| length.not.valid= | ||||
| user.username.not.valid= | ||||
| user.password.not.valid= | ||||
| user.email.not.valid= | ||||
| user.mobile.phone.number.not.valid= | ||||
| user.login.success= | ||||
| user.register.success=register success | ||||
| user.notfound= | ||||
| user.unknown.error= | ||||
|  | ||||
| not.null=* Required fill in | ||||
| user.jcaptcha.error=Captcha error | ||||
| user.jcaptcha.expire=Captcha invalid | ||||
| user.not.exists=Sorry, your account: {0} does not exist | ||||
| user.password.not.match=User does not exist/Password error | ||||
| user.password.retry.limit.count=Password input error {0} times | ||||
| user.password.retry.limit.exceed=Too many password errors, account locked for {0} minutes | ||||
| user.password.delete=Sorry, your account:{0} has been deleted | ||||
| user.blocked=Sorry, your account: {0} has been disabled. Please contact the administrator | ||||
| role.blocked=Role disabled,please contact administrators | ||||
| user.logout.success=Exit successful | ||||
| length.not.valid=The length must be between {min} and {max} characters | ||||
| user.username.not.valid=* 2 to 20 chinese characters, letters, numbers or underscores, and must start with a non number | ||||
| user.password.not.valid=* 5-50 characters | ||||
| user.email.not.valid=Mailbox format error | ||||
| user.mobile.phone.number.not.valid=Phone number format error | ||||
| user.login.success=Login successful | ||||
| user.register.success=Register successful | ||||
| user.notfound=Please login again | ||||
| user.forcelogout=The administrator is forced to exit,please login again | ||||
| user.unknown.error=Unknown error, please login again | ||||
| ##文件上传消息 | ||||
| upload.exceed.maxSize= | ||||
| upload.filename.exceed.length= | ||||
|  | ||||
| upload.exceed.maxSize=The uploaded file size exceeds the limit file size!<br/>the maximum allowed file size is:{0}MB! | ||||
| upload.filename.exceed.length=The maximum length of uploaded file name is {0} characters | ||||
| ##权限 | ||||
| no.permission= | ||||
| no.create.permission= | ||||
| no.update.permission= | ||||
| no.delete.permission= | ||||
| no.export.permission= | ||||
| no.view.permission= | ||||
| no.permission=You do not have permission to the data,please contact your administrator to add permissions [{0}] | ||||
| no.create.permission=You do not have permission to create data,please contact your administrator to add permissions [{0}] | ||||
| no.update.permission=You do not have permission to modify data,please contact your administrator to add permissions [{0}] | ||||
| no.delete.permission=You do not have permission to delete data,please contact your administrator to add permissions [{0}] | ||||
| no.export.permission=You do not have permission to export data,please contact your administrator to add permissions [{0}] | ||||
| no.view.permission=You do not have permission to view data,please contact your administrator to add permissions [{0}] | ||||
|   | ||||
| @@ -2,20 +2,17 @@ | ||||
| not.null=* 必须填写 | ||||
| user.jcaptcha.error=验证码错误 | ||||
| user.jcaptcha.expire=验证码已失效 | ||||
| user.not.exists=用户不存在/密码错误 | ||||
| user.not.exists=对不起, 您的账号:{0} 不存在. | ||||
| user.password.not.match=用户不存在/密码错误 | ||||
| user.password.retry.limit.count=密码输入错误{0}次 | ||||
| user.password.retry.limit.exceed=密码输入错误{0}次,帐户锁定10分钟 | ||||
| user.password.delete=对不起,您的账号已被删除 | ||||
| user.blocked=用户已封禁,请联系管理员 | ||||
| user.password.retry.limit.exceed=密码错误次数过多,帐户锁定{0}分钟 | ||||
| user.password.delete=对不起,您的账号:{0} 已被删除 | ||||
| user.blocked=对不起,您的账号:{0} 已禁用,请联系管理员 | ||||
| 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=登录成功 | ||||
| @@ -23,11 +20,9 @@ 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}] | ||||
|   | ||||
| @@ -7,7 +7,7 @@ | ||||
|  | ||||
| 	<!-- 控制台输出 --> | ||||
| 	<appender name="console" class="ch.qos.logback.core.ConsoleAppender"> | ||||
| 		<encoder> | ||||
|         <encoder class="com.yomahub.tlog.core.enhance.logback.AspectLogbackEncoder"> | ||||
| 			<pattern>${console.log.pattern}</pattern> | ||||
|             <charset>utf-8</charset> | ||||
| 		</encoder> | ||||
| @@ -22,7 +22,7 @@ | ||||
|             <!-- 日志最大 1天 --> | ||||
|             <maxHistory>1</maxHistory> | ||||
|         </rollingPolicy> | ||||
|         <encoder> | ||||
|         <encoder class="com.yomahub.tlog.core.enhance.logback.AspectLogbackEncoder"> | ||||
|             <pattern>${log.pattern}</pattern> | ||||
|             <charset>utf-8</charset> | ||||
|         </encoder> | ||||
| @@ -42,7 +42,7 @@ | ||||
| 			<!-- 日志最大的历史 60天 --> | ||||
| 			<maxHistory>60</maxHistory> | ||||
| 		</rollingPolicy> | ||||
| 		<encoder> | ||||
|         <encoder class="com.yomahub.tlog.core.enhance.logback.AspectLogbackEncoder"> | ||||
| 			<pattern>${log.pattern}</pattern> | ||||
| 		</encoder> | ||||
| 		<filter class="ch.qos.logback.classic.filter.LevelFilter"> | ||||
| @@ -64,7 +64,7 @@ | ||||
| 			<!-- 日志最大的历史 60天 --> | ||||
| 			<maxHistory>60</maxHistory> | ||||
|         </rollingPolicy> | ||||
|         <encoder> | ||||
|         <encoder class="com.yomahub.tlog.core.enhance.logback.AspectLogbackEncoder"> | ||||
|             <pattern>${log.pattern}</pattern> | ||||
|         </encoder> | ||||
|         <filter class="ch.qos.logback.classic.filter.LevelFilter"> | ||||
| @@ -77,20 +77,6 @@ | ||||
|         </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.ruoyi" level="info" /> | ||||
| 	<!-- Spring日志级别控制  --> | ||||
| @@ -107,8 +93,4 @@ | ||||
|         <appender-ref ref="file_console" /> | ||||
|     </root> | ||||
|  | ||||
| 	<!--系统用户操作日志--> | ||||
|     <logger name="sys-user" level="info"> | ||||
|         <appender-ref ref="sys-user"/> | ||||
|     </logger> | ||||
| </configuration> | ||||
| @@ -22,5 +22,3 @@ outagedetection=true | ||||
| outagedetectioninterval=2 | ||||
| # 是否过滤 Log | ||||
| filter=true | ||||
| # 过滤 Log 时所排除的表名列表,以逗号分隔 | ||||
| exclude=QRTZ_ | ||||
|   | ||||
| @@ -5,7 +5,7 @@ | ||||
|     <parent> | ||||
|         <artifactId>ruoyi-vue-plus</artifactId> | ||||
|         <groupId>com.ruoyi</groupId> | ||||
|         <version>3.1.0</version> | ||||
|         <version>3.5.0</version> | ||||
|     </parent> | ||||
|     <modelVersion>4.0.0</modelVersion> | ||||
|  | ||||
| @@ -37,8 +37,8 @@ | ||||
|  | ||||
|         <!-- 自定义验证注解 --> | ||||
|         <dependency> | ||||
|             <groupId>javax.validation</groupId> | ||||
|             <artifactId>validation-api</artifactId> | ||||
|             <groupId>org.springframework.boot</groupId> | ||||
|             <artifactId>spring-boot-starter-validation</artifactId> | ||||
|         </dependency> | ||||
|  | ||||
|         <!--常用工具类 --> | ||||
| @@ -64,28 +64,21 @@ | ||||
|             <artifactId>easyexcel</artifactId> | ||||
|         </dependency> | ||||
|  | ||||
|         <dependency> | ||||
|             <groupId>cglib</groupId> | ||||
|             <artifactId>cglib</artifactId> | ||||
|         </dependency> | ||||
|  | ||||
|         <!-- yml解析器 --> | ||||
|         <dependency> | ||||
|             <groupId>org.yaml</groupId> | ||||
|             <artifactId>snakeyaml</artifactId> | ||||
|         </dependency> | ||||
|  | ||||
|         <!--Token生成与解析--> | ||||
|         <!-- jdk11 缺失依赖 jaxb--> | ||||
|         <dependency> | ||||
|             <groupId>io.jsonwebtoken</groupId> | ||||
|             <artifactId>jjwt</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> | ||||
|             <groupId>com.sun.xml.bind</groupId> | ||||
|             <artifactId>jaxb-impl</artifactId> | ||||
|         </dependency> | ||||
|  | ||||
|         <!-- servlet包 --> | ||||
| @@ -102,39 +95,53 @@ | ||||
|             <groupId>com.baomidou</groupId> | ||||
|             <artifactId>mybatis-plus-extension</artifactId> | ||||
|         </dependency> | ||||
|  | ||||
|         <!-- dynamic-datasource 多数据源--> | ||||
|         <dependency> | ||||
|             <groupId>com.baomidou</groupId> | ||||
|             <artifactId>dynamic-datasource-spring-boot-starter</artifactId> | ||||
|         </dependency> | ||||
|  | ||||
|         <dependency> | ||||
|             <groupId>cn.hutool</groupId> | ||||
|             <artifactId>hutool-all</artifactId> | ||||
|             <artifactId>hutool-core</artifactId> | ||||
|         </dependency> | ||||
|  | ||||
|         <dependency> | ||||
|             <groupId>cn.hutool</groupId> | ||||
|             <artifactId>hutool-http</artifactId> | ||||
|         </dependency> | ||||
|  | ||||
|         <dependency> | ||||
|             <groupId>cn.hutool</groupId> | ||||
|             <artifactId>hutool-captcha</artifactId> | ||||
|         </dependency> | ||||
|  | ||||
|         <dependency> | ||||
|             <groupId>cn.hutool</groupId> | ||||
|             <artifactId>hutool-jwt</artifactId> | ||||
|         </dependency> | ||||
|  | ||||
|         <dependency> | ||||
|             <groupId>cn.hutool</groupId> | ||||
|             <artifactId>hutool-extra</artifactId> | ||||
|         </dependency> | ||||
|  | ||||
|         <dependency> | ||||
|             <groupId>org.projectlombok</groupId> | ||||
|             <artifactId>lombok</artifactId> | ||||
|         </dependency> | ||||
|  | ||||
|         <dependency> | ||||
|             <groupId>org.springframework.cloud</groupId> | ||||
|             <artifactId>spring-cloud-starter-openfeign</artifactId> | ||||
|         </dependency> | ||||
|  | ||||
|         <dependency> | ||||
|             <groupId>io.github.openfeign</groupId> | ||||
|             <artifactId>feign-okhttp</artifactId> | ||||
|         </dependency> | ||||
|  | ||||
|         <dependency> | ||||
|             <groupId>de.codecentric</groupId> | ||||
|             <artifactId>spring-boot-admin-starter-client</artifactId> | ||||
|         </dependency> | ||||
|  | ||||
|         <dependency> | ||||
|             <groupId>com.github.xiaoymin</groupId> | ||||
|             <artifactId>knife4j-spring-boot-starter</artifactId> | ||||
|         </dependency> | ||||
|  | ||||
|         <dependency> | ||||
|             <groupId>org.springframework.boot</groupId> | ||||
|             <artifactId>spring-boot-starter-actuator</artifactId> | ||||
|             <groupId>io.swagger</groupId> | ||||
|             <artifactId>swagger-annotations</artifactId> | ||||
|         </dependency> | ||||
|  | ||||
|         <!--  自动生成YML配置关联JSON文件  --> | ||||
|         <dependency> | ||||
|             <groupId>org.springframework.boot</groupId> | ||||
| @@ -147,17 +154,6 @@ | ||||
|             <artifactId>redisson-spring-boot-starter</artifactId> | ||||
|         </dependency> | ||||
|  | ||||
|         <!-- dynamic-datasource 多数据源--> | ||||
|         <dependency> | ||||
|             <groupId>com.baomidou</groupId> | ||||
|             <artifactId>dynamic-datasource-spring-boot-starter</artifactId> | ||||
|         </dependency> | ||||
|         <!-- sql性能分析插件 --> | ||||
|         <dependency> | ||||
|             <groupId>p6spy</groupId> | ||||
|             <artifactId>p6spy</artifactId> | ||||
|         </dependency> | ||||
|  | ||||
|         <dependency> | ||||
|             <groupId>com.baomidou</groupId> | ||||
|             <artifactId>lock4j-redisson-spring-boot-starter</artifactId> | ||||
|   | ||||
| @@ -0,0 +1,26 @@ | ||||
| package com.ruoyi.common.annotation; | ||||
|  | ||||
| import java.lang.annotation.*; | ||||
|  | ||||
| /** | ||||
|  * 数据权限 | ||||
|  * | ||||
|  * @author Lion Li | ||||
|  * @version 3.5.0 | ||||
|  */ | ||||
| @Target(ElementType.METHOD) | ||||
| @Retention(RetentionPolicy.RUNTIME) | ||||
| @Documented | ||||
| public @interface DataColumn { | ||||
|  | ||||
|     /** | ||||
|      * 占位符关键字 | ||||
|      */ | ||||
|     String key() default "deptName"; | ||||
|  | ||||
|     /** | ||||
|      * 占位符替换值 | ||||
|      */ | ||||
|     String value() default "dept_id"; | ||||
|  | ||||
| } | ||||
| @@ -0,0 +1,18 @@ | ||||
| package com.ruoyi.common.annotation; | ||||
|  | ||||
| import java.lang.annotation.*; | ||||
|  | ||||
| /** | ||||
|  * 数据权限组 | ||||
|  * | ||||
|  * @author Lion Li | ||||
|  * @version 3.5.0 | ||||
|  */ | ||||
| @Target({ElementType.METHOD, ElementType.TYPE}) | ||||
| @Retention(RetentionPolicy.RUNTIME) | ||||
| @Documented | ||||
| public @interface DataPermission { | ||||
|  | ||||
|     DataColumn[] value(); | ||||
|  | ||||
| } | ||||
| @@ -1,33 +1,32 @@ | ||||
| package com.ruoyi.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; | ||||
| import java.lang.annotation.*; | ||||
|  | ||||
| /** | ||||
|  * 数据权限过滤注解 | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  * @deprecated 3.6.0 移除 {@link com.ruoyi.common.annotation.DataPermission} | ||||
|  */ | ||||
| @Target(ElementType.METHOD) | ||||
| @Retention(RetentionPolicy.RUNTIME) | ||||
| @Documented | ||||
| public @interface DataScope | ||||
| { | ||||
| @Deprecated | ||||
| public @interface DataScope { | ||||
|  | ||||
|     /** | ||||
|      * 部门表的别名 | ||||
|      */ | ||||
|     public String deptAlias() default ""; | ||||
|     String deptAlias() default ""; | ||||
|  | ||||
|     /** | ||||
|      * 用户表的别名 | ||||
|      */ | ||||
|     public String userAlias() default ""; | ||||
|     String userAlias() default ""; | ||||
|  | ||||
|     /** | ||||
|      * 是否过滤用户权限 | ||||
|      */ | ||||
|     boolean isUser() default false; | ||||
|  | ||||
| 	/** | ||||
| 	 * 是否过滤用户权限 | ||||
| 	 */ | ||||
| 	public boolean isUser() default false; | ||||
| } | ||||
|   | ||||
| @@ -1,28 +1,25 @@ | ||||
| package com.ruoyi.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; | ||||
| import com.ruoyi.common.enums.DataSourceType; | ||||
|  | ||||
| import java.lang.annotation.*; | ||||
|  | ||||
| /** | ||||
|  * 自定义多数据源切换注解 | ||||
|  * | ||||
|  * <p> | ||||
|  * 优先级:先方法,后类,如果方法覆盖了类上的数据源类型,以方法的为准,否则以类上的为准 | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  * @deprecated 3.6.0 移除 使用原生注解处理 方法更全 {@link com.baomidou.dynamic.datasource.annotation.DS} | ||||
|  */ | ||||
| @Target({ ElementType.METHOD, ElementType.TYPE }) | ||||
| @Target({ElementType.METHOD, ElementType.TYPE}) | ||||
| @Retention(RetentionPolicy.RUNTIME) | ||||
| @Documented | ||||
| @Inherited | ||||
| public @interface DataSource | ||||
| { | ||||
| @Deprecated | ||||
| public @interface DataSource { | ||||
|     /** | ||||
|      * 切换数据源名称 | ||||
|      */ | ||||
|     public DataSourceType value() default DataSourceType.MASTER; | ||||
|     DataSourceType value() default DataSourceType.MASTER; | ||||
| } | ||||
|   | ||||
| @@ -12,19 +12,19 @@ import java.lang.annotation.*; | ||||
| @Inherited | ||||
| public @interface ExcelDictFormat { | ||||
|  | ||||
| 	/** | ||||
| 	 * 如果是字典类型,请设置字典的type值 (如: sys_user_sex) | ||||
| 	 */ | ||||
| 	String dictType() default ""; | ||||
|     /** | ||||
|      * 如果是字典类型,请设置字典的type值 (如: sys_user_sex) | ||||
|      */ | ||||
|     String dictType() default ""; | ||||
|  | ||||
| 	/** | ||||
| 	 * 读取内容转表达式 (如: 0=男,1=女,2=未知) | ||||
| 	 */ | ||||
| 	String readConverterExp() default ""; | ||||
|     /** | ||||
|      * 读取内容转表达式 (如: 0=男,1=女,2=未知) | ||||
|      */ | ||||
|     String readConverterExp() default ""; | ||||
|  | ||||
| 	/** | ||||
| 	 * 分隔符,读取字符串组内容 | ||||
| 	 */ | ||||
| 	String separator() default ","; | ||||
|     /** | ||||
|      * 分隔符,读取字符串组内容 | ||||
|      */ | ||||
|     String separator() default ","; | ||||
|  | ||||
| } | ||||
|   | ||||
| @@ -1,41 +1,41 @@ | ||||
| package com.ruoyi.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; | ||||
| import com.ruoyi.common.enums.BusinessType; | ||||
| import com.ruoyi.common.enums.OperatorType; | ||||
|  | ||||
| import java.lang.annotation.*; | ||||
|  | ||||
| /** | ||||
|  * 自定义操作日志记录注解 | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  * | ||||
|  */ | ||||
| @Target({ ElementType.PARAMETER, ElementType.METHOD }) | ||||
| @Target({ElementType.PARAMETER, ElementType.METHOD}) | ||||
| @Retention(RetentionPolicy.RUNTIME) | ||||
| @Documented | ||||
| public @interface Log | ||||
| { | ||||
| public @interface Log { | ||||
|     /** | ||||
|      * 模块 | ||||
|      */ | ||||
|     public String title() default ""; | ||||
|     String title() default ""; | ||||
|  | ||||
|     /** | ||||
|      * 功能 | ||||
|      */ | ||||
|     public BusinessType businessType() default BusinessType.OTHER; | ||||
|     BusinessType businessType() default BusinessType.OTHER; | ||||
|  | ||||
|     /** | ||||
|      * 操作人类别 | ||||
|      */ | ||||
|     public OperatorType operatorType() default OperatorType.MANAGE; | ||||
|     OperatorType operatorType() default OperatorType.MANAGE; | ||||
|  | ||||
|     /** | ||||
|      * 是否保存请求的参数 | ||||
|      */ | ||||
|     public boolean isSaveRequestData() default true; | ||||
|     boolean isSaveRequestData() default true; | ||||
|  | ||||
|     /** | ||||
|      * 是否保存响应的参数 | ||||
|      */ | ||||
|     boolean isSaveResponseData() default true; | ||||
| } | ||||
|   | ||||
| @@ -1,40 +1,36 @@ | ||||
| package com.ruoyi.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; | ||||
| import com.ruoyi.common.constant.Constants; | ||||
| import com.ruoyi.common.enums.LimitType; | ||||
|  | ||||
| import java.lang.annotation.*; | ||||
|  | ||||
| /** | ||||
|  * 限流注解 | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  * @author Lion Li | ||||
|  */ | ||||
| @Target(ElementType.METHOD) | ||||
| @Retention(RetentionPolicy.RUNTIME) | ||||
| @Documented | ||||
| public @interface RateLimiter | ||||
| { | ||||
| public @interface RateLimiter { | ||||
|     /** | ||||
|      * 限流key | ||||
|      */ | ||||
|     public String key() default Constants.RATE_LIMIT_KEY; | ||||
|     String key() default Constants.RATE_LIMIT_KEY; | ||||
|  | ||||
|     /** | ||||
|      * 限流时间,单位秒 | ||||
|      */ | ||||
|     public int time() default 60; | ||||
|     int time() default 60; | ||||
|  | ||||
|     /** | ||||
|      * 限流次数 | ||||
|      */ | ||||
|     public int count() default 100; | ||||
|     int count() default 100; | ||||
|  | ||||
|     /** | ||||
|      * 限流类型 | ||||
|      */ | ||||
|     public LimitType limitType() default LimitType.DEFAULT; | ||||
|     LimitType limitType() default LimitType.DEFAULT; | ||||
| } | ||||
|   | ||||
| @@ -1,11 +1,6 @@ | ||||
| package com.ruoyi.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; | ||||
| import java.lang.annotation.*; | ||||
| import java.util.concurrent.TimeUnit; | ||||
|  | ||||
| /** | ||||
| @@ -19,11 +14,16 @@ import java.util.concurrent.TimeUnit; | ||||
| @Documented | ||||
| public @interface RepeatSubmit { | ||||
|  | ||||
| 	/** | ||||
| 	 * 默认使用全局配置 | ||||
| 	 */ | ||||
| 	int intervalTime() default 0; | ||||
|     /** | ||||
|      * 间隔时间(ms),小于此时间视为重复提交 | ||||
|      */ | ||||
|     int interval() default 5000; | ||||
|  | ||||
| 	TimeUnit timeUnit() default TimeUnit.MILLISECONDS; | ||||
|     TimeUnit timeUnit() default TimeUnit.MILLISECONDS; | ||||
|  | ||||
|     /** | ||||
|      * 提示消息 | ||||
|      */ | ||||
|     String message() default "不允许重复提交,请稍候再试"; | ||||
|  | ||||
| } | ||||
|   | ||||
| @@ -2,7 +2,6 @@ package com.ruoyi.common.config; | ||||
|  | ||||
| import lombok.Data; | ||||
| import lombok.Getter; | ||||
| import lombok.NoArgsConstructor; | ||||
| import lombok.experimental.Accessors; | ||||
| import org.springframework.boot.context.properties.ConfigurationProperties; | ||||
| import org.springframework.stereotype.Component; | ||||
| @@ -10,34 +9,47 @@ import org.springframework.stereotype.Component; | ||||
| /** | ||||
|  * 读取项目相关配置 | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  * @author Lion Li | ||||
|  */ | ||||
|  | ||||
| @Data | ||||
| @NoArgsConstructor | ||||
| @Accessors(chain = true) | ||||
| @Component | ||||
| @ConfigurationProperties(prefix = "ruoyi") | ||||
| public class RuoYiConfig | ||||
| { | ||||
|     /** 项目名称 */ | ||||
| public class RuoYiConfig { | ||||
|  | ||||
|     /** | ||||
|      * 项目名称 | ||||
|      */ | ||||
|     private String name; | ||||
|  | ||||
|     /** 版本 */ | ||||
|     /** | ||||
|      * 版本 | ||||
|      */ | ||||
|     private String version; | ||||
|  | ||||
|     /** 版权年份 */ | ||||
|     /** | ||||
|      * 版权年份 | ||||
|      */ | ||||
|     private String copyrightYear; | ||||
|  | ||||
|     /** 实例演示开关 */ | ||||
|     /** | ||||
|      * 实例演示开关 | ||||
|      */ | ||||
|     private boolean demoEnabled; | ||||
|  | ||||
|     /** 获取地址开关 */ | ||||
|     /** | ||||
|      * 缓存懒加载 | ||||
|      */ | ||||
|     private boolean cacheLazy; | ||||
|  | ||||
|     /** | ||||
|      * 获取地址开关 | ||||
|      */ | ||||
|     @Getter | ||||
|     private static boolean addressEnabled; | ||||
|  | ||||
|     public void setAddressEnabled(boolean addressEnabled) | ||||
|     { | ||||
|     public void setAddressEnabled(boolean addressEnabled) { | ||||
|         RuoYiConfig.addressEnabled = addressEnabled; | ||||
|     } | ||||
|  | ||||
|   | ||||
| @@ -1,146 +1,151 @@ | ||||
| package com.ruoyi.common.constant; | ||||
|  | ||||
| import io.jsonwebtoken.Claims; | ||||
|  | ||||
| /** | ||||
|  * 通用常量信息 | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| public class Constants | ||||
| { | ||||
| public interface Constants { | ||||
|  | ||||
|     /** | ||||
|      * UTF-8 字符集 | ||||
|      */ | ||||
|     public static final String UTF8 = "UTF-8"; | ||||
|     String UTF8 = "UTF-8"; | ||||
|  | ||||
|     /** | ||||
|      * GBK 字符集 | ||||
|      */ | ||||
|     public static final String GBK = "GBK"; | ||||
|     String GBK = "GBK"; | ||||
|  | ||||
|     /** | ||||
|      * http请求 | ||||
|      */ | ||||
|     public static final String HTTP = "http://"; | ||||
|     String HTTP = "http://"; | ||||
|  | ||||
|     /** | ||||
|      * https请求 | ||||
|      */ | ||||
|     public static final String HTTPS = "https://"; | ||||
|     String HTTPS = "https://"; | ||||
|  | ||||
|     /** | ||||
|      * 通用成功标识 | ||||
|      */ | ||||
|     public static final String SUCCESS = "0"; | ||||
|     String SUCCESS = "0"; | ||||
|  | ||||
|     /** | ||||
|      * 通用失败标识 | ||||
|      */ | ||||
|     public static final String FAIL = "1"; | ||||
|     String FAIL = "1"; | ||||
|  | ||||
|     /** | ||||
|      * 登录成功 | ||||
|      */ | ||||
|     public static final String LOGIN_SUCCESS = "Success"; | ||||
|     String LOGIN_SUCCESS = "Success"; | ||||
|  | ||||
|     /** | ||||
|      * 注销 | ||||
|      */ | ||||
|     public static final String LOGOUT = "Logout"; | ||||
|     String LOGOUT = "Logout"; | ||||
|  | ||||
|     /** | ||||
|      * 注册 | ||||
|      */ | ||||
|     public static final String REGISTER = "Register"; | ||||
|     String REGISTER = "Register"; | ||||
|  | ||||
|     /** | ||||
|      * 登录失败 | ||||
|      */ | ||||
|     public static final String LOGIN_FAIL = "Error"; | ||||
|     String LOGIN_FAIL = "Error"; | ||||
|  | ||||
|     /** | ||||
|      * 验证码 redis key | ||||
|      */ | ||||
|     public static final String CAPTCHA_CODE_KEY = "captcha_codes:"; | ||||
|     String CAPTCHA_CODE_KEY = "captcha_codes:"; | ||||
|  | ||||
|     /** | ||||
|      * 登录用户 redis key | ||||
|      */ | ||||
|     public static final String LOGIN_TOKEN_KEY = "login_tokens:"; | ||||
|     String LOGIN_TOKEN_KEY = "login_tokens:"; | ||||
|  | ||||
|     /** | ||||
|      * 防重提交 redis key | ||||
|      */ | ||||
|     public static final String REPEAT_SUBMIT_KEY = "repeat_submit:"; | ||||
|     String REPEAT_SUBMIT_KEY = "repeat_submit:"; | ||||
|  | ||||
|     /** | ||||
|      * 限流 redis key | ||||
|      */ | ||||
|     public static final String RATE_LIMIT_KEY = "rate_limit:"; | ||||
|     String RATE_LIMIT_KEY = "rate_limit:"; | ||||
|  | ||||
|     /** | ||||
|      * 验证码有效期(分钟) | ||||
|      */ | ||||
|     public static final Integer CAPTCHA_EXPIRATION = 2; | ||||
|     Integer CAPTCHA_EXPIRATION = 2; | ||||
|  | ||||
|     /** | ||||
|      * 登陆错误 redis key | ||||
|      */ | ||||
|     String LOGIN_ERROR = "login_error:"; | ||||
|  | ||||
|     /** | ||||
|      * 登录错误次数 | ||||
|      */ | ||||
|     Integer LOGIN_ERROR_NUMBER = 5; | ||||
|  | ||||
|     /** | ||||
|      * 登录错误限制时间(分钟) | ||||
|      */ | ||||
|     Integer LOGIN_ERROR_LIMIT_TIME = 10; | ||||
|  | ||||
|     /** | ||||
|      * 令牌 | ||||
|      */ | ||||
|     public static final String TOKEN = "token"; | ||||
|     String TOKEN = "token"; | ||||
|  | ||||
|     /** | ||||
|      * 令牌前缀 | ||||
|      */ | ||||
|     public static final String TOKEN_PREFIX = "Bearer "; | ||||
|     String TOKEN_PREFIX = "Bearer "; | ||||
|  | ||||
|     /** | ||||
|      * 令牌前缀 | ||||
|      */ | ||||
|     public static final String LOGIN_USER_KEY = "login_user_key"; | ||||
|     String LOGIN_USER_KEY = "login_user_key"; | ||||
|  | ||||
|     /** | ||||
|      * 用户ID | ||||
|      */ | ||||
|     public static final String JWT_USERID = "userid"; | ||||
|     String JWT_USERID = "userid"; | ||||
|  | ||||
|     /** | ||||
|      * 用户名称 | ||||
|      */ | ||||
|     public static final String JWT_USERNAME = Claims.SUBJECT; | ||||
|     String JWT_USERNAME = "sub"; | ||||
|  | ||||
|     /** | ||||
|      * 用户头像 | ||||
|      */ | ||||
|     public static final String JWT_AVATAR = "avatar"; | ||||
|     String JWT_AVATAR = "avatar"; | ||||
|  | ||||
|     /** | ||||
|      * 创建时间 | ||||
|      */ | ||||
|     public static final String JWT_CREATED = "created"; | ||||
|     String JWT_CREATED = "created"; | ||||
|  | ||||
|     /** | ||||
|      * 用户权限 | ||||
|      */ | ||||
|     public static final String JWT_AUTHORITIES = "authorities"; | ||||
|     String JWT_AUTHORITIES = "authorities"; | ||||
|  | ||||
|     /** | ||||
|      * 参数管理 cache key | ||||
|      */ | ||||
|     public static final String SYS_CONFIG_KEY = "sys_config:"; | ||||
|     String SYS_CONFIG_KEY = "sys_config:"; | ||||
|  | ||||
|     /** | ||||
|      * 字典管理 cache key | ||||
|      */ | ||||
|     public static final String SYS_DICT_KEY = "sys_dict:"; | ||||
|     String SYS_DICT_KEY = "sys_dict:"; | ||||
|  | ||||
| 	/** | ||||
| 	 * RMI 远程方法调用 | ||||
| 	 */ | ||||
| 	public static final String LOOKUP_RMI = "rmi://"; | ||||
|  | ||||
| 	/** | ||||
| 	 * LDAP 远程方法调用 | ||||
| 	 */ | ||||
| 	public static final String LOOKUP_LDAP = "ldap://"; | ||||
| } | ||||
|   | ||||
| @@ -5,110 +5,184 @@ package com.ruoyi.common.constant; | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| public class GenConstants | ||||
| { | ||||
|     /** 单表(增删改查) */ | ||||
|     public static final String TPL_CRUD = "crud"; | ||||
| public interface GenConstants { | ||||
|     /** | ||||
|      * 单表(增删改查) | ||||
|      */ | ||||
|     String TPL_CRUD = "crud"; | ||||
|  | ||||
|     /** 树表(增删改查) */ | ||||
|     public static final String TPL_TREE = "tree"; | ||||
|     /** | ||||
|      * 树表(增删改查) | ||||
|      */ | ||||
|     String TPL_TREE = "tree"; | ||||
|  | ||||
|     /** 主子表(增删改查) */ | ||||
|     public static final String TPL_SUB = "sub"; | ||||
|     /** | ||||
|      * 主子表(增删改查) | ||||
|      */ | ||||
|     String TPL_SUB = "sub"; | ||||
|  | ||||
|     /** 树编码字段 */ | ||||
|     public static final String TREE_CODE = "treeCode"; | ||||
|     /** | ||||
|      * 树编码字段 | ||||
|      */ | ||||
|     String TREE_CODE = "treeCode"; | ||||
|  | ||||
|     /** 树父编码字段 */ | ||||
|     public static final String TREE_PARENT_CODE = "treeParentCode"; | ||||
|     /** | ||||
|      * 树父编码字段 | ||||
|      */ | ||||
|     String TREE_PARENT_CODE = "treeParentCode"; | ||||
|  | ||||
|     /** 树名称字段 */ | ||||
|     public static final String TREE_NAME = "treeName"; | ||||
|     /** | ||||
|      * 树名称字段 | ||||
|      */ | ||||
|     String TREE_NAME = "treeName"; | ||||
|  | ||||
|     /** 上级菜单ID字段 */ | ||||
|     public static final String PARENT_MENU_ID = "parentMenuId"; | ||||
|     /** | ||||
|      * 上级菜单ID字段 | ||||
|      */ | ||||
|     String PARENT_MENU_ID = "parentMenuId"; | ||||
|  | ||||
|     /** 上级菜单名称字段 */ | ||||
|     public static final String PARENT_MENU_NAME = "parentMenuName"; | ||||
|     /** | ||||
|      * 上级菜单名称字段 | ||||
|      */ | ||||
|     String PARENT_MENU_NAME = "parentMenuName"; | ||||
|  | ||||
|     /** 数据库字符串类型 */ | ||||
|     public static final String[] COLUMNTYPE_STR = { "char", "varchar", "nvarchar", "varchar2" }; | ||||
|     /** | ||||
|      * 数据库字符串类型 | ||||
|      */ | ||||
|     String[] COLUMNTYPE_STR = {"char", "varchar", "nvarchar", "varchar2"}; | ||||
|  | ||||
|     /** 数据库文本类型 */ | ||||
|     public static final String[] COLUMNTYPE_TEXT = { "tinytext", "text", "mediumtext", "longtext" }; | ||||
|     /** | ||||
|      * 数据库文本类型 | ||||
|      */ | ||||
|     String[] COLUMNTYPE_TEXT = {"tinytext", "text", "mediumtext", "longtext"}; | ||||
|  | ||||
|     /** 数据库时间类型 */ | ||||
|     public static final String[] COLUMNTYPE_TIME = { "datetime", "time", "date", "timestamp" }; | ||||
|     /** | ||||
|      * 数据库时间类型 | ||||
|      */ | ||||
|     String[] COLUMNTYPE_TIME = {"datetime", "time", "date", "timestamp"}; | ||||
|  | ||||
|     /** 数据库数字类型 */ | ||||
|     public static final String[] COLUMNTYPE_NUMBER = { "tinyint", "smallint", "mediumint", "int", "number", "integer", | ||||
|             "bit", "bigint", "float", "double", "decimal" }; | ||||
|     /** | ||||
|      * 数据库数字类型 | ||||
|      */ | ||||
|     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" }; | ||||
|     /** | ||||
|      * BO对象 不需要添加字段 | ||||
|      */ | ||||
|     String[] COLUMNNAME_NOT_ADD = {"create_by", "create_time", "del_flag", "update_by", | ||||
|         "update_time", "version"}; | ||||
|  | ||||
|     /** 页面不需要显示的列表字段 */ | ||||
|     public static final String[] COLUMNNAME_NOT_LIST = { "id", "create_by", "create_time", "del_flag", "update_by", | ||||
|             "update_time" }; | ||||
|     /** | ||||
|      * BO对象 不需要编辑字段 | ||||
|      */ | ||||
|     String[] COLUMNNAME_NOT_EDIT = {"create_by", "create_time", "del_flag", "update_by", | ||||
|         "update_time", "version"}; | ||||
|  | ||||
|     /** 页面不需要查询字段 */ | ||||
|     public static final String[] COLUMNNAME_NOT_QUERY = { "id", "create_by", "create_time", "del_flag", "update_by", | ||||
|             "update_time", "remark" }; | ||||
|     /** | ||||
|      * VO对象 不需要返回字段 | ||||
|      */ | ||||
|     String[] COLUMNNAME_NOT_LIST = {"create_by", "create_time", "del_flag", "update_by", | ||||
|         "update_time", "version"}; | ||||
|  | ||||
|     /** Entity基类字段 */ | ||||
|     public static final String[] BASE_ENTITY = { "createBy", "createTime", "updateBy", "updateTime", "remark" }; | ||||
|     /** | ||||
|      * BO对象 不需要查询字段 | ||||
|      */ | ||||
|     String[] COLUMNNAME_NOT_QUERY = {"id", "create_by", "create_time", "del_flag", "update_by", | ||||
|         "update_time", "remark", "version"}; | ||||
|  | ||||
|     /** Tree基类字段 */ | ||||
|     public static final String[] TREE_ENTITY = { "parentName", "parentId", "orderNum", "ancestors", "children" }; | ||||
|     /** | ||||
|      * Entity基类字段 | ||||
|      */ | ||||
|     String[] BASE_ENTITY = {"createBy", "createTime", "updateBy", "updateTime"}; | ||||
|  | ||||
|     /** 文本框 */ | ||||
|     public static final String HTML_INPUT = "input"; | ||||
|     /** | ||||
|      * Tree基类字段 | ||||
|      */ | ||||
|     String[] TREE_ENTITY = {"parentName", "parentId", "children"}; | ||||
|  | ||||
|     /** 文本域 */ | ||||
|     public static final String HTML_TEXTAREA = "textarea"; | ||||
|     /** | ||||
|      * 文本框 | ||||
|      */ | ||||
|     String HTML_INPUT = "input"; | ||||
|  | ||||
|     /** 下拉框 */ | ||||
|     public static final String HTML_SELECT = "select"; | ||||
|     /** | ||||
|      * 文本域 | ||||
|      */ | ||||
|     String HTML_TEXTAREA = "textarea"; | ||||
|  | ||||
|     /** 单选框 */ | ||||
|     public static final String HTML_RADIO = "radio"; | ||||
|     /** | ||||
|      * 下拉框 | ||||
|      */ | ||||
|     String HTML_SELECT = "select"; | ||||
|  | ||||
|     /** 复选框 */ | ||||
|     public static final String HTML_CHECKBOX = "checkbox"; | ||||
|     /** | ||||
|      * 单选框 | ||||
|      */ | ||||
|     String HTML_RADIO = "radio"; | ||||
|  | ||||
|     /** 日期控件 */ | ||||
|     public static final String HTML_DATETIME = "datetime"; | ||||
|     /** | ||||
|      * 复选框 | ||||
|      */ | ||||
|     String HTML_CHECKBOX = "checkbox"; | ||||
|  | ||||
|     /** 图片上传控件 */ | ||||
|     public static final String HTML_IMAGE_UPLOAD = "imageUpload"; | ||||
|     /** | ||||
|      * 日期控件 | ||||
|      */ | ||||
|     String HTML_DATETIME = "datetime"; | ||||
|  | ||||
|     /** 文件上传控件 */ | ||||
|     public static final String HTML_FILE_UPLOAD = "fileUpload"; | ||||
|     /** | ||||
|      * 图片上传控件 | ||||
|      */ | ||||
|     String HTML_IMAGE_UPLOAD = "imageUpload"; | ||||
|  | ||||
|     /** 富文本控件 */ | ||||
|     public static final String HTML_EDITOR = "editor"; | ||||
|     /** | ||||
|      * 文件上传控件 | ||||
|      */ | ||||
|     String HTML_FILE_UPLOAD = "fileUpload"; | ||||
|  | ||||
|     /** 字符串类型 */ | ||||
|     public static final String TYPE_STRING = "String"; | ||||
|     /** | ||||
|      * 富文本控件 | ||||
|      */ | ||||
|     String HTML_EDITOR = "editor"; | ||||
|  | ||||
|     /** 整型 */ | ||||
|     public static final String TYPE_INTEGER = "Integer"; | ||||
|     /** | ||||
|      * 字符串类型 | ||||
|      */ | ||||
|     String TYPE_STRING = "String"; | ||||
|  | ||||
|     /** 长整型 */ | ||||
|     public static final String TYPE_LONG = "Long"; | ||||
|     /** | ||||
|      * 整型 | ||||
|      */ | ||||
|     String TYPE_INTEGER = "Integer"; | ||||
|  | ||||
|     /** 浮点型 */ | ||||
|     public static final String TYPE_DOUBLE = "Double"; | ||||
|     /** | ||||
|      * 长整型 | ||||
|      */ | ||||
|     String TYPE_LONG = "Long"; | ||||
|  | ||||
|     /** 高精度计算类型 */ | ||||
|     public static final String TYPE_BIGDECIMAL = "BigDecimal"; | ||||
|     /** | ||||
|      * 浮点型 | ||||
|      */ | ||||
|     String TYPE_DOUBLE = "Double"; | ||||
|  | ||||
|     /** 时间类型 */ | ||||
|     public static final String TYPE_DATE = "Date"; | ||||
|     /** | ||||
|      * 高精度计算类型 | ||||
|      */ | ||||
|     String TYPE_BIGDECIMAL = "BigDecimal"; | ||||
|  | ||||
|     /** 模糊查询 */ | ||||
|     public static final String QUERY_LIKE = "LIKE"; | ||||
|     /** | ||||
|      * 时间类型 | ||||
|      */ | ||||
|     String TYPE_DATE = "Date"; | ||||
|  | ||||
|     /** 需要 */ | ||||
|     public static final String REQUIRE = "1"; | ||||
|     /** | ||||
|      * 模糊查询 | ||||
|      */ | ||||
|     String QUERY_LIKE = "LIKE"; | ||||
|  | ||||
|     /** | ||||
|      * 需要 | ||||
|      */ | ||||
|     String REQUIRE = "1"; | ||||
| } | ||||
|   | ||||
| @@ -1,50 +0,0 @@ | ||||
| package com.ruoyi.common.constant; | ||||
|  | ||||
| /** | ||||
|  * 任务调度通用常量 | ||||
|  *  | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| 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; | ||||
|         } | ||||
|     } | ||||
| } | ||||
| @@ -5,74 +5,108 @@ package com.ruoyi.common.constant; | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| public class UserConstants | ||||
| { | ||||
| public interface UserConstants { | ||||
|  | ||||
|     /** | ||||
|      * 平台内系统用户的唯一标志 | ||||
|      */ | ||||
|     public static final String SYS_USER = "SYS_USER"; | ||||
|     String SYS_USER = "SYS_USER"; | ||||
|  | ||||
|     /** 正常状态 */ | ||||
|     public static final String NORMAL = "0"; | ||||
|     /** | ||||
|      * 正常状态 | ||||
|      */ | ||||
|     String NORMAL = "0"; | ||||
|  | ||||
|     /** 异常状态 */ | ||||
|     public static final String EXCEPTION = "1"; | ||||
|     /** | ||||
|      * 异常状态 | ||||
|      */ | ||||
|     String EXCEPTION = "1"; | ||||
|  | ||||
|     /** 用户封禁状态 */ | ||||
|     public static final String USER_DISABLE = "1"; | ||||
|     /** | ||||
|      * 用户封禁状态 | ||||
|      */ | ||||
|     String USER_DISABLE = "1"; | ||||
|  | ||||
|     /** 角色封禁状态 */ | ||||
|     public static final String ROLE_DISABLE = "1"; | ||||
|     /** | ||||
|      * 角色封禁状态 | ||||
|      */ | ||||
|     String ROLE_DISABLE = "1"; | ||||
|  | ||||
|     /** 部门正常状态 */ | ||||
|     public static final String DEPT_NORMAL = "0"; | ||||
|     /** | ||||
|      * 部门正常状态 | ||||
|      */ | ||||
|     String DEPT_NORMAL = "0"; | ||||
|  | ||||
|     /** 部门停用状态 */ | ||||
|     public static final String DEPT_DISABLE = "1"; | ||||
|     /** | ||||
|      * 部门停用状态 | ||||
|      */ | ||||
|     String DEPT_DISABLE = "1"; | ||||
|  | ||||
|     /** 字典正常状态 */ | ||||
|     public static final String DICT_NORMAL = "0"; | ||||
|     /** | ||||
|      * 字典正常状态 | ||||
|      */ | ||||
|     String DICT_NORMAL = "0"; | ||||
|  | ||||
|     /** 是否为系统默认(是) */ | ||||
|     public static final String YES = "Y"; | ||||
|     /** | ||||
|      * 是否为系统默认(是) | ||||
|      */ | ||||
|     String YES = "Y"; | ||||
|  | ||||
|     /** 是否菜单外链(是) */ | ||||
|     public static final String YES_FRAME = "0"; | ||||
|     /** | ||||
|      * 是否菜单外链(是) | ||||
|      */ | ||||
|     String YES_FRAME = "0"; | ||||
|  | ||||
|     /** 是否菜单外链(否) */ | ||||
|     public static final String NO_FRAME = "1"; | ||||
|     /** | ||||
|      * 是否菜单外链(否) | ||||
|      */ | ||||
|     String NO_FRAME = "1"; | ||||
|  | ||||
|     /** 菜单类型(目录) */ | ||||
|     public static final String TYPE_DIR = "M"; | ||||
|     /** | ||||
|      * 菜单类型(目录) | ||||
|      */ | ||||
|     String TYPE_DIR = "M"; | ||||
|  | ||||
|     /** 菜单类型(菜单) */ | ||||
|     public static final String TYPE_MENU = "C"; | ||||
|     /** | ||||
|      * 菜单类型(菜单) | ||||
|      */ | ||||
|     String TYPE_MENU = "C"; | ||||
|  | ||||
|     /** 菜单类型(按钮) */ | ||||
|     public static final String TYPE_BUTTON = "F"; | ||||
|     /** | ||||
|      * 菜单类型(按钮) | ||||
|      */ | ||||
|     String TYPE_BUTTON = "F"; | ||||
|  | ||||
|     /** Layout组件标识 */ | ||||
|     public final static String LAYOUT = "Layout"; | ||||
|     /** | ||||
|      * Layout组件标识 | ||||
|      */ | ||||
|     String LAYOUT = "Layout"; | ||||
|  | ||||
|     /** ParentView组件标识 */ | ||||
|     public final static String PARENT_VIEW = "ParentView"; | ||||
|     /** | ||||
|      * ParentView组件标识 | ||||
|      */ | ||||
|     String PARENT_VIEW = "ParentView"; | ||||
|  | ||||
|     /** InnerLink组件标识 */ | ||||
|     public final static String INNER_LINK = "InnerLink"; | ||||
|     /** | ||||
|      * InnerLink组件标识 | ||||
|      */ | ||||
|     String INNER_LINK = "InnerLink"; | ||||
|  | ||||
|     /** 校验返回结果码 */ | ||||
|     public final static String UNIQUE = "0"; | ||||
|     public final static String NOT_UNIQUE = "1"; | ||||
|     /** | ||||
|      * 校验返回结果码 | ||||
|      */ | ||||
|     String UNIQUE = "0"; | ||||
|     String NOT_UNIQUE = "1"; | ||||
|  | ||||
|     /** | ||||
|      * 用户名长度限制 | ||||
|      */ | ||||
|     public static final int USERNAME_MIN_LENGTH = 2; | ||||
|     public static final int USERNAME_MAX_LENGTH = 20; | ||||
|     int USERNAME_MIN_LENGTH = 2; | ||||
|     int USERNAME_MAX_LENGTH = 20; | ||||
|  | ||||
|     /** | ||||
|      * 密码长度限制 | ||||
|      */ | ||||
|     public static final int PASSWORD_MIN_LENGTH = 5; | ||||
|     public static final int PASSWORD_MAX_LENGTH = 20; | ||||
|     int PASSWORD_MIN_LENGTH = 5; | ||||
|     int PASSWORD_MAX_LENGTH = 20; | ||||
| } | ||||
|   | ||||
| @@ -8,8 +8,10 @@ import com.alibaba.excel.metadata.CellData; | ||||
| import com.alibaba.excel.metadata.GlobalConfiguration; | ||||
| import com.alibaba.excel.metadata.property.ExcelContentProperty; | ||||
| import com.ruoyi.common.annotation.ExcelDictFormat; | ||||
| import com.ruoyi.common.core.service.DictService; | ||||
| import com.ruoyi.common.utils.StringUtils; | ||||
| import com.ruoyi.common.utils.poi.ExcelUtil; | ||||
| import com.ruoyi.common.utils.spring.SpringUtils; | ||||
| import lombok.extern.slf4j.Slf4j; | ||||
|  | ||||
| import java.lang.reflect.Field; | ||||
| @@ -41,7 +43,7 @@ public class ExcelDictConvert implements Converter<Object> { | ||||
| 		if (StringUtils.isBlank(type)) { | ||||
| 			value = ExcelUtil.reverseByExp(label, anno.readConverterExp(), anno.separator()); | ||||
| 		} else { | ||||
| 			value = ExcelUtil.reverseDictByExp(label, type, anno.separator()); | ||||
| 			value = SpringUtils.getBean(DictService.class).getDictValue(type, label, anno.separator()); | ||||
| 		} | ||||
| 		return Convert.convert(contentProperty.getField().getType(), value); | ||||
| 	} | ||||
| @@ -58,7 +60,7 @@ public class ExcelDictConvert implements Converter<Object> { | ||||
| 		if (StringUtils.isBlank(type)) { | ||||
| 			label = ExcelUtil.convertByExp(value, anno.readConverterExp(), anno.separator()); | ||||
| 		} else { | ||||
| 			label = ExcelUtil.convertDictByExp(value, type, anno.separator()); | ||||
| 			label = SpringUtils.getBean(DictService.class).getDictLabel(type, value, anno.separator()); | ||||
| 		} | ||||
| 		return new CellData<>(label); | ||||
| 	} | ||||
|   | ||||
| @@ -4,47 +4,39 @@ import com.ruoyi.common.core.domain.AjaxResult; | ||||
| import com.ruoyi.common.core.domain.model.LoginUser; | ||||
| import com.ruoyi.common.utils.SecurityUtils; | ||||
| import com.ruoyi.common.utils.StringUtils; | ||||
| import org.slf4j.Logger; | ||||
| import org.slf4j.LoggerFactory; | ||||
|  | ||||
| /** | ||||
|  * web层通用数据处理 | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| public class BaseController | ||||
| { | ||||
|     protected final Logger logger = LoggerFactory.getLogger(this.getClass()); | ||||
| public class BaseController { | ||||
|  | ||||
|     /** | ||||
|      * 返回成功 | ||||
|      */ | ||||
|     public AjaxResult<Void> success() | ||||
|     { | ||||
|     public AjaxResult<Void> success() { | ||||
|         return AjaxResult.success(); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 返回失败消息 | ||||
|      */ | ||||
|     public AjaxResult<Void> error() | ||||
|     { | ||||
|     public AjaxResult<Void> error() { | ||||
|         return AjaxResult.error(); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 返回成功消息 | ||||
|      */ | ||||
|     public AjaxResult<Void> success(String message) | ||||
|     { | ||||
|     public AjaxResult<Void> success(String message) { | ||||
|         return AjaxResult.success(message); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 返回失败消息 | ||||
|      */ | ||||
|     public AjaxResult<Void> error(String message) | ||||
|     { | ||||
|     public AjaxResult<Void> error(String message) { | ||||
|         return AjaxResult.error(message); | ||||
|     } | ||||
|  | ||||
| @@ -54,8 +46,7 @@ public class BaseController | ||||
|      * @param rows 影响行数 | ||||
|      * @return 操作结果 | ||||
|      */ | ||||
|     protected AjaxResult<Void> toAjax(int rows) | ||||
|     { | ||||
|     protected AjaxResult<Void> toAjax(int rows) { | ||||
|         return rows > 0 ? AjaxResult.success() : AjaxResult.error(); | ||||
|     } | ||||
|  | ||||
| @@ -65,48 +56,42 @@ public class BaseController | ||||
|      * @param result 结果 | ||||
|      * @return 操作结果 | ||||
|      */ | ||||
|     protected AjaxResult<Void> toAjax(boolean result) | ||||
|     { | ||||
|     protected AjaxResult<Void> toAjax(boolean result) { | ||||
|         return result ? success() : error(); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 页面跳转 | ||||
|      */ | ||||
|     public String redirect(String url) | ||||
|     { | ||||
|     public String redirect(String url) { | ||||
|         return StringUtils.format("redirect:{}", url); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 获取用户缓存信息 | ||||
|      */ | ||||
|     public LoginUser getLoginUser() | ||||
|     { | ||||
|     public LoginUser getLoginUser() { | ||||
|         return SecurityUtils.getLoginUser(); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 获取登录用户id | ||||
|      */ | ||||
|     public Long getUserId() | ||||
|     { | ||||
|     public Long getUserId() { | ||||
|         return getLoginUser().getUserId(); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 获取登录部门id | ||||
|      */ | ||||
|     public Long getDeptId() | ||||
|     { | ||||
|     public Long getDeptId() { | ||||
|         return getLoginUser().getDeptId(); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 获取登录用户名 | ||||
|      */ | ||||
|     public String getUsername() | ||||
|     { | ||||
|     public String getUsername() { | ||||
|         return getLoginUser().getUsername(); | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -1,8 +1,9 @@ | ||||
| package com.ruoyi.common.core.domain; | ||||
|  | ||||
| import com.baomidou.mybatisplus.annotation.FieldFill; | ||||
| import com.baomidou.mybatisplus.annotation.TableField; | ||||
| import io.swagger.annotations.ApiModelProperty; | ||||
| import lombok.Data; | ||||
| import lombok.NoArgsConstructor; | ||||
| import lombok.experimental.Accessors; | ||||
|  | ||||
| import java.io.Serializable; | ||||
| @@ -13,11 +14,10 @@ import java.util.Map; | ||||
| /** | ||||
|  * Entity基类 | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  * @author Lion Li | ||||
|  */ | ||||
|  | ||||
| @Data | ||||
| @NoArgsConstructor | ||||
| @Accessors(chain = true) | ||||
| public class BaseEntity implements Serializable { | ||||
|  | ||||
| @@ -27,42 +27,42 @@ public class BaseEntity implements Serializable { | ||||
| 	 * 搜索值 | ||||
| 	 */ | ||||
| 	@ApiModelProperty(value = "搜索值") | ||||
| 	@TableField(exist = false) | ||||
| 	private String searchValue; | ||||
|  | ||||
| 	/** | ||||
| 	 * 创建者 | ||||
| 	 */ | ||||
| 	@ApiModelProperty(value = "创建者") | ||||
| 	@TableField(fill = FieldFill.INSERT) | ||||
| 	private String createBy; | ||||
|  | ||||
| 	/** | ||||
| 	 * 创建时间 | ||||
| 	 */ | ||||
| 	@ApiModelProperty(value = "创建时间") | ||||
| 	@TableField(fill = FieldFill.INSERT) | ||||
| 	private Date createTime; | ||||
|  | ||||
| 	/** | ||||
| 	 * 更新者 | ||||
| 	 */ | ||||
| 	@ApiModelProperty(value = "更新者") | ||||
| 	@TableField(fill = FieldFill.INSERT_UPDATE) | ||||
| 	private String updateBy; | ||||
|  | ||||
| 	/** | ||||
| 	 * 更新时间 | ||||
| 	 */ | ||||
| 	@ApiModelProperty(value = "更新时间") | ||||
| 	@TableField(fill = FieldFill.INSERT_UPDATE) | ||||
| 	private Date updateTime; | ||||
|  | ||||
| 	/** | ||||
| 	 * 备注 | ||||
| 	 */ | ||||
| 	@ApiModelProperty(value = "备注") | ||||
| 	private String remark; | ||||
|  | ||||
| 	/** | ||||
| 	 * 请求参数 | ||||
| 	 */ | ||||
| 	@ApiModelProperty(value = "请求参数") | ||||
| 	@TableField(exist = false) | ||||
| 	private Map<String, Object> params = new HashMap<>(); | ||||
|  | ||||
| } | ||||
|   | ||||
| @@ -0,0 +1,93 @@ | ||||
| package com.ruoyi.common.core.domain; | ||||
|  | ||||
| import cn.hutool.core.util.ObjectUtil; | ||||
| import com.baomidou.mybatisplus.core.metadata.OrderItem; | ||||
| import com.baomidou.mybatisplus.extension.plugins.pagination.Page; | ||||
| import com.ruoyi.common.utils.StringUtils; | ||||
| import com.ruoyi.common.utils.sql.SqlUtil; | ||||
| import io.swagger.annotations.ApiModelProperty; | ||||
| import lombok.Data; | ||||
| import lombok.experimental.Accessors; | ||||
|  | ||||
| import java.io.Serializable; | ||||
|  | ||||
| /** | ||||
|  * 分页查询实体类 | ||||
|  * | ||||
|  * @author Lion Li | ||||
|  */ | ||||
|  | ||||
| @Data | ||||
| @Accessors(chain = true) | ||||
| public class PageQuery implements Serializable { | ||||
|  | ||||
| 	private static final long serialVersionUID = 1L; | ||||
|  | ||||
|     /** | ||||
|      * 分页大小 | ||||
|      */ | ||||
|     @ApiModelProperty("分页大小") | ||||
|     private Integer pageSize; | ||||
|  | ||||
|     /** | ||||
|      * 当前页数 | ||||
|      */ | ||||
|     @ApiModelProperty("当前页数") | ||||
|     private Integer pageNum; | ||||
|  | ||||
|     /** | ||||
|      * 排序列 | ||||
|      */ | ||||
|     @ApiModelProperty("排序列") | ||||
|     private String orderByColumn; | ||||
|  | ||||
|     /** | ||||
|      * 排序的方向desc或者asc | ||||
|      */ | ||||
|     @ApiModelProperty(value = "排序的方向", example = "asc,desc") | ||||
|     private String isAsc; | ||||
|  | ||||
|     /** | ||||
|      * 当前记录起始索引 默认值 | ||||
|      */ | ||||
|     public static final int DEFAULT_PAGE_NUM = 1; | ||||
|  | ||||
|     /** | ||||
|      * 每页显示记录数 默认值 默认查全部 | ||||
|      */ | ||||
|     public static final int DEFAULT_PAGE_SIZE = Integer.MAX_VALUE; | ||||
|  | ||||
|     public <T> Page<T> build() { | ||||
|         Integer pageNum = ObjectUtil.defaultIfNull(getPageNum(), DEFAULT_PAGE_NUM); | ||||
|         Integer pageSize = ObjectUtil.defaultIfNull(getPageSize(), DEFAULT_PAGE_SIZE); | ||||
|         if (pageNum <= 0) { | ||||
|             pageNum = DEFAULT_PAGE_NUM; | ||||
|         } | ||||
|         Page<T> page = new Page<>(pageNum, pageSize); | ||||
|         OrderItem orderItem = buildOrderItem(); | ||||
|         if (ObjectUtil.isNotNull(orderItem)) { | ||||
|             page.addOrder(orderItem); | ||||
|         } | ||||
|         return page; | ||||
|     } | ||||
|  | ||||
|     private OrderItem buildOrderItem() { | ||||
|         // 兼容前端排序类型 | ||||
|         if ("ascending".equals(isAsc)) { | ||||
|             isAsc = "asc"; | ||||
|         } else if ("descending".equals(isAsc)) { | ||||
|             isAsc = "desc"; | ||||
|         } | ||||
|         if (StringUtils.isNotBlank(orderByColumn)) { | ||||
|             String orderBy = SqlUtil.escapeOrderBySql(orderByColumn); | ||||
|             orderBy = StringUtils.toUnderScoreCase(orderBy); | ||||
|             if ("asc".equals(isAsc)) { | ||||
|                 return OrderItem.asc(orderBy); | ||||
|             } else if ("desc".equals(isAsc)) { | ||||
|                 return OrderItem.desc(orderBy); | ||||
|             } | ||||
|         } | ||||
|         return null; | ||||
|     } | ||||
|  | ||||
| } | ||||
| @@ -1,9 +1,9 @@ | ||||
| package com.ruoyi.common.core.domain; | ||||
|  | ||||
| import com.baomidou.mybatisplus.annotation.TableField; | ||||
| import io.swagger.annotations.ApiModelProperty; | ||||
| import lombok.Data; | ||||
| import lombok.EqualsAndHashCode; | ||||
| import lombok.NoArgsConstructor; | ||||
| import lombok.experimental.Accessors; | ||||
|  | ||||
| import java.util.ArrayList; | ||||
| @@ -12,12 +12,11 @@ import java.util.List; | ||||
| /** | ||||
|  * Tree基类 | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  * @author Lion Li | ||||
|  */ | ||||
|  | ||||
| @EqualsAndHashCode(callSuper = true) | ||||
| @Data | ||||
| @NoArgsConstructor | ||||
| @EqualsAndHashCode(callSuper = true) | ||||
| @Accessors(chain = true) | ||||
| public class TreeEntity extends BaseEntity { | ||||
|  | ||||
| @@ -26,6 +25,7 @@ public class TreeEntity extends BaseEntity { | ||||
| 	/** | ||||
| 	 * 父菜单名称 | ||||
| 	 */ | ||||
| 	@TableField(exist = false) | ||||
| 	@ApiModelProperty(value = "父菜单名称") | ||||
| 	private String parentName; | ||||
|  | ||||
| @@ -35,21 +35,10 @@ public class TreeEntity extends BaseEntity { | ||||
| 	@ApiModelProperty(value = "父菜单ID") | ||||
| 	private Long parentId; | ||||
|  | ||||
| 	/** | ||||
| 	 * 显示顺序 | ||||
| 	 */ | ||||
| 	@ApiModelProperty(value = "显示顺序") | ||||
| 	private Integer orderNum; | ||||
|  | ||||
| 	/** | ||||
| 	 * 祖级列表 | ||||
| 	 */ | ||||
| 	@ApiModelProperty(value = "祖级列表") | ||||
| 	private String ancestors; | ||||
|  | ||||
| 	/** | ||||
| 	 * 子部门 | ||||
| 	 */ | ||||
| 	@TableField(exist = false) | ||||
| 	@ApiModelProperty(value = "子部门") | ||||
| 	private List<?> children = new ArrayList<>(); | ||||
|  | ||||
|   | ||||
| @@ -1,50 +0,0 @@ | ||||
| package com.ruoyi.common.core.domain; | ||||
|  | ||||
| import com.fasterxml.jackson.annotation.JsonInclude; | ||||
| import com.ruoyi.common.core.domain.entity.SysDept; | ||||
| import com.ruoyi.common.core.domain.entity.SysMenu; | ||||
| import lombok.*; | ||||
| import lombok.experimental.Accessors; | ||||
|  | ||||
| import java.io.Serializable; | ||||
| import java.util.List; | ||||
| import java.util.stream.Collectors; | ||||
|  | ||||
| /** | ||||
|  * Treeselect树结构实体类 | ||||
|  *  | ||||
|  * @author ruoyi | ||||
|  */ | ||||
|  | ||||
| @Data | ||||
| @NoArgsConstructor | ||||
| @Accessors(chain = true) | ||||
| 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(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()); | ||||
|     } | ||||
|  | ||||
| } | ||||
| @@ -0,0 +1,108 @@ | ||||
| package com.ruoyi.common.core.domain.dto; | ||||
|  | ||||
| import lombok.Data; | ||||
| import lombok.NoArgsConstructor; | ||||
| import lombok.experimental.Accessors; | ||||
|  | ||||
| import java.io.Serializable; | ||||
| import java.util.Date; | ||||
|  | ||||
| /** | ||||
|  * 通用操作日志实体 | ||||
|  * | ||||
|  * @author Lion Li | ||||
|  */ | ||||
|  | ||||
| @Data | ||||
| @NoArgsConstructor | ||||
| @Accessors(chain = true) | ||||
| public class OperLogDTO implements Serializable { | ||||
|  | ||||
|     private static final long serialVersionUID = 1L; | ||||
|  | ||||
|     /** | ||||
|      * 日志主键 | ||||
|      */ | ||||
|     private Long operId; | ||||
|  | ||||
|     /** | ||||
|      * 操作模块 | ||||
|      */ | ||||
|     private String title; | ||||
|  | ||||
|     /** | ||||
|      * 业务类型(0其它 1新增 2修改 3删除) | ||||
|      */ | ||||
|     private Integer businessType; | ||||
|  | ||||
|     /** | ||||
|      * 业务类型数组 | ||||
|      */ | ||||
|     private Integer[] businessTypes; | ||||
|  | ||||
|     /** | ||||
|      * 请求方法 | ||||
|      */ | ||||
|     private String method; | ||||
|  | ||||
|     /** | ||||
|      * 请求方式 | ||||
|      */ | ||||
|     private String requestMethod; | ||||
|  | ||||
|     /** | ||||
|      * 操作类别(0其它 1后台用户 2手机端用户) | ||||
|      */ | ||||
|     private Integer operatorType; | ||||
|  | ||||
|     /** | ||||
|      * 操作人员 | ||||
|      */ | ||||
|     private String operName; | ||||
|  | ||||
|     /** | ||||
|      * 部门名称 | ||||
|      */ | ||||
|     private String deptName; | ||||
|  | ||||
|     /** | ||||
|      * 请求url | ||||
|      */ | ||||
|     private String operUrl; | ||||
|  | ||||
|     /** | ||||
|      * 操作地址 | ||||
|      */ | ||||
|     private String operIp; | ||||
|  | ||||
|     /** | ||||
|      * 操作地点 | ||||
|      */ | ||||
|     private String operLocation; | ||||
|  | ||||
|     /** | ||||
|      * 请求参数 | ||||
|      */ | ||||
|     private String operParam; | ||||
|  | ||||
|     /** | ||||
|      * 返回参数 | ||||
|      */ | ||||
|     private String jsonResult; | ||||
|  | ||||
|     /** | ||||
|      * 操作状态(0正常 1异常) | ||||
|      */ | ||||
|     private Integer status; | ||||
|  | ||||
|     /** | ||||
|      * 错误消息 | ||||
|      */ | ||||
|     private String errorMsg; | ||||
|  | ||||
|     /** | ||||
|      * 操作时间 | ||||
|      */ | ||||
|     private Date operTime; | ||||
|  | ||||
| } | ||||
| @@ -1,48 +1,44 @@ | ||||
| package com.ruoyi.common.core.domain.entity; | ||||
|  | ||||
| import com.baomidou.mybatisplus.annotation.*; | ||||
| import com.baomidou.mybatisplus.annotation.TableId; | ||||
| import com.baomidou.mybatisplus.annotation.TableLogic; | ||||
| import com.baomidou.mybatisplus.annotation.TableName; | ||||
| import com.ruoyi.common.core.domain.TreeEntity; | ||||
| import io.swagger.annotations.ApiModel; | ||||
| import io.swagger.annotations.ApiModelProperty; | ||||
| import lombok.Data; | ||||
| import lombok.NoArgsConstructor; | ||||
| import lombok.EqualsAndHashCode; | ||||
| import lombok.experimental.Accessors; | ||||
|  | ||||
| import javax.validation.constraints.Email; | ||||
| import javax.validation.constraints.NotBlank; | ||||
| import javax.validation.constraints.Size; | ||||
| import java.io.Serializable; | ||||
| import java.util.*; | ||||
|  | ||||
| /** | ||||
|  * 部门表 sys_dept | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  * @author Lion Li | ||||
|  */ | ||||
|  | ||||
| @Data | ||||
| @NoArgsConstructor | ||||
| @EqualsAndHashCode(callSuper = true) | ||||
| @Accessors(chain = true) | ||||
| @TableName("sys_dept") | ||||
| public class SysDept implements Serializable { | ||||
| @ApiModel("部门业务对象") | ||||
| public class SysDept extends TreeEntity { | ||||
| 	private static final long serialVersionUID = 1L; | ||||
|  | ||||
| 	/** | ||||
| 	 * 部门ID | ||||
| 	 */ | ||||
| 	@TableId(value = "dept_id", type = IdType.AUTO) | ||||
| 	@ApiModelProperty(value = "部门id") | ||||
| 	@TableId(value = "dept_id") | ||||
| 	private Long deptId; | ||||
|  | ||||
| 	/** | ||||
| 	 * 父部门ID | ||||
| 	 */ | ||||
| 	private Long parentId; | ||||
|  | ||||
| 	/** | ||||
| 	 * 祖级列表 | ||||
| 	 */ | ||||
| 	private String ancestors; | ||||
|  | ||||
| 	/** | ||||
| 	 * 部门名称 | ||||
| 	 */ | ||||
| 	@ApiModelProperty(value = "部门名称") | ||||
| 	@NotBlank(message = "部门名称不能为空") | ||||
| 	@Size(min = 0, max = 30, message = "部门名称长度不能超过30个字符") | ||||
| 	private String deptName; | ||||
| @@ -50,23 +46,27 @@ public class SysDept implements Serializable { | ||||
| 	/** | ||||
| 	 * 显示顺序 | ||||
| 	 */ | ||||
| 	@ApiModelProperty(value = "显示顺序") | ||||
| 	@NotBlank(message = "显示顺序不能为空") | ||||
| 	private String orderNum; | ||||
|  | ||||
| 	/** | ||||
| 	 * 负责人 | ||||
| 	 */ | ||||
| 	@ApiModelProperty(value = "负责人") | ||||
| 	private String leader; | ||||
|  | ||||
| 	/** | ||||
| 	 * 联系电话 | ||||
| 	 */ | ||||
| 	@ApiModelProperty(value = "联系电话") | ||||
| 	@Size(min = 0, max = 11, message = "联系电话长度不能超过11个字符") | ||||
| 	private String phone; | ||||
|  | ||||
| 	/** | ||||
| 	 * 邮箱 | ||||
| 	 */ | ||||
| 	@ApiModelProperty(value = "邮箱") | ||||
| 	@Email(message = "邮箱格式不正确") | ||||
| 	@Size(min = 0, max = 50, message = "邮箱长度不能超过50个字符") | ||||
| 	private String email; | ||||
| @@ -74,54 +74,20 @@ public class SysDept implements Serializable { | ||||
| 	/** | ||||
| 	 * 部门状态:0正常,1停用 | ||||
| 	 */ | ||||
| 	@ApiModelProperty(value = "部门状态:0正常,1停用") | ||||
| 	private String status; | ||||
|  | ||||
| 	/** | ||||
| 	 * 删除标志(0代表存在 2代表删除) | ||||
| 	 */ | ||||
| 	@ApiModelProperty(value = "删除标志(0代表存在 2代表删除)") | ||||
| 	@TableLogic | ||||
| 	private String delFlag; | ||||
|  | ||||
| 	/** | ||||
| 	 * 父部门名称 | ||||
| 	 * 祖级列表 | ||||
| 	 */ | ||||
| 	@TableField(exist = false) | ||||
| 	private String parentName; | ||||
|  | ||||
| 	/** | ||||
| 	 * 创建者 | ||||
| 	 */ | ||||
| 	@TableField(fill = FieldFill.INSERT) | ||||
| 	private String createBy; | ||||
|  | ||||
| 	/** | ||||
| 	 * 创建时间 | ||||
| 	 */ | ||||
| 	@TableField(fill = FieldFill.INSERT) | ||||
| 	private Date createTime; | ||||
|  | ||||
| 	/** | ||||
| 	 * 更新者 | ||||
| 	 */ | ||||
| 	@TableField(fill = FieldFill.INSERT_UPDATE) | ||||
| 	private String updateBy; | ||||
|  | ||||
| 	/** | ||||
| 	 * 更新时间 | ||||
| 	 */ | ||||
| 	@TableField(fill = FieldFill.INSERT_UPDATE) | ||||
| 	private Date updateTime; | ||||
|  | ||||
| 	/** | ||||
| 	 * 子部门 | ||||
| 	 */ | ||||
| 	@TableField(exist = false) | ||||
| 	private List<SysDept> children = new ArrayList<SysDept>(); | ||||
|  | ||||
| 	/** | ||||
| 	 * 请求参数 | ||||
| 	 */ | ||||
| 	@TableField(exist = false) | ||||
| 	private Map<String, Object> params = new HashMap<>(); | ||||
| 	@ApiModelProperty(value = "祖级列表") | ||||
| 	private String ancestors; | ||||
|  | ||||
| } | ||||
|   | ||||
| @@ -2,51 +2,54 @@ package com.ruoyi.common.core.domain.entity; | ||||
|  | ||||
| import com.alibaba.excel.annotation.ExcelIgnoreUnannotated; | ||||
| import com.alibaba.excel.annotation.ExcelProperty; | ||||
| import com.baomidou.mybatisplus.annotation.*; | ||||
| import com.baomidou.mybatisplus.annotation.TableId; | ||||
| import com.baomidou.mybatisplus.annotation.TableName; | ||||
| import com.ruoyi.common.annotation.ExcelDictFormat; | ||||
| import com.ruoyi.common.constant.UserConstants; | ||||
| import com.ruoyi.common.convert.ExcelDictConvert; | ||||
| import com.ruoyi.common.core.domain.BaseEntity; | ||||
| import io.swagger.annotations.ApiModel; | ||||
| import io.swagger.annotations.ApiModelProperty; | ||||
| import lombok.Data; | ||||
| import lombok.NoArgsConstructor; | ||||
| import lombok.EqualsAndHashCode; | ||||
| import lombok.experimental.Accessors; | ||||
|  | ||||
| import javax.validation.constraints.NotBlank; | ||||
| import javax.validation.constraints.Size; | ||||
| import java.io.Serializable; | ||||
| import java.util.Date; | ||||
| import java.util.HashMap; | ||||
| import java.util.Map; | ||||
|  | ||||
| /** | ||||
|  * 字典数据表 sys_dict_data | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  * @author Lion Li | ||||
|  */ | ||||
|  | ||||
| @Data | ||||
| @NoArgsConstructor | ||||
| @EqualsAndHashCode(callSuper = true) | ||||
| @Accessors(chain = true) | ||||
| @TableName("sys_dict_data") | ||||
| @ExcelIgnoreUnannotated | ||||
| public class SysDictData implements Serializable { | ||||
| 	private static final long serialVersionUID = 1L; | ||||
| @ApiModel("字典数据业务对象") | ||||
| public class SysDictData extends BaseEntity { | ||||
|  | ||||
| 	/** | ||||
| 	 * 字典编码 | ||||
| 	 */ | ||||
| 	@ApiModelProperty(value = "字典编码") | ||||
| 	@ExcelProperty(value = "字典编码") | ||||
| 	@TableId(value = "dict_code", type = IdType.AUTO) | ||||
| 	@TableId(value = "dict_code") | ||||
| 	private Long dictCode; | ||||
|  | ||||
| 	/** | ||||
| 	 * 字典排序 | ||||
| 	 */ | ||||
| 	@ApiModelProperty(value = "字典排序") | ||||
| 	@ExcelProperty(value = "字典排序") | ||||
| 	private Long dictSort; | ||||
|  | ||||
| 	/** | ||||
| 	 * 字典标签 | ||||
| 	 */ | ||||
| 	@ApiModelProperty(value = "字典标签") | ||||
| 	@ExcelProperty(value = "字典标签") | ||||
| 	@NotBlank(message = "字典标签不能为空") | ||||
| 	@Size(min = 0, max = 100, message = "字典标签长度不能超过100个字符") | ||||
| @@ -55,6 +58,7 @@ public class SysDictData implements Serializable { | ||||
| 	/** | ||||
| 	 * 字典键值 | ||||
| 	 */ | ||||
| 	@ApiModelProperty(value = "字典键值") | ||||
| 	@ExcelProperty(value = "字典键值") | ||||
| 	@NotBlank(message = "字典键值不能为空") | ||||
| 	@Size(min = 0, max = 100, message = "字典键值长度不能超过100个字符") | ||||
| @@ -63,6 +67,7 @@ public class SysDictData implements Serializable { | ||||
| 	/** | ||||
| 	 * 字典类型 | ||||
| 	 */ | ||||
| 	@ApiModelProperty(value = "字典类型") | ||||
| 	@ExcelProperty(value = "字典类型") | ||||
| 	@NotBlank(message = "字典类型不能为空") | ||||
| 	@Size(min = 0, max = 100, message = "字典类型长度不能超过100个字符") | ||||
| @@ -71,17 +76,20 @@ public class SysDictData implements Serializable { | ||||
| 	/** | ||||
| 	 * 样式属性(其他样式扩展) | ||||
| 	 */ | ||||
| 	@ApiModelProperty(value = "样式属性(其他样式扩展)") | ||||
| 	@Size(min = 0, max = 100, message = "样式属性长度不能超过100个字符") | ||||
| 	private String cssClass; | ||||
|  | ||||
| 	/** | ||||
| 	 * 表格字典样式 | ||||
| 	 */ | ||||
| 	@ApiModelProperty(value = "表格字典样式") | ||||
| 	private String listClass; | ||||
|  | ||||
| 	/** | ||||
| 	 * 是否默认(Y是 N否) | ||||
| 	 */ | ||||
| 	@ApiModelProperty(value = "是否默认(Y是 N否)") | ||||
| 	@ExcelProperty(value = "是否默认", converter = ExcelDictConvert.class) | ||||
| 	@ExcelDictFormat(dictType = "sys_yes_no") | ||||
| 	private String isDefault; | ||||
| @@ -89,47 +97,19 @@ public class SysDictData implements Serializable { | ||||
| 	/** | ||||
| 	 * 状态(0正常 1停用) | ||||
| 	 */ | ||||
| 	@ApiModelProperty(value = "状态(0正常 1停用)") | ||||
| 	@ExcelProperty(value = "状态", converter = ExcelDictConvert.class) | ||||
| 	@ExcelDictFormat(dictType = "sys_common_status") | ||||
| 	@ExcelDictFormat(dictType = "sys_normal_disable") | ||||
| 	private String status; | ||||
|  | ||||
| 	/** | ||||
| 	 * 创建者 | ||||
| 	 */ | ||||
| 	@TableField(fill = FieldFill.INSERT) | ||||
| 	private String createBy; | ||||
|  | ||||
| 	/** | ||||
| 	 * 创建时间 | ||||
| 	 */ | ||||
| 	@TableField(fill = FieldFill.INSERT) | ||||
| 	private Date createTime; | ||||
|  | ||||
| 	/** | ||||
| 	 * 更新者 | ||||
| 	 */ | ||||
| 	@TableField(fill = FieldFill.INSERT_UPDATE) | ||||
| 	private String updateBy; | ||||
|  | ||||
| 	/** | ||||
| 	 * 更新时间 | ||||
| 	 */ | ||||
| 	@TableField(fill = FieldFill.INSERT_UPDATE) | ||||
| 	private Date updateTime; | ||||
|  | ||||
| 	/** | ||||
| 	 * 备注 | ||||
| 	 */ | ||||
| 	@ApiModelProperty(value = "备注") | ||||
| 	private String remark; | ||||
|  | ||||
| 	/** | ||||
| 	 * 请求参数 | ||||
| 	 */ | ||||
| 	@TableField(exist = false) | ||||
| 	private Map<String, Object> params = new HashMap<>(); | ||||
|  | ||||
| 	public boolean getDefault() { | ||||
| 		return UserConstants.YES.equals(this.isDefault) ? true : false; | ||||
| 		return UserConstants.YES.equals(this.isDefault); | ||||
| 	} | ||||
|  | ||||
| } | ||||
|   | ||||
| @@ -2,44 +2,46 @@ package com.ruoyi.common.core.domain.entity; | ||||
|  | ||||
| import com.alibaba.excel.annotation.ExcelIgnoreUnannotated; | ||||
| import com.alibaba.excel.annotation.ExcelProperty; | ||||
| import com.baomidou.mybatisplus.annotation.*; | ||||
| import com.baomidou.mybatisplus.annotation.TableId; | ||||
| import com.baomidou.mybatisplus.annotation.TableName; | ||||
| import com.ruoyi.common.annotation.ExcelDictFormat; | ||||
| import com.ruoyi.common.convert.ExcelDictConvert; | ||||
| import com.ruoyi.common.core.domain.BaseEntity; | ||||
| import io.swagger.annotations.ApiModel; | ||||
| import io.swagger.annotations.ApiModelProperty; | ||||
| import lombok.Data; | ||||
| import lombok.NoArgsConstructor; | ||||
| import lombok.EqualsAndHashCode; | ||||
| import lombok.experimental.Accessors; | ||||
|  | ||||
| import javax.validation.constraints.NotBlank; | ||||
| import javax.validation.constraints.Size; | ||||
| import java.io.Serializable; | ||||
| import java.util.Date; | ||||
| import java.util.HashMap; | ||||
| import java.util.Map; | ||||
|  | ||||
| /** | ||||
|  * 字典类型表 sys_dict_type | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  * @author Lion Li | ||||
|  */ | ||||
|  | ||||
| @Data | ||||
| @NoArgsConstructor | ||||
| @EqualsAndHashCode(callSuper = true) | ||||
| @Accessors(chain = true) | ||||
| @TableName("sys_dict_type") | ||||
| @ExcelIgnoreUnannotated | ||||
| public class SysDictType implements Serializable { | ||||
| 	private static final long serialVersionUID = 1L; | ||||
| @ApiModel("字典类型业务对象") | ||||
| public class SysDictType extends BaseEntity { | ||||
|  | ||||
| 	/** | ||||
| 	 * 字典主键 | ||||
| 	 */ | ||||
| 	@ApiModelProperty(value = "字典主键") | ||||
| 	@ExcelProperty(value = "字典主键") | ||||
| 	@TableId(value = "dict_id", type = IdType.AUTO) | ||||
| 	@TableId(value = "dict_id") | ||||
| 	private Long dictId; | ||||
|  | ||||
| 	/** | ||||
| 	 * 字典名称 | ||||
| 	 */ | ||||
| 	@ApiModelProperty(value = "字典名称") | ||||
| 	@ExcelProperty(value = "字典名称") | ||||
| 	@NotBlank(message = "字典名称不能为空") | ||||
| 	@Size(min = 0, max = 100, message = "字典类型名称长度不能超过100个字符") | ||||
| @@ -48,6 +50,7 @@ public class SysDictType implements Serializable { | ||||
| 	/** | ||||
| 	 * 字典类型 | ||||
| 	 */ | ||||
| 	@ApiModelProperty(value = "字典类型") | ||||
| 	@ExcelProperty(value = "字典类型") | ||||
| 	@NotBlank(message = "字典类型不能为空") | ||||
| 	@Size(min = 0, max = 100, message = "字典类型类型长度不能超过100个字符") | ||||
| @@ -56,43 +59,15 @@ public class SysDictType implements Serializable { | ||||
| 	/** | ||||
| 	 * 状态(0正常 1停用) | ||||
| 	 */ | ||||
| 	@ApiModelProperty(value = "状态(0正常 1停用)") | ||||
| 	@ExcelProperty(value = "状态", converter = ExcelDictConvert.class) | ||||
| 	@ExcelDictFormat(dictType = "sys_common_status") | ||||
| 	@ExcelDictFormat(dictType = "sys_normal_disable") | ||||
| 	private String status; | ||||
|  | ||||
| 	/** | ||||
| 	 * 创建者 | ||||
| 	 */ | ||||
| 	@TableField(fill = FieldFill.INSERT) | ||||
| 	private String createBy; | ||||
|  | ||||
| 	/** | ||||
| 	 * 创建时间 | ||||
| 	 */ | ||||
| 	@TableField(fill = FieldFill.INSERT) | ||||
| 	private Date createTime; | ||||
|  | ||||
| 	/** | ||||
| 	 * 更新者 | ||||
| 	 */ | ||||
| 	@TableField(fill = FieldFill.INSERT_UPDATE) | ||||
| 	private String updateBy; | ||||
|  | ||||
| 	/** | ||||
| 	 * 更新时间 | ||||
| 	 */ | ||||
| 	@TableField(fill = FieldFill.INSERT_UPDATE) | ||||
| 	private Date updateTime; | ||||
|  | ||||
| 	/** | ||||
| 	 * 备注 | ||||
| 	 */ | ||||
| 	@ApiModelProperty(value = "备注") | ||||
| 	private String remark; | ||||
|  | ||||
| 	/** | ||||
| 	 * 请求参数 | ||||
| 	 */ | ||||
| 	@TableField(exist = false) | ||||
| 	private Map<String, Object> params = new HashMap<>(); | ||||
|  | ||||
| } | ||||
|   | ||||
| @@ -1,149 +1,122 @@ | ||||
| package com.ruoyi.common.core.domain.entity; | ||||
|  | ||||
| import com.baomidou.mybatisplus.annotation.*; | ||||
| import com.fasterxml.jackson.annotation.JsonFormat; | ||||
| import com.baomidou.mybatisplus.annotation.TableField; | ||||
| import com.baomidou.mybatisplus.annotation.TableId; | ||||
| import com.baomidou.mybatisplus.annotation.TableName; | ||||
| import com.ruoyi.common.core.domain.TreeEntity; | ||||
| import io.swagger.annotations.ApiModel; | ||||
| import io.swagger.annotations.ApiModelProperty; | ||||
| import lombok.Data; | ||||
| import lombok.NoArgsConstructor; | ||||
| import lombok.EqualsAndHashCode; | ||||
| import lombok.experimental.Accessors; | ||||
|  | ||||
| import javax.validation.constraints.NotBlank; | ||||
| import javax.validation.constraints.Size; | ||||
| import java.io.Serializable; | ||||
| import java.util.*; | ||||
|  | ||||
| /** | ||||
|  * 菜单权限表 sys_menu | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  * @author Lion Li | ||||
|  */ | ||||
|  | ||||
| @Data | ||||
| @NoArgsConstructor | ||||
| @EqualsAndHashCode(callSuper = true) | ||||
| @Accessors(chain = true) | ||||
| @TableName("sys_menu") | ||||
| public class SysMenu implements Serializable { | ||||
| 	private static final long serialVersionUID = 1L; | ||||
| @ApiModel("菜单权限业务对象") | ||||
| public class SysMenu extends TreeEntity { | ||||
|  | ||||
| 	/** | ||||
| 	 * 菜单ID | ||||
| 	 */ | ||||
| 	@TableId(value = "menu_id", type = IdType.AUTO) | ||||
| 	@ApiModelProperty(value = "菜单ID") | ||||
| 	@TableId(value = "menu_id") | ||||
| 	private Long menuId; | ||||
|  | ||||
| 	/** | ||||
| 	 * 菜单名称 | ||||
| 	 */ | ||||
| 	@ApiModelProperty(value = "菜单名称") | ||||
| 	@NotBlank(message = "菜单名称不能为空") | ||||
| 	@Size(min = 0, max = 50, message = "菜单名称长度不能超过50个字符") | ||||
| 	private String menuName; | ||||
|  | ||||
| 	/** | ||||
| 	 * 父菜单名称 | ||||
| 	 */ | ||||
| 	@TableField(exist = false) | ||||
| 	private String parentName; | ||||
|  | ||||
| 	/** | ||||
| 	 * 父菜单ID | ||||
| 	 */ | ||||
| 	private Long parentId; | ||||
|  | ||||
| 	/** | ||||
| 	 * 显示顺序 | ||||
| 	 */ | ||||
| 	@ApiModelProperty(value = "显示顺序") | ||||
| 	@NotBlank(message = "显示顺序不能为空") | ||||
| 	private String orderNum; | ||||
|  | ||||
| 	/** | ||||
| 	 * 路由地址 | ||||
| 	 */ | ||||
| 	@ApiModelProperty(value = "路由地址") | ||||
| 	@Size(min = 0, max = 200, message = "路由地址不能超过200个字符") | ||||
| 	private String path; | ||||
|  | ||||
| 	/** | ||||
| 	 * 组件路径 | ||||
| 	 */ | ||||
| 	@ApiModelProperty(value = "组件路径") | ||||
| 	@Size(min = 0, max = 200, message = "组件路径不能超过255个字符") | ||||
| 	private String component; | ||||
|  | ||||
|     /** | ||||
|      * 路由参数 | ||||
|      */ | ||||
| 	@ApiModelProperty(value = "路由参数") | ||||
|     @TableField("`query`") | ||||
|     private String query; | ||||
|  | ||||
| 	/** | ||||
| 	 * 是否为外链(0是 1否) | ||||
| 	 */ | ||||
| 	@ApiModelProperty(value = "是否为外链(0是 1否)") | ||||
| 	private String isFrame; | ||||
|  | ||||
| 	/** | ||||
| 	 * 是否缓存(0缓存 1不缓存) | ||||
| 	 */ | ||||
| 	@ApiModelProperty(value = "是否缓存(0缓存 1不缓存)") | ||||
| 	private String isCache; | ||||
|  | ||||
| 	/** | ||||
| 	 * 类型(M目录 C菜单 F按钮) | ||||
| 	 */ | ||||
| 	@ApiModelProperty(value = "类型(M目录 C菜单 F按钮)") | ||||
| 	@NotBlank(message = "菜单类型不能为空") | ||||
| 	private String menuType; | ||||
|  | ||||
| 	/** | ||||
| 	 * 显示状态(0显示 1隐藏) | ||||
| 	 */ | ||||
| 	@ApiModelProperty(value = "显示状态(0显示 1隐藏)") | ||||
| 	private String visible; | ||||
|  | ||||
| 	/** | ||||
| 	 * 菜单状态(0显示 1隐藏) | ||||
| 	 */ | ||||
| 	@ApiModelProperty(value = "菜单状态(0显示 1隐藏)") | ||||
| 	private String status; | ||||
|  | ||||
| 	/** | ||||
| 	 * 权限字符串 | ||||
| 	 */ | ||||
| 	@ApiModelProperty(value = "权限字符串") | ||||
| 	@Size(min = 0, max = 100, message = "权限标识长度不能超过100个字符") | ||||
| 	private String perms; | ||||
|  | ||||
| 	/** | ||||
| 	 * 菜单图标 | ||||
| 	 */ | ||||
| 	@ApiModelProperty(value = "菜单图标") | ||||
| 	private String icon; | ||||
|  | ||||
| 	/** | ||||
| 	 * 创建者 | ||||
| 	 */ | ||||
| 	@TableField(fill = FieldFill.INSERT) | ||||
| 	private String createBy; | ||||
|  | ||||
| 	/** | ||||
| 	 * 创建时间 | ||||
| 	 */ | ||||
| 	@TableField(fill = FieldFill.INSERT) | ||||
| 	@JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss") | ||||
| 	private Date createTime; | ||||
|  | ||||
| 	/** | ||||
| 	 * 更新者 | ||||
| 	 */ | ||||
| 	@TableField(fill = FieldFill.INSERT_UPDATE) | ||||
| 	private String updateBy; | ||||
|  | ||||
| 	/** | ||||
| 	 * 更新时间 | ||||
| 	 */ | ||||
| 	@TableField(fill = FieldFill.INSERT_UPDATE) | ||||
| 	@JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss") | ||||
| 	private Date updateTime; | ||||
|  | ||||
| 	/** | ||||
| 	 * 备注 | ||||
| 	 */ | ||||
| 	@ApiModelProperty(value = "备注") | ||||
| 	private String remark; | ||||
|  | ||||
| 	/** | ||||
| 	 * 请求参数 | ||||
| 	 */ | ||||
| 	@TableField(exist = false) | ||||
| 	private Map<String, Object> params = new HashMap<>(); | ||||
|  | ||||
| 	/** | ||||
| 	 * 子菜单 | ||||
| 	 */ | ||||
| 	@TableField(exist = false) | ||||
| 	private List<SysMenu> children = new ArrayList<SysMenu>(); | ||||
|  | ||||
| } | ||||
|   | ||||
| @@ -2,44 +2,48 @@ package com.ruoyi.common.core.domain.entity; | ||||
|  | ||||
| import com.alibaba.excel.annotation.ExcelIgnoreUnannotated; | ||||
| import com.alibaba.excel.annotation.ExcelProperty; | ||||
| import com.baomidou.mybatisplus.annotation.*; | ||||
| import com.baomidou.mybatisplus.annotation.TableField; | ||||
| import com.baomidou.mybatisplus.annotation.TableId; | ||||
| import com.baomidou.mybatisplus.annotation.TableLogic; | ||||
| import com.baomidou.mybatisplus.annotation.TableName; | ||||
| import com.ruoyi.common.annotation.ExcelDictFormat; | ||||
| import com.ruoyi.common.convert.ExcelDictConvert; | ||||
| import com.ruoyi.common.core.domain.BaseEntity; | ||||
| import io.swagger.annotations.ApiModelProperty; | ||||
| import lombok.Data; | ||||
| import lombok.EqualsAndHashCode; | ||||
| import lombok.NoArgsConstructor; | ||||
| import lombok.experimental.Accessors; | ||||
|  | ||||
| import javax.validation.constraints.NotBlank; | ||||
| import javax.validation.constraints.Size; | ||||
| import java.io.Serializable; | ||||
| import java.util.Date; | ||||
| import java.util.HashMap; | ||||
| import java.util.Map; | ||||
|  | ||||
| /** | ||||
|  * 角色表 sys_role | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  * @author Lion Li | ||||
|  */ | ||||
|  | ||||
| @Data | ||||
| @NoArgsConstructor | ||||
| @EqualsAndHashCode(callSuper = true) | ||||
| @Accessors(chain = true) | ||||
| @TableName("sys_role") | ||||
| @ExcelIgnoreUnannotated | ||||
| public class SysRole implements Serializable { | ||||
| 	private static final long serialVersionUID = 1L; | ||||
| public class SysRole extends BaseEntity { | ||||
|  | ||||
| 	/** | ||||
| 	 * 角色ID | ||||
| 	 */ | ||||
| 	@ApiModelProperty(value = "角色ID") | ||||
| 	@ExcelProperty(value = "角色序号") | ||||
| 	@TableId(value = "role_id", type = IdType.AUTO) | ||||
| 	@TableId(value = "role_id") | ||||
| 	private Long roleId; | ||||
|  | ||||
| 	/** | ||||
| 	 * 角色名称 | ||||
| 	 */ | ||||
| 	@ApiModelProperty(value = "角色名称") | ||||
| 	@ExcelProperty(value = "角色名称") | ||||
| 	@NotBlank(message = "角色名称不能为空") | ||||
| 	@Size(min = 0, max = 30, message = "角色名称长度不能超过30个字符") | ||||
| @@ -48,6 +52,7 @@ public class SysRole implements Serializable { | ||||
| 	/** | ||||
| 	 * 角色权限 | ||||
| 	 */ | ||||
| 	@ApiModelProperty(value = "角色权限") | ||||
| 	@ExcelProperty(value = "角色权限") | ||||
| 	@NotBlank(message = "权限字符不能为空") | ||||
| 	@Size(min = 0, max = 100, message = "权限字符长度不能超过100个字符") | ||||
| @@ -56,6 +61,7 @@ public class SysRole implements Serializable { | ||||
| 	/** | ||||
| 	 * 角色排序 | ||||
| 	 */ | ||||
| 	@ApiModelProperty(value = "角色排序") | ||||
| 	@ExcelProperty(value = "角色排序") | ||||
| 	@NotBlank(message = "显示顺序不能为空") | ||||
| 	private String roleSort; | ||||
| @@ -63,6 +69,7 @@ public class SysRole implements Serializable { | ||||
| 	/** | ||||
| 	 * 数据范围(1:所有数据权限;2:自定义数据权限;3:本部门数据权限;4:本部门及以下数据权限;5:仅本人数据权限) | ||||
| 	 */ | ||||
| 	@ApiModelProperty(value = "数据范围(1:所有数据权限;2:自定义数据权限;3:本部门数据权限;4:本部门及以下数据权限;5:仅本人数据权限)") | ||||
| 	@ExcelProperty(value = "数据范围", converter = ExcelDictConvert.class) | ||||
| 	@ExcelDictFormat(readConverterExp = "1=所有数据权限,2=自定义数据权限,3=本部门数据权限,4=本部门及以下数据权限,5=仅本人数据权限") | ||||
| 	private String dataScope; | ||||
| @@ -70,16 +77,19 @@ public class SysRole implements Serializable { | ||||
| 	/** | ||||
| 	 * 菜单树选择项是否关联显示( 0:父子不互相关联显示 1:父子互相关联显示) | ||||
| 	 */ | ||||
| 	@ApiModelProperty(value = "菜单树选择项是否关联显示( 0:父子不互相关联显示 1:父子互相关联显示)") | ||||
| 	private boolean menuCheckStrictly; | ||||
|  | ||||
| 	/** | ||||
| 	 * 部门树选择项是否关联显示(0:父子不互相关联显示 1:父子互相关联显示 ) | ||||
| 	 */ | ||||
| 	@ApiModelProperty(value = "部门树选择项是否关联显示(0:父子不互相关联显示 1:父子互相关联显示 )") | ||||
| 	private boolean deptCheckStrictly; | ||||
|  | ||||
| 	/** | ||||
| 	 * 角色状态(0正常 1停用) | ||||
| 	 */ | ||||
| 	@ApiModelProperty(value = "角色状态(0正常 1停用)") | ||||
| 	@ExcelProperty(value = "角色状态", converter = ExcelDictConvert.class) | ||||
| 	@ExcelDictFormat(dictType = "sys_common_status") | ||||
| 	private String status; | ||||
| @@ -87,59 +97,34 @@ public class SysRole implements Serializable { | ||||
| 	/** | ||||
| 	 * 删除标志(0代表存在 2代表删除) | ||||
| 	 */ | ||||
| 	@ApiModelProperty(value = "删除标志(0代表存在 2代表删除)") | ||||
| 	@TableLogic | ||||
| 	private String delFlag; | ||||
|  | ||||
| 	/** | ||||
| 	 * 创建者 | ||||
| 	 */ | ||||
| 	@TableField(fill = FieldFill.INSERT) | ||||
| 	private String createBy; | ||||
|  | ||||
| 	/** | ||||
| 	 * 创建时间 | ||||
| 	 */ | ||||
| 	@TableField(fill = FieldFill.INSERT) | ||||
| 	private Date createTime; | ||||
|  | ||||
| 	/** | ||||
| 	 * 更新者 | ||||
| 	 */ | ||||
| 	@TableField(fill = FieldFill.INSERT_UPDATE) | ||||
| 	private String updateBy; | ||||
|  | ||||
| 	/** | ||||
| 	 * 更新时间 | ||||
| 	 */ | ||||
| 	@TableField(fill = FieldFill.INSERT_UPDATE) | ||||
| 	private Date updateTime; | ||||
|  | ||||
| 	/** | ||||
| 	 * 备注 | ||||
| 	 */ | ||||
| 	@ApiModelProperty(value = "备注") | ||||
| 	private String remark; | ||||
|  | ||||
| 	/** | ||||
| 	 * 请求参数 | ||||
| 	 */ | ||||
| 	@TableField(exist = false) | ||||
| 	private Map<String, Object> params = new HashMap<>(); | ||||
|  | ||||
| 	/** | ||||
| 	 * 用户是否存在此角色标识 默认不存在 | ||||
| 	 */ | ||||
| 	@ApiModelProperty(value = "用户是否存在此角色标识 默认不存在") | ||||
| 	@TableField(exist = false) | ||||
| 	private boolean flag = false; | ||||
|  | ||||
| 	/** | ||||
| 	 * 菜单组 | ||||
| 	 */ | ||||
| 	@ApiModelProperty(value = "菜单组") | ||||
| 	@TableField(exist = false) | ||||
| 	private Long[] menuIds; | ||||
|  | ||||
| 	/** | ||||
| 	 * 部门组(数据权限) | ||||
| 	 */ | ||||
| 	@ApiModelProperty(value = "部门组(数据权限)") | ||||
| 	@TableField(exist = false) | ||||
| 	private Long[] deptIds; | ||||
|  | ||||
| @@ -147,6 +132,7 @@ public class SysRole implements Serializable { | ||||
| 		this.roleId = roleId; | ||||
| 	} | ||||
|  | ||||
| 	@ApiModelProperty(value = "是否管理员") | ||||
| 	public boolean isAdmin() { | ||||
| 		return isAdmin(this.roleId); | ||||
| 	} | ||||
|   | ||||
| @@ -3,59 +3,69 @@ package com.ruoyi.common.core.domain.entity; | ||||
| import com.baomidou.mybatisplus.annotation.*; | ||||
| import com.fasterxml.jackson.annotation.JsonIgnore; | ||||
| import com.fasterxml.jackson.annotation.JsonProperty; | ||||
| import com.ruoyi.common.core.domain.BaseEntity; | ||||
| import com.ruoyi.common.xss.Xss; | ||||
| import io.swagger.annotations.ApiModel; | ||||
| import io.swagger.annotations.ApiModelProperty; | ||||
| import lombok.Data; | ||||
| import lombok.EqualsAndHashCode; | ||||
| import lombok.NoArgsConstructor; | ||||
| import lombok.experimental.Accessors; | ||||
|  | ||||
| import javax.validation.constraints.Email; | ||||
| import javax.validation.constraints.NotBlank; | ||||
| import javax.validation.constraints.Size; | ||||
| import java.io.Serializable; | ||||
| import java.util.Date; | ||||
| import java.util.HashMap; | ||||
| import java.util.List; | ||||
| import java.util.Map; | ||||
|  | ||||
| /** | ||||
|  * 用户对象 sys_user | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  * @author Lion Li | ||||
|  */ | ||||
|  | ||||
| @Data | ||||
| @NoArgsConstructor | ||||
| @EqualsAndHashCode(callSuper = true) | ||||
| @Accessors(chain = true) | ||||
| @TableName("sys_user") | ||||
| public class SysUser implements Serializable { | ||||
| 	private static final long serialVersionUID = 1L; | ||||
| @ApiModel("用户信息业务对象") | ||||
| public class SysUser extends BaseEntity { | ||||
|  | ||||
| 	/** | ||||
| 	 * 用户ID | ||||
| 	 */ | ||||
| 	@TableId(value = "user_id", type = IdType.AUTO) | ||||
| 	@ApiModelProperty(value = "用户ID") | ||||
| 	@TableId(value = "user_id") | ||||
| 	private Long userId; | ||||
|  | ||||
| 	/** | ||||
| 	 * 部门ID | ||||
| 	 */ | ||||
| 	@ApiModelProperty(value = "部门ID") | ||||
| 	private Long deptId; | ||||
|  | ||||
| 	/** | ||||
| 	 * 用户账号 | ||||
| 	 */ | ||||
| 	@NotBlank(message = "用户账号不能为空") | ||||
| 	@ApiModelProperty(value = "用户账号") | ||||
|     @Xss(message = "用户账号不能包含脚本字符") | ||||
|     @NotBlank(message = "用户账号不能为空") | ||||
| 	@Size(min = 0, max = 30, message = "用户账号长度不能超过30个字符") | ||||
| 	private String userName; | ||||
|  | ||||
| 	/** | ||||
| 	 * 用户昵称 | ||||
| 	 */ | ||||
| 	@Size(min = 0, max = 30, message = "用户昵称长度不能超过30个字符") | ||||
|     @ApiModelProperty(value = "用户昵称") | ||||
|     @Xss(message = "用户昵称不能包含脚本字符") | ||||
|     @Size(min = 0, max = 30, message = "用户昵称长度不能超过30个字符") | ||||
| 	private String nickName; | ||||
|  | ||||
| 	/** | ||||
| 	 * 用户邮箱 | ||||
| 	 */ | ||||
| 	@ApiModelProperty(value = "用户邮箱") | ||||
| 	@Email(message = "邮箱格式不正确") | ||||
| 	@Size(min = 0, max = 50, message = "邮箱长度不能超过50个字符") | ||||
| 	private String email; | ||||
| @@ -63,21 +73,25 @@ public class SysUser implements Serializable { | ||||
| 	/** | ||||
| 	 * 手机号码 | ||||
| 	 */ | ||||
| 	@ApiModelProperty(value = "手机号码") | ||||
| 	private String phonenumber; | ||||
|  | ||||
| 	/** | ||||
| 	 * 用户性别 | ||||
| 	 */ | ||||
| 	@ApiModelProperty(value = "用户性别") | ||||
| 	private String sex; | ||||
|  | ||||
| 	/** | ||||
| 	 * 用户头像 | ||||
| 	 */ | ||||
| 	@ApiModelProperty(value = "用户头像") | ||||
| 	private String avatar; | ||||
|  | ||||
| 	/** | ||||
| 	 * 密码 | ||||
| 	 */ | ||||
| 	@ApiModelProperty(value = "密码") | ||||
| 	@TableField( | ||||
| 			insertStrategy = FieldStrategy.NOT_EMPTY, | ||||
| 			updateStrategy = FieldStrategy.NOT_EMPTY, | ||||
| @@ -91,94 +105,69 @@ public class SysUser implements Serializable { | ||||
| 		return password; | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * 盐加密 | ||||
| 	 */ | ||||
| 	private String salt; | ||||
|  | ||||
| 	/** | ||||
| 	 * 帐号状态(0正常 1停用) | ||||
| 	 */ | ||||
| 	@ApiModelProperty(value = "帐号状态(0正常 1停用)") | ||||
| 	private String status; | ||||
|  | ||||
| 	/** | ||||
| 	 * 删除标志(0代表存在 2代表删除) | ||||
| 	 */ | ||||
| 	@ApiModelProperty(value = "删除标志(0代表存在 2代表删除)") | ||||
| 	@TableLogic | ||||
| 	private String delFlag; | ||||
|  | ||||
| 	/** | ||||
| 	 * 最后登录IP | ||||
| 	 */ | ||||
| 	@ApiModelProperty(value = "最后登录IP") | ||||
| 	private String loginIp; | ||||
|  | ||||
| 	/** | ||||
| 	 * 最后登录时间 | ||||
| 	 */ | ||||
| 	@ApiModelProperty(value = "最后登录时间") | ||||
| 	private Date loginDate; | ||||
|  | ||||
| 	/** | ||||
| 	 * 创建者 | ||||
| 	 */ | ||||
| 	@TableField(fill = FieldFill.INSERT) | ||||
| 	private String createBy; | ||||
|  | ||||
| 	/** | ||||
| 	 * 创建时间 | ||||
| 	 */ | ||||
| 	@TableField(fill = FieldFill.INSERT) | ||||
| 	private Date createTime; | ||||
|  | ||||
| 	/** | ||||
| 	 * 更新者 | ||||
| 	 */ | ||||
| 	@TableField(fill = FieldFill.INSERT_UPDATE) | ||||
| 	private String updateBy; | ||||
|  | ||||
| 	/** | ||||
| 	 * 更新时间 | ||||
| 	 */ | ||||
| 	@TableField(fill = FieldFill.INSERT_UPDATE) | ||||
| 	private Date updateTime; | ||||
|  | ||||
| 	/** | ||||
| 	 * 备注 | ||||
| 	 */ | ||||
| 	@ApiModelProperty(value = "备注") | ||||
| 	private String remark; | ||||
|  | ||||
| 	/** | ||||
| 	 * 请求参数 | ||||
| 	 */ | ||||
| 	@TableField(exist = false) | ||||
| 	private Map<String, Object> params = new HashMap<>(); | ||||
|  | ||||
| 	/** | ||||
| 	 * 部门对象 | ||||
| 	 */ | ||||
| 	@ApiModelProperty(value = "部门对象") | ||||
| 	@TableField(exist = false) | ||||
| 	private SysDept dept; | ||||
|  | ||||
| 	/** | ||||
| 	 * 角色对象 | ||||
| 	 */ | ||||
| 	@ApiModelProperty(value = "角色对象") | ||||
| 	@TableField(exist = false) | ||||
| 	private List<SysRole> roles; | ||||
|  | ||||
| 	/** | ||||
| 	 * 角色组 | ||||
| 	 */ | ||||
| 	@ApiModelProperty(value = "角色组") | ||||
| 	@TableField(exist = false) | ||||
| 	private Long[] roleIds; | ||||
|  | ||||
| 	/** | ||||
| 	 * 岗位组 | ||||
| 	 */ | ||||
| 	@ApiModelProperty(value = "岗位组") | ||||
| 	@TableField(exist = false) | ||||
| 	private Long[] postIds; | ||||
|  | ||||
| 	/** | ||||
| 	 * 角色ID | ||||
| 	 * 数据权限 当前角色ID | ||||
| 	 */ | ||||
| 	@ApiModelProperty(value = "角色ID") | ||||
| 	@TableField(exist = false) | ||||
| 	private Long roleId; | ||||
|  | ||||
| @@ -186,6 +175,7 @@ public class SysUser implements Serializable { | ||||
| 		this.userId = userId; | ||||
| 	} | ||||
|  | ||||
| 	@ApiModelProperty(value = "是否管理员") | ||||
| 	public boolean isAdmin() { | ||||
| 		return isAdmin(this.userId); | ||||
| 	} | ||||
|   | ||||
| @@ -1,37 +1,43 @@ | ||||
| package com.ruoyi.common.core.domain.model; | ||||
|  | ||||
| import lombok.*; | ||||
| import io.swagger.annotations.ApiModel; | ||||
| import io.swagger.annotations.ApiModelProperty; | ||||
| import lombok.Data; | ||||
| import lombok.experimental.Accessors; | ||||
|  | ||||
| /** | ||||
|  * 用户登录对象 | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  * @author Lion Li | ||||
|  */ | ||||
|  | ||||
| @Data | ||||
| @NoArgsConstructor | ||||
| @Accessors(chain = true) | ||||
| public class LoginBody | ||||
| { | ||||
| @ApiModel("用户登录对象") | ||||
| public class LoginBody { | ||||
|  | ||||
|     /** | ||||
|      * 用户名 | ||||
|      */ | ||||
|     @ApiModelProperty(value = "用户名") | ||||
|     private String username; | ||||
|  | ||||
|     /** | ||||
|      * 用户密码 | ||||
|      */ | ||||
|     @ApiModelProperty(value = "用户密码") | ||||
|     private String password; | ||||
|  | ||||
|     /** | ||||
|      * 验证码 | ||||
|      */ | ||||
|     @ApiModelProperty(value = "验证码") | ||||
|     private String code; | ||||
|  | ||||
|     /** | ||||
|      * 唯一标识 | ||||
|      */ | ||||
|     @ApiModelProperty(value = "唯一标识") | ||||
|     private String uuid = ""; | ||||
|  | ||||
| } | ||||
|   | ||||
| @@ -1,8 +1,8 @@ | ||||
| package com.ruoyi.common.core.domain.model; | ||||
|  | ||||
| import com.fasterxml.jackson.annotation.JsonIgnore; | ||||
| import com.ruoyi.common.core.domain.entity.SysUser; | ||||
| import lombok.*; | ||||
| import lombok.Data; | ||||
| import lombok.NoArgsConstructor; | ||||
| import lombok.experimental.Accessors; | ||||
| import org.springframework.security.core.GrantedAuthority; | ||||
| import org.springframework.security.core.userdetails.UserDetails; | ||||
| @@ -13,14 +13,14 @@ import java.util.Set; | ||||
| /** | ||||
|  * 登录用户身份权限 | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  * @author Lion Li | ||||
|  */ | ||||
|  | ||||
| @Data | ||||
| @NoArgsConstructor | ||||
| @Accessors(chain = true) | ||||
| public class LoginUser implements UserDetails | ||||
| { | ||||
| public class LoginUser implements UserDetails { | ||||
|  | ||||
|     private static final long serialVersionUID = 1L; | ||||
|  | ||||
|     /** | ||||
| @@ -69,40 +69,34 @@ public class LoginUser implements UserDetails | ||||
|     private String os; | ||||
|  | ||||
|     /** | ||||
|      * 权限列表 | ||||
|      * 菜单权限 | ||||
|      */ | ||||
|     private Set<String> permissions; | ||||
|     private Set<String> menuPermissions; | ||||
|  | ||||
|     /** | ||||
|      * 用户信息 | ||||
|      * 角色权限 | ||||
|      */ | ||||
|     private SysUser user; | ||||
|     private Set<String> rolePermissions; | ||||
|  | ||||
|     public LoginUser(SysUser user, Set<String> permissions) | ||||
|     { | ||||
|         this.user = user; | ||||
|         this.permissions = permissions; | ||||
|     } | ||||
|     /** | ||||
|      * 用户名 | ||||
|      */ | ||||
|     private String username; | ||||
|  | ||||
|     public LoginUser(Long userId, Long deptId, SysUser user, Set<String> permissions) | ||||
|     { | ||||
|         this.userId = userId; | ||||
|         this.deptId = deptId; | ||||
|         this.user = user; | ||||
|         this.permissions = permissions; | ||||
|     } | ||||
|     /** | ||||
|      * 密码 | ||||
|      */ | ||||
|     private String password; | ||||
|  | ||||
|     @JsonIgnore | ||||
|     @Override | ||||
|     public String getPassword() | ||||
|     { | ||||
|         return user.getPassword(); | ||||
|     public String getPassword() { | ||||
|         return password; | ||||
|     } | ||||
|  | ||||
|     @Override | ||||
|     public String getUsername() | ||||
|     { | ||||
|         return user.getUserName(); | ||||
|     public String getUsername() { | ||||
|         return username; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
| @@ -110,50 +104,39 @@ public class LoginUser implements UserDetails | ||||
|      */ | ||||
|     @JsonIgnore | ||||
|     @Override | ||||
|     public boolean isAccountNonExpired() | ||||
|     { | ||||
|     public boolean isAccountNonExpired() { | ||||
|         return true; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 指定用户是否解锁,锁定的用户无法进行身份验证 | ||||
|      * | ||||
|      * @return | ||||
|      */ | ||||
|     @JsonIgnore | ||||
|     @Override | ||||
|     public boolean isAccountNonLocked() | ||||
|     { | ||||
|     public boolean isAccountNonLocked() { | ||||
|         return true; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 指示是否已过期的用户的凭据(密码),过期的凭据防止认证 | ||||
|      * | ||||
|      * @return | ||||
|      */ | ||||
|     @JsonIgnore | ||||
|     @Override | ||||
|     public boolean isCredentialsNonExpired() | ||||
|     { | ||||
|     public boolean isCredentialsNonExpired() { | ||||
|         return true; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 是否可用 ,禁用的用户不能身份验证 | ||||
|      * | ||||
|      * @return | ||||
|      */ | ||||
|     @JsonIgnore | ||||
|     @Override | ||||
|     public boolean isEnabled() | ||||
|     { | ||||
|     public boolean isEnabled() { | ||||
|         return true; | ||||
|     } | ||||
|  | ||||
|     @Override | ||||
|     public Collection<? extends GrantedAuthority> getAuthorities() | ||||
|     { | ||||
|     public Collection<? extends GrantedAuthority> getAuthorities() { | ||||
|         return null; | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -1,11 +1,13 @@ | ||||
| package com.ruoyi.common.core.domain.model; | ||||
|  | ||||
| import io.swagger.annotations.ApiModel; | ||||
|  | ||||
| /** | ||||
|  * 用户注册对象 | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  * @author Lion Li | ||||
|  */ | ||||
| public class RegisterBody extends LoginBody | ||||
| { | ||||
| @ApiModel("用户注册对象") | ||||
| public class RegisterBody extends LoginBody { | ||||
|  | ||||
| } | ||||
|   | ||||
| @@ -1,90 +0,0 @@ | ||||
| package com.ruoyi.common.core.mybatisplus.cache; | ||||
|  | ||||
| import cn.hutool.extra.spring.SpringUtil; | ||||
| import com.ruoyi.common.utils.RedisUtils; | ||||
| import lombok.extern.slf4j.Slf4j; | ||||
| import org.apache.ibatis.cache.Cache; | ||||
| import org.springframework.data.redis.connection.RedisServerCommands; | ||||
| import org.springframework.data.redis.core.RedisTemplate; | ||||
| import org.springframework.util.CollectionUtils; | ||||
|  | ||||
| import java.util.Collection; | ||||
| import java.util.concurrent.locks.ReadWriteLock; | ||||
| import java.util.concurrent.locks.ReentrantReadWriteLock; | ||||
|  | ||||
| /** | ||||
|  * mybatis-redis 二级缓存 | ||||
|  * | ||||
|  * 使用方法 配置文件开启 mybatis-plus 二级缓存 | ||||
|  * 在 XxxMapper.java 类上添加注解 @CacheNamespace(implementation = MybatisPlusRedisCache.class, eviction = MybatisPlusRedisCache.class) | ||||
|  * | ||||
|  * @author Lion Li | ||||
|  */ | ||||
| @Slf4j | ||||
| public class MybatisPlusRedisCache implements Cache { | ||||
|  | ||||
| 	private final ReadWriteLock readWriteLock = new ReentrantReadWriteLock(true); | ||||
|  | ||||
| 	private String id; | ||||
|  | ||||
| 	public MybatisPlusRedisCache(final String id) { | ||||
| 		if (id == null) { | ||||
| 			throw new IllegalArgumentException("Cache instances require an ID"); | ||||
| 		} | ||||
| 		this.id = id; | ||||
| 	} | ||||
|  | ||||
| 	@Override | ||||
| 	public String getId() { | ||||
| 		return this.id; | ||||
| 	} | ||||
|  | ||||
| 	@Override | ||||
| 	public void putObject(Object key, Object value) { | ||||
| 		if (value != null) { | ||||
| 			RedisUtils.setCacheObject(key.toString(), value); | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	@Override | ||||
| 	public Object getObject(Object key) { | ||||
| 		try { | ||||
| 			if (key != null) { | ||||
| 				return RedisUtils.getCacheObject(key.toString()); | ||||
| 			} | ||||
| 		} catch (Exception e) { | ||||
| 			e.printStackTrace(); | ||||
| 			log.error("缓存出错"); | ||||
| 		} | ||||
| 		return null; | ||||
| 	} | ||||
|  | ||||
| 	@Override | ||||
| 	public Object removeObject(Object key) { | ||||
| 		if (key != null) { | ||||
| 			RedisUtils.deleteObject(key.toString()); | ||||
| 		} | ||||
| 		return null; | ||||
| 	} | ||||
|  | ||||
| 	@Override | ||||
| 	public void clear() { | ||||
| 		log.debug("清空缓存"); | ||||
| 		Collection<String> keys = RedisUtils.keys("*:" + this.id + "*"); | ||||
| 		if (!CollectionUtils.isEmpty(keys)) { | ||||
| 			RedisUtils.deleteObject(keys); | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	@Override | ||||
| 	public int getSize() { | ||||
| 		RedisTemplate<String, Object> redisTemplate = SpringUtil.getBean("redisTemplate"); | ||||
| 		Long size = redisTemplate.execute(RedisServerCommands::dbSize); | ||||
| 		return size.intValue(); | ||||
| 	} | ||||
|  | ||||
| 	@Override | ||||
| 	public ReadWriteLock getReadWriteLock() { | ||||
| 		return this.readWriteLock; | ||||
| 	} | ||||
| } | ||||
| @@ -1,9 +1,18 @@ | ||||
| package com.ruoyi.common.core.mybatisplus.core; | ||||
|  | ||||
| import cn.hutool.core.collection.CollUtil; | ||||
| import cn.hutool.core.util.ObjectUtil; | ||||
| import com.baomidou.mybatisplus.core.conditions.Wrapper; | ||||
| import com.baomidou.mybatisplus.core.mapper.BaseMapper; | ||||
| import com.baomidou.mybatisplus.core.metadata.IPage; | ||||
| import com.baomidou.mybatisplus.extension.plugins.pagination.Page; | ||||
| import com.ruoyi.common.utils.BeanCopyUtils; | ||||
| import org.apache.ibatis.annotations.Param; | ||||
|  | ||||
| import java.io.Serializable; | ||||
| import java.util.Collection; | ||||
| import java.util.List; | ||||
| import java.util.Map; | ||||
|  | ||||
| /** | ||||
|  * 自定义 Mapper 接口, 实现 自定义扩展 | ||||
| @@ -18,4 +27,72 @@ public interface BaseMapperPlus<T> extends BaseMapper<T> { | ||||
| 	 */ | ||||
| 	int insertAll(@Param("list") Collection<T> batchList); | ||||
|  | ||||
|     /** | ||||
|      * 根据 ID 查询 | ||||
|      */ | ||||
|     default <V> V selectVoById(Serializable id, Class<V> voClass){ | ||||
|         T obj = this.selectById(id); | ||||
|         if (ObjectUtil.isNull(obj)) { | ||||
|             return null; | ||||
|         } | ||||
|         return BeanCopyUtils.copy(obj, voClass); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 查询(根据ID 批量查询) | ||||
|      */ | ||||
|     default <V> List<V> selectVoBatchIds(Collection<? extends Serializable> idList, Class<V> voClass){ | ||||
|         List<T> list = this.selectBatchIds(idList); | ||||
|         if (CollUtil.isEmpty(list)) { | ||||
|             return CollUtil.newArrayList(); | ||||
|         } | ||||
|         return BeanCopyUtils.copyList(list, voClass); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 查询(根据 columnMap 条件) | ||||
|      */ | ||||
|     default <V> List<V> selectVoByMap(Map<String, Object> map, Class<V> voClass){ | ||||
|         List<T> list = this.selectByMap(map); | ||||
|         if (CollUtil.isEmpty(list)) { | ||||
|             return CollUtil.newArrayList(); | ||||
|         } | ||||
|         return BeanCopyUtils.copyList(list, voClass); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 根据 entity 条件,查询一条记录 | ||||
|      */ | ||||
|     default <V> V selectVoOne(Wrapper<T> wrapper, Class<V> voClass) { | ||||
|         T obj = this.selectOne(wrapper); | ||||
|         if (ObjectUtil.isNull(obj)) { | ||||
|             return null; | ||||
|         } | ||||
|         return BeanCopyUtils.copy(obj, voClass); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 根据 entity 条件,查询全部记录 | ||||
|      */ | ||||
|     default <V> List<V> selectVoList(Wrapper<T> wrapper, Class<V> voClass) { | ||||
|         List<T> list = this.selectList(wrapper); | ||||
|         if (CollUtil.isEmpty(list)) { | ||||
|             return CollUtil.newArrayList(); | ||||
|         } | ||||
|         return BeanCopyUtils.copyList(list, voClass); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 分页查询VO | ||||
|      */ | ||||
|     default <V, P extends IPage<V>> P selectVoPage(IPage<T> page, Wrapper<T> wrapper, Class<V> voClass) { | ||||
|         IPage<T> pageData = this.selectPage(page, wrapper); | ||||
|         IPage<V> voPage = new Page<>(pageData.getCurrent(), pageData.getSize(), pageData.getTotal()); | ||||
|         if (CollUtil.isEmpty(pageData.getRecords())) { | ||||
|             return (P) voPage; | ||||
|         } | ||||
|         voPage.setRecords(BeanCopyUtils.copyList(pageData.getRecords(), voClass)); | ||||
|         return (P) voPage; | ||||
|     } | ||||
|  | ||||
| } | ||||
|   | ||||
| @@ -1,7 +1,7 @@ | ||||
| package com.ruoyi.common.core.mybatisplus.core; | ||||
|  | ||||
| import cn.hutool.core.bean.copier.CopyOptions; | ||||
| import com.baomidou.mybatisplus.core.conditions.Wrapper; | ||||
| import com.baomidou.mybatisplus.core.metadata.IPage; | ||||
| import com.baomidou.mybatisplus.core.toolkit.Wrappers; | ||||
| import com.baomidou.mybatisplus.extension.service.IService; | ||||
| import com.ruoyi.common.core.page.PagePlus; | ||||
| @@ -23,14 +23,9 @@ public interface IServicePlus<T, V> extends IService<T> { | ||||
|  | ||||
| 	/** | ||||
| 	 * @param id          主键id | ||||
| 	 * @param copyOptions copy条件 | ||||
| 	 * @return V对象 | ||||
| 	 */ | ||||
| 	V getVoById(Serializable id, CopyOptions copyOptions); | ||||
|  | ||||
| 	default V getVoById(Serializable id) { | ||||
| 		return getVoById(id, new CopyOptions()); | ||||
| 	} | ||||
| 	V getVoById(Serializable id); | ||||
|  | ||||
| 	/** | ||||
| 	 * @param convertor 自定义转换器 | ||||
| @@ -41,14 +36,9 @@ public interface IServicePlus<T, V> extends IService<T> { | ||||
|  | ||||
| 	/** | ||||
| 	 * @param idList      id列表 | ||||
| 	 * @param copyOptions copy条件 | ||||
| 	 * @return V对象 | ||||
| 	 */ | ||||
| 	List<V> listVoByIds(Collection<? extends Serializable> idList, CopyOptions copyOptions); | ||||
|  | ||||
| 	default List<V> listVoByIds(Collection<? extends Serializable> idList) { | ||||
| 		return listVoByIds(idList, new CopyOptions()); | ||||
| 	} | ||||
| 	List<V> listVoByIds(Collection<? extends Serializable> idList); | ||||
|  | ||||
| 	/** | ||||
| 	 * @param convertor 自定义转换器 | ||||
| @@ -64,14 +54,9 @@ public interface IServicePlus<T, V> extends IService<T> { | ||||
|  | ||||
| 	/** | ||||
| 	 * @param columnMap   表字段 map 对象 | ||||
| 	 * @param copyOptions copy条件 | ||||
| 	 * @return V对象 | ||||
| 	 */ | ||||
| 	List<V> listVoByMap(Map<String, Object> columnMap, CopyOptions copyOptions); | ||||
|  | ||||
| 	default List<V> listVoByMap(Map<String, Object> columnMap) { | ||||
| 		return listVoByMap(columnMap, new CopyOptions()); | ||||
| 	} | ||||
| 	List<V> listVoByMap(Map<String, Object> columnMap); | ||||
|  | ||||
| 	/** | ||||
| 	 * @param convertor 自定义转换器 | ||||
| @@ -87,14 +72,9 @@ public interface IServicePlus<T, V> extends IService<T> { | ||||
|  | ||||
| 	/** | ||||
| 	 * @param queryWrapper 查询条件 | ||||
| 	 * @param copyOptions  copy条件 | ||||
| 	 * @return V对象 | ||||
| 	 */ | ||||
| 	V getVoOne(Wrapper<T> queryWrapper, CopyOptions copyOptions); | ||||
|  | ||||
| 	default V getVoOne(Wrapper<T> queryWrapper) { | ||||
| 		return getVoOne(queryWrapper, new CopyOptions()); | ||||
| 	} | ||||
| 	V getVoOne(Wrapper<T> queryWrapper); | ||||
|  | ||||
| 	/** | ||||
| 	 * @param convertor 自定义转换器 | ||||
| @@ -105,14 +85,9 @@ public interface IServicePlus<T, V> extends IService<T> { | ||||
|  | ||||
| 	/** | ||||
| 	 * @param queryWrapper 查询条件 | ||||
| 	 * @param copyOptions  copy条件 | ||||
| 	 * @return V对象 | ||||
| 	 */ | ||||
| 	List<V> listVo(Wrapper<T> queryWrapper, CopyOptions copyOptions); | ||||
|  | ||||
| 	default List<V> listVo(Wrapper<T> queryWrapper) { | ||||
| 		return listVo(queryWrapper, new CopyOptions()); | ||||
| 	} | ||||
| 	List<V> listVo(Wrapper<T> queryWrapper); | ||||
|  | ||||
| 	/** | ||||
| 	 * @param convertor 自定义转换器 | ||||
| @@ -139,31 +114,36 @@ public interface IServicePlus<T, V> extends IService<T> { | ||||
| 	/** | ||||
| 	 * @param page         分页对象 | ||||
| 	 * @param queryWrapper 查询条件 | ||||
| 	 * @param copyOptions  copy条件 | ||||
| 	 * @return V对象 | ||||
|      * @deprecated 3.6.0 移除 请使用 {@link ServicePlusImpl#pageVo(IPage, Wrapper)} | ||||
| 	 */ | ||||
| 	PagePlus<T, V> pageVo(PagePlus<T, V> page, Wrapper<T> queryWrapper, CopyOptions copyOptions); | ||||
|     @Deprecated | ||||
| 	PagePlus<T, V> pageVo(PagePlus<T, V> page, Wrapper<T> queryWrapper); | ||||
|  | ||||
| 	default PagePlus<T, V> pageVo(PagePlus<T, V> page, Wrapper<T> queryWrapper) { | ||||
| 		return pageVo(page, queryWrapper, new CopyOptions()); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * @param convertor 自定义转换器 | ||||
| 	 */ | ||||
|     /** | ||||
|      * @param convertor 自定义转换器 | ||||
|      * @deprecated 3.6.0 移除 请使用 {@link ServicePlusImpl#pageVo(IPage, Wrapper)} | ||||
|      */ | ||||
|     @Deprecated | ||||
| 	default PagePlus<T, V> pageVo(PagePlus<T, V> page, Wrapper<T> queryWrapper, | ||||
| 								  Function<Collection<T>, List<V>> convertor) { | ||||
| 		PagePlus<T, V> result = getBaseMapper().selectPage(page, queryWrapper); | ||||
| 		return result.setRecordsVo(convertor.apply(result.getRecords())); | ||||
| 	} | ||||
|  | ||||
|     /** | ||||
|      * @deprecated 3.6.0 移除 请使用 {@link ServicePlusImpl#pageVo(IPage, Wrapper)} | ||||
|      */ | ||||
|     @Deprecated | ||||
| 	default PagePlus<T, V> pageVo(PagePlus<T, V> page) { | ||||
| 		return pageVo(page, Wrappers.emptyWrapper()); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * @param convertor 自定义转换器 | ||||
|      * @deprecated 3.6.0 移除 请使用 {@link ServicePlusImpl#pageVo(IPage, Wrapper)} | ||||
| 	 */ | ||||
|     @Deprecated | ||||
| 	default PagePlus<T, V> pageVo(PagePlus<T, V> page, Function<Collection<T>, List<V>> convertor) { | ||||
| 		return pageVo(page, Wrappers.emptyWrapper(), convertor); | ||||
| 	} | ||||
|   | ||||
| @@ -1,9 +1,9 @@ | ||||
| package com.ruoyi.common.core.mybatisplus.core; | ||||
|  | ||||
| import cn.hutool.core.bean.copier.CopyOptions; | ||||
| import cn.hutool.core.collection.CollUtil; | ||||
| import cn.hutool.core.util.ObjectUtil; | ||||
| import com.baomidou.mybatisplus.core.conditions.Wrapper; | ||||
| import com.baomidou.mybatisplus.core.metadata.IPage; | ||||
| import com.baomidou.mybatisplus.core.metadata.TableInfo; | ||||
| import com.baomidou.mybatisplus.core.metadata.TableInfoHelper; | ||||
| import com.baomidou.mybatisplus.core.toolkit.Assert; | ||||
| @@ -161,81 +161,66 @@ public class ServicePlusImpl<M extends BaseMapperPlus<T>, T, V> extends ServiceI | ||||
|  | ||||
| 	/** | ||||
| 	 * 根据 ID 查询 | ||||
| 	 * | ||||
| 	 * @param id 主键ID | ||||
| 	 */ | ||||
| 	@Override | ||||
| 	public V getVoById(Serializable id, CopyOptions copyOptions) { | ||||
| 		T t = getBaseMapper().selectById(id); | ||||
| 		return BeanCopyUtils.oneCopy(t, copyOptions, voClass); | ||||
| 	public V getVoById(Serializable id) { | ||||
|         return getBaseMapper().selectVoById(id, voClass); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * 查询(根据ID 批量查询) | ||||
| 	 * | ||||
| 	 * @param idList 主键ID列表 | ||||
| 	 */ | ||||
| 	@Override | ||||
| 	public List<V> listVoByIds(Collection<? extends Serializable> idList, CopyOptions copyOptions) { | ||||
| 		List<T> list = getBaseMapper().selectBatchIds(idList); | ||||
| 		if (list == null) { | ||||
| 			return null; | ||||
| 		} | ||||
| 		return BeanCopyUtils.listCopy(list, copyOptions, voClass); | ||||
| 	public List<V> listVoByIds(Collection<? extends Serializable> idList) { | ||||
|         return getBaseMapper().selectVoBatchIds(idList, voClass); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * 查询(根据 columnMap 条件) | ||||
| 	 * | ||||
| 	 * @param columnMap 表字段 map 对象 | ||||
| 	 */ | ||||
| 	@Override | ||||
| 	public List<V> listVoByMap(Map<String, Object> columnMap, CopyOptions copyOptions) { | ||||
| 		List<T> list = getBaseMapper().selectByMap(columnMap); | ||||
| 		if (list == null) { | ||||
| 			return null; | ||||
| 		} | ||||
| 		return BeanCopyUtils.listCopy(list, copyOptions, voClass); | ||||
| 	public List<V> listVoByMap(Map<String, Object> columnMap) { | ||||
|         return getBaseMapper().selectVoByMap(columnMap, voClass); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * 根据 Wrapper,查询一条记录 <br/> | ||||
| 	 * <p>结果集,如果是多个会抛出异常,随机取一条加上限制条件 wrapper.last("LIMIT 1")</p> | ||||
| 	 * | ||||
| 	 * @param queryWrapper 实体对象封装操作类 {@link com.baomidou.mybatisplus.core.conditions.query.QueryWrapper} | ||||
| 	 */ | ||||
| 	@Override | ||||
| 	public V getVoOne(Wrapper<T> queryWrapper, CopyOptions copyOptions) { | ||||
| 		T t = getOne(queryWrapper, true); | ||||
| 		return BeanCopyUtils.oneCopy(t, copyOptions, voClass); | ||||
| 	public V getVoOne(Wrapper<T> queryWrapper) { | ||||
|         return getBaseMapper().selectVoOne(queryWrapper, voClass); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * 查询列表 | ||||
| 	 * | ||||
| 	 * @param queryWrapper 实体对象封装操作类 {@link com.baomidou.mybatisplus.core.conditions.query.QueryWrapper} | ||||
| 	 */ | ||||
| 	@Override | ||||
| 	public List<V> listVo(Wrapper<T> queryWrapper, CopyOptions copyOptions) { | ||||
| 		List<T> list = getBaseMapper().selectList(queryWrapper); | ||||
| 		if (list == null) { | ||||
| 			return null; | ||||
| 		} | ||||
| 		return BeanCopyUtils.listCopy(list, copyOptions, voClass); | ||||
| 	public List<V> listVo(Wrapper<T> queryWrapper) { | ||||
|         return getBaseMapper().selectVoList(queryWrapper, voClass); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * 翻页查询 | ||||
| 	 * | ||||
| 	 * @param page         翻页对象 | ||||
| 	 * @param queryWrapper 实体对象封装操作类 | ||||
|      * @deprecated 3.6.0 移除 请使用 {@link #pageVo(IPage, Wrapper)} | ||||
| 	 */ | ||||
| 	@Override | ||||
| 	public PagePlus<T, V> pageVo(PagePlus<T, V> page, Wrapper<T> queryWrapper, CopyOptions copyOptions) { | ||||
|     @Deprecated | ||||
| 	public PagePlus<T, V> pageVo(PagePlus<T, V> page, Wrapper<T> queryWrapper) { | ||||
| 		PagePlus<T, V> result = getBaseMapper().selectPage(page, queryWrapper); | ||||
| 		List<V> volist = BeanCopyUtils.listCopy(result.getRecords(), copyOptions, voClass); | ||||
| 		List<V> volist = BeanCopyUtils.copyList(result.getRecords(), voClass); | ||||
| 		result.setRecordsVo(volist); | ||||
| 		return result; | ||||
| 	} | ||||
|  | ||||
|     /** | ||||
|      * 翻页查询 | ||||
|      * | ||||
|      * @param page         翻页对象 | ||||
|      * @param queryWrapper 实体对象封装操作类 | ||||
|      */ | ||||
|     public <P extends IPage<V>> P pageVo(IPage<T> page, Wrapper<T> queryWrapper) { | ||||
|         return getBaseMapper().selectVoPage(page, queryWrapper, voClass); | ||||
|     } | ||||
|  | ||||
| } | ||||
|   | ||||
| @@ -16,9 +16,11 @@ import java.util.List; | ||||
|  * @param <T> 数据库实体 | ||||
|  * @param <K> vo实体 | ||||
|  * @author Lion Li | ||||
|  * @deprecated 3.6.0 删除 请使用 {@link com.ruoyi.common.core.domain.PageQuery#build()} | ||||
|  */ | ||||
| @Data | ||||
| @Accessors(chain = true) | ||||
| @Deprecated | ||||
| public class PagePlus<T,K> implements IPage<T> { | ||||
|  | ||||
|     /** | ||||
|   | ||||
| @@ -1,5 +1,7 @@ | ||||
| package com.ruoyi.common.core.page; | ||||
|  | ||||
| import cn.hutool.http.HttpStatus; | ||||
| import com.baomidou.mybatisplus.core.metadata.IPage; | ||||
| import io.swagger.annotations.ApiModel; | ||||
| import io.swagger.annotations.ApiModelProperty; | ||||
| import lombok.Data; | ||||
| @@ -57,4 +59,29 @@ public class TableDataInfo<T> implements Serializable { | ||||
| 		this.total = total; | ||||
| 	} | ||||
|  | ||||
|     public static <T> TableDataInfo<T> build(IPage<T> page) { | ||||
|         TableDataInfo<T> rspData = new TableDataInfo<>(); | ||||
|         rspData.setCode(HttpStatus.HTTP_OK); | ||||
|         rspData.setMsg("查询成功"); | ||||
|         rspData.setRows(page.getRecords()); | ||||
|         rspData.setTotal(page.getTotal()); | ||||
|         return rspData; | ||||
|     } | ||||
|  | ||||
|     public static <T> TableDataInfo<T> build(List<T> list) { | ||||
|         TableDataInfo<T> rspData = new TableDataInfo<>(); | ||||
|         rspData.setCode(HttpStatus.HTTP_OK); | ||||
|         rspData.setMsg("查询成功"); | ||||
|         rspData.setRows(list); | ||||
|         rspData.setTotal(list.size()); | ||||
|         return rspData; | ||||
|     } | ||||
|  | ||||
|     public static <T> TableDataInfo<T> build() { | ||||
|         TableDataInfo<T> rspData = new TableDataInfo<>(); | ||||
|         rspData.setCode(HttpStatus.HTTP_OK); | ||||
|         rspData.setMsg("查询成功"); | ||||
|         return rspData; | ||||
|     } | ||||
|  | ||||
| } | ||||
|   | ||||
| @@ -1,260 +0,0 @@ | ||||
| package com.ruoyi.common.core.redis; | ||||
|  | ||||
| import com.google.common.collect.Lists; | ||||
| import org.redisson.api.*; | ||||
| import org.springframework.beans.factory.annotation.Autowired; | ||||
| import org.springframework.stereotype.Component; | ||||
|  | ||||
| import java.util.Collection; | ||||
| import java.util.List; | ||||
| import java.util.Map; | ||||
| import java.util.Set; | ||||
| import java.util.concurrent.TimeUnit; | ||||
| import java.util.function.Consumer; | ||||
|  | ||||
| /** | ||||
|  * spring redis 工具类 | ||||
|  * | ||||
|  * @author shenxinquan | ||||
|  * @see com.ruoyi.common.utils.RedisUtils | ||||
|  * @deprecated 3.2.0 删除此类 | ||||
|  **/ | ||||
| @SuppressWarnings(value = {"unchecked", "rawtypes"}) | ||||
| @Component | ||||
| @Deprecated | ||||
| public class RedisCache { | ||||
|  | ||||
| 	@Autowired | ||||
| 	private RedissonClient redissonClient; | ||||
|  | ||||
| 	/** | ||||
| 	 * 发布通道消息 | ||||
| 	 * | ||||
| 	 * @param channelKey 通道key | ||||
| 	 * @param msg 发送数据 | ||||
| 	 * @param consumer 自定义处理 | ||||
| 	 */ | ||||
| 	public <T> void publish(String channelKey, T msg, Consumer<T> consumer) { | ||||
| 		RTopic topic = redissonClient.getTopic(channelKey); | ||||
| 		topic.publish(msg); | ||||
| 		consumer.accept(msg); | ||||
| 	} | ||||
|  | ||||
| 	public <T> void publish(String channelKey, T msg) { | ||||
| 		RTopic topic = redissonClient.getTopic(channelKey); | ||||
| 		topic.publish(msg); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * 订阅通道接收消息 | ||||
| 	 * | ||||
| 	 * @param channelKey 通道key | ||||
| 	 * @param clazz 消息类型 | ||||
| 	 * @param consumer 自定义处理 | ||||
| 	 */ | ||||
| 	public <T> void subscribe(String channelKey, Class<T> clazz, Consumer<T> consumer) { | ||||
| 		RTopic topic = redissonClient.getTopic(channelKey); | ||||
| 		topic.addListener(clazz, (channel, msg) -> consumer.accept(msg)); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * 缓存基本的对象,Integer、String、实体类等 | ||||
| 	 * | ||||
| 	 * @param key   缓存的键值 | ||||
| 	 * @param value 缓存的值 | ||||
| 	 */ | ||||
| 	public <T> void setCacheObject(final String key, final T value) { | ||||
| 		redissonClient.getBucket(key).set(value); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * 缓存基本的对象,Integer、String、实体类等 | ||||
| 	 * | ||||
| 	 * @param key      缓存的键值 | ||||
| 	 * @param value    缓存的值 | ||||
| 	 * @param timeout  时间 | ||||
| 	 * @param timeUnit 时间颗粒度 | ||||
| 	 */ | ||||
| 	public <T> void setCacheObject(final String key, final T value, final Integer timeout, final TimeUnit timeUnit) { | ||||
| 		RBucket<T> result = redissonClient.getBucket(key); | ||||
| 		result.set(value); | ||||
| 		result.expire(timeout, timeUnit); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * 设置有效时间 | ||||
| 	 * | ||||
| 	 * @param key     Redis键 | ||||
| 	 * @param timeout 超时时间 | ||||
| 	 * @return true=设置成功;false=设置失败 | ||||
| 	 */ | ||||
| 	public boolean expire(final String key, final long timeout) { | ||||
| 		return expire(key, timeout, TimeUnit.SECONDS); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * 设置有效时间 | ||||
| 	 * | ||||
| 	 * @param key     Redis键 | ||||
| 	 * @param timeout 超时时间 | ||||
| 	 * @param unit    时间单位 | ||||
| 	 * @return true=设置成功;false=设置失败 | ||||
| 	 */ | ||||
| 	public boolean expire(final String key, final long timeout, final TimeUnit unit) { | ||||
| 		RBucket rBucket = redissonClient.getBucket(key); | ||||
| 		return rBucket.expire(timeout, unit); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * 获得缓存的基本对象。 | ||||
| 	 * | ||||
| 	 * @param key 缓存键值 | ||||
| 	 * @return 缓存键值对应的数据 | ||||
| 	 */ | ||||
| 	public <T> T getCacheObject(final String key) { | ||||
| 		RBucket<T> rBucket = redissonClient.getBucket(key); | ||||
| 		return rBucket.get(); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * 删除单个对象 | ||||
| 	 * | ||||
| 	 * @param key | ||||
| 	 */ | ||||
| 	public boolean deleteObject(final String key) { | ||||
| 		return redissonClient.getBucket(key).delete(); | ||||
| 	} | ||||
|  | ||||
| 	/* */ | ||||
|  | ||||
| 	/** | ||||
| 	 * 删除集合对象 | ||||
| 	 * | ||||
| 	 * @param collection 多个对象 | ||||
| 	 * @return | ||||
| 	 */ | ||||
| 	public void deleteObject(final Collection collection) { | ||||
| 		RBatch batch = redissonClient.createBatch(); | ||||
| 		collection.forEach(t->{ | ||||
| 			batch.getBucket(t.toString()).deleteAsync(); | ||||
| 		}); | ||||
| 		batch.execute(); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * 缓存List数据 | ||||
| 	 * | ||||
| 	 * @param key      缓存的键值 | ||||
| 	 * @param dataList 待缓存的List数据 | ||||
| 	 * @return 缓存的对象 | ||||
| 	 */ | ||||
| 	public <T> boolean setCacheList(final String key, final List<T> dataList) { | ||||
| 		RList<T> rList = redissonClient.getList(key); | ||||
| 		return rList.addAll(dataList); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * 获得缓存的list对象 | ||||
| 	 * | ||||
| 	 * @param key 缓存的键值 | ||||
| 	 * @return 缓存键值对应的数据 | ||||
| 	 */ | ||||
| 	public <T> List<T> getCacheList(final String key) { | ||||
| 		RList<T> rList = redissonClient.getList(key); | ||||
| 		return rList.readAll(); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * 缓存Set | ||||
| 	 * | ||||
| 	 * @param key     缓存键值 | ||||
| 	 * @param dataSet 缓存的数据 | ||||
| 	 * @return 缓存数据的对象 | ||||
| 	 */ | ||||
| 	public <T> boolean setCacheSet(final String key, final Set<T> dataSet) { | ||||
| 		RSet<T> rSet = redissonClient.getSet(key); | ||||
| 		return rSet.addAll(dataSet); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * 获得缓存的set | ||||
| 	 * | ||||
| 	 * @param key | ||||
| 	 * @return | ||||
| 	 */ | ||||
| 	public <T> Set<T> getCacheSet(final String key) { | ||||
| 		RSet<T> rSet = redissonClient.getSet(key); | ||||
| 		return rSet.readAll(); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * 缓存Map | ||||
| 	 * | ||||
| 	 * @param key | ||||
| 	 * @param dataMap | ||||
| 	 */ | ||||
| 	public <T> void setCacheMap(final String key, final Map<String, T> dataMap) { | ||||
| 		if (dataMap != null) { | ||||
| 			RMap<String, T> rMap = redissonClient.getMap(key); | ||||
| 			rMap.putAll(dataMap); | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * 获得缓存的Map | ||||
| 	 * | ||||
| 	 * @param key | ||||
| 	 * @return | ||||
| 	 */ | ||||
| 	public <T> Map<String, T> getCacheMap(final String key) { | ||||
| 		RMap<String, T> rMap = redissonClient.getMap(key); | ||||
| 		return rMap.getAll(rMap.keySet()); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * 往Hash中存入数据 | ||||
| 	 * | ||||
| 	 * @param key   Redis键 | ||||
| 	 * @param hKey  Hash键 | ||||
| 	 * @param value 值 | ||||
| 	 */ | ||||
| 	public <T> void setCacheMapValue(final String key, final String hKey, final T value) { | ||||
| 		RMap<String, T> rMap = redissonClient.getMap(key); | ||||
| 		rMap.put(hKey, value); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * 获取Hash中的数据 | ||||
| 	 * | ||||
| 	 * @param key  Redis键 | ||||
| 	 * @param hKey Hash键 | ||||
| 	 * @return Hash中的对象 | ||||
| 	 */ | ||||
| 	public <T> T getCacheMapValue(final String key, final String hKey) { | ||||
| 		RMap<String, T> rMap = redissonClient.getMap(key); | ||||
| 		return rMap.get(hKey); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * 获取多个Hash中的数据 | ||||
| 	 * | ||||
| 	 * @param key   Redis键 | ||||
| 	 * @param hKeys Hash键集合 | ||||
| 	 * @return Hash对象集合 | ||||
| 	 */ | ||||
| 	public <K,V> Map<K,V> getMultiCacheMapValue(final String key, final Set<K> hKeys) { | ||||
| 		RMap<K,V>  rMap = redissonClient.getMap(key); | ||||
| 		return rMap.getAll(hKeys); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * 获得缓存的基本对象列表 | ||||
| 	 * | ||||
| 	 * @param pattern 字符串前缀 | ||||
| 	 * @return 对象列表 | ||||
| 	 */ | ||||
| 	public Collection<String> keys(final String pattern) { | ||||
| 		Iterable<String> iterable = redissonClient.getKeys().getKeysByPattern(pattern); | ||||
| 		return Lists.newArrayList(iterable); | ||||
| 	} | ||||
| } | ||||
| @@ -0,0 +1,18 @@ | ||||
| package com.ruoyi.common.core.service; | ||||
|  | ||||
| /** | ||||
|  * 通用 参数配置服务 | ||||
|  * | ||||
|  * @author Lion Li | ||||
|  */ | ||||
| public interface ConfigService { | ||||
|  | ||||
|     /** | ||||
|      * 根据参数 key 获取参数值 | ||||
|      * | ||||
|      * @param configKey 参数 key | ||||
|      * @return 参数值 | ||||
|      */ | ||||
|     String getConfigValue(String configKey); | ||||
|  | ||||
| } | ||||
| @@ -0,0 +1,57 @@ | ||||
| package com.ruoyi.common.core.service; | ||||
|  | ||||
| /** | ||||
|  * 通用 字典服务 | ||||
|  * | ||||
|  * @author Lion Li | ||||
|  */ | ||||
| public interface DictService { | ||||
|  | ||||
|     /** | ||||
|      * 分隔符 | ||||
|      */ | ||||
|     String SEPARATOR = ","; | ||||
|  | ||||
|     /** | ||||
|      * 根据字典类型和字典值获取字典标签 | ||||
|      * | ||||
|      * @param dictType  字典类型 | ||||
|      * @param dictValue 字典值 | ||||
|      * @return 字典标签 | ||||
|      */ | ||||
|     default String getDictLabel(String dictType, String dictValue) { | ||||
|         return getDictLabel(dictType, dictValue, SEPARATOR); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 根据字典类型和字典标签获取字典值 | ||||
|      * | ||||
|      * @param dictType  字典类型 | ||||
|      * @param dictLabel 字典标签 | ||||
|      * @return 字典值 | ||||
|      */ | ||||
|     default String getDictValue(String dictType, String dictLabel) { | ||||
|         return getDictValue(dictType, dictLabel, SEPARATOR); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 根据字典类型和字典值获取字典标签 | ||||
|      * | ||||
|      * @param dictType  字典类型 | ||||
|      * @param dictValue 字典值 | ||||
|      * @param separator 分隔符 | ||||
|      * @return 字典标签 | ||||
|      */ | ||||
|     String getDictLabel(String dictType, String dictValue, String separator); | ||||
|  | ||||
|     /** | ||||
|      * 根据字典类型和字典标签获取字典值 | ||||
|      * | ||||
|      * @param dictType  字典类型 | ||||
|      * @param dictLabel 字典标签 | ||||
|      * @param separator 分隔符 | ||||
|      * @return 字典值 | ||||
|      */ | ||||
|     String getDictValue(String dictType, String dictLabel, String separator); | ||||
|  | ||||
| } | ||||
| @@ -0,0 +1,14 @@ | ||||
| package com.ruoyi.common.core.service; | ||||
|  | ||||
| import javax.servlet.http.HttpServletRequest; | ||||
|  | ||||
| /** | ||||
|  * 通用 系统访问日志 | ||||
|  * | ||||
|  * @author Lion Li | ||||
|  */ | ||||
| public interface LogininforService { | ||||
|  | ||||
|     void recordLogininfor(String username, String status, String message, | ||||
|                           HttpServletRequest request, Object... args); | ||||
| } | ||||
| @@ -0,0 +1,15 @@ | ||||
| package com.ruoyi.common.core.service; | ||||
|  | ||||
| import com.ruoyi.common.core.domain.dto.OperLogDTO; | ||||
| import org.springframework.scheduling.annotation.Async; | ||||
|  | ||||
| /** | ||||
|  * 通用 操作日志 | ||||
|  * | ||||
|  * @author Lion Li | ||||
|  */ | ||||
| public interface OperLogService { | ||||
|  | ||||
|     @Async | ||||
|     void recordOper(OperLogDTO operLogDTO); | ||||
| } | ||||
| @@ -0,0 +1,69 @@ | ||||
| package com.ruoyi.common.core.service; | ||||
|  | ||||
| import com.ruoyi.common.core.domain.model.LoginUser; | ||||
|  | ||||
| import javax.servlet.http.HttpServletRequest; | ||||
|  | ||||
| /** | ||||
|  * token验证处理 | ||||
|  * | ||||
|  * @author Lion Li | ||||
|  */ | ||||
| public interface TokenService { | ||||
|  | ||||
|     /** | ||||
|      * 获取用户身份信息 | ||||
|      * | ||||
|      * @return 用户信息 | ||||
|      */ | ||||
|      LoginUser getLoginUser(HttpServletRequest request); | ||||
|  | ||||
|     /** | ||||
|      * 设置用户身份信息 | ||||
|      */ | ||||
|     void setLoginUser(LoginUser loginUser); | ||||
|  | ||||
|     /** | ||||
|      * 删除用户身份信息 | ||||
|      */ | ||||
|     void delLoginUser(String token); | ||||
|  | ||||
|     /** | ||||
|      * 创建令牌 | ||||
|      * | ||||
|      * @param loginUser 用户信息 | ||||
|      * @return 令牌 | ||||
|      */ | ||||
|     String createToken(LoginUser loginUser); | ||||
|  | ||||
|     /** | ||||
|      * 验证令牌有效期,相差不足20分钟,自动刷新缓存 | ||||
|      * | ||||
|      * @param loginUser | ||||
|      * @return 令牌 | ||||
|      */ | ||||
|     void verifyToken(LoginUser loginUser); | ||||
|  | ||||
|     /** | ||||
|      * 刷新令牌有效期 | ||||
|      * | ||||
|      * @param loginUser 登录信息 | ||||
|      */ | ||||
|     void refreshToken(LoginUser loginUser); | ||||
|  | ||||
|     /** | ||||
|      * 设置用户代理信息 | ||||
|      * | ||||
|      * @param loginUser 登录信息 | ||||
|      */ | ||||
|     void setUserAgent(LoginUser loginUser); | ||||
|  | ||||
|     /** | ||||
|      * 从令牌中获取用户名 | ||||
|      * | ||||
|      * @param token 令牌 | ||||
|      * @return 用户名 | ||||
|      */ | ||||
|     String getUsernameFromToken(String token); | ||||
|  | ||||
| } | ||||
| @@ -0,0 +1,28 @@ | ||||
| package com.ruoyi.common.core.service; | ||||
|  | ||||
| import com.ruoyi.common.core.domain.entity.SysUser; | ||||
|  | ||||
| /** | ||||
|  * 通用 用户业务 | ||||
|  * | ||||
|  * @author Lion Li | ||||
|  */ | ||||
| public interface UserService { | ||||
|  | ||||
|     /** | ||||
|      * 通过用户名查询用户 | ||||
|      * | ||||
|      * @param userName 用户名 | ||||
|      * @return 用户对象信息 | ||||
|      */ | ||||
|     SysUser selectUserByUserName(String userName); | ||||
|  | ||||
|     /** | ||||
|      * 通过用户ID查询用户 | ||||
|      * | ||||
|      * @param userId 用户ID | ||||
|      * @return 用户对象信息 | ||||
|      */ | ||||
|     SysUser selectUserById(Long userId); | ||||
|  | ||||
| } | ||||
| @@ -4,10 +4,8 @@ package com.ruoyi.common.enums; | ||||
|  * 操作状态 | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  * | ||||
|  */ | ||||
| public enum BusinessStatus | ||||
| { | ||||
| public enum BusinessStatus { | ||||
|     /** | ||||
|      * 成功 | ||||
|      */ | ||||
|   | ||||
| @@ -5,8 +5,7 @@ package com.ruoyi.common.enums; | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| public enum BusinessType | ||||
| { | ||||
| public enum BusinessType { | ||||
|     /** | ||||
|      * 其它 | ||||
|      */ | ||||
|   | ||||
| @@ -0,0 +1,72 @@ | ||||
| package com.ruoyi.common.enums; | ||||
|  | ||||
| import com.ruoyi.common.utils.StringUtils; | ||||
| import lombok.AllArgsConstructor; | ||||
| import lombok.Getter; | ||||
|  | ||||
| /** | ||||
|  * 数据权限类型 | ||||
|  * | ||||
|  * 语法支持 spel 模板表达式 | ||||
|  * | ||||
|  * 内置数据 user 当前用户 内容参考 SysUser | ||||
|  * 如需扩展数据 可使用 {@link com.ruoyi.common.helper.DataPermissionHelper} 操作 | ||||
|  * 内置服务 sdss 系统数据权限服务 内容参考 SysDataScopeService | ||||
|  * 如需扩展更多自定义服务 可以参考 sdss 自行编写 | ||||
|  * | ||||
|  * @author Lion Li | ||||
|  * @version 3.5.0 | ||||
|  */ | ||||
| @Getter | ||||
| @AllArgsConstructor | ||||
| public enum DataScopeType { | ||||
|  | ||||
|     /** | ||||
|      * 全部数据权限 | ||||
|      */ | ||||
|     ALL("1", "", ""), | ||||
|  | ||||
|     /** | ||||
|      * 自定数据权限 | ||||
|      */ | ||||
|     CUSTOM("2", " #{#deptName} IN ( #{@sdss.getRoleCustom( #user.roleId )} ) ", ""), | ||||
|  | ||||
|     /** | ||||
|      * 部门数据权限 | ||||
|      */ | ||||
|     DEPT("3", " #{#deptName} = #{#user.deptId} ", ""), | ||||
|  | ||||
|     /** | ||||
|      * 部门及以下数据权限 | ||||
|      */ | ||||
|     DEPT_AND_CHILD("4", " #{#deptName} IN ( #{@sdss.getDeptAndChild( #user.deptId )} )", ""), | ||||
|  | ||||
|     /** | ||||
|      * 仅本人数据权限 | ||||
|      */ | ||||
|     SELF("5", " #{#userName} = #{#user.userId} " , " 1 = 0 "); | ||||
|  | ||||
|     private final String code; | ||||
|  | ||||
|     /** | ||||
|      * 语法 采用 spel 模板表达式 | ||||
|      */ | ||||
|     private final String sqlTemplate; | ||||
|  | ||||
|     /** | ||||
|      * 不满足 sqlTemplate 则填充 | ||||
|      */ | ||||
|     private final String elseSql; | ||||
|  | ||||
|     public static DataScopeType findCode(String code) { | ||||
|         if (StringUtils.isBlank(code)) { | ||||
|             return null; | ||||
|         } | ||||
|         for (DataScopeType type : values()) { | ||||
|             if (type.getCode().equals(code)) { | ||||
|                 return type; | ||||
|             } | ||||
|         } | ||||
|         return null; | ||||
|     } | ||||
| } | ||||
| @@ -7,19 +7,21 @@ import lombok.Getter; | ||||
|  * 数据源 | ||||
|  * | ||||
|  * @author Lion Li | ||||
|  * @deprecated 3.6.0 移除 | ||||
|  */ | ||||
| @AllArgsConstructor | ||||
| @Deprecated | ||||
| public enum DataSourceType { | ||||
| 	/** | ||||
| 	 * 主库 | ||||
| 	 */ | ||||
| 	MASTER("master"), | ||||
|     /** | ||||
|      * 主库 | ||||
|      */ | ||||
|     MASTER("master"), | ||||
|  | ||||
| 	/** | ||||
| 	 * 从库 | ||||
| 	 */ | ||||
| 	SLAVE("slave"); | ||||
|     /** | ||||
|      * 从库 | ||||
|      */ | ||||
|     SLAVE("slave"); | ||||
|  | ||||
| 	@Getter | ||||
| 	private final String source; | ||||
|     @Getter | ||||
|     private final String source; | ||||
| } | ||||
|   | ||||
| @@ -1,36 +1,32 @@ | ||||
| package com.ruoyi.common.enums; | ||||
|  | ||||
| import org.springframework.lang.Nullable; | ||||
|  | ||||
| import java.util.HashMap; | ||||
| import java.util.Map; | ||||
| import org.springframework.lang.Nullable; | ||||
|  | ||||
| /** | ||||
|  * 请求方式 | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| public enum HttpMethod | ||||
| { | ||||
| public enum HttpMethod { | ||||
|     GET, HEAD, POST, PUT, PATCH, DELETE, OPTIONS, TRACE; | ||||
|  | ||||
|     private static final Map<String, HttpMethod> mappings = new HashMap<>(16); | ||||
|  | ||||
|     static | ||||
|     { | ||||
|         for (HttpMethod httpMethod : values()) | ||||
|         { | ||||
|     static { | ||||
|         for (HttpMethod httpMethod : values()) { | ||||
|             mappings.put(httpMethod.name(), httpMethod); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     @Nullable | ||||
|     public static HttpMethod resolve(@Nullable String method) | ||||
|     { | ||||
|     public static HttpMethod resolve(@Nullable String method) { | ||||
|         return (method != null ? mappings.get(method) : null); | ||||
|     } | ||||
|  | ||||
|     public boolean matches(String method) | ||||
|     { | ||||
|     public boolean matches(String method) { | ||||
|         return (this == resolve(method)); | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -6,8 +6,7 @@ package com.ruoyi.common.enums; | ||||
|  * @author ruoyi | ||||
|  */ | ||||
|  | ||||
| public enum LimitType | ||||
| { | ||||
| public enum LimitType { | ||||
|     /** | ||||
|      * 默认策略全局限流 | ||||
|      */ | ||||
| @@ -16,5 +15,10 @@ public enum LimitType | ||||
|     /** | ||||
|      * 根据请求者IP进行限流 | ||||
|      */ | ||||
|     IP | ||||
|     IP, | ||||
|  | ||||
|     /** | ||||
|      * 实例限流(集群多后端实例) | ||||
|      */ | ||||
|     CLUSTER | ||||
| } | ||||
|   | ||||
| @@ -5,8 +5,7 @@ package com.ruoyi.common.enums; | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| public enum OperatorType | ||||
| { | ||||
| public enum OperatorType { | ||||
|     /** | ||||
|      * 其它 | ||||
|      */ | ||||
|   | ||||
| @@ -15,7 +15,7 @@ import java.util.concurrent.ThreadPoolExecutor; | ||||
| @AllArgsConstructor | ||||
| public enum ThreadPoolRejectedPolicy { | ||||
|  | ||||
|     CALLER_RUNS_POLICY("等待", ThreadPoolExecutor.CallerRunsPolicy.class), | ||||
|     CALLER_RUNS_POLICY("调用方执行", ThreadPoolExecutor.CallerRunsPolicy.class), | ||||
|     DISCARD_OLDEST_POLICY("放弃最旧的", ThreadPoolExecutor.DiscardOldestPolicy.class), | ||||
|     DISCARD_POLICY("丢弃", ThreadPoolExecutor.DiscardPolicy.class), | ||||
|     ABORT_POLICY("中止", ThreadPoolExecutor.AbortPolicy.class); | ||||
|   | ||||
| @@ -5,26 +5,22 @@ package com.ruoyi.common.enums; | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| public enum UserStatus | ||||
| { | ||||
| public enum UserStatus { | ||||
|     OK("0", "正常"), DISABLE("1", "停用"), DELETED("2", "删除"); | ||||
|  | ||||
|     private final String code; | ||||
|     private final String info; | ||||
|  | ||||
|     UserStatus(String code, String info) | ||||
|     { | ||||
|     UserStatus(String code, String info) { | ||||
|         this.code = code; | ||||
|         this.info = info; | ||||
|     } | ||||
|  | ||||
|     public String getCode() | ||||
|     { | ||||
|     public String getCode() { | ||||
|         return code; | ||||
|     } | ||||
|  | ||||
|     public String getInfo() | ||||
|     { | ||||
|     public String getInfo() { | ||||
|         return info; | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -0,0 +1,108 @@ | ||||
| package com.ruoyi.common.excel; | ||||
|  | ||||
| import cn.hutool.core.util.StrUtil; | ||||
| import com.alibaba.excel.context.AnalysisContext; | ||||
| import com.alibaba.excel.event.AnalysisEventListener; | ||||
| import com.alibaba.excel.exception.ExcelAnalysisException; | ||||
| import com.alibaba.excel.exception.ExcelDataConvertException; | ||||
| import com.ruoyi.common.utils.JsonUtils; | ||||
| import com.ruoyi.common.utils.ValidatorUtils; | ||||
| import lombok.NoArgsConstructor; | ||||
| import lombok.extern.slf4j.Slf4j; | ||||
|  | ||||
| import javax.validation.ConstraintViolation; | ||||
| import javax.validation.ConstraintViolationException; | ||||
| import java.util.Map; | ||||
| import java.util.Set; | ||||
| import java.util.stream.Collectors; | ||||
|  | ||||
| /** | ||||
|  * Excel 导入监听 | ||||
|  * | ||||
|  * @author Yjoioooo | ||||
|  * @author Lion Li | ||||
|  */ | ||||
| @Slf4j | ||||
| @NoArgsConstructor | ||||
| public class DefaultExcelListener<T> extends AnalysisEventListener<T> implements ExcelListener<T> { | ||||
|  | ||||
|     /** | ||||
|      * 是否Validator检验,默认为是 | ||||
|      */ | ||||
|     private Boolean isValidate = Boolean.TRUE; | ||||
|  | ||||
|     /** | ||||
|      * excel 表头数据 | ||||
|      */ | ||||
|     private Map<Integer, String> headMap; | ||||
|  | ||||
|     /** | ||||
|      * 导入回执 | ||||
|      */ | ||||
|     private ExcelResult<T> excelResult; | ||||
|  | ||||
|     public DefaultExcelListener(boolean isValidate) { | ||||
|         this.excelResult = new DefautExcelResult<>(); | ||||
|         this.isValidate = isValidate; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 处理异常 | ||||
|      * | ||||
|      * @param exception ExcelDataConvertException | ||||
|      * @param context   Excel 上下文 | ||||
|      */ | ||||
|     @Override | ||||
|     public void onException(Exception exception, AnalysisContext context) throws Exception { | ||||
|         String errMsg = null; | ||||
|         if (exception instanceof ExcelDataConvertException) { | ||||
|             // 如果是某一个单元格的转换异常 能获取到具体行号 | ||||
|             ExcelDataConvertException excelDataConvertException = (ExcelDataConvertException) exception; | ||||
|             Integer rowIndex = excelDataConvertException.getRowIndex(); | ||||
|             Integer columnIndex = excelDataConvertException.getColumnIndex(); | ||||
|             errMsg = StrUtil.format("第{}行-第{}列-表头{}: 解析异常<br/>", | ||||
|                 rowIndex + 1, columnIndex + 1, headMap.get(columnIndex)); | ||||
|             if (log.isDebugEnabled()) { | ||||
|                 log.error(errMsg); | ||||
|             } | ||||
|         } | ||||
|         if (exception instanceof ConstraintViolationException) { | ||||
|             ConstraintViolationException constraintViolationException = (ConstraintViolationException) exception; | ||||
|             Set<ConstraintViolation<?>> constraintViolations = constraintViolationException.getConstraintViolations(); | ||||
|             String constraintViolationsMsg = constraintViolations.stream() | ||||
|                 .map(ConstraintViolation::getMessage) | ||||
|                 .collect(Collectors.joining(", ")); | ||||
|             errMsg = StrUtil.format("第{}行数据校验异常: {}", context.readRowHolder().getRowIndex() + 1, constraintViolationsMsg); | ||||
|             if (log.isDebugEnabled()) { | ||||
|                 log.error(errMsg); | ||||
|             } | ||||
|         } | ||||
|         excelResult.getErrorList().add(errMsg); | ||||
|         throw new ExcelAnalysisException(errMsg); | ||||
|     } | ||||
|  | ||||
|     @Override | ||||
|     public void invokeHeadMap(Map<Integer, String> headMap, AnalysisContext context) { | ||||
|         this.headMap = headMap; | ||||
|         log.debug("解析到一条表头数据: {}", JsonUtils.toJsonString(headMap)); | ||||
|     } | ||||
|  | ||||
|     @Override | ||||
|     public void invoke(T data, AnalysisContext context) { | ||||
|         if (isValidate) { | ||||
|             ValidatorUtils.validate(data); | ||||
|         } | ||||
|         excelResult.getList().add(data); | ||||
|     } | ||||
|  | ||||
|     @Override | ||||
|     public void doAfterAllAnalysed(AnalysisContext context) { | ||||
|         log.debug("所有数据解析完成!"); | ||||
|     } | ||||
|  | ||||
|     @Override | ||||
|     public ExcelResult<T> getExcelResult() { | ||||
|         return excelResult; | ||||
|     } | ||||
|  | ||||
| } | ||||
| @@ -0,0 +1,73 @@ | ||||
| package com.ruoyi.common.excel; | ||||
|  | ||||
| import cn.hutool.core.util.StrUtil; | ||||
| import lombok.Setter; | ||||
|  | ||||
| import java.util.ArrayList; | ||||
| import java.util.List; | ||||
|  | ||||
| /** | ||||
|  * 默认excel返回对象 | ||||
|  * | ||||
|  * @author Yjoioooo | ||||
|  * @author Lion Li | ||||
|  */ | ||||
| public class DefautExcelResult<T> implements ExcelResult<T> { | ||||
|  | ||||
|     /** | ||||
|      * 数据对象list | ||||
|      */ | ||||
|     @Setter | ||||
|     private List<T> list; | ||||
|  | ||||
|     /** | ||||
|      * 错误信息列表 | ||||
|      */ | ||||
|     @Setter | ||||
|     private List<String> errorList; | ||||
|  | ||||
|     public DefautExcelResult() { | ||||
|         this.list = new ArrayList<>(); | ||||
|         this.errorList = new ArrayList<>(); | ||||
|     } | ||||
|  | ||||
|     public DefautExcelResult(List<T> list, List<String> errorList) { | ||||
|         this.list = list; | ||||
|         this.errorList = errorList; | ||||
|     } | ||||
|  | ||||
|     public DefautExcelResult(ExcelResult<T> excelResult) { | ||||
|         this.list = excelResult.getList(); | ||||
|         this.errorList = excelResult.getErrorList(); | ||||
|     } | ||||
|  | ||||
|     @Override | ||||
|     public List<T> getList() { | ||||
|         return list; | ||||
|     } | ||||
|  | ||||
|     @Override | ||||
|     public List<String> getErrorList() { | ||||
|         return errorList; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 获取导入回执 | ||||
|      * | ||||
|      * @return 导入回执 | ||||
|      */ | ||||
|     @Override | ||||
|     public String getAnalysis() { | ||||
|         int successCount = list.size(); | ||||
|         int errorCount = errorList.size(); | ||||
|         if (successCount == 0) { | ||||
|             return "读取失败,未解析到数据"; | ||||
|         } else { | ||||
|             if (errorCount == 0) { | ||||
|                 return StrUtil.format("恭喜您,全部读取成功!共{}条", successCount); | ||||
|             } else { | ||||
|                 return ""; | ||||
|             } | ||||
|         } | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,14 @@ | ||||
| package com.ruoyi.common.excel; | ||||
|  | ||||
| import com.alibaba.excel.read.listener.ReadListener; | ||||
|  | ||||
| /** | ||||
|  * Excel 导入监听 | ||||
|  * | ||||
|  * @author Lion Li | ||||
|  */ | ||||
| public interface ExcelListener<T> extends ReadListener<T> { | ||||
|  | ||||
|     ExcelResult<T> getExcelResult(); | ||||
|  | ||||
| } | ||||
| @@ -0,0 +1,26 @@ | ||||
| package com.ruoyi.common.excel; | ||||
|  | ||||
| import java.util.List; | ||||
|  | ||||
| /** | ||||
|  * excel返回对象 | ||||
|  * | ||||
|  * @author Lion Li | ||||
|  */ | ||||
| public interface ExcelResult<T> { | ||||
|  | ||||
|     /** | ||||
|      * 对象列表 | ||||
|      */ | ||||
|     List<T> getList(); | ||||
|  | ||||
|     /** | ||||
|      * 错误列表 | ||||
|      */ | ||||
|     List<String> getErrorList(); | ||||
|  | ||||
|     /** | ||||
|      * 导入回执 | ||||
|      */ | ||||
|     String getAnalysis(); | ||||
| } | ||||
| @@ -5,11 +5,9 @@ package com.ruoyi.common.exception; | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| public class DemoModeException extends RuntimeException | ||||
| { | ||||
| public class DemoModeException extends RuntimeException { | ||||
|     private static final long serialVersionUID = 1L; | ||||
|  | ||||
|     public DemoModeException() | ||||
|     { | ||||
|     public DemoModeException() { | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -5,8 +5,7 @@ package com.ruoyi.common.exception; | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| public class GlobalException extends RuntimeException | ||||
| { | ||||
| public class GlobalException extends RuntimeException { | ||||
|  | ||||
|     private static final long serialVersionUID = 1L; | ||||
|  | ||||
| @@ -17,7 +16,7 @@ public class GlobalException extends RuntimeException | ||||
|  | ||||
|     /** | ||||
|      * 错误明细,内部调试错误 | ||||
|      * | ||||
|      * <p> | ||||
|      * 和 {@link CommonResult#getDetailMessage()} 一致的设计 | ||||
|      */ | ||||
|     private String detailMessage; | ||||
| @@ -25,33 +24,28 @@ public class GlobalException extends RuntimeException | ||||
|     /** | ||||
|      * 空构造方法,避免反序列化问题 | ||||
|      */ | ||||
|     public GlobalException() | ||||
|     { | ||||
|     public GlobalException() { | ||||
|     } | ||||
|  | ||||
|     public GlobalException(String message) | ||||
|     { | ||||
|     public GlobalException(String message) { | ||||
|         this.message = message; | ||||
|     } | ||||
|  | ||||
|     public String getDetailMessage() | ||||
|     { | ||||
|     public String getDetailMessage() { | ||||
|         return detailMessage; | ||||
|     } | ||||
|  | ||||
|     public GlobalException setDetailMessage(String detailMessage) | ||||
|     { | ||||
|     public GlobalException setDetailMessage(String detailMessage) { | ||||
|         this.detailMessage = detailMessage; | ||||
|         return this; | ||||
|     } | ||||
|  | ||||
|     public String getMessage() | ||||
|     { | ||||
|     @Override | ||||
|     public String getMessage() { | ||||
|         return message; | ||||
|     } | ||||
|  | ||||
|     public GlobalException setMessage(String message) | ||||
|     { | ||||
|     public GlobalException setMessage(String message) { | ||||
|         this.message = message; | ||||
|         return this; | ||||
|     } | ||||
|   | ||||
| @@ -5,8 +5,7 @@ package com.ruoyi.common.exception; | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| public final class ServiceException extends RuntimeException | ||||
| { | ||||
| public final class ServiceException extends RuntimeException { | ||||
|     private static final long serialVersionUID = 1L; | ||||
|  | ||||
|     /** | ||||
| @@ -21,7 +20,7 @@ public final class ServiceException extends RuntimeException | ||||
|  | ||||
|     /** | ||||
|      * 错误明细,内部调试错误 | ||||
|      * | ||||
|      * <p> | ||||
|      * 和 {@link CommonResult#getDetailMessage()} 一致的设计 | ||||
|      */ | ||||
|     private String detailMessage; | ||||
| @@ -29,44 +28,37 @@ public final class ServiceException extends RuntimeException | ||||
|     /** | ||||
|      * 空构造方法,避免反序列化问题 | ||||
|      */ | ||||
|     public ServiceException() | ||||
|     { | ||||
|     public ServiceException() { | ||||
|     } | ||||
|  | ||||
|     public ServiceException(String message) | ||||
|     { | ||||
|     public ServiceException(String message) { | ||||
|         this.message = message; | ||||
|     } | ||||
|  | ||||
|     public ServiceException(String message, Integer code) | ||||
|     { | ||||
|     public ServiceException(String message, Integer code) { | ||||
|         this.message = message; | ||||
|         this.code = code; | ||||
|     } | ||||
|  | ||||
|     public String getDetailMessage() | ||||
|     { | ||||
|     public String getDetailMessage() { | ||||
|         return detailMessage; | ||||
|     } | ||||
|  | ||||
|     public String getMessage() | ||||
|     { | ||||
|     @Override | ||||
|     public String getMessage() { | ||||
|         return message; | ||||
|     } | ||||
|  | ||||
|     public Integer getCode() | ||||
|     { | ||||
|     public Integer getCode() { | ||||
|         return code; | ||||
|     } | ||||
|  | ||||
|     public ServiceException setMessage(String message) | ||||
|     { | ||||
|     public ServiceException setMessage(String message) { | ||||
|         this.message = message; | ||||
|         return this; | ||||
|     } | ||||
|  | ||||
|     public ServiceException setDetailMessage(String detailMessage) | ||||
|     { | ||||
|     public ServiceException setDetailMessage(String detailMessage) { | ||||
|         this.detailMessage = detailMessage; | ||||
|         return this; | ||||
|     } | ||||
|   | ||||
| @@ -5,22 +5,18 @@ package com.ruoyi.common.exception; | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| public class UtilException extends RuntimeException | ||||
| { | ||||
| public class UtilException extends RuntimeException { | ||||
|     private static final long serialVersionUID = 8247610319171014183L; | ||||
|  | ||||
|     public UtilException(Throwable e) | ||||
|     { | ||||
|     public UtilException(Throwable e) { | ||||
|         super(e.getMessage(), e); | ||||
|     } | ||||
|  | ||||
|     public UtilException(String message) | ||||
|     { | ||||
|     public UtilException(String message) { | ||||
|         super(message); | ||||
|     } | ||||
|  | ||||
|     public UtilException(String message, Throwable throwable) | ||||
|     { | ||||
|     public UtilException(String message, Throwable throwable) { | ||||
|         super(message, throwable); | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -2,14 +2,17 @@ package com.ruoyi.common.exception.base; | ||||
|  | ||||
| import com.ruoyi.common.utils.MessageUtils; | ||||
| import com.ruoyi.common.utils.StringUtils; | ||||
| import lombok.*; | ||||
|  | ||||
| /** | ||||
|  * 基础异常 | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| public class BaseException extends RuntimeException | ||||
| { | ||||
| @Data | ||||
| @EqualsAndHashCode(callSuper = true) | ||||
| @NoArgsConstructor | ||||
| public class BaseException extends RuntimeException { | ||||
|     private static final long serialVersionUID = 1L; | ||||
|  | ||||
|     /** | ||||
| @@ -32,66 +35,39 @@ public class BaseException extends RuntimeException | ||||
|      */ | ||||
|     private String defaultMessage; | ||||
|  | ||||
|     public BaseException(String module, String code, Object[] args, String defaultMessage) | ||||
|     { | ||||
|     public BaseException(String module, String code, Object[] args, String defaultMessage) { | ||||
|         this.module = module; | ||||
|         this.code = code; | ||||
|         this.args = args; | ||||
|         this.defaultMessage = defaultMessage; | ||||
|     } | ||||
|  | ||||
|     public BaseException(String module, String code, Object[] args) | ||||
|     { | ||||
|     public BaseException(String module, String code, Object[] args) { | ||||
|         this(module, code, args, null); | ||||
|     } | ||||
|  | ||||
|     public BaseException(String module, String defaultMessage) | ||||
|     { | ||||
|     public BaseException(String module, String defaultMessage) { | ||||
|         this(module, null, null, defaultMessage); | ||||
|     } | ||||
|  | ||||
|     public BaseException(String code, Object[] args) | ||||
|     { | ||||
|     public BaseException(String code, Object[] args) { | ||||
|         this(null, code, args, null); | ||||
|     } | ||||
|  | ||||
|     public BaseException(String defaultMessage) | ||||
|     { | ||||
|     public BaseException(String defaultMessage) { | ||||
|         this(null, null, null, defaultMessage); | ||||
|     } | ||||
|  | ||||
|     @Override | ||||
|     public String getMessage() | ||||
|     { | ||||
|     public String getMessage() { | ||||
|         String message = null; | ||||
|         if (!StringUtils.isEmpty(code)) | ||||
|         { | ||||
|         if (!StringUtils.isEmpty(code)) { | ||||
|             message = MessageUtils.message(code, args); | ||||
|         } | ||||
|         if (message == null) | ||||
|         { | ||||
|         if (message == null) { | ||||
|             message = defaultMessage; | ||||
|         } | ||||
|         return message; | ||||
|     } | ||||
|  | ||||
|     public String getModule() | ||||
|     { | ||||
|         return module; | ||||
|     } | ||||
|  | ||||
|     public String getCode() | ||||
|     { | ||||
|         return code; | ||||
|     } | ||||
|  | ||||
|     public Object[] getArgs() | ||||
|     { | ||||
|         return args; | ||||
|     } | ||||
|  | ||||
|     public String getDefaultMessage() | ||||
|     { | ||||
|         return defaultMessage; | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -7,12 +7,10 @@ import com.ruoyi.common.exception.base.BaseException; | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| public class FileException extends BaseException | ||||
| { | ||||
| public class FileException extends BaseException { | ||||
|     private static final long serialVersionUID = 1L; | ||||
|  | ||||
|     public FileException(String code, Object[] args) | ||||
|     { | ||||
|     public FileException(String code, Object[] args) { | ||||
|         super("file", code, args, null); | ||||
|     } | ||||
|  | ||||
|   | ||||
| @@ -5,12 +5,10 @@ package com.ruoyi.common.exception.file; | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| public class FileNameLengthLimitExceededException extends FileException | ||||
| { | ||||
| public class FileNameLengthLimitExceededException extends FileException { | ||||
|     private static final long serialVersionUID = 1L; | ||||
|  | ||||
|     public FileNameLengthLimitExceededException(int defaultFileNameLength) | ||||
|     { | ||||
|         super("upload.filename.exceed.length", new Object[] { defaultFileNameLength }); | ||||
|     public FileNameLengthLimitExceededException(int defaultFileNameLength) { | ||||
|         super("upload.filename.exceed.length", new Object[]{defaultFileNameLength}); | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -5,12 +5,10 @@ package com.ruoyi.common.exception.file; | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| public class FileSizeLimitExceededException extends FileException | ||||
| { | ||||
| public class FileSizeLimitExceededException extends FileException { | ||||
|     private static final long serialVersionUID = 1L; | ||||
|  | ||||
|     public FileSizeLimitExceededException(long defaultMaxSize) | ||||
|     { | ||||
|         super("upload.exceed.maxSize", new Object[] { defaultMaxSize }); | ||||
|     public FileSizeLimitExceededException(long defaultMaxSize) { | ||||
|         super("upload.exceed.maxSize", new Object[]{defaultMaxSize}); | ||||
|     } | ||||
| } | ||||
|   | ||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user