From ec4c372b1cefd38b1247b795b789bab9a74bc584 Mon Sep 17 00:00:00 2001 From: ljlong_2630 <ljlong_2630@yeah.net> Date: Tue, 1 Aug 2023 15:28:43 +0800 Subject: [PATCH] =?UTF-8?q?=E4=BB=A3=E7=A0=81=E5=88=9D=E5=A7=8B=E5=8C=96?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .gitignore | 5 + LICENSE | 20 + README.md | 95 + bin/clean.bat | 12 + bin/package.bat | 12 + bin/run.bat | 14 + dc-admin/pom.xml | 96 + .../main/java/com/dc/web/DcApplication.java | 24 + .../java/com/dc/web/DcServletInitializer.java | 18 + .../java/com/dc/web/config/SwaggerConfig.java | 121 + .../controller/common/CaptchaController.java | 95 + .../controller/common/CommonController.java | 169 + .../controller/monitor/CacheController.java | 103 + .../controller/monitor/ServerController.java | 25 + .../monitor/SysLogininforController.java | 72 + .../monitor/SysOperlogController.java | 60 + .../monitor/SysUserOnlineController.java | 86 + .../controller/system/SysCityController.java | 44 + .../system/SysConfigController.java | 120 + .../controller/system/SysDeptController.java | 119 + .../system/SysDictDataController.java | 108 + .../system/SysDictTypeController.java | 128 + .../controller/system/SysIndexController.java | 29 + .../controller/system/SysLoginController.java | 87 + .../controller/system/SysMenuController.java | 130 + .../system/SysNoticeController.java | 79 + .../controller/system/SysPostController.java | 117 + .../system/SysProfileController.java | 144 + .../system/SysRegisterController.java | 38 + .../controller/system/SysRoleController.java | 241 + .../controller/system/SysUserController.java | 237 + .../controller/tool/SwaggerController.java | 22 + .../web/controller/tool/TestController.java | 167 + .../com/dc/web/websocket/SemaphoreUtils.java | 46 + .../com/dc/web/websocket/WebSocketConfig.java | 18 + .../com/dc/web/websocket/WebSocketServer.java | 91 + .../com/dc/web/websocket/WebSocketUsers.java | 114 + .../META-INF/spring-devtools.properties | 1 + .../src/main/resources/application-dev.yml | 157 + .../src/main/resources/application-druid.yml | 47 + .../main/resources/application-mybatis.yml | 57 + .../src/main/resources/application-prod.yml | 157 + .../src/main/resources/application-test.yml | 157 + dc-admin/src/main/resources/application.yml | 39 + .../main/resources/i18n/messages.properties | 37 + .../src/main/resources/logback-spring.xml | 108 + .../main/resources/mybatis/mybatis-config.xml | 20 + dc-app/pom.xml | 84 + .../main/java/com/dc/app/AppApplication.java | 25 + .../java/com/dc/app/config/SwaggerConfig.java | 121 + .../java/com/dc/app/config/WebConfig.java | 35 + .../controller/common/CommonController.java | 124 + .../system/SysDictDataController.java | 43 + .../META-INF/spring-devtools.properties | 1 + dc-app/src/main/resources/application-dev.yml | 158 + .../src/main/resources/application-druid.yml | 47 + .../main/resources/application-mybatis.yml | 57 + .../src/main/resources/application-prod.yml | 156 + .../src/main/resources/application-test.yml | 158 + dc-app/src/main/resources/application.yml | 39 + .../main/resources/i18n/messages.properties | 37 + dc-app/src/main/resources/logback-spring.xml | 108 + dc-common/pom.xml | 146 + .../com/dc/common/annotation/Anonymous.java | 19 + .../com/dc/common/annotation/DataScope.java | 33 + .../dc/common/annotation/DataScopeCommon.java | 23 + .../java/com/dc/common/annotation/Excel.java | 188 + .../java/com/dc/common/annotation/Excels.java | 18 + .../java/com/dc/common/annotation/Log.java | 45 + .../com/dc/common/annotation/RateLimiter.java | 37 + .../dc/common/annotation/RepeatSubmit.java | 31 + .../java/com/dc/common/config/WinConfig.java | 135 + .../dc/common/constant/CacheConstants.java | 44 + .../com/dc/common/constant/Constants.java | 148 + .../com/dc/common/constant/DBConstants.java | 9 + .../com/dc/common/constant/GenConstants.java | 117 + .../com/dc/common/constant/HttpStatus.java | 94 + .../dc/common/constant/ScheduleConstants.java | 50 + .../com/dc/common/constant/UserConstants.java | 78 + .../dc/common/context/DataScopeHolder.java | 28 + .../core/controller/BaseController.java | 213 + .../com/dc/common/core/domain/AjaxResult.java | 186 + .../com/dc/common/core/domain/BaseEntity.java | 82 + .../com/dc/common/core/domain/IdEntity.java | 62 + .../java/com/dc/common/core/domain/R.java | 116 + .../com/dc/common/core/domain/TreeEntity.java | 79 + .../com/dc/common/core/domain/TreeSelect.java | 78 + .../dc/common/core/domain/WinBaseEntity.java | 119 + .../dc/common/core/domain/entity/SysDept.java | 207 + .../core/domain/entity/SysDictData.java | 179 + .../core/domain/entity/SysDictType.java | 99 + .../dc/common/core/domain/entity/SysMenu.java | 264 + .../dc/common/core/domain/entity/SysRole.java | 244 + .../dc/common/core/domain/entity/SysUser.java | 334 + .../common/core/domain/model/LoginBody.java | 69 + .../common/core/domain/model/LoginUser.java | 267 + .../core/domain/model/RegisterBody.java | 11 + .../com/dc/common/core/page/PageDomain.java | 101 + .../dc/common/core/page/TableDataInfo.java | 85 + .../com/dc/common/core/page/TableSupport.java | 56 + .../com/dc/common/core/redis/RedisCache.java | 282 + .../com/dc/common/core/text/CharsetKit.java | 87 + .../java/com/dc/common/core/text/Convert.java | 1001 +++ .../com/dc/common/core/text/StrFormatter.java | 92 + .../com/dc/common/enums/AccessoryType.java | 40 + .../com/dc/common/enums/BusinessStatus.java | 20 + .../com/dc/common/enums/BusinessType.java | 59 + .../com/dc/common/enums/DataSourceType.java | 19 + .../java/com/dc/common/enums/HttpMethod.java | 37 + .../java/com/dc/common/enums/LimitType.java | 20 + .../com/dc/common/enums/OperatorType.java | 24 + .../java/com/dc/common/enums/UserStatus.java | 30 + .../dc/common/exception/CustomException.java | 37 + .../common/exception/DatabaseException.java | 74 + .../common/exception/DemoModeException.java | 15 + .../dc/common/exception/GlobalException.java | 58 + .../common/exception/NotExistsException.java | 59 + .../dc/common/exception/ServiceException.java | 74 + .../dc/common/exception/UtilException.java | 26 + .../common/exception/base/BaseException.java | 97 + .../common/exception/file/FileException.java | 19 + .../FileNameLengthLimitExceededException.java | 16 + .../file/FileSizeLimitExceededException.java | 16 + .../file/InvalidExtensionException.java | 81 + .../common/exception/job/TaskException.java | 34 + .../exception/user/CaptchaException.java | 16 + .../user/CaptchaExpireException.java | 16 + .../common/exception/user/UserException.java | 18 + .../user/UserPasswordNotMatchException.java | 16 + ...UserPasswordRetryLimitExceedException.java | 16 + .../dc/common/extension/MpSqlInjector.java | 19 + .../filter/PropertyPreExcludeFilter.java | 24 + .../dc/common/filter/RepeatableFilter.java | 48 + .../filter/RepeatedlyRequestWrapper.java | 77 + .../java/com/dc/common/filter/XssFilter.java | 71 + .../filter/XssHttpServletRequestWrapper.java | 112 + .../main/java/com/dc/common/utils/AESKit.java | 139 + .../main/java/com/dc/common/utils/Arith.java | 114 + .../java/com/dc/common/utils/DateUtils.java | 184 + .../java/com/dc/common/utils/DictUtils.java | 159 + .../com/dc/common/utils/ExceptionUtil.java | 40 + .../java/com/dc/common/utils/IdEncodes.java | 90 + .../java/com/dc/common/utils/LogUtils.java | 18 + .../com/dc/common/utils/MessageUtils.java | 26 + .../java/com/dc/common/utils/PageUtils.java | 35 + .../com/dc/common/utils/SecurityUtils.java | 144 + .../com/dc/common/utils/ServletUtils.java | 219 + .../java/com/dc/common/utils/StringUtils.java | 605 ++ .../java/com/dc/common/utils/Threads.java | 96 + .../com/dc/common/utils/bean/BeanUtils.java | 110 + .../dc/common/utils/bean/BeanValidators.java | 24 + .../dc/common/utils/file/FileTypeUtils.java | 77 + .../dc/common/utils/file/FileUploadUtils.java | 233 + .../com/dc/common/utils/file/FileUtils.java | 286 + .../com/dc/common/utils/file/ImageUtils.java | 99 + .../dc/common/utils/file/MimeTypeUtils.java | 59 + .../com/dc/common/utils/html/EscapeUtil.java | 167 + .../com/dc/common/utils/html/HTMLFilter.java | 570 ++ .../com/dc/common/utils/http/HttpHelper.java | 56 + .../com/dc/common/utils/http/HttpUtils.java | 266 + .../com/dc/common/utils/ip/AddressUtils.java | 56 + .../java/com/dc/common/utils/ip/IpUtils.java | 265 + .../common/utils/poi/ExcelHandlerAdapter.java | 17 + .../com/dc/common/utils/poi/ExcelUtil.java | 1511 ++++ .../dc/common/utils/reflect/ReflectUtils.java | 406 + .../java/com/dc/common/utils/sign/Base64.java | 291 + .../com/dc/common/utils/sign/Md5Utils.java | 68 + .../dc/common/utils/spring/SpringUtils.java | 158 + .../java/com/dc/common/utils/sql/SqlUtil.java | 61 + .../com/dc/common/utils/uuid/IdUtils.java | 49 + .../java/com/dc/common/utils/uuid/Seq.java | 87 + .../java/com/dc/common/utils/uuid/UUID.java | 485 ++ .../src/main/java/com/dc/common/xss/Xss.java | 27 + .../java/com/dc/common/xss/XssValidator.java | 35 + dc-framework/pom.xml | 70 + .../dc/framework/aspectj/DataScopeAspect.java | 168 + .../aspectj/DataScopeCommonAspect.java | 151 + .../com/dc/framework/aspectj/LogAspect.java | 228 + .../framework/aspectj/RateLimiterAspect.java | 91 + .../framework/config/ApplicationConfig.java | 31 + .../dc/framework/config/CaptchaConfig.java | 85 + .../config/DataSourceConfiguration.java | 112 + .../config/FastJson2JsonRedisSerializer.java | 49 + .../com/dc/framework/config/FilterConfig.java | 59 + .../framework/config/KaptchaTextCreator.java | 69 + .../framework/config/MybatisPlusConfig.java | 72 + .../com/dc/framework/config/RedisConfig.java | 69 + .../dc/framework/config/ResourcesConfig.java | 74 + .../dc/framework/config/SecurityConfig.java | 149 + .../com/dc/framework/config/ServerConfig.java | 38 + .../dc/framework/config/ThreadPoolConfig.java | 63 + .../properties/PermitAllUrlProperties.java | 73 + .../interceptor/RepeatSubmitInterceptor.java | 56 + .../interceptor/UnionIdInterceptor.java | 50 + .../impl/DataScopeInterceptor.java | 56 + .../impl/SameUrlDataInterceptor.java | 111 + .../dc/framework/manager/AsyncManager.java | 56 + .../dc/framework/manager/ShutdownManager.java | 39 + .../manager/factory/AsyncFactory.java | 103 + .../context/AuthenticationContextHolder.java | 28 + .../context/PermissionContextHolder.java | 27 + .../filter/JwtAuthenticationTokenFilter.java | 45 + .../handle/AuthenticationEntryPointImpl.java | 35 + .../handle/LogoutSuccessHandlerImpl.java | 54 + .../com/dc/framework/web/domain/Server.java | 237 + .../dc/framework/web/domain/server/Cpu.java | 101 + .../dc/framework/web/domain/server/Jvm.java | 131 + .../dc/framework/web/domain/server/Mem.java | 61 + .../dc/framework/web/domain/server/Sys.java | 84 + .../framework/web/domain/server/SysFile.java | 114 + .../web/exception/GlobalExceptionHandler.java | 127 + .../web/service/PermissionService.java | 169 + .../web/service/SysLoginService.java | 160 + .../web/service/SysPasswordService.java | 95 + .../web/service/SysPermissionService.java | 83 + .../web/service/SysRegisterService.java | 115 + .../framework/web/service/TokenService.java | 263 + .../web/service/UserDetailsServiceImpl.java | 65 + dc-generator/pom.xml | 40 + .../com/dc/generator/config/GenConfig.java | 73 + .../generator/controller/GenController.java | 208 + .../com/dc/generator/domain/GenTable.java | 151 + .../dc/generator/domain/GenTableColumn.java | 197 + .../mapper/GenTableColumnMapper.java | 64 + .../dc/generator/mapper/GenTableMapper.java | 87 + .../service/GenTableColumnService.java | 65 + .../dc/generator/service/GenTableService.java | 505 ++ .../java/com/dc/generator/util/GenUtils.java | 258 + .../generator/util/VelocityInitializer.java | 35 + .../com/dc/generator/util/VelocityUtils.java | 398 + dc-generator/src/main/resources/generator.yml | 10 + .../mapper/generator/GenTableColumnMapper.xml | 128 + .../mapper/generator/GenTableMapper.xml | 217 + .../src/main/resources/vm/doc/doc.md.vm | 172 + .../main/resources/vm/java/controller.java.vm | 264 + .../src/main/resources/vm/java/domain.java.vm | 59 + .../src/main/resources/vm/java/mapper.java.vm | 19 + .../main/resources/vm/java/service.java.vm | 46 + .../main/resources/vm/java/sub-domain.java.vm | 80 + .../src/main/resources/vm/js/api.js.vm | 53 + dc-generator/src/main/resources/vm/sql/sql.vm | 27 + .../main/resources/vm/vue/index-tree.vue.vm | 486 ++ .../src/main/resources/vm/vue/index.vue.vm | 611 ++ .../resources/vm/vue/v3/index-tree.vue.vm | 486 ++ .../src/main/resources/vm/vue/v3/index.vue.vm | 596 ++ .../src/main/resources/vm/vue/v3/readme.txt | 1 + .../src/main/resources/vm/xml/mapper.xml.vm | 29 + dc-model/pom.xml | 12 + .../resources/META-INF/maven/archetype.xml | 9 + .../resources/archetype-resources/pom.xml | 15 + .../src/main/java/App.java | 13 + .../src/test/java/AppTest.java | 38 + dc-quartz/pom.xml | 40 + .../com/dc/quartz/config/ScheduleConfig.java | 57 + .../quartz/controller/SysJobController.java | 179 + .../controller/SysJobLogController.java | 88 + .../java/com/dc/quartz/domain/SysJob.java | 171 + .../java/com/dc/quartz/domain/SysJobLog.java | 156 + .../com/dc/quartz/mapper/SysJobLogMapper.java | 66 + .../com/dc/quartz/mapper/SysJobMapper.java | 69 + .../dc/quartz/service/SysJobLogService.java | 79 + .../com/dc/quartz/service/SysJobService.java | 249 + .../main/java/com/dc/quartz/task/RyTask.java | 28 + .../com/dc/quartz/util/AbstractQuartzJob.java | 108 + .../java/com/dc/quartz/util/CronUtils.java | 64 + .../com/dc/quartz/util/JobInvokeUtil.java | 183 + .../QuartzDisallowConcurrentExecution.java | 21 + .../dc/quartz/util/QuartzJobExecution.java | 19 + .../com/dc/quartz/util/ScheduleUtils.java | 138 + .../mapper/quartz/SysJobLogMapper.xml | 93 + .../resources/mapper/quartz/SysJobMapper.xml | 111 + dc-system/pom.xml | 41 + .../java/com/dc/system/domain/Accessory.java | 45 + .../java/com/dc/system/domain/SysCache.java | 45 + .../java/com/dc/system/domain/SysCity.java | 37 + .../java/com/dc/system/domain/SysConfig.java | 115 + .../com/dc/system/domain/SysLogininfor.java | 67 + .../java/com/dc/system/domain/SysNotice.java | 106 + .../java/com/dc/system/domain/SysOperLog.java | 98 + .../java/com/dc/system/domain/SysPost.java | 128 + .../com/dc/system/domain/SysRoleDept.java | 25 + .../com/dc/system/domain/SysRoleMenu.java | 25 + .../com/dc/system/domain/SysTaskForm.java | 66 + .../com/dc/system/domain/SysUserOnline.java | 43 + .../com/dc/system/domain/SysUserPost.java | 25 + .../com/dc/system/domain/SysUserRole.java | 25 + .../java/com/dc/system/domain/vo/MetaVo.java | 106 + .../com/dc/system/domain/vo/RouterVo.java | 148 + .../com/dc/system/mapper/AccessoryMapper.java | 17 + .../com/dc/system/mapper/SysCityMapper.java | 16 + .../com/dc/system/mapper/SysConfigMapper.java | 78 + .../com/dc/system/mapper/SysDeptMapper.java | 120 + .../dc/system/mapper/SysDictDataMapper.java | 97 + .../dc/system/mapper/SysDictTypeMapper.java | 85 + .../dc/system/mapper/SysLogininforMapper.java | 44 + .../com/dc/system/mapper/SysMenuMapper.java | 136 + .../com/dc/system/mapper/SysNoticeMapper.java | 62 + .../dc/system/mapper/SysOperLogMapper.java | 50 + .../com/dc/system/mapper/SysPostMapper.java | 101 + .../dc/system/mapper/SysRoleDeptMapper.java | 46 + .../com/dc/system/mapper/SysRoleMapper.java | 109 + .../dc/system/mapper/SysRoleMenuMapper.java | 46 + .../dc/system/mapper/SysTaskFormMapper.java | 61 + .../com/dc/system/mapper/SysUserMapper.java | 137 + .../dc/system/mapper/SysUserPostMapper.java | 46 + .../dc/system/mapper/SysUserRoleMapper.java | 66 + .../dc/system/service/AccessoryService.java | 41 + .../com/dc/system/service/SysCityService.java | 18 + .../dc/system/service/SysConfigService.java | 219 + .../com/dc/system/service/SysDeptService.java | 325 + .../dc/system/service/SysDictDataService.java | 105 + .../dc/system/service/SysDictTypeService.java | 202 + .../system/service/SysLogininforService.java | 61 + .../com/dc/system/service/SysMenuService.java | 458 + .../dc/system/service/SysNoticeService.java | 86 + .../dc/system/service/SysOperLogService.java | 71 + .../com/dc/system/service/SysPostService.java | 168 + .../com/dc/system/service/SysRoleService.java | 401 + .../system/service/SysUserOnlineService.java | 91 + .../com/dc/system/service/SysUserService.java | 522 ++ .../dc/system/service/cache/SysCityCache.java | 54 + .../mapper/system/AccessoryMapper.xml | 29 + .../resources/mapper/system/SysCityMapper.xml | 25 + .../mapper/system/SysConfigMapper.xml | 113 + .../resources/mapper/system/SysDeptMapper.xml | 161 + .../mapper/system/SysDictDataMapper.xml | 125 + .../mapper/system/SysDictTypeMapper.xml | 105 + .../mapper/system/SysLogininforMapper.xml | 57 + .../resources/mapper/system/SysMenuMapper.xml | 207 + .../mapper/system/SysNoticeMapper.xml | 90 + .../mapper/system/SysOperLogMapper.xml | 86 + .../resources/mapper/system/SysPostMapper.xml | 122 + .../mapper/system/SysRoleDeptMapper.xml | 34 + .../resources/mapper/system/SysRoleMapper.xml | 153 + .../mapper/system/SysRoleMenuMapper.xml | 34 + .../resources/mapper/system/SysUserMapper.xml | 226 + .../mapper/system/SysUserPostMapper.xml | 34 + .../mapper/system/SysUserRoleMapper.xml | 44 + dc.bat | 67 + dc.sh | 86 + doc/开发文档说明.docx | Bin 0 -> 428430 bytes logs/sys-error.2023-03-08.log | 0 logs/sys-error.2023-03-09.log | 110 + logs/sys-error.2023-07-06.log | 54 + logs/sys-error.2023-07-19.log | 221 + logs/sys-error.2023-07-20.log | 202 + logs/sys-error.2023-07-24.log | 107 + logs/sys-error.2023-07-28.log | 7616 +++++++++++++++++ logs/sys-error.log | 3588 ++++++++ logs/sys-info.2023-03-08.log | 154 + logs/sys-info.2023-03-09.log | 41 + logs/sys-info.2023-03-10.log | 185 + logs/sys-info.2023-07-06.log | 78 + logs/sys-info.2023-07-19.log | 781 ++ logs/sys-info.2023-07-20.log | 821 ++ logs/sys-info.2023-07-21.log | 243 + logs/sys-info.2023-07-24.log | 1037 +++ logs/sys-info.2023-07-25.log | 167 + logs/sys-info.2023-07-27.log | 862 ++ logs/sys-info.2023-07-28.log | 503 ++ logs/sys-info.2023-07-29.log | 6 + logs/sys-info.2023-07-31.log | 211 + logs/sys-info.log | 784 ++ logs/sys-user.2023-03-08.log | 6 + logs/sys-user.2023-03-09.log | 4 + logs/sys-user.2023-07-06.log | 8 + logs/sys-user.2023-07-19.log | 18 + logs/sys-user.2023-07-20.log | 10 + logs/sys-user.2023-07-21.log | 3 + logs/sys-user.2023-07-24.log | 17 + logs/sys-user.2023-07-25.log | 3 + logs/sys-user.2023-07-27.log | 26 + logs/sys-user.2023-07-28.log | 17 + logs/sys-user.2023-07-29.log | 1 + logs/sys-user.2023-07-31.log | 10 + logs/sys-user.log | 19 + mybatis-plus-mate.md | 47 + pom.xml | 306 + sql/quartz.sql | 174 + sql/ry_20220822.sql | 692 ++ .../resources/META-INF/maven/archetype.xml | 9 + .../resources/archetype-resources/pom.xml | 15 + .../src/main/java/App.java | 13 + .../src/test/java/AppTest.java | 38 + 384 files changed, 57031 insertions(+) create mode 100644 .gitignore create mode 100644 LICENSE create mode 100644 README.md create mode 100644 bin/clean.bat create mode 100644 bin/package.bat create mode 100644 bin/run.bat create mode 100644 dc-admin/pom.xml create mode 100644 dc-admin/src/main/java/com/dc/web/DcApplication.java create mode 100644 dc-admin/src/main/java/com/dc/web/DcServletInitializer.java create mode 100644 dc-admin/src/main/java/com/dc/web/config/SwaggerConfig.java create mode 100644 dc-admin/src/main/java/com/dc/web/controller/common/CaptchaController.java create mode 100644 dc-admin/src/main/java/com/dc/web/controller/common/CommonController.java create mode 100644 dc-admin/src/main/java/com/dc/web/controller/monitor/CacheController.java create mode 100644 dc-admin/src/main/java/com/dc/web/controller/monitor/ServerController.java create mode 100644 dc-admin/src/main/java/com/dc/web/controller/monitor/SysLogininforController.java create mode 100644 dc-admin/src/main/java/com/dc/web/controller/monitor/SysOperlogController.java create mode 100644 dc-admin/src/main/java/com/dc/web/controller/monitor/SysUserOnlineController.java create mode 100644 dc-admin/src/main/java/com/dc/web/controller/system/SysCityController.java create mode 100644 dc-admin/src/main/java/com/dc/web/controller/system/SysConfigController.java create mode 100644 dc-admin/src/main/java/com/dc/web/controller/system/SysDeptController.java create mode 100644 dc-admin/src/main/java/com/dc/web/controller/system/SysDictDataController.java create mode 100644 dc-admin/src/main/java/com/dc/web/controller/system/SysDictTypeController.java create mode 100644 dc-admin/src/main/java/com/dc/web/controller/system/SysIndexController.java create mode 100644 dc-admin/src/main/java/com/dc/web/controller/system/SysLoginController.java create mode 100644 dc-admin/src/main/java/com/dc/web/controller/system/SysMenuController.java create mode 100644 dc-admin/src/main/java/com/dc/web/controller/system/SysNoticeController.java create mode 100644 dc-admin/src/main/java/com/dc/web/controller/system/SysPostController.java create mode 100644 dc-admin/src/main/java/com/dc/web/controller/system/SysProfileController.java create mode 100644 dc-admin/src/main/java/com/dc/web/controller/system/SysRegisterController.java create mode 100644 dc-admin/src/main/java/com/dc/web/controller/system/SysRoleController.java create mode 100644 dc-admin/src/main/java/com/dc/web/controller/system/SysUserController.java create mode 100644 dc-admin/src/main/java/com/dc/web/controller/tool/SwaggerController.java create mode 100644 dc-admin/src/main/java/com/dc/web/controller/tool/TestController.java create mode 100644 dc-admin/src/main/java/com/dc/web/websocket/SemaphoreUtils.java create mode 100644 dc-admin/src/main/java/com/dc/web/websocket/WebSocketConfig.java create mode 100644 dc-admin/src/main/java/com/dc/web/websocket/WebSocketServer.java create mode 100644 dc-admin/src/main/java/com/dc/web/websocket/WebSocketUsers.java create mode 100644 dc-admin/src/main/resources/META-INF/spring-devtools.properties create mode 100644 dc-admin/src/main/resources/application-dev.yml create mode 100644 dc-admin/src/main/resources/application-druid.yml create mode 100644 dc-admin/src/main/resources/application-mybatis.yml create mode 100644 dc-admin/src/main/resources/application-prod.yml create mode 100644 dc-admin/src/main/resources/application-test.yml create mode 100644 dc-admin/src/main/resources/application.yml create mode 100644 dc-admin/src/main/resources/i18n/messages.properties create mode 100644 dc-admin/src/main/resources/logback-spring.xml create mode 100644 dc-admin/src/main/resources/mybatis/mybatis-config.xml create mode 100644 dc-app/pom.xml create mode 100644 dc-app/src/main/java/com/dc/app/AppApplication.java create mode 100644 dc-app/src/main/java/com/dc/app/config/SwaggerConfig.java create mode 100644 dc-app/src/main/java/com/dc/app/config/WebConfig.java create mode 100644 dc-app/src/main/java/com/dc/app/controller/common/CommonController.java create mode 100644 dc-app/src/main/java/com/dc/app/controller/system/SysDictDataController.java create mode 100644 dc-app/src/main/resources/META-INF/spring-devtools.properties create mode 100644 dc-app/src/main/resources/application-dev.yml create mode 100644 dc-app/src/main/resources/application-druid.yml create mode 100644 dc-app/src/main/resources/application-mybatis.yml create mode 100644 dc-app/src/main/resources/application-prod.yml create mode 100644 dc-app/src/main/resources/application-test.yml create mode 100644 dc-app/src/main/resources/application.yml create mode 100644 dc-app/src/main/resources/i18n/messages.properties create mode 100644 dc-app/src/main/resources/logback-spring.xml create mode 100644 dc-common/pom.xml create mode 100644 dc-common/src/main/java/com/dc/common/annotation/Anonymous.java create mode 100644 dc-common/src/main/java/com/dc/common/annotation/DataScope.java create mode 100644 dc-common/src/main/java/com/dc/common/annotation/DataScopeCommon.java create mode 100644 dc-common/src/main/java/com/dc/common/annotation/Excel.java create mode 100644 dc-common/src/main/java/com/dc/common/annotation/Excels.java create mode 100644 dc-common/src/main/java/com/dc/common/annotation/Log.java create mode 100644 dc-common/src/main/java/com/dc/common/annotation/RateLimiter.java create mode 100644 dc-common/src/main/java/com/dc/common/annotation/RepeatSubmit.java create mode 100644 dc-common/src/main/java/com/dc/common/config/WinConfig.java create mode 100644 dc-common/src/main/java/com/dc/common/constant/CacheConstants.java create mode 100644 dc-common/src/main/java/com/dc/common/constant/Constants.java create mode 100644 dc-common/src/main/java/com/dc/common/constant/DBConstants.java create mode 100644 dc-common/src/main/java/com/dc/common/constant/GenConstants.java create mode 100644 dc-common/src/main/java/com/dc/common/constant/HttpStatus.java create mode 100644 dc-common/src/main/java/com/dc/common/constant/ScheduleConstants.java create mode 100644 dc-common/src/main/java/com/dc/common/constant/UserConstants.java create mode 100644 dc-common/src/main/java/com/dc/common/context/DataScopeHolder.java create mode 100644 dc-common/src/main/java/com/dc/common/core/controller/BaseController.java create mode 100644 dc-common/src/main/java/com/dc/common/core/domain/AjaxResult.java create mode 100644 dc-common/src/main/java/com/dc/common/core/domain/BaseEntity.java create mode 100644 dc-common/src/main/java/com/dc/common/core/domain/IdEntity.java create mode 100644 dc-common/src/main/java/com/dc/common/core/domain/R.java create mode 100644 dc-common/src/main/java/com/dc/common/core/domain/TreeEntity.java create mode 100644 dc-common/src/main/java/com/dc/common/core/domain/TreeSelect.java create mode 100644 dc-common/src/main/java/com/dc/common/core/domain/WinBaseEntity.java create mode 100644 dc-common/src/main/java/com/dc/common/core/domain/entity/SysDept.java create mode 100644 dc-common/src/main/java/com/dc/common/core/domain/entity/SysDictData.java create mode 100644 dc-common/src/main/java/com/dc/common/core/domain/entity/SysDictType.java create mode 100644 dc-common/src/main/java/com/dc/common/core/domain/entity/SysMenu.java create mode 100644 dc-common/src/main/java/com/dc/common/core/domain/entity/SysRole.java create mode 100644 dc-common/src/main/java/com/dc/common/core/domain/entity/SysUser.java create mode 100644 dc-common/src/main/java/com/dc/common/core/domain/model/LoginBody.java create mode 100644 dc-common/src/main/java/com/dc/common/core/domain/model/LoginUser.java create mode 100644 dc-common/src/main/java/com/dc/common/core/domain/model/RegisterBody.java create mode 100644 dc-common/src/main/java/com/dc/common/core/page/PageDomain.java create mode 100644 dc-common/src/main/java/com/dc/common/core/page/TableDataInfo.java create mode 100644 dc-common/src/main/java/com/dc/common/core/page/TableSupport.java create mode 100644 dc-common/src/main/java/com/dc/common/core/redis/RedisCache.java create mode 100644 dc-common/src/main/java/com/dc/common/core/text/CharsetKit.java create mode 100644 dc-common/src/main/java/com/dc/common/core/text/Convert.java create mode 100644 dc-common/src/main/java/com/dc/common/core/text/StrFormatter.java create mode 100644 dc-common/src/main/java/com/dc/common/enums/AccessoryType.java create mode 100644 dc-common/src/main/java/com/dc/common/enums/BusinessStatus.java create mode 100644 dc-common/src/main/java/com/dc/common/enums/BusinessType.java create mode 100644 dc-common/src/main/java/com/dc/common/enums/DataSourceType.java create mode 100644 dc-common/src/main/java/com/dc/common/enums/HttpMethod.java create mode 100644 dc-common/src/main/java/com/dc/common/enums/LimitType.java create mode 100644 dc-common/src/main/java/com/dc/common/enums/OperatorType.java create mode 100644 dc-common/src/main/java/com/dc/common/enums/UserStatus.java create mode 100644 dc-common/src/main/java/com/dc/common/exception/CustomException.java create mode 100644 dc-common/src/main/java/com/dc/common/exception/DatabaseException.java create mode 100644 dc-common/src/main/java/com/dc/common/exception/DemoModeException.java create mode 100644 dc-common/src/main/java/com/dc/common/exception/GlobalException.java create mode 100644 dc-common/src/main/java/com/dc/common/exception/NotExistsException.java create mode 100644 dc-common/src/main/java/com/dc/common/exception/ServiceException.java create mode 100644 dc-common/src/main/java/com/dc/common/exception/UtilException.java create mode 100644 dc-common/src/main/java/com/dc/common/exception/base/BaseException.java create mode 100644 dc-common/src/main/java/com/dc/common/exception/file/FileException.java create mode 100644 dc-common/src/main/java/com/dc/common/exception/file/FileNameLengthLimitExceededException.java create mode 100644 dc-common/src/main/java/com/dc/common/exception/file/FileSizeLimitExceededException.java create mode 100644 dc-common/src/main/java/com/dc/common/exception/file/InvalidExtensionException.java create mode 100644 dc-common/src/main/java/com/dc/common/exception/job/TaskException.java create mode 100644 dc-common/src/main/java/com/dc/common/exception/user/CaptchaException.java create mode 100644 dc-common/src/main/java/com/dc/common/exception/user/CaptchaExpireException.java create mode 100644 dc-common/src/main/java/com/dc/common/exception/user/UserException.java create mode 100644 dc-common/src/main/java/com/dc/common/exception/user/UserPasswordNotMatchException.java create mode 100644 dc-common/src/main/java/com/dc/common/exception/user/UserPasswordRetryLimitExceedException.java create mode 100644 dc-common/src/main/java/com/dc/common/extension/MpSqlInjector.java create mode 100644 dc-common/src/main/java/com/dc/common/filter/PropertyPreExcludeFilter.java create mode 100644 dc-common/src/main/java/com/dc/common/filter/RepeatableFilter.java create mode 100644 dc-common/src/main/java/com/dc/common/filter/RepeatedlyRequestWrapper.java create mode 100644 dc-common/src/main/java/com/dc/common/filter/XssFilter.java create mode 100644 dc-common/src/main/java/com/dc/common/filter/XssHttpServletRequestWrapper.java create mode 100644 dc-common/src/main/java/com/dc/common/utils/AESKit.java create mode 100644 dc-common/src/main/java/com/dc/common/utils/Arith.java create mode 100644 dc-common/src/main/java/com/dc/common/utils/DateUtils.java create mode 100644 dc-common/src/main/java/com/dc/common/utils/DictUtils.java create mode 100644 dc-common/src/main/java/com/dc/common/utils/ExceptionUtil.java create mode 100644 dc-common/src/main/java/com/dc/common/utils/IdEncodes.java create mode 100644 dc-common/src/main/java/com/dc/common/utils/LogUtils.java create mode 100644 dc-common/src/main/java/com/dc/common/utils/MessageUtils.java create mode 100644 dc-common/src/main/java/com/dc/common/utils/PageUtils.java create mode 100644 dc-common/src/main/java/com/dc/common/utils/SecurityUtils.java create mode 100644 dc-common/src/main/java/com/dc/common/utils/ServletUtils.java create mode 100644 dc-common/src/main/java/com/dc/common/utils/StringUtils.java create mode 100644 dc-common/src/main/java/com/dc/common/utils/Threads.java create mode 100644 dc-common/src/main/java/com/dc/common/utils/bean/BeanUtils.java create mode 100644 dc-common/src/main/java/com/dc/common/utils/bean/BeanValidators.java create mode 100644 dc-common/src/main/java/com/dc/common/utils/file/FileTypeUtils.java create mode 100644 dc-common/src/main/java/com/dc/common/utils/file/FileUploadUtils.java create mode 100644 dc-common/src/main/java/com/dc/common/utils/file/FileUtils.java create mode 100644 dc-common/src/main/java/com/dc/common/utils/file/ImageUtils.java create mode 100644 dc-common/src/main/java/com/dc/common/utils/file/MimeTypeUtils.java create mode 100644 dc-common/src/main/java/com/dc/common/utils/html/EscapeUtil.java create mode 100644 dc-common/src/main/java/com/dc/common/utils/html/HTMLFilter.java create mode 100644 dc-common/src/main/java/com/dc/common/utils/http/HttpHelper.java create mode 100644 dc-common/src/main/java/com/dc/common/utils/http/HttpUtils.java create mode 100644 dc-common/src/main/java/com/dc/common/utils/ip/AddressUtils.java create mode 100644 dc-common/src/main/java/com/dc/common/utils/ip/IpUtils.java create mode 100644 dc-common/src/main/java/com/dc/common/utils/poi/ExcelHandlerAdapter.java create mode 100644 dc-common/src/main/java/com/dc/common/utils/poi/ExcelUtil.java create mode 100644 dc-common/src/main/java/com/dc/common/utils/reflect/ReflectUtils.java create mode 100644 dc-common/src/main/java/com/dc/common/utils/sign/Base64.java create mode 100644 dc-common/src/main/java/com/dc/common/utils/sign/Md5Utils.java create mode 100644 dc-common/src/main/java/com/dc/common/utils/spring/SpringUtils.java create mode 100644 dc-common/src/main/java/com/dc/common/utils/sql/SqlUtil.java create mode 100644 dc-common/src/main/java/com/dc/common/utils/uuid/IdUtils.java create mode 100644 dc-common/src/main/java/com/dc/common/utils/uuid/Seq.java create mode 100644 dc-common/src/main/java/com/dc/common/utils/uuid/UUID.java create mode 100644 dc-common/src/main/java/com/dc/common/xss/Xss.java create mode 100644 dc-common/src/main/java/com/dc/common/xss/XssValidator.java create mode 100644 dc-framework/pom.xml create mode 100644 dc-framework/src/main/java/com/dc/framework/aspectj/DataScopeAspect.java create mode 100644 dc-framework/src/main/java/com/dc/framework/aspectj/DataScopeCommonAspect.java create mode 100644 dc-framework/src/main/java/com/dc/framework/aspectj/LogAspect.java create mode 100644 dc-framework/src/main/java/com/dc/framework/aspectj/RateLimiterAspect.java create mode 100644 dc-framework/src/main/java/com/dc/framework/config/ApplicationConfig.java create mode 100644 dc-framework/src/main/java/com/dc/framework/config/CaptchaConfig.java create mode 100644 dc-framework/src/main/java/com/dc/framework/config/DataSourceConfiguration.java create mode 100644 dc-framework/src/main/java/com/dc/framework/config/FastJson2JsonRedisSerializer.java create mode 100644 dc-framework/src/main/java/com/dc/framework/config/FilterConfig.java create mode 100644 dc-framework/src/main/java/com/dc/framework/config/KaptchaTextCreator.java create mode 100644 dc-framework/src/main/java/com/dc/framework/config/MybatisPlusConfig.java create mode 100644 dc-framework/src/main/java/com/dc/framework/config/RedisConfig.java create mode 100644 dc-framework/src/main/java/com/dc/framework/config/ResourcesConfig.java create mode 100644 dc-framework/src/main/java/com/dc/framework/config/SecurityConfig.java create mode 100644 dc-framework/src/main/java/com/dc/framework/config/ServerConfig.java create mode 100644 dc-framework/src/main/java/com/dc/framework/config/ThreadPoolConfig.java create mode 100644 dc-framework/src/main/java/com/dc/framework/config/properties/PermitAllUrlProperties.java create mode 100644 dc-framework/src/main/java/com/dc/framework/interceptor/RepeatSubmitInterceptor.java create mode 100644 dc-framework/src/main/java/com/dc/framework/interceptor/UnionIdInterceptor.java create mode 100644 dc-framework/src/main/java/com/dc/framework/interceptor/impl/DataScopeInterceptor.java create mode 100644 dc-framework/src/main/java/com/dc/framework/interceptor/impl/SameUrlDataInterceptor.java create mode 100644 dc-framework/src/main/java/com/dc/framework/manager/AsyncManager.java create mode 100644 dc-framework/src/main/java/com/dc/framework/manager/ShutdownManager.java create mode 100644 dc-framework/src/main/java/com/dc/framework/manager/factory/AsyncFactory.java create mode 100644 dc-framework/src/main/java/com/dc/framework/security/context/AuthenticationContextHolder.java create mode 100644 dc-framework/src/main/java/com/dc/framework/security/context/PermissionContextHolder.java create mode 100644 dc-framework/src/main/java/com/dc/framework/security/filter/JwtAuthenticationTokenFilter.java create mode 100644 dc-framework/src/main/java/com/dc/framework/security/handle/AuthenticationEntryPointImpl.java create mode 100644 dc-framework/src/main/java/com/dc/framework/security/handle/LogoutSuccessHandlerImpl.java create mode 100644 dc-framework/src/main/java/com/dc/framework/web/domain/Server.java create mode 100644 dc-framework/src/main/java/com/dc/framework/web/domain/server/Cpu.java create mode 100644 dc-framework/src/main/java/com/dc/framework/web/domain/server/Jvm.java create mode 100644 dc-framework/src/main/java/com/dc/framework/web/domain/server/Mem.java create mode 100644 dc-framework/src/main/java/com/dc/framework/web/domain/server/Sys.java create mode 100644 dc-framework/src/main/java/com/dc/framework/web/domain/server/SysFile.java create mode 100644 dc-framework/src/main/java/com/dc/framework/web/exception/GlobalExceptionHandler.java create mode 100644 dc-framework/src/main/java/com/dc/framework/web/service/PermissionService.java create mode 100644 dc-framework/src/main/java/com/dc/framework/web/service/SysLoginService.java create mode 100644 dc-framework/src/main/java/com/dc/framework/web/service/SysPasswordService.java create mode 100644 dc-framework/src/main/java/com/dc/framework/web/service/SysPermissionService.java create mode 100644 dc-framework/src/main/java/com/dc/framework/web/service/SysRegisterService.java create mode 100644 dc-framework/src/main/java/com/dc/framework/web/service/TokenService.java create mode 100644 dc-framework/src/main/java/com/dc/framework/web/service/UserDetailsServiceImpl.java create mode 100644 dc-generator/pom.xml create mode 100644 dc-generator/src/main/java/com/dc/generator/config/GenConfig.java create mode 100644 dc-generator/src/main/java/com/dc/generator/controller/GenController.java create mode 100644 dc-generator/src/main/java/com/dc/generator/domain/GenTable.java create mode 100644 dc-generator/src/main/java/com/dc/generator/domain/GenTableColumn.java create mode 100644 dc-generator/src/main/java/com/dc/generator/mapper/GenTableColumnMapper.java create mode 100644 dc-generator/src/main/java/com/dc/generator/mapper/GenTableMapper.java create mode 100644 dc-generator/src/main/java/com/dc/generator/service/GenTableColumnService.java create mode 100644 dc-generator/src/main/java/com/dc/generator/service/GenTableService.java create mode 100644 dc-generator/src/main/java/com/dc/generator/util/GenUtils.java create mode 100644 dc-generator/src/main/java/com/dc/generator/util/VelocityInitializer.java create mode 100644 dc-generator/src/main/java/com/dc/generator/util/VelocityUtils.java create mode 100644 dc-generator/src/main/resources/generator.yml create mode 100644 dc-generator/src/main/resources/mapper/generator/GenTableColumnMapper.xml create mode 100644 dc-generator/src/main/resources/mapper/generator/GenTableMapper.xml create mode 100644 dc-generator/src/main/resources/vm/doc/doc.md.vm create mode 100644 dc-generator/src/main/resources/vm/java/controller.java.vm create mode 100644 dc-generator/src/main/resources/vm/java/domain.java.vm create mode 100644 dc-generator/src/main/resources/vm/java/mapper.java.vm create mode 100644 dc-generator/src/main/resources/vm/java/service.java.vm create mode 100644 dc-generator/src/main/resources/vm/java/sub-domain.java.vm create mode 100644 dc-generator/src/main/resources/vm/js/api.js.vm create mode 100644 dc-generator/src/main/resources/vm/sql/sql.vm create mode 100644 dc-generator/src/main/resources/vm/vue/index-tree.vue.vm create mode 100644 dc-generator/src/main/resources/vm/vue/index.vue.vm create mode 100644 dc-generator/src/main/resources/vm/vue/v3/index-tree.vue.vm create mode 100644 dc-generator/src/main/resources/vm/vue/v3/index.vue.vm create mode 100644 dc-generator/src/main/resources/vm/vue/v3/readme.txt create mode 100644 dc-generator/src/main/resources/vm/xml/mapper.xml.vm create mode 100644 dc-model/pom.xml create mode 100644 dc-model/src/main/resources/META-INF/maven/archetype.xml create mode 100644 dc-model/src/main/resources/archetype-resources/pom.xml create mode 100644 dc-model/src/main/resources/archetype-resources/src/main/java/App.java create mode 100644 dc-model/src/main/resources/archetype-resources/src/test/java/AppTest.java create mode 100644 dc-quartz/pom.xml create mode 100644 dc-quartz/src/main/java/com/dc/quartz/config/ScheduleConfig.java create mode 100644 dc-quartz/src/main/java/com/dc/quartz/controller/SysJobController.java create mode 100644 dc-quartz/src/main/java/com/dc/quartz/controller/SysJobLogController.java create mode 100644 dc-quartz/src/main/java/com/dc/quartz/domain/SysJob.java create mode 100644 dc-quartz/src/main/java/com/dc/quartz/domain/SysJobLog.java create mode 100644 dc-quartz/src/main/java/com/dc/quartz/mapper/SysJobLogMapper.java create mode 100644 dc-quartz/src/main/java/com/dc/quartz/mapper/SysJobMapper.java create mode 100644 dc-quartz/src/main/java/com/dc/quartz/service/SysJobLogService.java create mode 100644 dc-quartz/src/main/java/com/dc/quartz/service/SysJobService.java create mode 100644 dc-quartz/src/main/java/com/dc/quartz/task/RyTask.java create mode 100644 dc-quartz/src/main/java/com/dc/quartz/util/AbstractQuartzJob.java create mode 100644 dc-quartz/src/main/java/com/dc/quartz/util/CronUtils.java create mode 100644 dc-quartz/src/main/java/com/dc/quartz/util/JobInvokeUtil.java create mode 100644 dc-quartz/src/main/java/com/dc/quartz/util/QuartzDisallowConcurrentExecution.java create mode 100644 dc-quartz/src/main/java/com/dc/quartz/util/QuartzJobExecution.java create mode 100644 dc-quartz/src/main/java/com/dc/quartz/util/ScheduleUtils.java create mode 100644 dc-quartz/src/main/resources/mapper/quartz/SysJobLogMapper.xml create mode 100644 dc-quartz/src/main/resources/mapper/quartz/SysJobMapper.xml create mode 100644 dc-system/pom.xml create mode 100644 dc-system/src/main/java/com/dc/system/domain/Accessory.java create mode 100644 dc-system/src/main/java/com/dc/system/domain/SysCache.java create mode 100644 dc-system/src/main/java/com/dc/system/domain/SysCity.java create mode 100644 dc-system/src/main/java/com/dc/system/domain/SysConfig.java create mode 100644 dc-system/src/main/java/com/dc/system/domain/SysLogininfor.java create mode 100644 dc-system/src/main/java/com/dc/system/domain/SysNotice.java create mode 100644 dc-system/src/main/java/com/dc/system/domain/SysOperLog.java create mode 100644 dc-system/src/main/java/com/dc/system/domain/SysPost.java create mode 100644 dc-system/src/main/java/com/dc/system/domain/SysRoleDept.java create mode 100644 dc-system/src/main/java/com/dc/system/domain/SysRoleMenu.java create mode 100644 dc-system/src/main/java/com/dc/system/domain/SysTaskForm.java create mode 100644 dc-system/src/main/java/com/dc/system/domain/SysUserOnline.java create mode 100644 dc-system/src/main/java/com/dc/system/domain/SysUserPost.java create mode 100644 dc-system/src/main/java/com/dc/system/domain/SysUserRole.java create mode 100644 dc-system/src/main/java/com/dc/system/domain/vo/MetaVo.java create mode 100644 dc-system/src/main/java/com/dc/system/domain/vo/RouterVo.java create mode 100644 dc-system/src/main/java/com/dc/system/mapper/AccessoryMapper.java create mode 100644 dc-system/src/main/java/com/dc/system/mapper/SysCityMapper.java create mode 100644 dc-system/src/main/java/com/dc/system/mapper/SysConfigMapper.java create mode 100644 dc-system/src/main/java/com/dc/system/mapper/SysDeptMapper.java create mode 100644 dc-system/src/main/java/com/dc/system/mapper/SysDictDataMapper.java create mode 100644 dc-system/src/main/java/com/dc/system/mapper/SysDictTypeMapper.java create mode 100644 dc-system/src/main/java/com/dc/system/mapper/SysLogininforMapper.java create mode 100644 dc-system/src/main/java/com/dc/system/mapper/SysMenuMapper.java create mode 100644 dc-system/src/main/java/com/dc/system/mapper/SysNoticeMapper.java create mode 100644 dc-system/src/main/java/com/dc/system/mapper/SysOperLogMapper.java create mode 100644 dc-system/src/main/java/com/dc/system/mapper/SysPostMapper.java create mode 100644 dc-system/src/main/java/com/dc/system/mapper/SysRoleDeptMapper.java create mode 100644 dc-system/src/main/java/com/dc/system/mapper/SysRoleMapper.java create mode 100644 dc-system/src/main/java/com/dc/system/mapper/SysRoleMenuMapper.java create mode 100644 dc-system/src/main/java/com/dc/system/mapper/SysTaskFormMapper.java create mode 100644 dc-system/src/main/java/com/dc/system/mapper/SysUserMapper.java create mode 100644 dc-system/src/main/java/com/dc/system/mapper/SysUserPostMapper.java create mode 100644 dc-system/src/main/java/com/dc/system/mapper/SysUserRoleMapper.java create mode 100644 dc-system/src/main/java/com/dc/system/service/AccessoryService.java create mode 100644 dc-system/src/main/java/com/dc/system/service/SysCityService.java create mode 100644 dc-system/src/main/java/com/dc/system/service/SysConfigService.java create mode 100644 dc-system/src/main/java/com/dc/system/service/SysDeptService.java create mode 100644 dc-system/src/main/java/com/dc/system/service/SysDictDataService.java create mode 100644 dc-system/src/main/java/com/dc/system/service/SysDictTypeService.java create mode 100644 dc-system/src/main/java/com/dc/system/service/SysLogininforService.java create mode 100644 dc-system/src/main/java/com/dc/system/service/SysMenuService.java create mode 100644 dc-system/src/main/java/com/dc/system/service/SysNoticeService.java create mode 100644 dc-system/src/main/java/com/dc/system/service/SysOperLogService.java create mode 100644 dc-system/src/main/java/com/dc/system/service/SysPostService.java create mode 100644 dc-system/src/main/java/com/dc/system/service/SysRoleService.java create mode 100644 dc-system/src/main/java/com/dc/system/service/SysUserOnlineService.java create mode 100644 dc-system/src/main/java/com/dc/system/service/SysUserService.java create mode 100644 dc-system/src/main/java/com/dc/system/service/cache/SysCityCache.java create mode 100644 dc-system/src/main/resources/mapper/system/AccessoryMapper.xml create mode 100644 dc-system/src/main/resources/mapper/system/SysCityMapper.xml create mode 100644 dc-system/src/main/resources/mapper/system/SysConfigMapper.xml create mode 100644 dc-system/src/main/resources/mapper/system/SysDeptMapper.xml create mode 100644 dc-system/src/main/resources/mapper/system/SysDictDataMapper.xml create mode 100644 dc-system/src/main/resources/mapper/system/SysDictTypeMapper.xml create mode 100644 dc-system/src/main/resources/mapper/system/SysLogininforMapper.xml create mode 100644 dc-system/src/main/resources/mapper/system/SysMenuMapper.xml create mode 100644 dc-system/src/main/resources/mapper/system/SysNoticeMapper.xml create mode 100644 dc-system/src/main/resources/mapper/system/SysOperLogMapper.xml create mode 100644 dc-system/src/main/resources/mapper/system/SysPostMapper.xml create mode 100644 dc-system/src/main/resources/mapper/system/SysRoleDeptMapper.xml create mode 100644 dc-system/src/main/resources/mapper/system/SysRoleMapper.xml create mode 100644 dc-system/src/main/resources/mapper/system/SysRoleMenuMapper.xml create mode 100644 dc-system/src/main/resources/mapper/system/SysUserMapper.xml create mode 100644 dc-system/src/main/resources/mapper/system/SysUserPostMapper.xml create mode 100644 dc-system/src/main/resources/mapper/system/SysUserRoleMapper.xml create mode 100644 dc.bat create mode 100644 dc.sh create mode 100644 doc/开发文档说明.docx create mode 100644 logs/sys-error.2023-03-08.log create mode 100644 logs/sys-error.2023-03-09.log create mode 100644 logs/sys-error.2023-07-06.log create mode 100644 logs/sys-error.2023-07-19.log create mode 100644 logs/sys-error.2023-07-20.log create mode 100644 logs/sys-error.2023-07-24.log create mode 100644 logs/sys-error.2023-07-28.log create mode 100644 logs/sys-error.log create mode 100644 logs/sys-info.2023-03-08.log create mode 100644 logs/sys-info.2023-03-09.log create mode 100644 logs/sys-info.2023-03-10.log create mode 100644 logs/sys-info.2023-07-06.log create mode 100644 logs/sys-info.2023-07-19.log create mode 100644 logs/sys-info.2023-07-20.log create mode 100644 logs/sys-info.2023-07-21.log create mode 100644 logs/sys-info.2023-07-24.log create mode 100644 logs/sys-info.2023-07-25.log create mode 100644 logs/sys-info.2023-07-27.log create mode 100644 logs/sys-info.2023-07-28.log create mode 100644 logs/sys-info.2023-07-29.log create mode 100644 logs/sys-info.2023-07-31.log create mode 100644 logs/sys-info.log create mode 100644 logs/sys-user.2023-03-08.log create mode 100644 logs/sys-user.2023-03-09.log create mode 100644 logs/sys-user.2023-07-06.log create mode 100644 logs/sys-user.2023-07-19.log create mode 100644 logs/sys-user.2023-07-20.log create mode 100644 logs/sys-user.2023-07-21.log create mode 100644 logs/sys-user.2023-07-24.log create mode 100644 logs/sys-user.2023-07-25.log create mode 100644 logs/sys-user.2023-07-27.log create mode 100644 logs/sys-user.2023-07-28.log create mode 100644 logs/sys-user.2023-07-29.log create mode 100644 logs/sys-user.2023-07-31.log create mode 100644 logs/sys-user.log create mode 100644 mybatis-plus-mate.md create mode 100644 pom.xml create mode 100644 sql/quartz.sql create mode 100644 sql/ry_20220822.sql create mode 100644 src/main/resources/META-INF/maven/archetype.xml create mode 100644 src/main/resources/archetype-resources/pom.xml create mode 100644 src/main/resources/archetype-resources/src/main/java/App.java create mode 100644 src/main/resources/archetype-resources/src/test/java/AppTest.java diff --git a/.gitignore b/.gitignore new file mode 100644 index 0000000..5dfe643 --- /dev/null +++ b/.gitignore @@ -0,0 +1,5 @@ +*.idea +*.gitignore +*/target/ +*.imi +*.DS_Store \ No newline at end of file diff --git a/LICENSE b/LICENSE new file mode 100644 index 0000000..2631087 --- /dev/null +++ b/LICENSE @@ -0,0 +1,20 @@ +The MIT License (MIT) + +Copyright (c) 2018 Dc + +Permission is hereby granted, free of charge, to any person obtaining a copy of +this software and associated documentation files (the "Software"), to deal in +the Software without restriction, including without limitation the rights to +use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of +the Software, and to permit persons to whom the Software is furnished to do so, +subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all +copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS +FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR +COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER +IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN +CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. \ No newline at end of file diff --git a/README.md b/README.md new file mode 100644 index 0000000..cd0899d --- /dev/null +++ b/README.md @@ -0,0 +1,95 @@ +<p align="center"> + <img alt="logo" src="https://oscimg.oschina.net/oscnet/up-d3d0a9303e11d522a06cd263f3079027715.png"> +</p> +<h1 align="center" style="margin: 30px 0 30px; font-weight: bold;">RuoYi v3.8.4</h1> +<h4 align="center">基于SpringBoot+Vue前后端分离的Java快速开发框架</h4> +<p align="center"> + <a href="https://gitee.com/y_project/RuoYi-Vue/stargazers"><img src="https://gitee.com/y_project/RuoYi-Vue/badge/star.svg?theme=dark"></a> + <a href="https://gitee.com/y_project/RuoYi-Vue"><img src="https://img.shields.io/badge/RuoYi-v3.8.4-brightgreen.svg"></a> + <a href="https://gitee.com/y_project/RuoYi-Vue/blob/master/LICENSE"><img src="https://img.shields.io/github/license/mashape/apistatus.svg"></a> +</p> + +## 平台简介 + +[若依](https://gitee.com/zhangmrit/RuoYi-Vue) 是一套全部开源的快速开发平台,毫无保留给个人及企业免费使用。 + +* 前端采用Vue、Element UI。 +* 后端采用Spring Boot、Spring Security、Redis & Jwt。 +* 权限认证使用Jwt,支持多终端认证系统。 +* 支持加载动态权限菜单,多方式轻松权限控制。 +* 高效率开发,使用代码生成器可以一键生成前后端代码。 +* 在原有基础上添加了 lombok mybatis-plus hutool guava +* 代码生成添加了markdown api文档 +* nested 嵌套路由分支 +* shardingsphere shardingsphere分支 + +## 内置功能 + +1. 用户管理:用户是系统操作者,该功能主要完成系统用户配置。 +2. 部门管理:配置系统组织机构(公司、部门、小组),树结构展现支持数据权限。 +3. 岗位管理:配置系统用户所属担任职务。 +4. 菜单管理:配置系统菜单,操作权限,按钮权限标识等。 +5. 角色管理:角色菜单权限分配、设置角色按机构进行数据范围权限划分。 +6. 字典管理:对系统中经常使用的一些较为固定的数据进行维护。 +7. 参数管理:对系统动态配置常用参数。 +8. 通知公告:系统通知公告信息发布维护。 +9. 操作日志:系统正常操作日志记录和查询;系统异常信息日志记录和查询。 +10. 登录日志:系统登录日志记录查询包含登录异常。 +11. 在线用户:当前系统中活跃用户状态监控。 +12. 定时任务:在线(添加、修改、删除)任务调度包含执行结果日志。 +13. 代码生成:前后端代码的生成(java、html、xml、sql)支持CRUD下载 。 +14. 系统接口:根据业务代码自动生成相关的api接口文档。 +15. 服务监控:监视当前系统CPU、内存、磁盘、堆栈等相关信息。 +16. 缓存监控:对系统的缓存信息查询,命令统计等。 +17. 在线构建器:拖动表单元素生成相应的HTML代码。 +18. 连接池监视:监视当前系统数据库连接池状态,可进行分析SQL找出系统性能瓶颈。 + +## 在线体验 + +- admin/admin123 +- 陆陆续续收到一些打赏,为了更好的体验已用于演示服务器升级。谢谢各位小伙伴。 + +演示地址:http://vue.ruoyi.vip +文档地址:http://doc.ruoyi.vip + +## 演示图 + +<table> + <tr> + <td><img src="https://oscimg.oschina.net/oscnet/cd1f90be5f2684f4560c9519c0f2a232ee8.jpg"/></td> + <td><img src="https://oscimg.oschina.net/oscnet/1cbcf0e6f257c7d3a063c0e3f2ff989e4b3.jpg"/></td> + </tr> + <tr> + <td><img src="https://oscimg.oschina.net/oscnet/up-8074972883b5ba0622e13246738ebba237a.png"/></td> + <td><img src="https://oscimg.oschina.net/oscnet/up-9f88719cdfca9af2e58b352a20e23d43b12.png"/></td> + </tr> + <tr> + <td><img src="https://oscimg.oschina.net/oscnet/up-39bf2584ec3a529b0d5a3b70d15c9b37646.png"/></td> + <td><img src="https://oscimg.oschina.net/oscnet/up-936ec82d1f4872e1bc980927654b6007307.png"/></td> + </tr> + <tr> + <td><img src="https://oscimg.oschina.net/oscnet/up-b2d62ceb95d2dd9b3fbe157bb70d26001e9.png"/></td> + <td><img src="https://oscimg.oschina.net/oscnet/up-d67451d308b7a79ad6819723396f7c3d77a.png"/></td> + </tr> + <tr> + <td><img src="https://oscimg.oschina.net/oscnet/5e8c387724954459291aafd5eb52b456f53.jpg"/></td> + <td><img src="https://oscimg.oschina.net/oscnet/644e78da53c2e92a95dfda4f76e6d117c4b.jpg"/></td> + </tr> + <tr> + <td><img src="https://oscimg.oschina.net/oscnet/up-8370a0d02977eebf6dbf854c8450293c937.png"/></td> + <td><img src="https://oscimg.oschina.net/oscnet/up-49003ed83f60f633e7153609a53a2b644f7.png"/></td> + </tr> + <tr> + <td><img src="https://oscimg.oschina.net/oscnet/up-d4fe726319ece268d4746602c39cffc0621.png"/></td> + <td><img src="https://oscimg.oschina.net/oscnet/up-c195234bbcd30be6927f037a6755e6ab69c.png"/></td> + </tr> + <tr> + <td><img src="https://oscimg.oschina.net/oscnet/b6115bc8c31de52951982e509930b20684a.jpg"/></td> + <td><img src="https://oscimg.oschina.net/oscnet/up-5e4daac0bb59612c5038448acbcef235e3a.png"/></td> + </tr> +</table> + + +## 若依前后端分离交流群 + +QQ群: [](https://jq.qq.com/?_wv=1027&k=5bVB1og) [](https://jq.qq.com/?_wv=1027&k=5eiA4DH) [](https://jq.qq.com/?_wv=1027&k=5AxMKlC) [](https://jq.qq.com/?_wv=1027&k=51G72yr) [](https://jq.qq.com/?_wv=1027&k=VvjN2nvu) [](https://jq.qq.com/?_wv=1027&k=5vYAqA05) [](https://jq.qq.com/?_wv=1027&k=kOIINEb5) [](https://jq.qq.com/?_wv=1027&k=UKtX5jhs) [](https://jq.qq.com/?_wv=1027&k=EI9an8lJ) [](https://jq.qq.com/?_wv=1027&k=SWCtLnMz) [](https://jq.qq.com/?_wv=1027&k=96Dkdq0k) [](https://jq.qq.com/?_wv=1027&k=0fsNiYZt) 点击按钮入群。 \ No newline at end of file diff --git a/bin/clean.bat b/bin/clean.bat new file mode 100644 index 0000000..af841d8 --- /dev/null +++ b/bin/clean.bat @@ -0,0 +1,12 @@ +@echo off +echo. +echo [��Ϣ] ��������target����·���� +echo. + +%~d0 +cd %~dp0 + +cd .. +call mvn clean + +pause \ No newline at end of file diff --git a/bin/package.bat b/bin/package.bat new file mode 100644 index 0000000..af8af8e --- /dev/null +++ b/bin/package.bat @@ -0,0 +1,12 @@ +@echo off +echo. +echo [��Ϣ] ���Web���̣�����war/jar���ļ��� +echo. + +%~d0 +cd %~dp0 + +cd .. +call mvn clean package -Dmaven.test.skip=true + +pause \ No newline at end of file diff --git a/bin/run.bat b/bin/run.bat new file mode 100644 index 0000000..3dc8207 --- /dev/null +++ b/bin/run.bat @@ -0,0 +1,14 @@ +@echo off +echo. +echo [��Ϣ] ʹ��Jar��������Web���̡� +echo. + +cd %~dp0 +cd ../dc-admin/target + +set JAVA_OPTS=-Xms256m -Xmx1024m -XX:MetaspaceSize=128m -XX:MaxMetaspaceSize=512m + +java -jar %JAVA_OPTS% dc-admin.jar + +cd bin +pause \ No newline at end of file diff --git a/dc-admin/pom.xml b/dc-admin/pom.xml new file mode 100644 index 0000000..151104c --- /dev/null +++ b/dc-admin/pom.xml @@ -0,0 +1,96 @@ +<?xml version="1.0" encoding="UTF-8"?> +<project xmlns="http://maven.apache.org/POM/4.0.0" + xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" + xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> + <parent> + <artifactId>dc</artifactId> + <groupId>com.dc</groupId> + <version>1.0.0</version> + </parent> + <modelVersion>4.0.0</modelVersion> + <packaging>jar</packaging> + <artifactId>dc-admin</artifactId> + + <description> + web服务入口 + </description> + + <dependencies> + + <!-- spring-boot-devtools --> + <dependency> + <groupId>org.springframework.boot</groupId> + <artifactId>spring-boot-devtools</artifactId> + <optional>true</optional> <!-- 表示依赖不会传递 --> + </dependency> + + <!-- swagger3--> + <dependency> + <groupId>io.springfox</groupId> + <artifactId>springfox-boot-starter</artifactId> + </dependency> + + <!-- Mysql驱动包 --> + <dependency> + <groupId>mysql</groupId> + <artifactId>mysql-connector-java</artifactId> + </dependency> + + <!-- Postgresql驱动包 --> + <dependency> + <groupId>org.postgresql</groupId> + <artifactId>postgresql</artifactId> + <scope>runtime</scope> + </dependency> + + <!-- 核心模块--> + <dependency> + <groupId>com.dc</groupId> + <artifactId>dc-framework</artifactId> + </dependency> + + <!-- 定时任务--> + <dependency> + <groupId>com.dc</groupId> + <artifactId>dc-quartz</artifactId> + </dependency> + + <!-- 代码生成--> + <dependency> + <groupId>com.dc</groupId> + <artifactId>dc-generator</artifactId> + </dependency> + + </dependencies> + + <build> + <plugins> + <plugin> + <groupId>org.springframework.boot</groupId> + <artifactId>spring-boot-maven-plugin</artifactId> + <version>2.1.1.RELEASE</version> + <configuration> + <fork>true</fork> <!-- 如果没有该配置,devtools不会生效 --> + </configuration> + <executions> + <execution> + <goals> + <goal>repackage</goal> + </goals> + </execution> + </executions> + </plugin> + <plugin> + <groupId>org.apache.maven.plugins</groupId> + <artifactId>maven-war-plugin</artifactId> + <version>3.1.0</version> + <configuration> + <failOnMissingWebXml>false</failOnMissingWebXml> + <warName>${project.artifactId}</warName> + </configuration> + </plugin> + </plugins> + <finalName>${project.artifactId}</finalName> + </build> + +</project> \ No newline at end of file diff --git a/dc-admin/src/main/java/com/dc/web/DcApplication.java b/dc-admin/src/main/java/com/dc/web/DcApplication.java new file mode 100644 index 0000000..64b88e9 --- /dev/null +++ b/dc-admin/src/main/java/com/dc/web/DcApplication.java @@ -0,0 +1,24 @@ +package com.dc.web; + +import com.alibaba.druid.spring.boot.autoconfigure.DruidDataSourceAutoConfigure; +import org.springframework.boot.SpringApplication; +import org.springframework.boot.autoconfigure.SpringBootApplication; +import org.springframework.boot.autoconfigure.jdbc.DataSourceAutoConfiguration; + +/** + * 启动程序 + * + * @author win + */ +@SpringBootApplication( + scanBasePackages = { "com.dc.common", "com.dc.system", "com.dc.framework", "com.dc.generator", "com.dc.quartz", "com.dc.web"}, + exclude = {DataSourceAutoConfiguration.class, DruidDataSourceAutoConfigure.class}) +public class DcApplication { + + public static void main(String[] args) { + // System.setProperty("spring.devtools.restart.enabled", "false"); + SpringApplication.run(DcApplication.class, args); + System.out.println("中台系统启动成功"); + } + +} diff --git a/dc-admin/src/main/java/com/dc/web/DcServletInitializer.java b/dc-admin/src/main/java/com/dc/web/DcServletInitializer.java new file mode 100644 index 0000000..69e49d5 --- /dev/null +++ b/dc-admin/src/main/java/com/dc/web/DcServletInitializer.java @@ -0,0 +1,18 @@ +package com.dc.web; + +import org.springframework.boot.builder.SpringApplicationBuilder; +import org.springframework.boot.web.servlet.support.SpringBootServletInitializer; + +/** + * web容器中进行部署 + * + * @author win + */ +public class DcServletInitializer extends SpringBootServletInitializer +{ + @Override + protected SpringApplicationBuilder configure(SpringApplicationBuilder application) + { + return application.sources(DcApplication.class); + } +} diff --git a/dc-admin/src/main/java/com/dc/web/config/SwaggerConfig.java b/dc-admin/src/main/java/com/dc/web/config/SwaggerConfig.java new file mode 100644 index 0000000..1527154 --- /dev/null +++ b/dc-admin/src/main/java/com/dc/web/config/SwaggerConfig.java @@ -0,0 +1,121 @@ +package com.dc.web.config; + +import com.dc.common.config.WinConfig; +import io.swagger.annotations.ApiOperation; +import io.swagger.models.auth.In; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.beans.factory.annotation.Value; +import org.springframework.context.annotation.Bean; +import org.springframework.context.annotation.Configuration; +import springfox.documentation.builders.ApiInfoBuilder; +import springfox.documentation.builders.PathSelectors; +import springfox.documentation.builders.RequestHandlerSelectors; +import springfox.documentation.service.*; +import springfox.documentation.spi.DocumentationType; +import springfox.documentation.spi.service.contexts.SecurityContext; +import springfox.documentation.spring.web.plugins.Docket; + +import java.util.ArrayList; +import java.util.List; + +/** + * Swagger2的接口配置 + * + * @author win + */ +@Configuration +public class SwaggerConfig +{ + /** 系统基础配置 */ + @Autowired + private WinConfig winConfig; + + /** 是否开启swagger */ + @Value("${swagger.enabled}") + private boolean enabled; + + /** 设置请求的统一前缀 */ + @Value("${swagger.pathMapping}") + private String pathMapping; + + /** + * 创建API + */ + @Bean + public Docket createRestApi() + { + return new Docket(DocumentationType.OAS_30) + // 是否启用Swagger + .enable(enabled) + // 用来创建该API的基本信息,展示在文档的页面中(自定义展示的信息) + .apiInfo(apiInfo()) + // 设置哪些接口暴露给Swagger展示 + .select() + // 扫描所有有注解的api,用这种方式更灵活 + .apis(RequestHandlerSelectors.withMethodAnnotation(ApiOperation.class)) + // 扫描指定包中的swagger注解 + // .apis(RequestHandlerSelectors.basePackage("com.dc.project.tool.swagger")) + // 扫描所有 .apis(RequestHandlerSelectors.any()) + .paths(PathSelectors.any()) + .build() + /* 设置安全模式,swagger可以设置访问token */ + .securitySchemes(securitySchemes()) + .securityContexts(securityContexts()) + .pathMapping(pathMapping); + } + + /** + * 安全模式,这里指定token通过Authorization头请求头传递 + */ + private List<SecurityScheme> securitySchemes() + { + List<SecurityScheme> apiKeyList = new ArrayList<SecurityScheme>(); + apiKeyList.add(new ApiKey("Authorization", "Authorization", In.HEADER.toValue())); + return apiKeyList; + } + + /** + * 安全上下文 + */ + private List<SecurityContext> securityContexts() + { + List<SecurityContext> securityContexts = new ArrayList<>(); + securityContexts.add( + SecurityContext.builder() + .securityReferences(defaultAuth()) + .operationSelector(o -> o.requestMappingPattern().matches("/.*")) + .build()); + return securityContexts; + } + + /** + * 默认的安全上引用 + */ + private List<SecurityReference> defaultAuth() + { + AuthorizationScope authorizationScope = new AuthorizationScope("global", "accessEverything"); + AuthorizationScope[] authorizationScopes = new AuthorizationScope[1]; + authorizationScopes[0] = authorizationScope; + List<SecurityReference> securityReferences = new ArrayList<>(); + securityReferences.add(new SecurityReference("Authorization", authorizationScopes)); + return securityReferences; + } + + /** + * 添加摘要信息 + */ + private ApiInfo apiInfo() + { + // 用ApiInfoBuilder进行定制 + return new ApiInfoBuilder() + // 设置标题 + .title("标题:闻音管理系统_接口文档") + // 描述 + .description("描述:用于管理集团旗下公司的人员信息,具体包括XXX,XXX模块...") + // 作者信息 + .contact(new Contact(winConfig.getName(), null, null)) + // 版本 + .version("版本号:" + winConfig.getVersion()) + .build(); + } +} diff --git a/dc-admin/src/main/java/com/dc/web/controller/common/CaptchaController.java b/dc-admin/src/main/java/com/dc/web/controller/common/CaptchaController.java new file mode 100644 index 0000000..d27d659 --- /dev/null +++ b/dc-admin/src/main/java/com/dc/web/controller/common/CaptchaController.java @@ -0,0 +1,95 @@ +package com.dc.web.controller.common; + +import com.google.code.kaptcha.Producer; +import com.dc.common.config.WinConfig; +import com.dc.common.constant.CacheConstants; +import com.dc.common.constant.Constants; +import com.dc.common.core.domain.AjaxResult; +import com.dc.common.core.redis.RedisCache; +import com.dc.common.utils.sign.Base64; +import com.dc.common.utils.uuid.IdUtils; +import com.dc.system.service.SysConfigService; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.util.FastByteArrayOutputStream; +import org.springframework.web.bind.annotation.GetMapping; +import org.springframework.web.bind.annotation.RestController; + +import javax.annotation.Resource; +import javax.imageio.ImageIO; +import javax.servlet.http.HttpServletResponse; +import java.awt.image.BufferedImage; +import java.io.IOException; +import java.util.concurrent.TimeUnit; + +/** + * 验证码操作处理 + * + * @author win + */ +@RestController +public class CaptchaController +{ + @Resource(name = "captchaProducer") + private Producer captchaProducer; + + @Resource(name = "captchaProducerMath") + private Producer captchaProducerMath; + + @Autowired + private RedisCache redisCache; + + @Autowired + private SysConfigService configService; + /** + * 生成验证码 + */ + @GetMapping("/captchaImage") + public AjaxResult getCode(HttpServletResponse response) throws IOException + { + AjaxResult ajax = AjaxResult.success(); + boolean captchaEnabled = configService.selectCaptchaEnabled(); + ajax.put("captchaEnabled", captchaEnabled); + if (!captchaEnabled) + { + return ajax; + } + + // 保存验证码信息 + String uuid = IdUtils.simpleUUID(); + String verifyKey = CacheConstants.CAPTCHA_CODE_KEY + uuid; + + String capStr = null, code = null; + BufferedImage image = null; + + // 生成验证码 + String captchaType = WinConfig.getCaptchaType(); + if ("math".equals(captchaType)) + { + String capText = captchaProducerMath.createText(); + capStr = capText.substring(0, capText.lastIndexOf("@")); + code = capText.substring(capText.lastIndexOf("@") + 1); + image = captchaProducerMath.createImage(capStr); + } + else if ("char".equals(captchaType)) + { + capStr = code = captchaProducer.createText(); + image = captchaProducer.createImage(capStr); + } + + redisCache.setCacheObject(verifyKey, code, Constants.CAPTCHA_EXPIRATION, TimeUnit.MINUTES); + // 转换流信息写出 + FastByteArrayOutputStream os = new FastByteArrayOutputStream(); + try + { + ImageIO.write(image, "jpg", os); + } + catch (IOException e) + { + return AjaxResult.error(e.getMessage()); + } + + ajax.put("uuid", uuid); + ajax.put("img", Base64.encode(os.toByteArray())); + return ajax; + } +} diff --git a/dc-admin/src/main/java/com/dc/web/controller/common/CommonController.java b/dc-admin/src/main/java/com/dc/web/controller/common/CommonController.java new file mode 100644 index 0000000..8c6e308 --- /dev/null +++ b/dc-admin/src/main/java/com/dc/web/controller/common/CommonController.java @@ -0,0 +1,169 @@ +package com.dc.web.controller.common; + +import com.dc.common.config.WinConfig; +import com.dc.common.constant.Constants; +import com.dc.common.core.domain.AjaxResult; +import com.dc.common.utils.StringUtils; +import com.dc.common.utils.file.FileUploadUtils; +import com.dc.common.utils.file.FileUtils; +import com.dc.framework.config.ServerConfig; +import com.dc.system.domain.Accessory; +import com.dc.system.service.AccessoryService; +import org.slf4j.Logger; +import org.slf4j.LoggerFactory; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.http.MediaType; +import org.springframework.web.bind.annotation.GetMapping; +import org.springframework.web.bind.annotation.PostMapping; +import org.springframework.web.bind.annotation.RequestMapping; +import org.springframework.web.bind.annotation.RestController; +import org.springframework.web.multipart.MultipartFile; + +import javax.servlet.http.HttpServletRequest; +import javax.servlet.http.HttpServletResponse; +import java.time.LocalDateTime; +import java.util.ArrayList; +import java.util.List; + +/** + * 通用请求处理 + * + * @author win + */ +@RestController +@RequestMapping("/common") +public class CommonController { + private static final Logger log = LoggerFactory.getLogger(CommonController.class); + + @Autowired + private ServerConfig serverConfig; + @Autowired + private AccessoryService accessoryService; + + private static final String FILE_DELIMETER = ","; + + /** + * 通用下载请求 + * + * @param fileName 文件名称 + * @param delete 是否删除 + */ + @GetMapping("/download") + public void fileDownload(String fileName, Boolean delete, HttpServletResponse response, HttpServletRequest request) { + try { + if (!FileUtils.checkAllowDownload(fileName)) { + throw new Exception(StringUtils.format("文件名称({})非法,不允许下载。 ", fileName)); + } + String realFileName = System.currentTimeMillis() + fileName.substring(fileName.indexOf("_") + 1); + String filePath = WinConfig.getDownloadPath() + fileName; + + response.setContentType(MediaType.APPLICATION_OCTET_STREAM_VALUE); + FileUtils.setAttachmentResponseHeader(response, realFileName); + FileUtils.writeBytes(filePath, response.getOutputStream()); + if (delete) { + FileUtils.deleteFile(filePath); + } + } catch (Exception e) { + log.error("下载文件失败", e); + } + } + + /** + * 通用上传请求(单个) + */ + @PostMapping("/upload") + public AjaxResult uploadFile(MultipartFile file) throws Exception { + try { + // 上传文件路径 + String filePath = WinConfig.getUploadPath(); + // 上传并返回新文件名称 + String fileName = FileUploadUtils.upload(filePath, file); + String url = serverConfig.getUrl() + fileName; + String originalFilename = file.getOriginalFilename(); + AjaxResult ajax = AjaxResult.success(); + ajax.put("url", url); + ajax.put("fileName", fileName); + ajax.put("newFileName", FileUtils.getName(fileName)); + ajax.put("originalFilename", originalFilename); + Accessory accessory = new Accessory(); + String suffix = originalFilename.substring(originalFilename.lastIndexOf(".") + 1); + String name = originalFilename.replace("." + suffix, ""); + accessory.setName(name); + accessory.setSuffix(suffix); + accessory.setUrl(fileName); + accessory.setCreateTime(LocalDateTime.now()); + accessoryService.save(accessory); + ajax.put("accessoryId", accessory.getId()); + return ajax; + } catch (Exception e) { + return AjaxResult.error(e.getMessage()); + } + } + + /** + * 通用上传请求(多个) + */ + @PostMapping("/uploads") + public AjaxResult uploadFiles(List<MultipartFile> files) throws Exception { + try { + // 上传文件路径 + String filePath = WinConfig.getUploadPath(); + List<String> urls = new ArrayList<String>(); + List<String> fileNames = new ArrayList<String>(); + List<String> newFileNames = new ArrayList<String>(); + List<String> originalFilenames = new ArrayList<String>(); + List<Long> accessoryIds = new ArrayList<>(); + for (int i = 0; i < files.size(); i++) { + MultipartFile file = files.get(i); + String originalFilename = originalFilenames.get(i); + // 上传并返回新文件名称 + String fileName = FileUploadUtils.upload(filePath, file); + String url = serverConfig.getUrl() + fileName; + urls.add(url); + fileNames.add(fileName); + newFileNames.add(FileUtils.getName(fileName)); + originalFilenames.add(file.getOriginalFilename()); + String suffix = originalFilename.substring(originalFilename.lastIndexOf(".") + 1); + String name = originalFilename.replace("." + suffix, ""); + Accessory accessory = new Accessory(); + accessory.setName(name); + accessory.setSuffix(suffix); + accessory.setUrl(fileName); + accessoryService.save(accessory); + accessoryIds.add(accessory.getId()); + } + AjaxResult ajax = AjaxResult.success(); + ajax.put("urls", StringUtils.join(urls, FILE_DELIMETER)); + ajax.put("fileNames", StringUtils.join(fileNames, FILE_DELIMETER)); + ajax.put("newFileNames", StringUtils.join(newFileNames, FILE_DELIMETER)); + ajax.put("originalFilenames", StringUtils.join(originalFilenames, FILE_DELIMETER)); + ajax.put("accessoryIds", accessoryIds); + return ajax; + } catch (Exception e) { + return AjaxResult.error(e.getMessage()); + } + } + + /** + * 本地资源通用下载 + */ + @GetMapping("/download/resource") + public void resourceDownload(String resource, HttpServletRequest request, HttpServletResponse response) throws Exception { + try { + if (!FileUtils.checkAllowDownload(resource)) { + throw new Exception(StringUtils.format("资源文件({})非法,不允许下载。 ", resource)); + } + // 本地资源路径 + String localPath = WinConfig.getProfile(); + // 数据库资源地址 + String downloadPath = localPath + StringUtils.substringAfter(resource, Constants.RESOURCE_PREFIX); + // 下载名称 + String downloadName = StringUtils.substringAfterLast(downloadPath, "/"); + response.setContentType(MediaType.APPLICATION_OCTET_STREAM_VALUE); + FileUtils.setAttachmentResponseHeader(response, downloadName); + FileUtils.writeBytes(downloadPath, response.getOutputStream()); + } catch (Exception e) { + log.error("下载文件失败", e); + } + } +} diff --git a/dc-admin/src/main/java/com/dc/web/controller/monitor/CacheController.java b/dc-admin/src/main/java/com/dc/web/controller/monitor/CacheController.java new file mode 100644 index 0000000..195ffe0 --- /dev/null +++ b/dc-admin/src/main/java/com/dc/web/controller/monitor/CacheController.java @@ -0,0 +1,103 @@ +package com.dc.web.controller.monitor; + +import com.dc.common.constant.CacheConstants; +import com.dc.common.core.domain.AjaxResult; +import com.dc.common.utils.StringUtils; +import com.dc.system.domain.SysCache; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.data.redis.core.RedisCallback; +import org.springframework.data.redis.core.RedisTemplate; +import org.springframework.web.bind.annotation.*; + +import java.util.*; + +/** + * 缓存监控 + * + * @author win + */ +@RestController +@RequestMapping("/monitor/cache") +public class CacheController +{ + @Autowired + private RedisTemplate<String, String> redisTemplate; + + private final static List<SysCache> caches = new ArrayList<SysCache>(); + { + caches.add(new SysCache(CacheConstants.LOGIN_TOKEN_KEY, "用户信息")); + caches.add(new SysCache(CacheConstants.SYS_CONFIG_KEY, "配置信息")); + caches.add(new SysCache(CacheConstants.SYS_DICT_KEY, "数据字典")); + caches.add(new SysCache(CacheConstants.CAPTCHA_CODE_KEY, "验证码")); + caches.add(new SysCache(CacheConstants.REPEAT_SUBMIT_KEY, "防重提交")); + caches.add(new SysCache(CacheConstants.RATE_LIMIT_KEY, "限流处理")); + caches.add(new SysCache(CacheConstants.PWD_ERR_CNT_KEY, "密码错误次数")); + } + + @GetMapping() + public AjaxResult getInfo() throws Exception + { + Properties info = (Properties) redisTemplate.execute((RedisCallback<Object>) connection -> connection.info()); + Properties commandStats = (Properties) redisTemplate.execute((RedisCallback<Object>) connection -> connection.info("commandstats")); + Object dbSize = redisTemplate.execute((RedisCallback<Object>) connection -> connection.dbSize()); + + Map<String, Object> result = new HashMap<>(3); + result.put("info", info); + result.put("dbSize", dbSize); + + List<Map<String, String>> pieList = new ArrayList<>(); + commandStats.stringPropertyNames().forEach(key -> { + Map<String, String> data = new HashMap<>(2); + String property = commandStats.getProperty(key); + data.put("name", StringUtils.removeStart(key, "cmdstat_")); + data.put("value", StringUtils.substringBetween(property, "calls=", ",usec")); + pieList.add(data); + }); + result.put("commandStats", pieList); + return AjaxResult.success(result); + } + + @GetMapping("/getNames") + public AjaxResult cache() + { + return AjaxResult.success(caches); + } + + @GetMapping("/getKeys/{cacheName}") + public AjaxResult getCacheKeys(@PathVariable String cacheName) + { + Set<String> cacheKeys = redisTemplate.keys(cacheName + "*"); + return AjaxResult.success(cacheKeys); + } + + @GetMapping("/getValue/{cacheName}/{cacheKey}") + public AjaxResult getCacheValue(@PathVariable String cacheName, @PathVariable String cacheKey) + { + String cacheValue = redisTemplate.opsForValue().get(cacheKey); + SysCache sysCache = new SysCache(cacheName, cacheKey, cacheValue); + return AjaxResult.success(sysCache); + } + + @DeleteMapping("/clearCacheName/{cacheName}") + public AjaxResult clearCacheName(@PathVariable String cacheName) + { + Collection<String> cacheKeys = redisTemplate.keys(cacheName + "*"); + redisTemplate.delete(cacheKeys); + return AjaxResult.success(); + } + + @DeleteMapping("/clearCacheKey/{cacheKey}") + public AjaxResult clearCacheKey(@PathVariable String cacheKey) + { + redisTemplate.delete(cacheKey); + return AjaxResult.success(); + } + + @DeleteMapping("/clearCacheAll") + public AjaxResult clearCacheAll() + { + Collection<String> cacheKeys = redisTemplate.keys("*"); + redisTemplate.delete(cacheKeys); + return AjaxResult.success(); + } +} diff --git a/dc-admin/src/main/java/com/dc/web/controller/monitor/ServerController.java b/dc-admin/src/main/java/com/dc/web/controller/monitor/ServerController.java new file mode 100644 index 0000000..e2711e4 --- /dev/null +++ b/dc-admin/src/main/java/com/dc/web/controller/monitor/ServerController.java @@ -0,0 +1,25 @@ +package com.dc.web.controller.monitor; + +import com.dc.common.core.domain.AjaxResult; +import com.dc.framework.web.domain.Server; +import org.springframework.web.bind.annotation.GetMapping; +import org.springframework.web.bind.annotation.RequestMapping; +import org.springframework.web.bind.annotation.RestController; + +/** + * 服务器监控 + * + * @author win + */ +@RestController +@RequestMapping("/monitor/server") +public class ServerController +{ + @GetMapping() + public AjaxResult getInfo() throws Exception + { + Server server = new Server(); + server.copyTo(); + return AjaxResult.success(server); + } +} diff --git a/dc-admin/src/main/java/com/dc/web/controller/monitor/SysLogininforController.java b/dc-admin/src/main/java/com/dc/web/controller/monitor/SysLogininforController.java new file mode 100644 index 0000000..83dec78 --- /dev/null +++ b/dc-admin/src/main/java/com/dc/web/controller/monitor/SysLogininforController.java @@ -0,0 +1,72 @@ +package com.dc.web.controller.monitor; + +import com.dc.common.annotation.Log; +import com.dc.common.core.controller.BaseController; +import com.dc.common.core.domain.AjaxResult; +import com.dc.common.core.page.TableDataInfo; +import com.dc.common.enums.BusinessType; +import com.dc.common.utils.poi.ExcelUtil; +import com.dc.framework.web.service.SysPasswordService; +import com.dc.system.domain.SysLogininfor; +import com.dc.system.service.SysLogininforService; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.web.bind.annotation.*; + +import javax.servlet.http.HttpServletResponse; +import java.util.List; + +/** + * 系统访问记录 + * + * @author win + */ +@RestController +@RequestMapping("/monitor/logininfor") +public class SysLogininforController extends BaseController +{ + @Autowired + private SysLogininforService logininforService; + + @Autowired + private SysPasswordService passwordService; + + @GetMapping("/list") + public TableDataInfo list(SysLogininfor logininfor) + { + startPage(); + List<SysLogininfor> list = logininforService.selectLogininforList(logininfor); + return getDataTable(list); + } + + @Log(title = "登录日志", businessType = BusinessType.EXPORT) + @PostMapping("/export") + public void export(HttpServletResponse response, SysLogininfor logininfor) + { + List<SysLogininfor> list = logininforService.selectLogininforList(logininfor); + ExcelUtil<SysLogininfor> util = new ExcelUtil<SysLogininfor>(SysLogininfor.class); + util.exportExcel(response, list, "登录日志"); + } + + @Log(title = "登录日志", businessType = BusinessType.DELETE) + @DeleteMapping("/{infoIds}") + public AjaxResult remove(@PathVariable Long[] infoIds) + { + return toAjax(logininforService.deleteLogininforByIds(infoIds)); + } + + @Log(title = "登录日志", businessType = BusinessType.CLEAN) + @DeleteMapping("/clean") + public AjaxResult clean() + { + logininforService.cleanLogininfor(); + return success(); + } + + @Log(title = "账户解锁", businessType = BusinessType.OTHER) + @GetMapping("/unlock/{userName}") + public AjaxResult unlock(@PathVariable("userName") String userName) + { + passwordService.clearLoginRecordCache(userName); + return success(); + } +} diff --git a/dc-admin/src/main/java/com/dc/web/controller/monitor/SysOperlogController.java b/dc-admin/src/main/java/com/dc/web/controller/monitor/SysOperlogController.java new file mode 100644 index 0000000..6eebaac --- /dev/null +++ b/dc-admin/src/main/java/com/dc/web/controller/monitor/SysOperlogController.java @@ -0,0 +1,60 @@ +package com.dc.web.controller.monitor; + +import com.dc.common.annotation.Log; +import com.dc.common.core.controller.BaseController; +import com.dc.common.core.domain.AjaxResult; +import com.dc.common.core.page.TableDataInfo; +import com.dc.common.enums.BusinessType; +import com.dc.common.utils.poi.ExcelUtil; +import com.dc.system.domain.SysOperLog; +import com.dc.system.service.SysOperLogService; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.web.bind.annotation.*; + +import javax.servlet.http.HttpServletResponse; +import java.util.List; + +/** + * 操作日志记录 + * + * @author win + */ +@RestController +@RequestMapping("/monitor/operlog") +public class SysOperlogController extends BaseController +{ + @Autowired + private SysOperLogService operLogService; + + @GetMapping("/list") + public TableDataInfo list(SysOperLog operLog) + { + startPage(); + List<SysOperLog> list = operLogService.selectOperLogList(operLog); + return getDataTable(list); + } + + @Log(title = "操作日志", businessType = BusinessType.EXPORT) + @PostMapping("/export") + public void export(HttpServletResponse response, SysOperLog operLog) + { + List<SysOperLog> list = operLogService.selectOperLogList(operLog); + ExcelUtil<SysOperLog> util = new ExcelUtil<SysOperLog>(SysOperLog.class); + util.exportExcel(response, list, "操作日志"); + } + + @Log(title = "操作日志", businessType = BusinessType.DELETE) + @DeleteMapping("/{operIds}") + public AjaxResult remove(@PathVariable Long[] operIds) + { + return toAjax(operLogService.deleteOperLogByIds(operIds)); + } + + @Log(title = "操作日志", businessType = BusinessType.CLEAN) + @DeleteMapping("/clean") + public AjaxResult clean() + { + operLogService.cleanOperLog(); + return success(); + } +} diff --git a/dc-admin/src/main/java/com/dc/web/controller/monitor/SysUserOnlineController.java b/dc-admin/src/main/java/com/dc/web/controller/monitor/SysUserOnlineController.java new file mode 100644 index 0000000..1c1270b --- /dev/null +++ b/dc-admin/src/main/java/com/dc/web/controller/monitor/SysUserOnlineController.java @@ -0,0 +1,86 @@ +package com.dc.web.controller.monitor; + +import com.dc.common.annotation.Log; +import com.dc.common.constant.CacheConstants; +import com.dc.common.core.controller.BaseController; +import com.dc.common.core.domain.AjaxResult; +import com.dc.common.core.domain.model.LoginUser; +import com.dc.common.core.page.TableDataInfo; +import com.dc.common.core.redis.RedisCache; +import com.dc.common.enums.BusinessType; +import com.dc.common.utils.StringUtils; +import com.dc.system.domain.SysUserOnline; +import com.dc.system.service.SysUserOnlineService; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.web.bind.annotation.*; + +import java.util.ArrayList; +import java.util.Collection; +import java.util.Collections; +import java.util.List; + +/** + * 在线用户监控 + * + * @author win + */ +@RestController +@RequestMapping("/monitor/online") +public class SysUserOnlineController extends BaseController +{ + @Autowired + private SysUserOnlineService userOnlineService; + + @Autowired + private RedisCache redisCache; + + @GetMapping("/list") + public TableDataInfo list(String ipaddr, String userName) + { + Collection<String> keys = redisCache.keys(CacheConstants.LOGIN_TOKEN_KEY + "*"); + List<SysUserOnline> userOnlineList = new ArrayList<SysUserOnline>(); + for (String key : keys) + { + LoginUser user = redisCache.getCacheObject(key); + if (StringUtils.isNotEmpty(ipaddr) && StringUtils.isNotEmpty(userName)) + { + if (StringUtils.equals(ipaddr, user.getIpaddr()) && StringUtils.equals(userName, user.getUsername())) + { + userOnlineList.add(userOnlineService.selectOnlineByInfo(ipaddr, userName, user)); + } + } + else if (StringUtils.isNotEmpty(ipaddr)) + { + if (StringUtils.equals(ipaddr, user.getIpaddr())) + { + userOnlineList.add(userOnlineService.selectOnlineByIpaddr(ipaddr, user)); + } + } + else if (StringUtils.isNotEmpty(userName) && StringUtils.isNotNull(user.getUser())) + { + if (StringUtils.equals(userName, user.getUsername())) + { + userOnlineList.add(userOnlineService.selectOnlineByUserName(userName, user)); + } + } + else + { + userOnlineList.add(userOnlineService.loginUserToUserOnline(user)); + } + } + Collections.reverse(userOnlineList); + userOnlineList.removeAll(Collections.singleton(null)); + return getDataTable(userOnlineList); + } + + /** + * 强退用户 + */ + @Log(title = "在线用户", businessType = BusinessType.FORCE) + @DeleteMapping("/{tokenId}") + public AjaxResult forceLogout(@PathVariable String tokenId) + { + redisCache.deleteObject(CacheConstants.LOGIN_TOKEN_KEY + tokenId); + return success(); + } +} diff --git a/dc-admin/src/main/java/com/dc/web/controller/system/SysCityController.java b/dc-admin/src/main/java/com/dc/web/controller/system/SysCityController.java new file mode 100644 index 0000000..0f34780 --- /dev/null +++ b/dc-admin/src/main/java/com/dc/web/controller/system/SysCityController.java @@ -0,0 +1,44 @@ +package com.dc.web.controller.system; + +import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; +import com.dc.common.core.controller.BaseController; +import com.dc.common.core.domain.AjaxResult; +import com.dc.system.domain.SysCity; +import com.dc.system.service.SysCityService; +import io.swagger.annotations.ApiOperation; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.web.bind.annotation.GetMapping; +import org.springframework.web.bind.annotation.PathVariable; +import org.springframework.web.bind.annotation.RequestMapping; +import org.springframework.web.bind.annotation.RestController; + +import java.util.List; + +/** + * 省市区Controller + * + * @author win + * @date 2023-03-14 + */ +@RestController +@RequestMapping("/system/sysCity") +public class SysCityController extends BaseController { + + @Autowired + private SysCityService sysCityService; + + /** + * 根据pid查询省市区列表0是顶级 + */ + @ApiOperation("根据pid查询省市区列表") + @GetMapping("/list/{pid}") + public AjaxResult list(@PathVariable("pid") Long pid) { + QueryWrapper<SysCity> queryWrapper = new QueryWrapper<>(); + queryWrapper.isNull("delete_time"); + queryWrapper.eq("pid", pid); + queryWrapper.orderByAsc("id"); + List<SysCity> list = sysCityService.list(queryWrapper); + return success(list); + } + +} diff --git a/dc-admin/src/main/java/com/dc/web/controller/system/SysConfigController.java b/dc-admin/src/main/java/com/dc/web/controller/system/SysConfigController.java new file mode 100644 index 0000000..ada1f81 --- /dev/null +++ b/dc-admin/src/main/java/com/dc/web/controller/system/SysConfigController.java @@ -0,0 +1,120 @@ +package com.dc.web.controller.system; + +import com.dc.common.annotation.Log; +import com.dc.common.constant.UserConstants; +import com.dc.common.core.controller.BaseController; +import com.dc.common.core.domain.AjaxResult; +import com.dc.common.core.page.TableDataInfo; +import com.dc.common.enums.BusinessType; +import com.dc.common.utils.poi.ExcelUtil; +import com.dc.system.domain.SysConfig; +import com.dc.system.service.SysConfigService; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.validation.annotation.Validated; +import org.springframework.web.bind.annotation.*; + +import javax.servlet.http.HttpServletResponse; +import java.util.List; + +/** + * 参数配置 信息操作处理 + * + * @author win + */ +@RestController +@RequestMapping("/system/config") +public class SysConfigController extends BaseController +{ + @Autowired + private SysConfigService configService; + + /** + * 获取参数配置列表 + */ + @GetMapping("/list") + public TableDataInfo list(SysConfig config) + { + startPage(); + List<SysConfig> list = configService.selectConfigList(config); + return getDataTable(list); + } + + @Log(title = "参数管理", businessType = BusinessType.EXPORT) + @PostMapping("/export") + public void export(HttpServletResponse response, SysConfig config) + { + List<SysConfig> list = configService.selectConfigList(config); + ExcelUtil<SysConfig> util = new ExcelUtil<SysConfig>(SysConfig.class); + util.exportExcel(response, list, "参数数据"); + } + + /** + * 根据参数编号获取详细信息 + */ + @GetMapping(value = "/{configId}") + public AjaxResult getInfo(@PathVariable Long configId) + { + return success(configService.selectConfigById(configId)); + } + + /** + * 根据参数键名查询参数值 + */ + @GetMapping(value = "/configKey/{configKey}") + public AjaxResult getConfigKey(@PathVariable String configKey) + { + return success(configService.selectConfigByKey(configKey)); + } + + /** + * 新增参数配置 + */ + @Log(title = "参数管理", businessType = BusinessType.INSERT) + @PostMapping + public AjaxResult add(@Validated @RequestBody SysConfig config) + { + if (UserConstants.NOT_UNIQUE.equals(configService.checkConfigKeyUnique(config))) + { + return error("新增参数'" + config.getConfigName() + "'失败,参数键名已存在"); + } + config.setCreateBy(getUsername()); + return toAjax(configService.insertConfig(config)); + } + + /** + * 修改参数配置 + */ + @Log(title = "参数管理", businessType = BusinessType.UPDATE) + @PutMapping + public AjaxResult edit(@Validated @RequestBody SysConfig config) + { + if (UserConstants.NOT_UNIQUE.equals(configService.checkConfigKeyUnique(config))) + { + return error("修改参数'" + config.getConfigName() + "'失败,参数键名已存在"); + } + config.setUpdateBy(getUsername()); + return toAjax(configService.updateConfig(config)); + } + + /** + * 删除参数配置 + */ + @Log(title = "参数管理", businessType = BusinessType.DELETE) + @DeleteMapping("/{configIds}") + public AjaxResult remove(@PathVariable Long[] configIds) + { + configService.deleteConfigByIds(configIds); + return success(); + } + + /** + * 刷新参数缓存 + */ + @Log(title = "参数管理", businessType = BusinessType.CLEAN) + @DeleteMapping("/refreshCache") + public AjaxResult refreshCache() + { + configService.resetConfigCache(); + return success(); + } +} diff --git a/dc-admin/src/main/java/com/dc/web/controller/system/SysDeptController.java b/dc-admin/src/main/java/com/dc/web/controller/system/SysDeptController.java new file mode 100644 index 0000000..fc1ed4d --- /dev/null +++ b/dc-admin/src/main/java/com/dc/web/controller/system/SysDeptController.java @@ -0,0 +1,119 @@ +package com.dc.web.controller.system; + +import com.dc.common.annotation.Log; +import com.dc.common.constant.UserConstants; +import com.dc.common.core.controller.BaseController; +import com.dc.common.core.domain.AjaxResult; +import com.dc.common.core.domain.entity.SysDept; +import com.dc.common.enums.BusinessType; +import com.dc.common.utils.StringUtils; +import com.dc.system.service.SysDeptService; +import org.apache.commons.lang3.ArrayUtils; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.validation.annotation.Validated; +import org.springframework.web.bind.annotation.*; + +import java.util.List; + +/** + * 部门信息 + * + * @author win + */ +@RestController +@RequestMapping("/system/dept") +public class SysDeptController extends BaseController +{ + @Autowired + private SysDeptService deptService; + + /** + * 获取部门列表 + */ + @GetMapping("/list") + public AjaxResult list(SysDept dept) + { + List<SysDept> depts = deptService.selectDeptList(dept); + return success(depts); + } + + /** + * 查询部门列表(排除节点) + */ + @GetMapping("/list/exclude/{deptId}") + public AjaxResult excludeChild(@PathVariable(value = "deptId", required = false) Long deptId) + { + List<SysDept> depts = deptService.selectDeptList(new SysDept()); + depts.removeIf(d -> d.getDeptId().intValue() == deptId || ArrayUtils.contains(StringUtils.split(d.getAncestors(), ","), deptId + "")); + return success(depts); + } + + /** + * 根据部门编号获取详细信息 + */ + @GetMapping(value = "/{deptId}") + public AjaxResult getInfo(@PathVariable Long deptId) + { + deptService.checkDeptDataScope(deptId); + return success(deptService.selectDeptById(deptId)); + } + + /** + * 新增部门 + */ + @Log(title = "部门管理", businessType = BusinessType.INSERT) + @PostMapping + public AjaxResult add(@Validated @RequestBody SysDept dept) + { + if (UserConstants.NOT_UNIQUE.equals(deptService.checkDeptNameUnique(dept))) + { + return error("新增部门'" + dept.getDeptName() + "'失败,部门名称已存在"); + } + dept.setCreateBy(getUsername()); + return toAjax(deptService.insertDept(dept)); + } + + /** + * 修改部门 + */ + @Log(title = "部门管理", businessType = BusinessType.UPDATE) + @PutMapping + public AjaxResult edit(@Validated @RequestBody SysDept dept) + { + Long deptId = dept.getDeptId(); + deptService.checkDeptDataScope(deptId); + if (UserConstants.NOT_UNIQUE.equals(deptService.checkDeptNameUnique(dept))) + { + return error("修改部门'" + dept.getDeptName() + "'失败,部门名称已存在"); + } + else if (dept.getParentId().equals(deptId)) + { + return error("修改部门'" + dept.getDeptName() + "'失败,上级部门不能是自己"); + } + else if (StringUtils.equals(UserConstants.DEPT_DISABLE, dept.getStatus()) && deptService.selectNormalChildrenDeptById(deptId) > 0) + { + return error("该部门包含未停用的子部门!"); + } + dept.setUpdateBy(getUsername()); + return toAjax(deptService.updateDept(dept)); + } + + /** + * 删除部门 + */ + @Log(title = "部门管理", businessType = BusinessType.DELETE) + @DeleteMapping("/{deptId}") + public AjaxResult remove(@PathVariable Long deptId) + { + if (deptService.hasChildByDeptId(deptId)) + { + return warn("存在下级部门,不允许删除"); + } + if (deptService.checkDeptExistUser(deptId)) + { + return warn("部门存在用户,不允许删除"); + } + deptService.checkDeptDataScope(deptId); + return toAjax(deptService.deleteDeptById(deptId)); + } +} diff --git a/dc-admin/src/main/java/com/dc/web/controller/system/SysDictDataController.java b/dc-admin/src/main/java/com/dc/web/controller/system/SysDictDataController.java new file mode 100644 index 0000000..1995b05 --- /dev/null +++ b/dc-admin/src/main/java/com/dc/web/controller/system/SysDictDataController.java @@ -0,0 +1,108 @@ +package com.dc.web.controller.system; + +import com.dc.common.annotation.Log; +import com.dc.common.core.controller.BaseController; +import com.dc.common.core.domain.AjaxResult; +import com.dc.common.core.domain.entity.SysDictData; +import com.dc.common.core.page.TableDataInfo; +import com.dc.common.enums.BusinessType; +import com.dc.common.utils.StringUtils; +import com.dc.common.utils.poi.ExcelUtil; +import com.dc.system.service.SysDictDataService; +import com.dc.system.service.SysDictTypeService; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.validation.annotation.Validated; +import org.springframework.web.bind.annotation.*; + +import javax.servlet.http.HttpServletResponse; +import java.util.ArrayList; +import java.util.List; + +/** + * 数据字典信息 + * + * @author win + */ +@RestController +@RequestMapping("/system/dict/data") +public class SysDictDataController extends BaseController +{ + @Autowired + private SysDictDataService dictDataService; + + @Autowired + private SysDictTypeService dictTypeService; + + @GetMapping("/list") + public TableDataInfo list(SysDictData dictData) + { + startPage(); + List<SysDictData> list = dictDataService.selectDictDataList(dictData); + return getDataTable(list); + } + + @Log(title = "字典数据", businessType = BusinessType.EXPORT) + @PostMapping("/export") + public void export(HttpServletResponse response, SysDictData dictData) + { + List<SysDictData> list = dictDataService.selectDictDataList(dictData); + ExcelUtil<SysDictData> util = new ExcelUtil<SysDictData>(SysDictData.class); + util.exportExcel(response, list, "字典数据"); + } + + /** + * 查询字典数据详细 + */ + @GetMapping(value = "/{dictCode}") + public AjaxResult getInfo(@PathVariable Long dictCode) + { + return success(dictDataService.selectDictDataById(dictCode)); + } + + /** + * 根据字典类型查询字典数据信息 + */ + @GetMapping(value = "/type/{dictType}") + public AjaxResult dictType(@PathVariable String dictType) + { + List<SysDictData> data = dictTypeService.selectDictDataByType(dictType); + if (StringUtils.isNull(data)) + { + data = new ArrayList<SysDictData>(); + } + return success(data); + } + + /** + * 新增字典类型 + */ + @Log(title = "字典数据", businessType = BusinessType.INSERT) + @PostMapping + public AjaxResult add(@Validated @RequestBody SysDictData dict) + { + dict.setCreateBy(getUsername()); + return toAjax(dictDataService.insertDictData(dict)); + } + + /** + * 修改保存字典类型 + */ + @Log(title = "字典数据", businessType = BusinessType.UPDATE) + @PutMapping + public AjaxResult edit(@Validated @RequestBody SysDictData dict) + { + dict.setUpdateBy(getUsername()); + return toAjax(dictDataService.updateDictData(dict)); + } + + /** + * 删除字典类型 + */ + @Log(title = "字典类型", businessType = BusinessType.DELETE) + @DeleteMapping("/{dictCodes}") + public AjaxResult remove(@PathVariable Long[] dictCodes) + { + dictDataService.deleteDictDataByIds(dictCodes); + return success(); + } +} diff --git a/dc-admin/src/main/java/com/dc/web/controller/system/SysDictTypeController.java b/dc-admin/src/main/java/com/dc/web/controller/system/SysDictTypeController.java new file mode 100644 index 0000000..1e32784 --- /dev/null +++ b/dc-admin/src/main/java/com/dc/web/controller/system/SysDictTypeController.java @@ -0,0 +1,128 @@ +package com.dc.web.controller.system; + +import com.dc.common.annotation.Log; +import com.dc.common.constant.UserConstants; +import com.dc.common.core.controller.BaseController; +import com.dc.common.core.domain.AjaxResult; +import com.dc.common.core.domain.entity.SysDictType; +import com.dc.common.core.page.TableDataInfo; +import com.dc.common.enums.BusinessType; +import com.dc.common.utils.poi.ExcelUtil; +import com.dc.system.service.SysDictTypeService; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.validation.annotation.Validated; +import org.springframework.web.bind.annotation.*; + +import javax.annotation.PostConstruct; +import javax.servlet.http.HttpServletResponse; +import java.util.List; + +/** + * 数据字典信息 + * + * @author win + */ +@RestController +@RequestMapping("/system/dict/type") +public class SysDictTypeController extends BaseController +{ + @Autowired + private SysDictTypeService dictTypeService; + + /** + * 项目启动时,初始化字典到缓存 + */ + @PostConstruct + public void init() + { + dictTypeService.loadingDictCache(); + } + + @GetMapping("/list") + public TableDataInfo list(SysDictType dictType) + { + startPage(); + List<SysDictType> list = dictTypeService.selectDictTypeList(dictType); + return getDataTable(list); + } + + @Log(title = "字典类型", businessType = BusinessType.EXPORT) + @PostMapping("/export") + public void export(HttpServletResponse response, SysDictType dictType) + { + List<SysDictType> list = dictTypeService.selectDictTypeList(dictType); + ExcelUtil<SysDictType> util = new ExcelUtil<SysDictType>(SysDictType.class); + util.exportExcel(response, list, "字典类型"); + } + + /** + * 查询字典类型详细 + */ + @GetMapping(value = "/{dictId}") + public AjaxResult getInfo(@PathVariable Long dictId) + { + return success(dictTypeService.selectDictTypeById(dictId)); + } + + /** + * 新增字典类型 + */ + @Log(title = "字典类型", businessType = BusinessType.INSERT) + @PostMapping + public AjaxResult add(@Validated @RequestBody SysDictType dict) + { + if (UserConstants.NOT_UNIQUE.equals(dictTypeService.checkDictTypeUnique(dict))) + { + return error("新增字典'" + dict.getDictName() + "'失败,字典类型已存在"); + } + dict.setCreateBy(getUsername()); + return toAjax(dictTypeService.insertDictType(dict)); + } + + /** + * 修改字典类型 + */ + @Log(title = "字典类型", businessType = BusinessType.UPDATE) + @PutMapping + public AjaxResult edit(@Validated @RequestBody SysDictType dict) + { + if (UserConstants.NOT_UNIQUE.equals(dictTypeService.checkDictTypeUnique(dict))) + { + return error("修改字典'" + dict.getDictName() + "'失败,字典类型已存在"); + } + dict.setUpdateBy(getUsername()); + return toAjax(dictTypeService.updateDictType(dict)); + } + + /** + * 删除字典类型 + */ + @Log(title = "字典类型", businessType = BusinessType.DELETE) + @DeleteMapping("/{dictIds}") + public AjaxResult remove(@PathVariable Long[] dictIds) + { + dictTypeService.deleteDictTypeByIds(dictIds); + return success(); + } + + /** + * 刷新字典缓存 + */ + @Log(title = "字典类型", businessType = BusinessType.CLEAN) + @DeleteMapping("/refreshCache") + public AjaxResult refreshCache() + { + dictTypeService.resetDictCache(); + return success(); + } + + /** + * 获取字典选择框列表 + */ + @GetMapping("/optionselect") + public AjaxResult optionselect() + { + List<SysDictType> dictTypes = dictTypeService.selectDictTypeAll(); + return success(dictTypes); + } +} diff --git a/dc-admin/src/main/java/com/dc/web/controller/system/SysIndexController.java b/dc-admin/src/main/java/com/dc/web/controller/system/SysIndexController.java new file mode 100644 index 0000000..d15fe10 --- /dev/null +++ b/dc-admin/src/main/java/com/dc/web/controller/system/SysIndexController.java @@ -0,0 +1,29 @@ +package com.dc.web.controller.system; + +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.web.bind.annotation.RequestMapping; +import org.springframework.web.bind.annotation.RestController; +import com.dc.common.config.WinConfig; +import com.dc.common.utils.StringUtils; + +/** + * 首页 + * + * @author win + */ +@RestController +public class SysIndexController +{ + /** 系统基础配置 */ + @Autowired + private WinConfig winConfig; + + /** + * 访问首页,提示语 + */ + @RequestMapping("/") + public String index() + { + return StringUtils.format("欢迎使用{}后台管理框架,当前版本:v{},请通过前端地址访问。", winConfig.getName(), winConfig.getVersion()); + } +} diff --git a/dc-admin/src/main/java/com/dc/web/controller/system/SysLoginController.java b/dc-admin/src/main/java/com/dc/web/controller/system/SysLoginController.java new file mode 100644 index 0000000..b988cc3 --- /dev/null +++ b/dc-admin/src/main/java/com/dc/web/controller/system/SysLoginController.java @@ -0,0 +1,87 @@ +package com.dc.web.controller.system; + +import com.dc.common.constant.Constants; +import com.dc.common.core.domain.AjaxResult; +import com.dc.common.core.domain.entity.SysMenu; +import com.dc.common.core.domain.entity.SysUser; +import com.dc.common.core.domain.model.LoginBody; +import com.dc.common.utils.SecurityUtils; +import com.dc.framework.web.service.SysLoginService; +import com.dc.framework.web.service.SysPermissionService; +import com.dc.system.service.SysMenuService; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.web.bind.annotation.GetMapping; +import org.springframework.web.bind.annotation.PostMapping; +import org.springframework.web.bind.annotation.RequestBody; +import org.springframework.web.bind.annotation.RestController; + +import java.util.List; +import java.util.Set; + +/** + * 登录验证 + * + * @author win + */ +@RestController +public class SysLoginController +{ + @Autowired + private SysLoginService loginService; + + @Autowired + private SysMenuService menuService; + + @Autowired + private SysPermissionService permissionService; + + /** + * 登录方法 + * + * @param loginBody 登录信息 + * @return 结果 + */ + @PostMapping("/login") + public AjaxResult login(@RequestBody LoginBody loginBody) + { + AjaxResult ajax = AjaxResult.success(); + // 生成令牌 + String token = loginService.login(loginBody.getUsername(), loginBody.getPassword(), loginBody.getCode(), + loginBody.getUuid()); + ajax.put(Constants.TOKEN, token); + return ajax; + } + + /** + * 获取用户信息 + * + * @return 用户信息 + */ + @GetMapping("getInfo") + public AjaxResult getInfo() + { + SysUser user = SecurityUtils.getLoginUser().getUser(); + // 角色集合 + Set<String> roles = permissionService.getRolePermission(user); + // 权限集合 + Set<String> permissions = permissionService.getMenuPermission(user); + AjaxResult ajax = AjaxResult.success(); + ajax.put("user", user); + ajax.put("roles", roles); + ajax.put("permissions", permissions); + return ajax; + } + + /** + * 获取路由信息 + * + * @return 路由信息 + */ + @GetMapping("getRouters") + public AjaxResult getRouters() + { + Long userId = SecurityUtils.getUserId(); + List<SysMenu> menus = menuService.selectMenuTreeByUserId(userId); + return AjaxResult.success(menuService.buildMenus(menus)); + } +} diff --git a/dc-admin/src/main/java/com/dc/web/controller/system/SysMenuController.java b/dc-admin/src/main/java/com/dc/web/controller/system/SysMenuController.java new file mode 100644 index 0000000..291d446 --- /dev/null +++ b/dc-admin/src/main/java/com/dc/web/controller/system/SysMenuController.java @@ -0,0 +1,130 @@ +package com.dc.web.controller.system; + +import com.dc.common.annotation.Log; +import com.dc.common.constant.UserConstants; +import com.dc.common.core.controller.BaseController; +import com.dc.common.core.domain.AjaxResult; +import com.dc.common.core.domain.entity.SysMenu; +import com.dc.common.enums.BusinessType; +import com.dc.common.utils.StringUtils; +import com.dc.system.service.SysMenuService; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.validation.annotation.Validated; +import org.springframework.web.bind.annotation.*; + +import java.util.List; + +/** + * 菜单信息 + * + * @author win + */ +@RestController +@RequestMapping("/system/menu") +public class SysMenuController extends BaseController +{ + @Autowired + private SysMenuService menuService; + + /** + * 获取菜单列表 + */ + @GetMapping("/list") + public AjaxResult list(SysMenu menu) + { + List<SysMenu> menus = menuService.selectMenuList(menu, getUserId()); + return success(menus); + } + + /** + * 根据菜单编号获取详细信息 + */ + @GetMapping(value = "/{menuId}") + public AjaxResult getInfo(@PathVariable Long menuId) + { + return success(menuService.selectMenuById(menuId)); + } + + /** + * 获取菜单下拉树列表 + */ + @GetMapping("/treeselect") + public AjaxResult treeselect(SysMenu menu) + { + List<SysMenu> menus = menuService.selectMenuList(menu, getUserId()); + return success(menuService.buildMenuTreeSelect(menus)); + } + + /** + * 加载对应角色菜单列表树 + */ + @GetMapping(value = "/roleMenuTreeselect/{roleId}") + public AjaxResult roleMenuTreeselect(@PathVariable("roleId") Long roleId) + { + List<SysMenu> menus = menuService.selectMenuList(getUserId()); + AjaxResult ajax = AjaxResult.success(); + ajax.put("checkedKeys", menuService.selectMenuListByRoleId(roleId)); + ajax.put("menus", menuService.buildMenuTreeSelect(menus)); + return ajax; + } + + /** + * 新增菜单 + */ + @Log(title = "菜单管理", businessType = BusinessType.INSERT) + @PostMapping + public AjaxResult add(@Validated @RequestBody SysMenu menu) + { + if (UserConstants.NOT_UNIQUE.equals(menuService.checkMenuNameUnique(menu))) + { + return error("新增菜单'" + menu.getMenuName() + "'失败,菜单名称已存在"); + } + else if (UserConstants.YES_FRAME.equals(menu.getIsFrame()) && !StringUtils.ishttp(menu.getPath())) + { + return error("新增菜单'" + menu.getMenuName() + "'失败,地址必须以http(s)://开头"); + } + menu.setCreateBy(getUsername()); + return toAjax(menuService.insertMenu(menu)); + } + + /** + * 修改菜单 + */ + @Log(title = "菜单管理", businessType = BusinessType.UPDATE) + @PutMapping + public AjaxResult edit(@Validated @RequestBody SysMenu menu) + { + if (UserConstants.NOT_UNIQUE.equals(menuService.checkMenuNameUnique(menu))) + { + return error("修改菜单'" + menu.getMenuName() + "'失败,菜单名称已存在"); + } + else if (UserConstants.YES_FRAME.equals(menu.getIsFrame()) && !StringUtils.ishttp(menu.getPath())) + { + return error("修改菜单'" + menu.getMenuName() + "'失败,地址必须以http(s)://开头"); + } + else if (menu.getMenuId().equals(menu.getParentId())) + { + return error("修改菜单'" + menu.getMenuName() + "'失败,上级菜单不能选择自己"); + } + menu.setUpdateBy(getUsername()); + return toAjax(menuService.updateMenu(menu)); + } + + /** + * 删除菜单 + */ + @Log(title = "菜单管理", businessType = BusinessType.DELETE) + @DeleteMapping("/{menuId}") + public AjaxResult remove(@PathVariable("menuId") Long menuId) + { + if (menuService.hasChildByMenuId(menuId)) + { + return warn("存在子菜单,不允许删除"); + } + if (menuService.checkMenuExistRole(menuId)) + { + return warn("菜单已分配,不允许删除"); + } + return toAjax(menuService.deleteMenuById(menuId)); + } +} \ No newline at end of file diff --git a/dc-admin/src/main/java/com/dc/web/controller/system/SysNoticeController.java b/dc-admin/src/main/java/com/dc/web/controller/system/SysNoticeController.java new file mode 100644 index 0000000..29c3e4f --- /dev/null +++ b/dc-admin/src/main/java/com/dc/web/controller/system/SysNoticeController.java @@ -0,0 +1,79 @@ +package com.dc.web.controller.system; + +import com.dc.common.annotation.Log; +import com.dc.common.core.controller.BaseController; +import com.dc.common.core.domain.AjaxResult; +import com.dc.common.core.page.TableDataInfo; +import com.dc.common.enums.BusinessType; +import com.dc.system.domain.SysNotice; +import com.dc.system.service.SysNoticeService; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.validation.annotation.Validated; +import org.springframework.web.bind.annotation.*; + +import java.util.List; + +/** + * 公告 信息操作处理 + * + * @author win + */ +@RestController +@RequestMapping("/system/notice") +public class SysNoticeController extends BaseController +{ + @Autowired + private SysNoticeService noticeService; + + /** + * 获取通知公告列表 + */ + @GetMapping("/list") + public TableDataInfo list(SysNotice notice) + { + startPage(); + List<SysNotice> list = noticeService.selectNoticeList(notice); + return getDataTable(list); + } + + /** + * 根据通知公告编号获取详细信息 + */ + @GetMapping(value = "/{noticeId}") + public AjaxResult getInfo(@PathVariable Long noticeId) + { + return success(noticeService.selectNoticeById(noticeId)); + } + + /** + * 新增通知公告 + */ + @Log(title = "通知公告", businessType = BusinessType.INSERT) + @PostMapping + public AjaxResult add(@Validated @RequestBody SysNotice notice) + { + notice.setCreateBy(getUsername()); + return toAjax(noticeService.insertNotice(notice)); + } + + /** + * 修改通知公告 + */ + @Log(title = "通知公告", businessType = BusinessType.UPDATE) + @PutMapping + public AjaxResult edit(@Validated @RequestBody SysNotice notice) + { + notice.setUpdateBy(getUsername()); + return toAjax(noticeService.updateNotice(notice)); + } + + /** + * 删除通知公告 + */ + @Log(title = "通知公告", businessType = BusinessType.DELETE) + @DeleteMapping("/{noticeIds}") + public AjaxResult remove(@PathVariable Long[] noticeIds) + { + return toAjax(noticeService.deleteNoticeByIds(noticeIds)); + } +} diff --git a/dc-admin/src/main/java/com/dc/web/controller/system/SysPostController.java b/dc-admin/src/main/java/com/dc/web/controller/system/SysPostController.java new file mode 100644 index 0000000..df93932 --- /dev/null +++ b/dc-admin/src/main/java/com/dc/web/controller/system/SysPostController.java @@ -0,0 +1,117 @@ +package com.dc.web.controller.system; + +import com.dc.common.annotation.Log; +import com.dc.common.constant.UserConstants; +import com.dc.common.core.controller.BaseController; +import com.dc.common.core.domain.AjaxResult; +import com.dc.common.core.page.TableDataInfo; +import com.dc.common.enums.BusinessType; +import com.dc.common.utils.poi.ExcelUtil; +import com.dc.system.domain.SysPost; +import com.dc.system.service.SysPostService; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.validation.annotation.Validated; +import org.springframework.web.bind.annotation.*; + +import javax.servlet.http.HttpServletResponse; +import java.util.List; + +/** + * 岗位信息操作处理 + * + * @author win + */ +@RestController +@RequestMapping("/system/post") +public class SysPostController extends BaseController +{ + @Autowired + private SysPostService postService; + + /** + * 获取岗位列表 + */ + @GetMapping("/list") + public TableDataInfo list(SysPost post) + { + startPage(); + List<SysPost> list = postService.selectPostList(post); + return getDataTable(list); + } + + @Log(title = "岗位管理", businessType = BusinessType.EXPORT) + @PostMapping("/export") + public void export(HttpServletResponse response, SysPost post) + { + List<SysPost> list = postService.selectPostList(post); + ExcelUtil<SysPost> util = new ExcelUtil<SysPost>(SysPost.class); + util.exportExcel(response, list, "岗位数据"); + } + + /** + * 根据岗位编号获取详细信息 + */ + @GetMapping(value = "/{postId}") + public AjaxResult getInfo(@PathVariable Long postId) + { + return success(postService.selectPostById(postId)); + } + + /** + * 新增岗位 + */ + @Log(title = "岗位管理", businessType = BusinessType.INSERT) + @PostMapping + public AjaxResult add(@Validated @RequestBody SysPost post) + { + if (UserConstants.NOT_UNIQUE.equals(postService.checkPostNameUnique(post))) + { + return error("新增岗位'" + post.getPostName() + "'失败,岗位名称已存在"); + } + else if (UserConstants.NOT_UNIQUE.equals(postService.checkPostCodeUnique(post))) + { + return error("新增岗位'" + post.getPostName() + "'失败,岗位编码已存在"); + } + post.setCreateBy(getUsername()); + return toAjax(postService.insertPost(post)); + } + + /** + * 修改岗位 + */ + @Log(title = "岗位管理", businessType = BusinessType.UPDATE) + @PutMapping + public AjaxResult edit(@Validated @RequestBody SysPost post) + { + if (UserConstants.NOT_UNIQUE.equals(postService.checkPostNameUnique(post))) + { + return error("修改岗位'" + post.getPostName() + "'失败,岗位名称已存在"); + } + else if (UserConstants.NOT_UNIQUE.equals(postService.checkPostCodeUnique(post))) + { + return error("修改岗位'" + post.getPostName() + "'失败,岗位编码已存在"); + } + post.setUpdateBy(getUsername()); + return toAjax(postService.updatePost(post)); + } + + /** + * 删除岗位 + */ + @Log(title = "岗位管理", businessType = BusinessType.DELETE) + @DeleteMapping("/{postIds}") + public AjaxResult remove(@PathVariable Long[] postIds) + { + return toAjax(postService.deletePostByIds(postIds)); + } + + /** + * 获取岗位选择框列表 + */ + @GetMapping("/optionselect") + public AjaxResult optionselect() + { + List<SysPost> posts = postService.selectPostAll(); + return success(posts); + } +} diff --git a/dc-admin/src/main/java/com/dc/web/controller/system/SysProfileController.java b/dc-admin/src/main/java/com/dc/web/controller/system/SysProfileController.java new file mode 100644 index 0000000..eb24914 --- /dev/null +++ b/dc-admin/src/main/java/com/dc/web/controller/system/SysProfileController.java @@ -0,0 +1,144 @@ +package com.dc.web.controller.system; + +import com.dc.system.service.SysUserService; +import com.dc.common.core.controller.BaseController; +import com.dc.common.core.domain.AjaxResult; +import com.dc.common.core.domain.entity.SysUser; +import com.dc.common.core.domain.model.LoginUser; +import com.dc.common.enums.BusinessType; +import com.dc.framework.web.service.TokenService; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.web.bind.annotation.GetMapping; +import org.springframework.web.bind.annotation.PostMapping; +import org.springframework.web.bind.annotation.PutMapping; +import org.springframework.web.bind.annotation.RequestBody; +import org.springframework.web.bind.annotation.RequestMapping; +import org.springframework.web.bind.annotation.RequestParam; +import org.springframework.web.bind.annotation.RestController; +import org.springframework.web.multipart.MultipartFile; +import com.dc.common.annotation.Log; +import com.dc.common.config.WinConfig; +import com.dc.common.constant.UserConstants; +import com.dc.common.utils.SecurityUtils; +import com.dc.common.utils.StringUtils; +import com.dc.common.utils.file.FileUploadUtils; +import com.dc.common.utils.file.MimeTypeUtils; + +/** + * 个人信息 业务处理 + * + * @author win + */ +@RestController +@RequestMapping("/system/user/profile") +public class SysProfileController extends BaseController +{ + @Autowired + private SysUserService userService; + + @Autowired + private TokenService tokenService; + + /** + * 个人信息 + */ + @GetMapping + public AjaxResult profile() + { + LoginUser loginUser = getLoginUser(); + SysUser user = loginUser.getUser(); + AjaxResult ajax = AjaxResult.success(user); + ajax.put("roleGroup", userService.selectUserRoleGroup(loginUser.getUsername())); + ajax.put("postGroup", userService.selectUserPostGroup(loginUser.getUsername())); + return ajax; + } + + /** + * 修改用户 + */ + @Log(title = "个人信息", businessType = BusinessType.UPDATE) + @PutMapping + public AjaxResult updateProfile(@RequestBody SysUser user) + { + LoginUser loginUser = getLoginUser(); + SysUser sysUser = loginUser.getUser(); + user.setUserName(sysUser.getUserName()); + if (StringUtils.isNotEmpty(user.getPhonenumber()) + && UserConstants.NOT_UNIQUE.equals(userService.checkPhoneUnique(user))) + { + return error("修改用户'" + user.getUserName() + "'失败,手机号码已存在"); + } + if (StringUtils.isNotEmpty(user.getEmail()) + && UserConstants.NOT_UNIQUE.equals(userService.checkEmailUnique(user))) + { + return error("修改用户'" + user.getUserName() + "'失败,邮箱账号已存在"); + } + user.setUserId(sysUser.getUserId()); + user.setPassword(null); + user.setAvatar(null); + user.setDeptId(null); + if (userService.updateUserProfile(user) > 0) + { + // 更新缓存用户信息 + sysUser.setNickName(user.getNickName()); + sysUser.setPhonenumber(user.getPhonenumber()); + sysUser.setEmail(user.getEmail()); + sysUser.setSex(user.getSex()); + tokenService.setLoginUser(loginUser); + return success(); + } + return error("修改个人信息异常,请联系管理员"); + } + + /** + * 重置密码 + */ + @Log(title = "个人信息", businessType = BusinessType.UPDATE) + @PutMapping("/updatePwd") + public AjaxResult updatePwd(String oldPassword, String newPassword) + { + LoginUser loginUser = getLoginUser(); + String userName = loginUser.getUsername(); + String password = loginUser.getPassword(); + if (!SecurityUtils.matchesPassword(oldPassword, password)) + { + return error("修改密码失败,旧密码错误"); + } + if (SecurityUtils.matchesPassword(newPassword, password)) + { + return error("新密码不能与旧密码相同"); + } + if (userService.resetUserPwd(userName, SecurityUtils.encryptPassword(newPassword)) > 0) + { + // 更新缓存用户密码 + loginUser.getUser().setPassword(SecurityUtils.encryptPassword(newPassword)); + tokenService.setLoginUser(loginUser); + return success(); + } + return error("修改密码异常,请联系管理员"); + } + + /** + * 头像上传 + */ + @Log(title = "用户头像", businessType = BusinessType.UPDATE) + @PostMapping("/avatar") + public AjaxResult avatar(@RequestParam("avatarfile") MultipartFile file) throws Exception + { + if (!file.isEmpty()) + { + LoginUser loginUser = getLoginUser(); + String avatar = FileUploadUtils.upload(WinConfig.getAvatarPath(), file, MimeTypeUtils.IMAGE_EXTENSION); + if (userService.updateUserAvatar(loginUser.getUsername(), avatar)) + { + AjaxResult ajax = AjaxResult.success(); + ajax.put("imgUrl", avatar); + // 更新缓存用户头像 + loginUser.getUser().setAvatar(avatar); + tokenService.setLoginUser(loginUser); + return ajax; + } + } + return error("上传图片异常,请联系管理员"); + } +} diff --git a/dc-admin/src/main/java/com/dc/web/controller/system/SysRegisterController.java b/dc-admin/src/main/java/com/dc/web/controller/system/SysRegisterController.java new file mode 100644 index 0000000..20e5712 --- /dev/null +++ b/dc-admin/src/main/java/com/dc/web/controller/system/SysRegisterController.java @@ -0,0 +1,38 @@ +package com.dc.web.controller.system; + +import com.dc.system.service.SysConfigService; +import com.dc.common.core.controller.BaseController; +import com.dc.common.core.domain.AjaxResult; +import com.dc.common.core.domain.model.RegisterBody; +import com.dc.framework.web.service.SysRegisterService; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.web.bind.annotation.PostMapping; +import org.springframework.web.bind.annotation.RequestBody; +import org.springframework.web.bind.annotation.RestController; +import com.dc.common.utils.StringUtils; + +/** + * 注册验证 + * + * @author win + */ +@RestController +public class SysRegisterController extends BaseController +{ + @Autowired + private SysRegisterService registerService; + + @Autowired + private SysConfigService configService; + + @PostMapping("/register") + public AjaxResult register(@RequestBody RegisterBody user) + { + if (!("true".equals(configService.selectConfigByKey("sys.account.registerUser")))) + { + return error("当前系统没有开启注册功能!"); + } + String msg = registerService.register(user); + return StringUtils.isEmpty(msg) ? success() : error(msg); + } +} diff --git a/dc-admin/src/main/java/com/dc/web/controller/system/SysRoleController.java b/dc-admin/src/main/java/com/dc/web/controller/system/SysRoleController.java new file mode 100644 index 0000000..8584b43 --- /dev/null +++ b/dc-admin/src/main/java/com/dc/web/controller/system/SysRoleController.java @@ -0,0 +1,241 @@ +package com.dc.web.controller.system; + +import com.dc.common.annotation.Log; +import com.dc.common.constant.UserConstants; +import com.dc.common.core.controller.BaseController; +import com.dc.common.core.domain.AjaxResult; +import com.dc.common.core.domain.entity.SysDept; +import com.dc.common.core.domain.entity.SysRole; +import com.dc.common.core.domain.entity.SysUser; +import com.dc.common.core.domain.model.LoginUser; +import com.dc.common.core.page.TableDataInfo; +import com.dc.common.enums.BusinessType; +import com.dc.common.utils.StringUtils; +import com.dc.common.utils.poi.ExcelUtil; +import com.dc.framework.web.service.SysPermissionService; +import com.dc.framework.web.service.TokenService; +import com.dc.system.domain.SysUserRole; +import com.dc.system.service.SysDeptService; +import com.dc.system.service.SysRoleService; +import com.dc.system.service.SysUserService; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.validation.annotation.Validated; +import org.springframework.web.bind.annotation.*; + +import javax.servlet.http.HttpServletResponse; +import java.util.List; + +/** + * 角色信息 + * + * @author win + */ +@RestController +@RequestMapping("/system/role") +public class SysRoleController extends BaseController +{ + @Autowired + private SysRoleService roleService; + + @Autowired + private TokenService tokenService; + + @Autowired + private SysPermissionService permissionService; + + @Autowired + private SysUserService userService; + + @Autowired + private SysDeptService deptService; + + @GetMapping("/list") + public TableDataInfo list(SysRole role) + { + startPage(); + List<SysRole> list = roleService.selectRoleList(role); + return getDataTable(list); + } + + @Log(title = "角色管理", businessType = BusinessType.EXPORT) + @PostMapping("/export") + public void export(HttpServletResponse response, SysRole role) + { + List<SysRole> list = roleService.selectRoleList(role); + ExcelUtil<SysRole> util = new ExcelUtil<SysRole>(SysRole.class); + util.exportExcel(response, list, "角色数据"); + } + + /** + * 根据角色编号获取详细信息 + */ + @GetMapping(value = "/{roleId}") + public AjaxResult getInfo(@PathVariable Long roleId) + { + roleService.checkRoleDataScope(roleId); + return success(roleService.selectRoleById(roleId)); + } + + /** + * 新增角色 + */ + @Log(title = "角色管理", businessType = BusinessType.INSERT) + @PostMapping + public AjaxResult add(@Validated @RequestBody SysRole role) + { + if (UserConstants.NOT_UNIQUE.equals(roleService.checkRoleNameUnique(role))) + { + return error("新增角色'" + role.getRoleName() + "'失败,角色名称已存在"); + } + else if (UserConstants.NOT_UNIQUE.equals(roleService.checkRoleKeyUnique(role))) + { + return error("新增角色'" + role.getRoleName() + "'失败,角色权限已存在"); + } + role.setCreateBy(getUsername()); + return toAjax(roleService.insertRole(role)); + + } + + /** + * 修改保存角色 + */ + @Log(title = "角色管理", businessType = BusinessType.UPDATE) + @PutMapping + public AjaxResult edit(@Validated @RequestBody SysRole role) + { + roleService.checkRoleAllowed(role); + roleService.checkRoleDataScope(role.getRoleId()); + if (UserConstants.NOT_UNIQUE.equals(roleService.checkRoleNameUnique(role))) + { + return error("修改角色'" + role.getRoleName() + "'失败,角色名称已存在"); + } + else if (UserConstants.NOT_UNIQUE.equals(roleService.checkRoleKeyUnique(role))) + { + return error("修改角色'" + role.getRoleName() + "'失败,角色权限已存在"); + } + role.setUpdateBy(getUsername()); + + if (roleService.updateRole(role) > 0) + { + // 更新缓存用户权限 + LoginUser loginUser = getLoginUser(); + if (StringUtils.isNotNull(loginUser.getUser()) && !loginUser.getUser().isAdmin()) + { + loginUser.setPermissions(permissionService.getMenuPermission(loginUser.getUser())); + loginUser.setUser(userService.selectUserByUserName(loginUser.getUser().getUserName())); + tokenService.setLoginUser(loginUser); + } + return success(); + } + return error("修改角色'" + role.getRoleName() + "'失败,请联系管理员"); + } + + /** + * 修改保存数据权限 + */ + @Log(title = "角色管理", businessType = BusinessType.UPDATE) + @PutMapping("/dataScope") + public AjaxResult dataScope(@RequestBody SysRole role) + { + roleService.checkRoleAllowed(role); + roleService.checkRoleDataScope(role.getRoleId()); + return toAjax(roleService.authDataScope(role)); + } + + /** + * 状态修改 + */ + @Log(title = "角色管理", businessType = BusinessType.UPDATE) + @PutMapping("/changeStatus") + public AjaxResult changeStatus(@RequestBody SysRole role) + { + roleService.checkRoleAllowed(role); + roleService.checkRoleDataScope(role.getRoleId()); + role.setUpdateBy(getUsername()); + return toAjax(roleService.updateRoleStatus(role)); + } + + /** + * 删除角色 + */ + @Log(title = "角色管理", businessType = BusinessType.DELETE) + @DeleteMapping("/{roleIds}") + public AjaxResult remove(@PathVariable Long[] roleIds) + { + return toAjax(roleService.deleteRoleByIds(roleIds)); + } + + /** + * 获取角色选择框列表 + */ + @GetMapping("/optionselect") + public AjaxResult optionselect() + { + return success(roleService.selectRoleAll()); + } + + /** + * 查询已分配用户角色列表 + */ + @GetMapping("/authUser/allocatedList") + public TableDataInfo allocatedList(SysUser user) + { + startPage(); + List<SysUser> list = userService.selectAllocatedList(user); + return getDataTable(list); + } + + /** + * 查询未分配用户角色列表 + */ + @GetMapping("/authUser/unallocatedList") + public TableDataInfo unallocatedList(SysUser user) + { + startPage(); + List<SysUser> list = userService.selectUnallocatedList(user); + return getDataTable(list); + } + + /** + * 取消授权用户 + */ + @Log(title = "角色管理", businessType = BusinessType.GRANT) + @PutMapping("/authUser/cancel") + public AjaxResult cancelAuthUser(@RequestBody SysUserRole userRole) + { + return toAjax(roleService.deleteAuthUser(userRole)); + } + + /** + * 批量取消授权用户 + */ + @Log(title = "角色管理", businessType = BusinessType.GRANT) + @PutMapping("/authUser/cancelAll") + public AjaxResult cancelAuthUserAll(Long roleId, Long[] userIds) + { + return toAjax(roleService.deleteAuthUsers(roleId, userIds)); + } + + /** + * 批量选择用户授权 + */ + @Log(title = "角色管理", businessType = BusinessType.GRANT) + @PutMapping("/authUser/selectAll") + public AjaxResult selectAuthUserAll(Long roleId, Long[] userIds) + { + roleService.checkRoleDataScope(roleId); + return toAjax(roleService.insertAuthUsers(roleId, userIds)); + } + + /** + * 获取对应角色部门树列表 + */ + @GetMapping(value = "/deptTree/{roleId}") + public AjaxResult deptTree(@PathVariable("roleId") Long roleId) + { + AjaxResult ajax = AjaxResult.success(); + ajax.put("checkedKeys", deptService.selectDeptListByRoleId(roleId)); + ajax.put("depts", deptService.selectDeptTreeList(new SysDept())); + return ajax; + } +} diff --git a/dc-admin/src/main/java/com/dc/web/controller/system/SysUserController.java b/dc-admin/src/main/java/com/dc/web/controller/system/SysUserController.java new file mode 100644 index 0000000..a13565e --- /dev/null +++ b/dc-admin/src/main/java/com/dc/web/controller/system/SysUserController.java @@ -0,0 +1,237 @@ +package com.dc.web.controller.system; + +import com.dc.common.annotation.Log; +import com.dc.common.constant.UserConstants; +import com.dc.common.core.controller.BaseController; +import com.dc.common.core.domain.AjaxResult; +import com.dc.common.core.domain.entity.SysDept; +import com.dc.common.core.domain.entity.SysRole; +import com.dc.common.core.domain.entity.SysUser; +import com.dc.common.core.page.TableDataInfo; +import com.dc.common.enums.BusinessType; +import com.dc.common.utils.SecurityUtils; +import com.dc.common.utils.StringUtils; +import com.dc.common.utils.poi.ExcelUtil; +import com.dc.system.service.SysDeptService; +import com.dc.system.service.SysPostService; +import com.dc.system.service.SysRoleService; +import com.dc.system.service.SysUserService; +import org.apache.commons.lang3.ArrayUtils; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.validation.annotation.Validated; +import org.springframework.web.bind.annotation.*; +import org.springframework.web.multipart.MultipartFile; + +import javax.servlet.http.HttpServletResponse; +import java.util.List; +import java.util.stream.Collectors; + +/** + * 用户信息 + * + * @author win + */ +@RestController +@RequestMapping("/system/user") +public class SysUserController extends BaseController +{ + @Autowired + private SysUserService userService; + + @Autowired + private SysRoleService roleService; + + @Autowired + private SysDeptService deptService; + + @Autowired + private SysPostService postService; + + /** + * 获取用户列表 + */ + @GetMapping("/list") + public TableDataInfo list(SysUser user) + { + startPage(); + List<SysUser> list = userService.selectUserList(user); + return getDataTable(list); + } + + @Log(title = "用户管理", businessType = BusinessType.EXPORT) + @PostMapping("/export") + public void export(HttpServletResponse response, SysUser user) + { + List<SysUser> list = userService.selectUserList(user); + ExcelUtil<SysUser> util = new ExcelUtil<SysUser>(SysUser.class); + util.exportExcel(response, list, "用户数据"); + } + + @Log(title = "用户管理", businessType = BusinessType.IMPORT) + @PostMapping("/importData") + public AjaxResult importData(MultipartFile file, boolean updateSupport) throws Exception + { + ExcelUtil<SysUser> util = new ExcelUtil<SysUser>(SysUser.class); + List<SysUser> userList = util.importExcel(file.getInputStream()); + String operName = getUsername(); + String message = userService.importUser(userList, updateSupport, operName); + return success(message); + } + + @PostMapping("/importTemplate") + public void importTemplate(HttpServletResponse response) + { + ExcelUtil<SysUser> util = new ExcelUtil<SysUser>(SysUser.class); + util.importTemplateExcel(response, "用户数据"); + } + + /** + * 根据用户编号获取详细信息 + */ + @GetMapping(value = { "/", "/{userId}" }) + public AjaxResult getInfo(@PathVariable(value = "userId", required = false) Long userId) + { + userService.checkUserDataScope(userId); + AjaxResult ajax = AjaxResult.success(); + List<SysRole> roles = roleService.selectRoleAll(); + ajax.put("roles", SysUser.isAdmin(userId) ? roles : roles.stream().filter(r -> !r.isAdmin()).collect(Collectors.toList())); + ajax.put("posts", postService.selectPostAll()); + if (StringUtils.isNotNull(userId)) + { + SysUser sysUser = userService.selectUserById(userId); + ajax.put(AjaxResult.DATA_TAG, sysUser); + ajax.put("postIds", postService.selectPostListByUserId(userId)); + ajax.put("roleIds", sysUser.getRoles().stream().map(SysRole::getRoleId).collect(Collectors.toList())); + } + return ajax; + } + + /** + * 新增用户 + */ + @Log(title = "用户管理", businessType = BusinessType.INSERT) + @PostMapping + public AjaxResult add(@Validated @RequestBody SysUser user) + { + if (UserConstants.NOT_UNIQUE.equals(userService.checkUserNameUnique(user))) + { + return error("新增用户'" + user.getUserName() + "'失败,登录账号已存在"); + } + else if (StringUtils.isNotEmpty(user.getPhonenumber()) + && UserConstants.NOT_UNIQUE.equals(userService.checkPhoneUnique(user))) + { + return error("新增用户'" + user.getUserName() + "'失败,手机号码已存在"); + } + else if (StringUtils.isNotEmpty(user.getEmail()) + && UserConstants.NOT_UNIQUE.equals(userService.checkEmailUnique(user))) + { + return error("新增用户'" + user.getUserName() + "'失败,邮箱账号已存在"); + } + user.setCreateBy(getUsername()); + user.setPassword(SecurityUtils.encryptPassword(user.getPassword())); + return toAjax(userService.insertUser(user)); + } + + /** + * 修改用户 + */ + @Log(title = "用户管理", businessType = BusinessType.UPDATE) + @PutMapping + public AjaxResult edit(@Validated @RequestBody SysUser user) + { + userService.checkUserAllowed(user); + userService.checkUserDataScope(user.getUserId()); + if (UserConstants.NOT_UNIQUE.equals(userService.checkUserNameUnique(user))) + { + return error("修改用户'" + user.getUserName() + "'失败,登录账号已存在"); + } + else if (StringUtils.isNotEmpty(user.getPhonenumber()) + && UserConstants.NOT_UNIQUE.equals(userService.checkPhoneUnique(user))) + { + return error("修改用户'" + user.getUserName() + "'失败,手机号码已存在"); + } + else if (StringUtils.isNotEmpty(user.getEmail()) + && UserConstants.NOT_UNIQUE.equals(userService.checkEmailUnique(user))) + { + return error("修改用户'" + user.getUserName() + "'失败,邮箱账号已存在"); + } + user.setUpdateBy(getUsername()); + return toAjax(userService.updateUser(user)); + } + + /** + * 删除用户 + */ + @Log(title = "用户管理", businessType = BusinessType.DELETE) + @DeleteMapping("/{userIds}") + public AjaxResult remove(@PathVariable Long[] userIds) + { + if (ArrayUtils.contains(userIds, getUserId())) + { + return error("当前用户不能删除"); + } + return toAjax(userService.deleteUserByIds(userIds)); + } + + /** + * 重置密码 + */ + @Log(title = "用户管理", businessType = BusinessType.UPDATE) + @PutMapping("/resetPwd") + public AjaxResult resetPwd(@RequestBody SysUser user) + { + userService.checkUserAllowed(user); + userService.checkUserDataScope(user.getUserId()); + user.setPassword(SecurityUtils.encryptPassword(user.getPassword())); + user.setUpdateBy(getUsername()); + return toAjax(userService.resetPwd(user)); + } + + /** + * 状态修改 + */ + @Log(title = "用户管理", businessType = BusinessType.UPDATE) + @PutMapping("/changeStatus") + public AjaxResult changeStatus(@RequestBody SysUser user) + { + userService.checkUserAllowed(user); + userService.checkUserDataScope(user.getUserId()); + user.setUpdateBy(getUsername()); + return toAjax(userService.updateUserStatus(user)); + } + + /** + * 根据用户编号获取授权角色 + */ + @GetMapping("/authRole/{userId}") + public AjaxResult authRole(@PathVariable("userId") Long userId) + { + AjaxResult ajax = AjaxResult.success(); + SysUser user = userService.selectUserById(userId); + List<SysRole> roles = roleService.selectRolesByUserId(userId); + ajax.put("user", user); + ajax.put("roles", SysUser.isAdmin(userId) ? roles : roles.stream().filter(r -> !r.isAdmin()).collect(Collectors.toList())); + return ajax; + } + + /** + * 用户授权角色 + */ + @Log(title = "用户管理", businessType = BusinessType.GRANT) + @PutMapping("/authRole") + public AjaxResult insertAuthRole(Long userId, Long[] roleIds) + { + userService.checkUserDataScope(userId); + userService.insertUserAuth(userId, roleIds); + return success(); + } + + /** + * 获取部门树列表 + */ + @GetMapping("/deptTree") + public AjaxResult deptTree(SysDept dept) + { + return success(deptService.selectDeptTreeList(dept)); + } +} diff --git a/dc-admin/src/main/java/com/dc/web/controller/tool/SwaggerController.java b/dc-admin/src/main/java/com/dc/web/controller/tool/SwaggerController.java new file mode 100644 index 0000000..0d755e0 --- /dev/null +++ b/dc-admin/src/main/java/com/dc/web/controller/tool/SwaggerController.java @@ -0,0 +1,22 @@ +package com.dc.web.controller.tool; + +import com.dc.common.core.controller.BaseController; +import org.springframework.stereotype.Controller; +import org.springframework.web.bind.annotation.GetMapping; +import org.springframework.web.bind.annotation.RequestMapping; + +/** + * swagger 接口 + * + * @author win + */ +@Controller +@RequestMapping("/tool/swagger") +public class SwaggerController extends BaseController +{ + @GetMapping() + public String index() + { + return redirect("/swagger-ui.html"); + } +} diff --git a/dc-admin/src/main/java/com/dc/web/controller/tool/TestController.java b/dc-admin/src/main/java/com/dc/web/controller/tool/TestController.java new file mode 100644 index 0000000..4b070ee --- /dev/null +++ b/dc-admin/src/main/java/com/dc/web/controller/tool/TestController.java @@ -0,0 +1,167 @@ +package com.dc.web.controller.tool; + +import com.dc.common.core.controller.BaseController; +import com.dc.common.core.domain.R; +import com.dc.common.utils.StringUtils; +import io.swagger.annotations.*; +import org.springframework.web.bind.annotation.*; + +import java.util.ArrayList; +import java.util.LinkedHashMap; +import java.util.List; +import java.util.Map; + +/** + * swagger 用户测试方法 + * + * @author win + */ +@Api("用户信息管理") +@RestController +@RequestMapping("/test/user") +public class TestController extends BaseController +{ + private final static Map<Integer, UserEntity> users = new LinkedHashMap<Integer, UserEntity>(); + { + users.put(1, new UserEntity(1, "admin", "admin123", "15888888888")); + users.put(2, new UserEntity(2, "ry", "admin123", "15666666666")); + } + + @GetMapping("/list") + public R<List<UserEntity>> userList() + { + List<UserEntity> userList = new ArrayList<UserEntity>(users.values()); + return R.ok(userList); + } + + @ApiImplicitParam(name = "userId", value = "用户ID", required = true, dataType = "int", paramType = "path", dataTypeClass = Integer.class) + @GetMapping("/{userId}") + public R<UserEntity> getUser(@PathVariable Integer userId) + { + if (!users.isEmpty() && users.containsKey(userId)) + { + return R.ok(users.get(userId)); + } + else + { + return R.fail("用户不存在"); + } + } + + @ApiImplicitParams({ + @ApiImplicitParam(name = "userId", value = "用户id", dataType = "Integer", dataTypeClass = Integer.class), + @ApiImplicitParam(name = "username", value = "用户名称", dataType = "String", dataTypeClass = String.class), + @ApiImplicitParam(name = "password", value = "用户密码", dataType = "String", dataTypeClass = String.class), + @ApiImplicitParam(name = "mobile", value = "用户手机", dataType = "String", dataTypeClass = String.class) + }) + @PostMapping("/save") + public R<String> save(UserEntity user) + { + if (StringUtils.isNull(user) || StringUtils.isNull(user.getUserId())) + { + return R.fail("用户ID不能为空"); + } + users.put(user.getUserId(), user); + return R.ok(); + } + + @PutMapping("/update") + public R<String> update(@RequestBody UserEntity user) + { + if (StringUtils.isNull(user) || StringUtils.isNull(user.getUserId())) + { + return R.fail("用户ID不能为空"); + } + if (users.isEmpty() || !users.containsKey(user.getUserId())) + { + return R.fail("用户不存在"); + } + users.remove(user.getUserId()); + users.put(user.getUserId(), user); + return R.ok(); + } + + @ApiImplicitParam(name = "userId", value = "用户ID", required = true, dataType = "int", paramType = "path", dataTypeClass = Integer.class) + @DeleteMapping("/{userId}") + public R<String> delete(@PathVariable Integer userId) + { + if (!users.isEmpty() && users.containsKey(userId)) + { + users.remove(userId); + return R.ok(); + } + else + { + return R.fail("用户不存在"); + } + } +} + +@ApiModel(value = "UserEntity", description = "用户实体") +class UserEntity +{ + @ApiModelProperty("用户ID") + private Integer userId; + + @ApiModelProperty("用户名称") + private String username; + + @ApiModelProperty("用户密码") + private String password; + + @ApiModelProperty("用户手机") + private String mobile; + + public UserEntity() + { + + } + + public UserEntity(Integer userId, String username, String password, String mobile) + { + this.userId = userId; + this.username = username; + this.password = password; + this.mobile = mobile; + } + + public Integer getUserId() + { + return userId; + } + + public void setUserId(Integer userId) + { + this.userId = userId; + } + + public String getUsername() + { + return username; + } + + public void setUsername(String username) + { + this.username = username; + } + + public String getPassword() + { + return password; + } + + public void setPassword(String password) + { + this.password = password; + } + + public String getMobile() + { + return mobile; + } + + public void setMobile(String mobile) + { + this.mobile = mobile; + } +} diff --git a/dc-admin/src/main/java/com/dc/web/websocket/SemaphoreUtils.java b/dc-admin/src/main/java/com/dc/web/websocket/SemaphoreUtils.java new file mode 100644 index 0000000..3baf3db --- /dev/null +++ b/dc-admin/src/main/java/com/dc/web/websocket/SemaphoreUtils.java @@ -0,0 +1,46 @@ +package com.dc.web.websocket; + +import lombok.extern.slf4j.Slf4j; + +import java.util.concurrent.Semaphore; + +/** + * 信号量相关处理 + * + * @author ruoyi + */ +@Slf4j +public class SemaphoreUtils { + + /** + * 获取信号量 + * + * @param semaphore + * @return + */ + public static boolean tryAcquire(Semaphore semaphore) { + boolean flag = false; + + try { + flag = semaphore.tryAcquire(); + } catch (Exception e) { + log.error("获取信号量异常", e); + } + + return flag; + } + + /** + * 释放信号量 + * + * @param semaphore + */ + public static void release(Semaphore semaphore) { + + try { + semaphore.release(); + } catch (Exception e) { + log.error("释放信号量异常", e); + } + } +} diff --git a/dc-admin/src/main/java/com/dc/web/websocket/WebSocketConfig.java b/dc-admin/src/main/java/com/dc/web/websocket/WebSocketConfig.java new file mode 100644 index 0000000..b403966 --- /dev/null +++ b/dc-admin/src/main/java/com/dc/web/websocket/WebSocketConfig.java @@ -0,0 +1,18 @@ +package com.dc.web.websocket; + +import org.springframework.context.annotation.Bean; +import org.springframework.context.annotation.Configuration; +import org.springframework.web.socket.server.standard.ServerEndpointExporter; + +/** + * websocket 配置 + * + * @author ruoyi + */ +@Configuration +public class WebSocketConfig { + @Bean + public ServerEndpointExporter serverEndpointExporter() { + return new ServerEndpointExporter(); + } +} diff --git a/dc-admin/src/main/java/com/dc/web/websocket/WebSocketServer.java b/dc-admin/src/main/java/com/dc/web/websocket/WebSocketServer.java new file mode 100644 index 0000000..e44bf59 --- /dev/null +++ b/dc-admin/src/main/java/com/dc/web/websocket/WebSocketServer.java @@ -0,0 +1,91 @@ +package com.dc.web.websocket; + +import lombok.extern.slf4j.Slf4j; +import org.springframework.stereotype.Component; + +import javax.websocket.*; +import javax.websocket.server.PathParam; +import javax.websocket.server.ServerEndpoint; +import java.util.concurrent.Semaphore; + +/** + * websocket 消息处理 + * + * @author ruoyi + */ +@Slf4j +@Component +@ServerEndpoint("/websocket/{sessionId}") +public class WebSocketServer { + + /** + * 默认最多允许同时在线人数100 + */ + public static int socketMaxOnlineCount = 100; + + private static Semaphore socketSemaphore = new Semaphore(socketMaxOnlineCount); + + /** + * 连接建立成功调用的方法 + */ + @OnOpen + public void onOpen(Session session, @PathParam("sessionId") String sessionId) throws Exception { + log.info("sessionId - {}", sessionId); + boolean semaphoreFlag = false; + // 尝试获取信号量 + semaphoreFlag = SemaphoreUtils.tryAcquire(socketSemaphore); + if (!semaphoreFlag) { + // 未获取到信号量 + log.error("\n 当前在线人数超过限制数- {}", socketMaxOnlineCount); + WebSocketUsers.sendMessageToUserByText(session, "当前在线人数超过限制数:" + socketMaxOnlineCount); + session.close(); + } else { + // 添加用户 + WebSocketUsers.put(sessionId, session); + log.info("\n 建立连接 - {}", session); + log.info("\n 当前人数 - {}", WebSocketUsers.getUsers().size()); + WebSocketUsers.sendMessageToUserByText(session, "连接成功"); + } + } + + /** + * 连接关闭时处理 + */ + @OnClose + public void onClose(Session session) { + log.info("\n 关闭连接 - {}", session); + // 移除用户 + WebSocketUsers.remove(session.getId()); + // 获取到信号量则需释放 + SemaphoreUtils.release(socketSemaphore); + } + + /** + * 抛出异常时处理 + */ + @OnError + public void onError(Session session, Throwable exception) throws Exception { + if (session.isOpen()) { + // 关闭连接 + session.close(); + } + String sessionId = session.getId(); + log.info("\n 连接异常 - {}", sessionId); + log.info("\n 异常信息 - {}", exception); + // 移出用户 + WebSocketUsers.remove(sessionId); + // 获取到信号量则需释放 + SemaphoreUtils.release(socketSemaphore); + } + + /** + * 服务器接收到客户端消息时调用的方法 + * 自定义sessionId,每个设备不同的sessionId,这样就可以给每个设备发送消息了 + */ + @OnMessage + public void onMessage(String message, @PathParam("sessionId") String sessionId) { + log.info("sessionId - {}", sessionId); + String msg = message.replace("你", "我").replace("吗", ""); + WebSocketUsers.sendMessageToUserByText(WebSocketUsers.getUsers().get(sessionId), msg); + } +} diff --git a/dc-admin/src/main/java/com/dc/web/websocket/WebSocketUsers.java b/dc-admin/src/main/java/com/dc/web/websocket/WebSocketUsers.java new file mode 100644 index 0000000..f5a5b64 --- /dev/null +++ b/dc-admin/src/main/java/com/dc/web/websocket/WebSocketUsers.java @@ -0,0 +1,114 @@ +package com.dc.web.websocket; + +import lombok.extern.slf4j.Slf4j; + +import javax.websocket.Session; +import java.io.IOException; +import java.util.Collection; +import java.util.Map; +import java.util.Set; +import java.util.concurrent.ConcurrentHashMap; + +/** + * websocket 客户端用户集 + * + * @author ruoyi + */ +@Slf4j +public class WebSocketUsers { + + /** + * 用户集 + */ + private static Map<String, Session> USERS = new ConcurrentHashMap<String, Session>(); + + /** + * 存储用户 + * + * @param key 唯一键 + * @param session 用户信息 + */ + public static void put(String key, Session session) { + USERS.put(key, session); + } + + /** + * 移除用户 + * + * @param session 用户信息 + * @return 移除结果 + */ + public static boolean remove(Session session) { + String key = null; + boolean flag = USERS.containsValue(session); + if (flag) { + Set<Map.Entry<String, Session>> entries = USERS.entrySet(); + for (Map.Entry<String, Session> entry : entries) { + Session value = entry.getValue(); + if (value.equals(session)) { + key = entry.getKey(); + break; + } + } + } else { + return true; + } + return remove(key); + } + + /** + * 移出用户 + * + * @param key 键 + */ + public static boolean remove(String key) { + log.info("\n 正在移出用户 - {}", key); + Session remove = USERS.remove(key); + if (remove != null) { + boolean containsValue = USERS.containsValue(remove); + log.info("\n 移出结果 - {}", containsValue ? "失败" : "成功"); + return containsValue; + } else { + return true; + } + } + + /** + * 获取在线用户列表 + * + * @return 返回用户集合 + */ + public static Map<String, Session> getUsers() { + return USERS; + } + + /** + * 群发消息文本消息 + * + * @param message 消息内容 + */ + public static void sendMessageToUsersByText(String message) { + Collection<Session> values = USERS.values(); + for (Session value : values) { + sendMessageToUserByText(value, message); + } + } + + /** + * 发送文本消息 + * + * @param session 自己的用户名 + * @param message 消息内容 + */ + public static void sendMessageToUserByText(Session session, String message) { + if (session != null) { + try { + session.getBasicRemote().sendText(message); + } catch (IOException e) { + log.error("\n[发送消息异常]", e); + } + } else { + log.info("\n[你已离线]"); + } + } +} diff --git a/dc-admin/src/main/resources/META-INF/spring-devtools.properties b/dc-admin/src/main/resources/META-INF/spring-devtools.properties new file mode 100644 index 0000000..2b23f85 --- /dev/null +++ b/dc-admin/src/main/resources/META-INF/spring-devtools.properties @@ -0,0 +1 @@ +restart.include.json=/com.alibaba.fastjson.*.jar \ No newline at end of file diff --git a/dc-admin/src/main/resources/application-dev.yml b/dc-admin/src/main/resources/application-dev.yml new file mode 100644 index 0000000..c252aeb --- /dev/null +++ b/dc-admin/src/main/resources/application-dev.yml @@ -0,0 +1,157 @@ +# 开发环境配置 +server: + # 服务器的HTTP端口,默认为8080 + port: 9000 + servlet: + # 应用的访问路径 + context-path: / + tomcat: + # tomcat的URI编码 + uri-encoding: UTF-8 + # 连接数满后的排队数,默认为100 + accept-count: 1000 + threads: + # tomcat最大线程数,默认为200 + max: 800 + # Tomcat启动初始化的线程数,默认值10 + min-spare: 100 + +# 日志配置 +logging: + file: + path: logs + level: + com.dc: debug + org.springframework: warn + +# 用户配置 +user: + password: + # 密码最大错误次数 + maxRetryCount: 5 + # 密码锁定时间(默认10分钟) + lockTime: 10 + +# Spring配置 +spring: + shardingsphere: + mode: + type: Memory + # 属性配置 + props: + sql.show: true + ## 数据源配置 + datasource: + names: master,slave0,slave1 + # 主数据源 + master: +# type: com.alibaba.druid.pool.DruidDataSource +# driverClassName: com.mysql.cj.jdbc.Driver +# url: jdbc:mysql://dev.ccwin-in.com:23113/ccwin?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8 +# username: root +# password: Microdoft@2021 + # 读数据源 + slave0: +# type: com.alibaba.druid.pool.DruidDataSource +# driverClassName: com.mysql.cj.jdbc.Driver +# url: jdbc:mysql://dev.ccwin-in.com:23113/ccwin?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8 +# username: root +# password: Microdoft@2021 + # 读数据源 + slave1: +# type: com.alibaba.druid.pool.DruidDataSource +# driverClassName: com.mysql.cj.jdbc.Driver +# url: jdbc:mysql://dev.ccwin-in.com:23113/ccwin?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8 +# username: root +# password: Microdoft@2021 + # 读写分离类型,如: Static,Dynamic + rules: + readwrite-splitting: + data-sources: + myds: + type: Static + props: + write-data-source-name: master + read-data-source-names: slave0,slave1 + load-balancer-name: alg_round + load-balancers: + alg_round: + type: ROUND_ROBIN + datasource: + dynamic: + strict: true + datasource: + dcdata: + driver-class-name: org.postgresql.Driver + type: com.alibaba.druid.pool.DruidDataSource + url: jdbc:postgresql://10.10.10.59:5432/dcdatabase?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai + username: postgres + password: 123456 + primary: dcdata + # 资源信息 + messages: + # 国际化资源文件路径 + basename: i18n/messages + # 文件上传 + servlet: + multipart: + # 单个文件大小 + max-file-size: 10MB + # 设置总上传的文件大小 + max-request-size: 20MB + # 服务模块 + devtools: + restart: + # 热部署开关 + enabled: true + # 彩色日志开关 + output: + ansi: + enabled: ALWAYS + # redis 配置 + redis: + # 地址 + host: 10.10.10.55 + # 端口,默认为6379 + port: 7000 + # 数据库索引 + database: 0 + # 密码 + password: redis123 + # 连接超时时间 + timeout: 10s + lettuce: + pool: + # 连接池中的最小空闲连接 + min-idle: 0 + # 连接池中的最大空闲连接 + max-idle: 8 + # 连接池的最大数据库连接数 + max-active: 8 + # #连接池最大阻塞等待时间(使用负值表示没有限制) + max-wait: -1ms + +# token配置 +token: + # 令牌自定义标识 + header: Authorization + # 令牌密钥 + secret: data_center + # 令牌有效期(12小时) + expireTime: 720 + # 是否允许账户多终端同时登录(true允许 false不允许) + soloLogin: true + +# Swagger配置 +swagger: + # 是否开启swagger + enabled: true + # 请求前缀 + pathMapping: / + +# flowable相关表 +flowable: + # true 会对数据库中所有表进行更新操作。如果表不存在,则自动创建(建议开发时使用) + database-schema-update: false + # 关闭定时任务JOB + async-executor-activate: false diff --git a/dc-admin/src/main/resources/application-druid.yml b/dc-admin/src/main/resources/application-druid.yml new file mode 100644 index 0000000..ea3f8e8 --- /dev/null +++ b/dc-admin/src/main/resources/application-druid.yml @@ -0,0 +1,47 @@ +# 数据源配置 +spring: + datasource: + druid: + # 初始连接数 + initialSize: 20 + # 最小连接池数量 + minIdle: 20 + # 最大连接池数量 + maxActive: 200 + # 配置获取连接等待超时的时间 + maxWait: 60000 + # 配置间隔多久才进行一次检测,检测需要关闭的空闲连接,单位是毫秒 + timeBetweenEvictionRunsMillis: 60000 + # 配置一个连接在池中最小生存的时间,单位是毫秒 + minEvictableIdleTimeMillis: 300000 + # 配置一个连接在池中最大生存的时间,单位是毫秒 + maxEvictableIdleTimeMillis: 900000 + # 配置检测连接是否有效 + validationQuery: SELECT 1 FROM DUAL + testWhileIdle: true + testOnBorrow: false + testOnReturn: false + webStatFilter: + enabled: false + url-pattern: /* # 过滤所有url + exclusions: "*.js,*.gif,*.jpg,*.png,*.css,*.ico,/druid/*" # 排除一些不必要的url + session-stat-enable: true # 开启session统计功能 + session-stat-max-count: 1000 # session的最大个数,默认100 + statViewServlet: + enabled: true + # 设置白名单,不填则允许所有访问 + allow: + url-pattern: /druid/* + # 控制台管理用户名和密码 + login-username: win + login-password: 123456 + filter: + stat: + enabled: true + # 慢SQL记录 + log-slow-sql: true + slow-sql-millis: 1000 + merge-sql: true + wall: + config: + multi-statement-allow: true \ No newline at end of file diff --git a/dc-admin/src/main/resources/application-mybatis.yml b/dc-admin/src/main/resources/application-mybatis.yml new file mode 100644 index 0000000..22247b4 --- /dev/null +++ b/dc-admin/src/main/resources/application-mybatis.yml @@ -0,0 +1,57 @@ +# MyBatis Plus配置 +mybatis-plus: + # 不支持多包, 如有需要可在注解配置 或 提升扫包等级 + # 例如 com.**.**.mapper + mapperPackage: com.dc.**.mapper + # 对应的 XML 文件位置 + mapperLocations: classpath*:mapper/**/*Mapper.xml + # 实体扫描,多个package用逗号或者分号分隔 + typeAliasesPackage: com.dc.**.domain + # 加载全局的配置文件 + configLocation: classpath:mybatis/mybatis-config.xml + # 启动时是否检查 MyBatis XML 文件的存在,默认不检查 + checkConfigLocation: false + configuration: + # 自动驼峰命名规则(camel case)映射 + mapUnderscoreToCamelCase: true + # MyBatis 自动映射策略 + # NONE:不启用 PARTIAL:只对非嵌套 resultMap 自动映射 FULL:对所有 resultMap 自动映射 + autoMappingBehavior: PARTIAL + # MyBatis 自动映射时未知列或未知属性处理策 + # NONE:不做处理 WARNING:打印相关警告 FAILING:抛出异常和详细信息 + autoMappingUnknownColumnBehavior: NONE + # 开启缓存 + cache-enabled: true + # 更详细的日志输出 会有性能损耗 org.apache.ibatis.logging.stdout.StdOutImpl + # 关闭日志记录 (可单纯使用 p6spy 分析) org.apache.ibatis.logging.nologging.NoLoggingImpl + # 默认日志输出 org.apache.ibatis.logging.slf4j.Slf4jImpl + logImpl: org.apache.ibatis.logging.slf4j.Slf4jImpl + global-config: + # 是否打印 Logo banner + banner: false + dbConfig: + # 主键类型 + # AUTO 自增 NONE 空 INPUT 用户输入 ASSIGN_ID 雪花 ASSIGN_UUID 唯一 UUID + id_type: AUTO + # 全局逻辑删除的实体字段名(since 3.3.0,配置后可以忽略不配置步骤2) + # logic-delete-field: flag + # 逻辑已删除值(默认为 1) + logic-delete-value: 1 + # 逻辑未删除值(默认为 0) + logic-not-delete-value: 0 + # 逻辑已删除值 + logicDeleteValue: 2 + logicNotDeleteValue: 0 + # 字段验证策略之 insert,在 insert 的时候的字段验证策略 + # IGNORED 忽略 NOT_NULL 非NULL NOT_EMPTY 非空 DEFAULT 默认 NEVER 不加入 SQL + insert_strategy: NOT_NULL + # 字段验证策略之 update,在 update 的时候的字段验证策略 + update_strategy: NOT_NULL + # 字段验证策略之 select,在 select 的时候的字段验证策略既 wrapper 根据内部 entity 生成的 where 条件 + where-strategy: NOT_NULL + +# PageHelper分页插件 +pagehelper: + helperDialect: postgresql + supportMethodsArguments: true + params: count=countSql diff --git a/dc-admin/src/main/resources/application-prod.yml b/dc-admin/src/main/resources/application-prod.yml new file mode 100644 index 0000000..b39e4ff --- /dev/null +++ b/dc-admin/src/main/resources/application-prod.yml @@ -0,0 +1,157 @@ +# 开发环境配置 +server: + # 服务器的HTTP端口,默认为8080 + port: 9000 + servlet: + # 应用的访问路径 + context-path: / + tomcat: + # tomcat的URI编码 + uri-encoding: UTF-8 + # 连接数满后的排队数,默认为100 + accept-count: 1000 + threads: + # tomcat最大线程数,默认为200 + max: 800 + # Tomcat启动初始化的线程数,默认值10 + min-spare: 100 + +# 日志配置 +logging: + file: + path: logs + level: + com.dc: warn + org.springframework: warn + +# 用户配置 +user: + password: + # 密码最大错误次数 + maxRetryCount: 5 + # 密码锁定时间(默认10分钟) + lockTime: 10 + +# Spring配置 +spring: + shardingsphere: + mode: + type: Memory + # 属性配置 + props: + sql.show: true + ## 数据源配置 + datasource: + names: master,slave0,slave1 + # 主数据源 + master: +# type: com.alibaba.druid.pool.DruidDataSource +# driverClassName: com.mysql.cj.jdbc.Driver +# url: jdbc:mysql://localhost:3306/ccwin?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8 +# username: root +# password: Microdoft@2021 + # 读数据源 + slave0: +# type: com.alibaba.druid.pool.DruidDataSource +# driverClassName: com.mysql.cj.jdbc.Driver +# url: jdbc:mysql://localhost:3306/ccwin?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8 +# username: root +# password: Microdoft@2021 + # 读数据源 + slave1: +# type: com.alibaba.druid.pool.DruidDataSource +# driverClassName: com.mysql.cj.jdbc.Driver +# url: jdbc:mysql://localhost:3306/ccwin?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8 +# username: root +# password: Microdoft@2021 + # 读写分离类型,如: Static,Dynamic + rules: + readwrite-splitting: + data-sources: + myds: + type: Static + props: + write-data-source-name: master + read-data-source-names: slave0,slave1 + load-balancer-name: alg_round + load-balancers: + alg_round: + type: ROUND_ROBIN + datasource: + dynamic: + strict: true + datasource: + dcdata: + driver-class-name: org.postgresql.Driver + type: com.alibaba.druid.pool.DruidDataSource + url: jdbc:postgresql://10.10.10.56:5432/dcdatabase?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai + username: postgres + password: 123456 + primary: dcdata + # 资源信息 + messages: + # 国际化资源文件路径 + basename: i18n/messages + # 文件上传 + servlet: + multipart: + # 单个文件大小 + max-file-size: 10MB + # 设置总上传的文件大小 + max-request-size: 20MB + # 服务模块 + devtools: + restart: + # 热部署开关 + enabled: true + # 彩色日志开关 + output: + ansi: + enabled: ALWAYS + # redis 配置 + redis: + # 地址 + host: 10.10.10.55 + # 端口,默认为6379 + port: 7000 + # 数据库索引 + database: 1 + # 密码 + password: redis123 + # 连接超时时间 + timeout: 10s + lettuce: + pool: + # 连接池中的最小空闲连接 + min-idle: 0 + # 连接池中的最大空闲连接 + max-idle: 8 + # 连接池的最大数据库连接数 + max-active: 8 + # #连接池最大阻塞等待时间(使用负值表示没有限制) + max-wait: -1ms + +# token配置 +token: + # 令牌自定义标识 + header: Authorization + # 令牌密钥 + secret: data_center + # 令牌有效期(12小时) + expireTime: 720 + # 是否允许账户多终端同时登录(true允许 false不允许) + soloLogin: true + +# Swagger配置 +swagger: + # 是否开启swagger + enabled: false + # 请求前缀 + pathMapping: / + +# flowable相关表 +flowable: + # true 会对数据库中所有表进行更新操作。如果表不存在,则自动创建(建议开发时使用) + database-schema-update: false + # 关闭定时任务JOB + async-executor-activate: false \ No newline at end of file diff --git a/dc-admin/src/main/resources/application-test.yml b/dc-admin/src/main/resources/application-test.yml new file mode 100644 index 0000000..8bb00c0 --- /dev/null +++ b/dc-admin/src/main/resources/application-test.yml @@ -0,0 +1,157 @@ +# 开发环境配置 +server: + # 服务器的HTTP端口,默认为8080 + port: 8080 + servlet: + # 应用的访问路径 + context-path: / + tomcat: + # tomcat的URI编码 + uri-encoding: UTF-8 + # 连接数满后的排队数,默认为100 + accept-count: 1000 + threads: + # tomcat最大线程数,默认为200 + max: 800 + # Tomcat启动初始化的线程数,默认值10 + min-spare: 100 + +# 日志配置 +logging: + file: + path: logs + level: + com.dc: debug + org.springframework: warn + +# 用户配置 +user: + password: + # 密码最大错误次数 + maxRetryCount: 5 + # 密码锁定时间(默认10分钟) + lockTime: 10 + +# Spring配置 +spring: + shardingsphere: + mode: + type: Memory + # 属性配置 + props: + sql.show: true + ## 数据源配置 + datasource: + names: master,slave0,slave1 + # 主数据源 + master: + type: com.alibaba.druid.pool.DruidDataSource + driverClassName: com.mysql.cj.jdbc.Driver + url: jdbc:mysql://dev.ccwin-in.com:23113/ccwin?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8 + username: root + password: Microdoft@2021 + # 读数据源 + slave0: + type: com.alibaba.druid.pool.DruidDataSource + driverClassName: com.mysql.cj.jdbc.Driver + url: jdbc:mysql://dev.ccwin-in.com:23113/ccwin?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8 + username: root + password: Microdoft@2021 + # 读数据源 + slave1: + type: com.alibaba.druid.pool.DruidDataSource + driverClassName: com.mysql.cj.jdbc.Driver + url: jdbc:mysql://dev.ccwin-in.com:23113/ccwin?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8 + username: root + password: Microdoft@2021 + # 读写分离类型,如: Static,Dynamic + rules: + readwrite-splitting: + data-sources: + myds: + type: Static + props: + write-data-source-name: master + read-data-source-names: slave0,slave1 + load-balancer-name: alg_round + load-balancers: + alg_round: + type: ROUND_ROBIN + datasource: + dynamic: + strict: true + datasource: + ccwin: + driver-class-name: com.mysql.cj.jdbc.Driver + type: com.alibaba.druid.pool.DruidDataSource + url: jdbc:mysql://dev.ccwin-in.com:23113/ccwin?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8 + username: root + password: Microdoft@2021 + primary: ccwin + # 资源信息 + messages: + # 国际化资源文件路径 + basename: i18n/messages + # 文件上传 + servlet: + multipart: + # 单个文件大小 + max-file-size: 10MB + # 设置总上传的文件大小 + max-request-size: 20MB + # 服务模块 + devtools: + restart: + # 热部署开关 + enabled: true + # 彩色日志开关 + output: + ansi: + enabled: ALWAYS + # redis 配置 + redis: + # 地址 + host: dev.ccwin-in.com + # 端口,默认为6379 + port: 23114 + # 数据库索引 + database: 1 + # 密码 + password: + # 连接超时时间 + timeout: 10s + lettuce: + pool: + # 连接池中的最小空闲连接 + min-idle: 0 + # 连接池中的最大空闲连接 + max-idle: 8 + # 连接池的最大数据库连接数 + max-active: 8 + # #连接池最大阻塞等待时间(使用负值表示没有限制) + max-wait: -1ms + +# token配置 +token: + # 令牌自定义标识 + header: Authorization + # 令牌密钥 + secret: ccwin-in.com + # 令牌有效期(12小时) + expireTime: 720 + # 是否允许账户多终端同时登录(true允许 false不允许) + soloLogin: true + +# Swagger配置 +swagger: + # 是否开启swagger + enabled: true + # 请求前缀 + pathMapping: / + +# flowable相关表 +flowable: + # true 会对数据库中所有表进行更新操作。如果表不存在,则自动创建(建议开发时使用) + database-schema-update: false + # 关闭定时任务JOB + async-executor-activate: false \ No newline at end of file diff --git a/dc-admin/src/main/resources/application.yml b/dc-admin/src/main/resources/application.yml new file mode 100644 index 0000000..5db32ba --- /dev/null +++ b/dc-admin/src/main/resources/application.yml @@ -0,0 +1,39 @@ +spring: + application: + name: data_center + profiles: + include: druid,mybatis + active: prod + main: + allow-bean-definition-overriding: true + servlet: + multipart: + enabled: true + max-file-size: 200MB + max-request-size: 1000MB + +# 项目相关配置 +dccenter: + # 名称 + name: dc + # 版本 + version: 3.8.5 + # 版权年份 + copyrightYear: 2023 + # 实例演示开关 + demoEnabled: true + # 文件路径 示例( Windows配置D:/win/uploadPath,Linux配置 /home/win/uploadPath) + profile: /uploadPath + # 获取ip地址开关 + addressEnabled: false + # 验证码类型 math 数组计算 char 字符验证 + captchaType: math + +# 防止XSS攻击 +xss: + # 过滤开关 + enabled: true + # 排除链接(多个用逗号分隔) + excludes: /system/notice + # 匹配链接 + urlPatterns: /system/*,/monitor/*,/tool/* diff --git a/dc-admin/src/main/resources/i18n/messages.properties b/dc-admin/src/main/resources/i18n/messages.properties new file mode 100644 index 0000000..b7433dc --- /dev/null +++ b/dc-admin/src/main/resources/i18n/messages.properties @@ -0,0 +1,37 @@ +#错误消息 +not.null=* 必须填写 +user.jcaptcha.error=验证码错误 +user.jcaptcha.expire=验证码已失效 +user.not.exists=用户不存在/密码错误 +user.password.not.match=用户不存在/密码错误 +user.password.retry.limit.count=密码输入错误{0}次 +user.password.retry.limit.exceed=密码输入错误{0}次,帐户锁定{1}分钟 +user.password.delete=对不起,您的账号已被删除 +user.blocked=用户已封禁,请联系管理员 +role.blocked=角色已封禁,请联系管理员 +user.logout.success=退出成功 + +length.not.valid=长度必须在{min}到{max}个字符之间 + +user.username.not.valid=* 2到20个汉字、字母、数字或下划线组成,且必须以非数字开头 +user.password.not.valid=* 5-50个字符 + +user.email.not.valid=邮箱格式错误 +user.mobile.phone.number.not.valid=手机号格式错误 +user.login.success=登录成功 +user.register.success=注册成功 +user.notfound=请重新登录 +user.forcelogout=管理员强制退出,请重新登录 +user.unknown.error=未知错误,请重新登录 + +##文件上传消息 +upload.exceed.maxSize=上传的文件大小超出限制的文件大小!<br/>允许的文件最大大小是:{0}MB! +upload.filename.exceed.length=上传的文件名最长{0}个字符 + +##权限 +no.permission=您没有数据的权限,请联系管理员添加权限 [{0}] +no.create.permission=您没有创建数据的权限,请联系管理员添加权限 [{0}] +no.update.permission=您没有修改数据的权限,请联系管理员添加权限 [{0}] +no.delete.permission=您没有删除数据的权限,请联系管理员添加权限 [{0}] +no.export.permission=您没有导出数据的权限,请联系管理员添加权限 [{0}] +no.view.permission=您没有查看数据的权限,请联系管理员添加权限 [{0}] diff --git a/dc-admin/src/main/resources/logback-spring.xml b/dc-admin/src/main/resources/logback-spring.xml new file mode 100644 index 0000000..aca3b77 --- /dev/null +++ b/dc-admin/src/main/resources/logback-spring.xml @@ -0,0 +1,108 @@ +<?xml version="1.0" encoding="UTF-8"?> +<configuration> + <springProperty scope="context" name="logPath" source="logging.file.path" defaultValue="logs"/> + <!-- 日志存放路径 --> + <property name="log.path" value="${logPath}" /> + + <!--0. 日志格式和颜色渲染 --> + <!-- 彩色日志依赖的渲染类 --> + <conversionRule conversionWord="clr" converterClass="org.springframework.boot.logging.logback.ColorConverter" /> + <conversionRule conversionWord="wex" converterClass="org.springframework.boot.logging.logback.WhitespaceThrowableProxyConverter" /> + <conversionRule conversionWord="wEx" converterClass="org.springframework.boot.logging.logback.ExtendedWhitespaceThrowableProxyConverter" /> + <!-- 彩色日志格式 --> + <property name="CONSOLE_LOG_PATTERN" value="${CONSOLE_LOG_PATTERN:-%clr(%d{yyyy-MM-dd HH:mm:ss.SSS}){faint} %clr(${LOG_LEVEL_PATTERN:-%5p}) %clr(${PID:- }){magenta} %clr(---){faint} %clr([%15.15t]){faint} %clr(%-40.40logger{39}){cyan} %clr(:){faint} %m%n${LOG_EXCEPTION_CONVERSION_WORD:-%wEx}}" /> + <!-- 日志输出格式 --> + <property name="log.pattern" value="%d{HH:mm:ss.SSS} [%thread] %-5level %logger{20} - [%method,%line] - %msg%n" /> + + <!-- 控制台输出 --> + <appender name="console" class="ch.qos.logback.core.ConsoleAppender"> + <!-- 此日志appender是为开发使用,只配置最底级别,控制台输出的日志级别是大于或等于此级别的日志信息 --> + <filter class="ch.qos.logback.classic.filter.ThresholdFilter"> + <level>debug</level> + </filter> + <encoder> + <Pattern>${CONSOLE_LOG_PATTERN}</Pattern> + <!-- 设置字符集 --> + <charset>UTF-8</charset> + </encoder> + </appender> + + <!-- 系统日志输出 --> + <appender name="file_info" class="ch.qos.logback.core.rolling.RollingFileAppender"> + <file>${log.path}/sys-info.log</file> + <!-- 循环政策:基于时间创建日志文件 --> + <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy"> + <!-- 日志文件名格式 --> + <fileNamePattern>${log.path}/sys-info.%d{yyyy-MM-dd}.log</fileNamePattern> + <!-- 日志最大的历史 60天 --> + <maxHistory>60</maxHistory> + </rollingPolicy> + <encoder> + <pattern>${log.pattern}</pattern> + </encoder> + <filter class="ch.qos.logback.classic.filter.LevelFilter"> + <!-- 过滤的级别 --> + <level>INFO</level> + <!-- 匹配时的操作:接收(记录) --> + <onMatch>ACCEPT</onMatch> + <!-- 不匹配时的操作:拒绝(不记录) --> + <onMismatch>DENY</onMismatch> + </filter> + </appender> + + <appender name="file_error" class="ch.qos.logback.core.rolling.RollingFileAppender"> + <file>${log.path}/sys-error.log</file> + <!-- 循环政策:基于时间创建日志文件 --> + <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy"> + <!-- 日志文件名格式 --> + <fileNamePattern>${log.path}/sys-error.%d{yyyy-MM-dd}.log</fileNamePattern> + <!-- 日志最大的历史 60天 --> + <maxHistory>60</maxHistory> + </rollingPolicy> + <encoder> + <pattern>${log.pattern}</pattern> + </encoder> + <filter class="ch.qos.logback.classic.filter.LevelFilter"> + <!-- 过滤的级别 --> + <level>ERROR</level> + <!-- 匹配时的操作:接收(记录) --> + <onMatch>ACCEPT</onMatch> + <!-- 不匹配时的操作:拒绝(不记录) --> + <onMismatch>DENY</onMismatch> + </filter> + </appender> + + <!-- 用户访问日志输出 --> + <appender name="sys-user" class="ch.qos.logback.core.rolling.RollingFileAppender"> + <file>${log.path}/sys-user.log</file> + <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy"> + <!-- 按天回滚 daily --> + <fileNamePattern>${log.path}/sys-user.%d{yyyy-MM-dd}.log</fileNamePattern> + <!-- 日志最大的历史 60天 --> + <maxHistory>60</maxHistory> + </rollingPolicy> + <encoder> + <pattern>${log.pattern}</pattern> + </encoder> + </appender> + + <!-- 系统模块日志级别控制 --> + <logger name="com.hc" level="info" /> + <!-- Spring日志级别控制 --> + <logger name="org.springframework" level="warn" /> + + <root level="error"> + <appender-ref ref="console" /> + </root> + + <!--系统操作日志--> + <root level="info"> + <appender-ref ref="file_info" /> + <appender-ref ref="file_error" /> + </root> + + <!--系统用户操作日志--> + <logger name="sys-user" level="info"> + <appender-ref ref="sys-user"/> + </logger> +</configuration> \ No newline at end of file diff --git a/dc-admin/src/main/resources/mybatis/mybatis-config.xml b/dc-admin/src/main/resources/mybatis/mybatis-config.xml new file mode 100644 index 0000000..4b8c496 --- /dev/null +++ b/dc-admin/src/main/resources/mybatis/mybatis-config.xml @@ -0,0 +1,20 @@ +<?xml version="1.0" encoding="UTF-8" ?> +<!DOCTYPE configuration +PUBLIC "-//mybatis.org//DTD Config 3.0//EN" +"http://mybatis.org/dtd/mybatis-3-config.dtd"> +<configuration> + <!-- 全局参数 --> + <settings> + <!-- 使全局的映射器启用或禁用缓存 --> + <setting name="cacheEnabled" value="true" /> + <!-- 允许JDBC 支持自动生成主键 --> + <setting name="useGeneratedKeys" value="true" /> + <!-- 配置默认的执行器.SIMPLE就是普通执行器;REUSE执行器会重用预处理语句(prepared statements);BATCH执行器将重用语句并执行批量更新 --> + <setting name="defaultExecutorType" value="SIMPLE" /> + <!-- 指定 MyBatis 所用日志的具体实现 --> + <setting name="logImpl" value="SLF4J" /> + <!-- 使用驼峰命名法转换字段 --> + <!-- <setting name="mapUnderscoreToCamelCase" value="true"/> --> + </settings> + +</configuration> diff --git a/dc-app/pom.xml b/dc-app/pom.xml new file mode 100644 index 0000000..f4431ac --- /dev/null +++ b/dc-app/pom.xml @@ -0,0 +1,84 @@ +<?xml version="1.0" encoding="UTF-8"?> +<project xmlns="http://maven.apache.org/POM/4.0.0" + xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" + xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> + <parent> + <artifactId>dc</artifactId> + <groupId>com.dc</groupId> + <version>1.0.0</version> + </parent> + <modelVersion>4.0.0</modelVersion> + <packaging>jar</packaging> + <artifactId>dc-app</artifactId> + + <description> + web服务入口 + </description> + + <dependencies> + + <!-- spring-boot-devtools --> + <dependency> + <groupId>org.springframework.boot</groupId> + <artifactId>spring-boot-devtools</artifactId> + <optional>true</optional> <!-- 表示依赖不会传递 --> + </dependency> + + <!-- swagger3--> + <dependency> + <groupId>io.springfox</groupId> + <artifactId>springfox-boot-starter</artifactId> + </dependency> + + <!-- 防止进入swagger页面报类型转换错误,排除3.0.0中的引用,手动增加1.6.2版本 --> + <dependency> + <groupId>io.swagger</groupId> + <artifactId>swagger-models</artifactId> + <version>1.6.2</version> + </dependency> + + <!-- Mysql驱动包 --> + <dependency> + <groupId>mysql</groupId> + <artifactId>mysql-connector-java</artifactId> + </dependency> + + <!-- 核心模块--> + <dependency> + <groupId>com.dc</groupId> + <artifactId>dc-framework</artifactId> + </dependency> + + </dependencies> + + <build> + <plugins> + <plugin> + <groupId>org.springframework.boot</groupId> + <artifactId>spring-boot-maven-plugin</artifactId> + <version>2.1.1.RELEASE</version> + <configuration> + <fork>true</fork> <!-- 如果没有该配置,devtools不会生效 --> + </configuration> + <executions> + <execution> + <goals> + <goal>repackage</goal> + </goals> + </execution> + </executions> + </plugin> + <plugin> + <groupId>org.apache.maven.plugins</groupId> + <artifactId>maven-war-plugin</artifactId> + <version>3.1.0</version> + <configuration> + <failOnMissingWebXml>false</failOnMissingWebXml> + <warName>${project.artifactId}</warName> + </configuration> + </plugin> + </plugins> + <finalName>${project.artifactId}</finalName> + </build> + +</project> \ No newline at end of file diff --git a/dc-app/src/main/java/com/dc/app/AppApplication.java b/dc-app/src/main/java/com/dc/app/AppApplication.java new file mode 100644 index 0000000..005ef9b --- /dev/null +++ b/dc-app/src/main/java/com/dc/app/AppApplication.java @@ -0,0 +1,25 @@ +package com.dc.app; + +import com.alibaba.druid.spring.boot.autoconfigure.DruidDataSourceAutoConfigure; +import org.springframework.boot.SpringApplication; +import org.springframework.boot.autoconfigure.SpringBootApplication; +import org.springframework.boot.autoconfigure.jdbc.DataSourceAutoConfiguration; +import org.springframework.boot.autoconfigure.security.servlet.SecurityAutoConfiguration; + +/** + * 启动程序 + * + * @author win + */ +@SpringBootApplication( + scanBasePackages={"com.dc.system", "com.dc.framework", "com.dc.common", "com.dc.app"}, + exclude = { DataSourceAutoConfiguration.class, DruidDataSourceAutoConfigure.class, SecurityAutoConfiguration.class}) +public class AppApplication +{ + public static void main(String[] args) + { + // System.setProperty("spring.devtools.restart.enabled", "false"); + SpringApplication.run(AppApplication.class, args); + System.out.println("闻音启动成功"); + } +} diff --git a/dc-app/src/main/java/com/dc/app/config/SwaggerConfig.java b/dc-app/src/main/java/com/dc/app/config/SwaggerConfig.java new file mode 100644 index 0000000..ed55e4b --- /dev/null +++ b/dc-app/src/main/java/com/dc/app/config/SwaggerConfig.java @@ -0,0 +1,121 @@ +package com.dc.app.config; + +import com.dc.common.config.WinConfig; +import io.swagger.annotations.ApiOperation; +import io.swagger.models.auth.In; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.beans.factory.annotation.Value; +import org.springframework.context.annotation.Bean; +import org.springframework.context.annotation.Configuration; +import springfox.documentation.builders.ApiInfoBuilder; +import springfox.documentation.builders.PathSelectors; +import springfox.documentation.builders.RequestHandlerSelectors; +import springfox.documentation.service.*; +import springfox.documentation.spi.DocumentationType; +import springfox.documentation.spi.service.contexts.SecurityContext; +import springfox.documentation.spring.web.plugins.Docket; + +import java.util.ArrayList; +import java.util.List; + +/** + * Swagger2的接口配置 + * + * @author win + */ +@Configuration +public class SwaggerConfig +{ + /** 系统基础配置 */ + @Autowired + private WinConfig winConfig; + + /** 是否开启swagger */ + @Value("${swagger.enabled}") + private boolean enabled; + + /** 设置请求的统一前缀 */ + @Value("${swagger.pathMapping}") + private String pathMapping; + + /** + * 创建API + */ + @Bean + public Docket createRestApi() + { + return new Docket(DocumentationType.OAS_30) + // 是否启用Swagger + .enable(enabled) + // 用来创建该API的基本信息,展示在文档的页面中(自定义展示的信息) + .apiInfo(apiInfo()) + // 设置哪些接口暴露给Swagger展示 + .select() + // 扫描所有有注解的api,用这种方式更灵活 + .apis(RequestHandlerSelectors.withMethodAnnotation(ApiOperation.class)) + // 扫描指定包中的swagger注解 + // .apis(RequestHandlerSelectors.basePackage("com.dc.project.tool.swagger")) + // 扫描所有 .apis(RequestHandlerSelectors.any()) + .paths(PathSelectors.any()) + .build() + /* 设置安全模式,swagger可以设置访问token */ + .securitySchemes(securitySchemes()) + .securityContexts(securityContexts()) + .pathMapping(pathMapping); + } + + /** + * 安全模式,这里指定token通过Authorization头请求头传递 + */ + private List<SecurityScheme> securitySchemes() + { + List<SecurityScheme> apiKeyList = new ArrayList<SecurityScheme>(); + apiKeyList.add(new ApiKey("Authorization", "Authorization", In.HEADER.toValue())); + return apiKeyList; + } + + /** + * 安全上下文 + */ + private List<SecurityContext> securityContexts() + { + List<SecurityContext> securityContexts = new ArrayList<>(); + securityContexts.add( + SecurityContext.builder() + .securityReferences(defaultAuth()) + .operationSelector(o -> o.requestMappingPattern().matches("/.*")) + .build()); + return securityContexts; + } + + /** + * 默认的安全上引用 + */ + private List<SecurityReference> defaultAuth() + { + AuthorizationScope authorizationScope = new AuthorizationScope("global", "accessEverything"); + AuthorizationScope[] authorizationScopes = new AuthorizationScope[1]; + authorizationScopes[0] = authorizationScope; + List<SecurityReference> securityReferences = new ArrayList<>(); + securityReferences.add(new SecurityReference("Authorization", authorizationScopes)); + return securityReferences; + } + + /** + * 添加摘要信息 + */ + private ApiInfo apiInfo() + { + // 用ApiInfoBuilder进行定制 + return new ApiInfoBuilder() + // 设置标题 + .title("标题:闻音管理系统_接口文档") + // 描述 + .description("描述:用于管理集团旗下公司的人员信息,具体包括XXX,XXX模块...") + // 作者信息 + .contact(new Contact(winConfig.getName(), null, null)) + // 版本 + .version("版本号:" + winConfig.getVersion()) + .build(); + } +} diff --git a/dc-app/src/main/java/com/dc/app/config/WebConfig.java b/dc-app/src/main/java/com/dc/app/config/WebConfig.java new file mode 100644 index 0000000..bdf8ade --- /dev/null +++ b/dc-app/src/main/java/com/dc/app/config/WebConfig.java @@ -0,0 +1,35 @@ +package com.dc.app.config; + +import com.dc.framework.interceptor.UnionIdInterceptor; +import org.springframework.context.annotation.Bean; +import org.springframework.context.annotation.Configuration; +import org.springframework.web.servlet.config.annotation.EnableWebMvc; +import org.springframework.web.servlet.config.annotation.InterceptorRegistry; +import org.springframework.web.servlet.config.annotation.ResourceHandlerRegistry; +import org.springframework.web.servlet.config.annotation.WebMvcConfigurer; + +@Configuration +@EnableWebMvc +public class WebConfig implements WebMvcConfigurer { + + @Bean + UnionIdInterceptor localInterceptor() { + return new UnionIdInterceptor(); + } + + @Override + public void addInterceptors(InterceptorRegistry registry) { + registry.addInterceptor(localInterceptor()) + .addPathPatterns("/**") + .excludePathPatterns("/swagger-resources/**", "/webjars/**", "/v3/**", "/swagger-ui.html/**"); + } + + @Override + public void addResourceHandlers(ResourceHandlerRegistry registry) { + registry.addResourceHandler("swagger-ui.html") + .addResourceLocations("classpath:/META-INF/resources/"); + registry.addResourceHandler("/webjars/**") + .addResourceLocations("classpath:/META-INF/resources/webjars/"); + } + +} diff --git a/dc-app/src/main/java/com/dc/app/controller/common/CommonController.java b/dc-app/src/main/java/com/dc/app/controller/common/CommonController.java new file mode 100644 index 0000000..43b9b00 --- /dev/null +++ b/dc-app/src/main/java/com/dc/app/controller/common/CommonController.java @@ -0,0 +1,124 @@ +package com.dc.app.controller.common; + +import com.dc.framework.config.ServerConfig; +import com.dc.common.config.WinConfig; +import com.dc.common.core.domain.AjaxResult; +import com.dc.common.utils.StringUtils; +import com.dc.common.utils.file.FileUploadUtils; +import com.dc.common.utils.file.FileUtils; +import com.dc.system.domain.Accessory; +import com.dc.system.service.AccessoryService; +import io.swagger.annotations.ApiOperation; +import org.slf4j.Logger; +import org.slf4j.LoggerFactory; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.beans.factory.annotation.Value; +import org.springframework.web.bind.annotation.PostMapping; +import org.springframework.web.bind.annotation.RequestMapping; +import org.springframework.web.bind.annotation.RestController; +import org.springframework.web.multipart.MultipartFile; + +import java.time.LocalDateTime; +import java.util.ArrayList; +import java.util.List; + +/** + * 通用请求处理 + * + * @author win + */ +@RestController +@RequestMapping("/common") +public class CommonController +{ + private static final Logger log = LoggerFactory.getLogger(CommonController.class); + + @Autowired + private ServerConfig serverConfig; + @Autowired + private AccessoryService accessoryService; + @Value("${upload-file.prefix}") + private String prefix; + + private static final String FILE_DELIMETER = ","; + + /** + * 上传文件(单个) + */ + @ApiOperation("上传文件(单个)") + @PostMapping("/upload") + public AjaxResult uploadFile(MultipartFile file) throws Exception { + try { + // 上传文件路径 + String filePath = WinConfig.getUploadPath(); + // 上传并返回新文件名称 + String fileName = FileUploadUtils.upload(filePath, file); + String url = prefix + fileName; + String originalFilename = file.getOriginalFilename(); + AjaxResult ajax = AjaxResult.success(); + ajax.put("url", url); + ajax.put("fileName", fileName); + ajax.put("newFileName", FileUtils.getName(fileName)); + ajax.put("originalFilename", originalFilename); + Accessory accessory = new Accessory(); + String suffix = originalFilename.substring(originalFilename.lastIndexOf(".") + 1); + String name = originalFilename.replace("." + suffix, ""); + accessory.setName(name); + accessory.setSuffix(suffix); + accessory.setUrl(fileName); + accessory.setCreateTime(LocalDateTime.now()); + accessoryService.save(accessory); + ajax.put("accessoryId", accessory.getId()); + return ajax; + } catch (Exception e) { + log.error(e.getMessage(), e); + return AjaxResult.error(e.getMessage()); + } + } + + /** + * 通用上传请求(多个) + */ + @PostMapping("/uploads") + public AjaxResult uploadFiles(List<MultipartFile> files) throws Exception { + try { + // 上传文件路径 + String filePath = WinConfig.getUploadPath(); + List<String> urls = new ArrayList<String>(); + List<String> fileNames = new ArrayList<String>(); + List<String> newFileNames = new ArrayList<String>(); + List<String> originalFilenames = new ArrayList<String>(); + List<Long> accessoryIds = new ArrayList<>(); + for (int i = 0; i < files.size(); i++) { + MultipartFile file = files.get(i); + String originalFilename = originalFilenames.get(i); + // 上传并返回新文件名称 + String fileName = FileUploadUtils.upload(filePath, file); + String url = prefix + fileName; + urls.add(url); + fileNames.add(fileName); + newFileNames.add(FileUtils.getName(fileName)); + originalFilenames.add(file.getOriginalFilename()); + String suffix = originalFilename.substring(originalFilename.lastIndexOf(".") + 1); + String name = originalFilename.replace("." + suffix, ""); + Accessory accessory = new Accessory(); + accessory.setName(name); + accessory.setSuffix(suffix); + accessory.setUrl(fileName); + accessoryService.save(accessory); + accessoryIds.add(accessory.getId()); + } + AjaxResult ajax = AjaxResult.success(); + ajax.put("urls", StringUtils.join(urls, FILE_DELIMETER)); + ajax.put("fileNames", StringUtils.join(fileNames, FILE_DELIMETER)); + ajax.put("newFileNames", StringUtils.join(newFileNames, FILE_DELIMETER)); + ajax.put("originalFilenames", StringUtils.join(originalFilenames, FILE_DELIMETER)); + ajax.put("accessoryIds", accessoryIds); + return ajax; + } catch (Exception e) { + log.error(e.getMessage(), e); + return AjaxResult.error(e.getMessage()); + } + } + +} diff --git a/dc-app/src/main/java/com/dc/app/controller/system/SysDictDataController.java b/dc-app/src/main/java/com/dc/app/controller/system/SysDictDataController.java new file mode 100644 index 0000000..9a46101 --- /dev/null +++ b/dc-app/src/main/java/com/dc/app/controller/system/SysDictDataController.java @@ -0,0 +1,43 @@ +package com.dc.app.controller.system; + +import com.dc.common.core.controller.BaseController; +import com.dc.common.core.domain.AjaxResult; +import com.dc.common.core.domain.entity.SysDictData; +import com.dc.common.utils.StringUtils; +import com.dc.system.service.SysDictTypeService; +import io.swagger.annotations.ApiOperation; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.web.bind.annotation.GetMapping; +import org.springframework.web.bind.annotation.PathVariable; +import org.springframework.web.bind.annotation.RequestMapping; +import org.springframework.web.bind.annotation.RestController; + +import java.util.ArrayList; +import java.util.List; + +/** + * 数据字典信息 + * + * @author win + */ +@RestController +@RequestMapping("/system/dict/data") +public class SysDictDataController extends BaseController { + + @Autowired + private SysDictTypeService dictTypeService; + + /** + * 根据字典类型查询字典数据信息 + */ + @ApiOperation("根据字典类型查询字典数据信息") + @GetMapping(value = "/type/{dictType}") + public AjaxResult dictType(@PathVariable String dictType) { + List<SysDictData> data = dictTypeService.selectDictDataByType(dictType); + if (StringUtils.isNull(data)) { + data = new ArrayList<SysDictData>(); + } + return success(data); + } + +} diff --git a/dc-app/src/main/resources/META-INF/spring-devtools.properties b/dc-app/src/main/resources/META-INF/spring-devtools.properties new file mode 100644 index 0000000..2b23f85 --- /dev/null +++ b/dc-app/src/main/resources/META-INF/spring-devtools.properties @@ -0,0 +1 @@ +restart.include.json=/com.alibaba.fastjson.*.jar \ No newline at end of file diff --git a/dc-app/src/main/resources/application-dev.yml b/dc-app/src/main/resources/application-dev.yml new file mode 100644 index 0000000..b728c37 --- /dev/null +++ b/dc-app/src/main/resources/application-dev.yml @@ -0,0 +1,158 @@ +# 开发环境配置 +server: + # 服务器的HTTP端口,默认为8080 + port: 8090 + servlet: + # 应用的访问路径 + context-path: / + tomcat: + # tomcat的URI编码 + uri-encoding: UTF-8 + # 连接数满后的排队数,默认为100 + accept-count: 1000 + threads: + # tomcat最大线程数,默认为200 + max: 800 + # Tomcat启动初始化的线程数,默认值10 + min-spare: 100 + +# 日志配置 +logging: + file: + path: logs + level: + com.dc: debug + org.springframework: warn + +# 用户配置 +user: + password: + # 密码最大错误次数 + maxRetryCount: 5 + # 密码锁定时间(默认10分钟) + lockTime: 10 + +# Spring配置 +spring: + shardingsphere: + mode: + type: Memory + # 属性配置 + props: + sql.show: true + ## 数据源配置 + datasource: + names: master,slave0,slave1 + # 主数据源 + master: + type: com.alibaba.druid.pool.DruidDataSource + driverClassName: com.mysql.cj.jdbc.Driver + url: jdbc:mysql://dev.ccwin-in.com:23113/ccwin?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8 + username: root + password: Microdoft@2021 + # 读数据源 + slave0: + type: com.alibaba.druid.pool.DruidDataSource + driverClassName: com.mysql.cj.jdbc.Driver + url: jdbc:mysql://dev.ccwin-in.com:23113/ccwin?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8 + username: root + password: Microdoft@2021 + # 读数据源 + slave1: + type: com.alibaba.druid.pool.DruidDataSource + driverClassName: com.mysql.cj.jdbc.Driver + url: jdbc:mysql://dev.ccwin-in.com:23113/ccwin?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8 + username: root + password: Microdoft@2021 + # 读写分离类型,如: Static,Dynamic + rules: + readwrite-splitting: + data-sources: + myds: + type: Static + props: + write-data-source-name: master + read-data-source-names: slave0,slave1 + load-balancer-name: alg_round + load-balancers: + alg_round: + type: ROUND_ROBIN + datasource: + dynamic: + strict: true + datasource: + ccwin: + driver-class-name: com.mysql.cj.jdbc.Driver + type: com.alibaba.druid.pool.DruidDataSource + url: jdbc:mysql://dev.ccwin-in.com:23113/ccwin?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8 + username: root + password: Microdoft@2021 + primary: ccwin + # 资源信息 + messages: + # 国际化资源文件路径 + basename: i18n/messages + # 文件上传 + servlet: + multipart: + # 单个文件大小 + max-file-size: 10MB + # 设置总上传的文件大小 + max-request-size: 20MB + # 服务模块 + devtools: + restart: + # 热部署开关 + enabled: true + # 彩色日志开关 + output: + ansi: + enabled: ALWAYS + # redis 配置 + redis: + # 地址 + host: dev.ccwin-in.com + # 端口,默认为6379 + port: 23114 + # 数据库索引 + database: 0 + # 密码 + password: + # 连接超时时间 + timeout: 10s + lettuce: + pool: + # 连接池中的最小空闲连接 + min-idle: 0 + # 连接池中的最大空闲连接 + max-idle: 8 + # 连接池的最大数据库连接数 + max-active: 8 + # #连接池最大阻塞等待时间(使用负值表示没有限制) + max-wait: -1ms + +# token配置 +token: + # 令牌自定义标识 + header: Authorization + # 令牌密钥 + secret: abcdefghijklmnopqrstuvwxyz + # 令牌有效期(默认30分钟) + expireTime: 30 + # 是否允许账户多终端同时登录(true允许 false不允许) + soloLogin: true + +# Swagger配置 +swagger: + # 是否开启swagger + enabled: true + # 请求前缀 + pathMapping: / +#微信设置 +weixin: + union-id-url: https://api.weixin.qq.com/sns/jscode2session + app-id: wx6176535b0b0153f0 + app-secret: d8f9e009da15d8eb58c89f87a1e6081e +#上传文件url +upload-file: + prefix: http://192.168.0.136:8080 diff --git a/dc-app/src/main/resources/application-druid.yml b/dc-app/src/main/resources/application-druid.yml new file mode 100644 index 0000000..ea3f8e8 --- /dev/null +++ b/dc-app/src/main/resources/application-druid.yml @@ -0,0 +1,47 @@ +# 数据源配置 +spring: + datasource: + druid: + # 初始连接数 + initialSize: 20 + # 最小连接池数量 + minIdle: 20 + # 最大连接池数量 + maxActive: 200 + # 配置获取连接等待超时的时间 + maxWait: 60000 + # 配置间隔多久才进行一次检测,检测需要关闭的空闲连接,单位是毫秒 + timeBetweenEvictionRunsMillis: 60000 + # 配置一个连接在池中最小生存的时间,单位是毫秒 + minEvictableIdleTimeMillis: 300000 + # 配置一个连接在池中最大生存的时间,单位是毫秒 + maxEvictableIdleTimeMillis: 900000 + # 配置检测连接是否有效 + validationQuery: SELECT 1 FROM DUAL + testWhileIdle: true + testOnBorrow: false + testOnReturn: false + webStatFilter: + enabled: false + url-pattern: /* # 过滤所有url + exclusions: "*.js,*.gif,*.jpg,*.png,*.css,*.ico,/druid/*" # 排除一些不必要的url + session-stat-enable: true # 开启session统计功能 + session-stat-max-count: 1000 # session的最大个数,默认100 + statViewServlet: + enabled: true + # 设置白名单,不填则允许所有访问 + allow: + url-pattern: /druid/* + # 控制台管理用户名和密码 + login-username: win + login-password: 123456 + filter: + stat: + enabled: true + # 慢SQL记录 + log-slow-sql: true + slow-sql-millis: 1000 + merge-sql: true + wall: + config: + multi-statement-allow: true \ No newline at end of file diff --git a/dc-app/src/main/resources/application-mybatis.yml b/dc-app/src/main/resources/application-mybatis.yml new file mode 100644 index 0000000..60d5afb --- /dev/null +++ b/dc-app/src/main/resources/application-mybatis.yml @@ -0,0 +1,57 @@ +# MyBatis Plus配置 +mybatis-plus: + # 不支持多包, 如有需要可在注解配置 或 提升扫包等级 + # 例如 com.**.**.mapper + mapperPackage: com.dc.**.mapper + # 对应的 XML 文件位置 + mapperLocations: classpath*:mapper/**/*Mapper.xml + # 实体扫描,多个package用逗号或者分号分隔 + typeAliasesPackage: com.dc.**.domain + # 加载全局的配置文件 + configLocation: classpath:mybatis/mybatis-config.xml + # 启动时是否检查 MyBatis XML 文件的存在,默认不检查 + checkConfigLocation: false + configuration: + # 自动驼峰命名规则(camel case)映射 + mapUnderscoreToCamelCase: true + # MyBatis 自动映射策略 + # NONE:不启用 PARTIAL:只对非嵌套 resultMap 自动映射 FULL:对所有 resultMap 自动映射 + autoMappingBehavior: PARTIAL + # MyBatis 自动映射时未知列或未知属性处理策 + # NONE:不做处理 WARNING:打印相关警告 FAILING:抛出异常和详细信息 + autoMappingUnknownColumnBehavior: NONE + # 开启缓存 + cache-enabled: true + # 更详细的日志输出 会有性能损耗 org.apache.ibatis.logging.stdout.StdOutImpl + # 关闭日志记录 (可单纯使用 p6spy 分析) org.apache.ibatis.logging.nologging.NoLoggingImpl + # 默认日志输出 org.apache.ibatis.logging.slf4j.Slf4jImpl + logImpl: org.apache.ibatis.logging.slf4j.Slf4jImpl + global-config: + # 是否打印 Logo banner + banner: false + dbConfig: + # 主键类型 + # AUTO 自增 NONE 空 INPUT 用户输入 ASSIGN_ID 雪花 ASSIGN_UUID 唯一 UUID + id_type: AUTO + # 全局逻辑删除的实体字段名(since 3.3.0,配置后可以忽略不配置步骤2) + # logic-delete-field: flag + # 逻辑已删除值(默认为 1) + logic-delete-value: 1 + # 逻辑未删除值(默认为 0) + logic-not-delete-value: 0 + # 逻辑已删除值 + logicDeleteValue: 2 + logicNotDeleteValue: 0 + # 字段验证策略之 insert,在 insert 的时候的字段验证策略 + # IGNORED 忽略 NOT_NULL 非NULL NOT_EMPTY 非空 DEFAULT 默认 NEVER 不加入 SQL + insert_strategy: NOT_NULL + # 字段验证策略之 update,在 update 的时候的字段验证策略 + update_strategy: NOT_NULL + # 字段验证策略之 select,在 select 的时候的字段验证策略既 wrapper 根据内部 entity 生成的 where 条件 + where-strategy: NOT_NULL + +# PageHelper分页插件 +pagehelper: + helperDialect: mysql + supportMethodsArguments: true + params: count=countSql diff --git a/dc-app/src/main/resources/application-prod.yml b/dc-app/src/main/resources/application-prod.yml new file mode 100644 index 0000000..4f67fa2 --- /dev/null +++ b/dc-app/src/main/resources/application-prod.yml @@ -0,0 +1,156 @@ +# 开发环境配置 +server: + # 服务器的HTTP端口,默认为8090 + port: 8090 + servlet: + # 应用的访问路径 + context-path: / + tomcat: + # tomcat的URI编码 + uri-encoding: UTF-8 + # 连接数满后的排队数,默认为100 + accept-count: 1000 + threads: + # tomcat最大线程数,默认为200 + max: 800 + # Tomcat启动初始化的线程数,默认值10 + min-spare: 100 + +# 日志配置 +logging: + file: + path: logs + level: + com.dc: warn + org.springframework: warn + +# 用户配置 +user: + password: + # 密码最大错误次数 + maxRetryCount: 5 + # 密码锁定时间(默认10分钟) + lockTime: 10 + +# Spring配置 +spring: + shardingsphere: + mode: + type: Memory + # 属性配置 + props: + sql.show: true + ## 数据源配置 + datasource: + names: master,slave0,slave1 + # 主数据源 + master: + type: com.alibaba.druid.pool.DruidDataSource + driverClassName: com.mysql.cj.jdbc.Driver + url: jdbc:mysql://localhost:3306/ccwin?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8 + username: root + password: Microdoft@2021 + # 读数据源 + slave0: + type: com.alibaba.druid.pool.DruidDataSource + driverClassName: com.mysql.cj.jdbc.Driver + url: jdbc:mysql://localhost:3306/ccwin?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8 + username: root + password: Microdoft@2021 + # 读数据源 + slave1: + type: com.alibaba.druid.pool.DruidDataSource + driverClassName: com.mysql.cj.jdbc.Driver + url: jdbc:mysql://localhost:3306/ccwin?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8 + username: root + password: Microdoft@2021 + # 读写分离类型,如: Static,Dynamic + rules: + readwrite-splitting: + data-sources: + myds: + type: Static + props: + write-data-source-name: master + read-data-source-names: slave0,slave1 + load-balancer-name: alg_round + load-balancers: + alg_round: + type: ROUND_ROBIN + datasource: + dynamic: + strict: true + datasource: + ccwin: + driver-class-name: com.mysql.cj.jdbc.Driver + type: com.alibaba.druid.pool.DruidDataSource + url: jdbc:mysql://localhost:3306/ccwin?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8 + username: root + password: Microdoft@2021 + primary: ccwin + # 资源信息 + messages: + # 国际化资源文件路径 + basename: i18n/messages + # 文件上传 + servlet: + multipart: + # 单个文件大小 + max-file-size: 10MB + # 设置总上传的文件大小 + max-request-size: 20MB + # 服务模块 + devtools: + restart: + # 热部署开关 + enabled: true + # 彩色日志开关 + output: + ansi: + enabled: ALWAYS + # redis 配置 + redis: + # 地址 + host: localhost + # 端口,默认为6379 + port: 6379 + # 数据库索引 + database: 1 + # 密码 + password: + # 连接超时时间 + timeout: 10s + lettuce: + pool: + # 连接池中的最小空闲连接 + min-idle: 0 + # 连接池中的最大空闲连接 + max-idle: 8 + # 连接池的最大数据库连接数 + max-active: 8 + # #连接池最大阻塞等待时间(使用负值表示没有限制) + max-wait: -1ms +token: + # 令牌自定义标识 + header: Authorization + # 令牌密钥 + secret: abcdefghijklmnopqrstuvwxyz + # 令牌有效期(默认30分钟) + expireTime: 30 + # 是否允许账户多终端同时登录(true允许 false不允许) + soloLogin: true + +# Swagger配置 +swagger: + # 是否开启swagger + enabled: false + # 请求前缀 + pathMapping: / +#微信设置 +weixin: + union-id-url: https://api.weixin.qq.com/sns/jscode2session + app-id: wx6176535b0b0153f0 + app-secret: d8f9e009da15d8eb58c89f87a1e6081e +#上传文件url +upload-file: + prefix: http://192.168.1.155:8080 \ No newline at end of file diff --git a/dc-app/src/main/resources/application-test.yml b/dc-app/src/main/resources/application-test.yml new file mode 100644 index 0000000..a72242d --- /dev/null +++ b/dc-app/src/main/resources/application-test.yml @@ -0,0 +1,158 @@ +# 开发环境配置 +server: + # 服务器的HTTP端口,默认为8080 + port: 8090 + servlet: + # 应用的访问路径 + context-path: / + tomcat: + # tomcat的URI编码 + uri-encoding: UTF-8 + # 连接数满后的排队数,默认为100 + accept-count: 1000 + threads: + # tomcat最大线程数,默认为200 + max: 800 + # Tomcat启动初始化的线程数,默认值10 + min-spare: 100 + +# 日志配置 +logging: + file: + path: logs + level: + com.dc: info + org.springframework: warn + +# 用户配置 +user: + password: + # 密码最大错误次数 + maxRetryCount: 5 + # 密码锁定时间(默认10分钟) + lockTime: 10 + +# Spring配置 +spring: + shardingsphere: + mode: + type: Memory + # 属性配置 + props: + sql.show: true + ## 数据源配置 + datasource: + names: master,slave0,slave1 + # 主数据源 + master: + type: com.alibaba.druid.pool.DruidDataSource + driverClassName: com.mysql.cj.jdbc.Driver + url: jdbc:mysql://dev.ccwin-in.com:23113/ccwin?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8 + username: root + password: Microdoft@2021 + # 读数据源 + slave0: + type: com.alibaba.druid.pool.DruidDataSource + driverClassName: com.mysql.cj.jdbc.Driver + url: jdbc:mysql://dev.ccwin-in.com:23113/ccwin?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8 + username: root + password: Microdoft@2021 + # 读数据源 + slave1: + type: com.alibaba.druid.pool.DruidDataSource + driverClassName: com.mysql.cj.jdbc.Driver + url: jdbc:mysql://dev.ccwin-in.com:23113/ccwin?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8 + username: root + password: Microdoft@2021 + # 读写分离类型,如: Static,Dynamic + rules: + readwrite-splitting: + data-sources: + myds: + type: Static + props: + write-data-source-name: master + read-data-source-names: slave0,slave1 + load-balancer-name: alg_round + load-balancers: + alg_round: + type: ROUND_ROBIN + datasource: + dynamic: + strict: true + datasource: + ccwin: + driver-class-name: com.mysql.cj.jdbc.Driver + type: com.alibaba.druid.pool.DruidDataSource + url: jdbc:mysql://dev.ccwin-in.com:23113/ccwin?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8 + username: root + password: Microdoft@2021 + primary: ccwin + # 资源信息 + messages: + # 国际化资源文件路径 + basename: i18n/messages + # 文件上传 + servlet: + multipart: + # 单个文件大小 + max-file-size: 10MB + # 设置总上传的文件大小 + max-request-size: 20MB + # 服务模块 + devtools: + restart: + # 热部署开关 + enabled: true + # 彩色日志开关 + output: + ansi: + enabled: ALWAYS + # redis 配置 + redis: + # 地址 + host: dev.ccwin-in.com + # 端口,默认为6379 + port: 23114 + # 数据库索引 + database: 1 + # 密码 + password: + # 连接超时时间 + timeout: 10s + lettuce: + pool: + # 连接池中的最小空闲连接 + min-idle: 0 + # 连接池中的最大空闲连接 + max-idle: 8 + # 连接池的最大数据库连接数 + max-active: 8 + # #连接池最大阻塞等待时间(使用负值表示没有限制) + max-wait: -1ms + +# token配置 +token: + # 令牌自定义标识 + header: Authorization + # 令牌密钥 + secret: abcdefghijklmnopqrstuvwxyz + # 令牌有效期(默认30分钟) + expireTime: 30 + # 是否允许账户多终端同时登录(true允许 false不允许) + soloLogin: true + +# Swagger配置 +swagger: + # 是否开启swagger + enabled: true + # 请求前缀 + pathMapping: / +#微信设置 +weixin: + union-id-url: https://api.weixin.qq.com/sns/jscode2session + app-id: wx6176535b0b0153f0 + app-secret: d8f9e009da15d8eb58c89f87a1e6081e +#上传文件url +upload-file: + prefix: http://dev.ccwin-in.com:23111 \ No newline at end of file diff --git a/dc-app/src/main/resources/application.yml b/dc-app/src/main/resources/application.yml new file mode 100644 index 0000000..19b100c --- /dev/null +++ b/dc-app/src/main/resources/application.yml @@ -0,0 +1,39 @@ +spring: + application: + name: app + profiles: + include: druid,mybatis + active: dev + main: + allow-bean-definition-overriding: true + servlet: + multipart: + enabled: true + max-file-size: 200MB + max-request-size: 1000MB + +# 项目相关配置 +win: + # 名称 + name: win-in + # 版本 + version: 3.8.5 + # 版权年份 + copyrightYear: 2023 + # 实例演示开关 + demoEnabled: true + # 文件路径 示例( Windows配置D:/win/uploadPath,Linux配置 /home/win/uploadPath) + profile: /opt/uploadPath + # 获取ip地址开关 + addressEnabled: false + # 验证码类型 math 数组计算 char 字符验证 + captchaType: math + +# 防止XSS攻击 +xss: + # 过滤开关 + enabled: true + # 排除链接(多个用逗号分隔) + excludes: /system/notice + # 匹配链接 + urlPatterns: /system/*,/monitor/*,/tool/* diff --git a/dc-app/src/main/resources/i18n/messages.properties b/dc-app/src/main/resources/i18n/messages.properties new file mode 100644 index 0000000..b7433dc --- /dev/null +++ b/dc-app/src/main/resources/i18n/messages.properties @@ -0,0 +1,37 @@ +#错误消息 +not.null=* 必须填写 +user.jcaptcha.error=验证码错误 +user.jcaptcha.expire=验证码已失效 +user.not.exists=用户不存在/密码错误 +user.password.not.match=用户不存在/密码错误 +user.password.retry.limit.count=密码输入错误{0}次 +user.password.retry.limit.exceed=密码输入错误{0}次,帐户锁定{1}分钟 +user.password.delete=对不起,您的账号已被删除 +user.blocked=用户已封禁,请联系管理员 +role.blocked=角色已封禁,请联系管理员 +user.logout.success=退出成功 + +length.not.valid=长度必须在{min}到{max}个字符之间 + +user.username.not.valid=* 2到20个汉字、字母、数字或下划线组成,且必须以非数字开头 +user.password.not.valid=* 5-50个字符 + +user.email.not.valid=邮箱格式错误 +user.mobile.phone.number.not.valid=手机号格式错误 +user.login.success=登录成功 +user.register.success=注册成功 +user.notfound=请重新登录 +user.forcelogout=管理员强制退出,请重新登录 +user.unknown.error=未知错误,请重新登录 + +##文件上传消息 +upload.exceed.maxSize=上传的文件大小超出限制的文件大小!<br/>允许的文件最大大小是:{0}MB! +upload.filename.exceed.length=上传的文件名最长{0}个字符 + +##权限 +no.permission=您没有数据的权限,请联系管理员添加权限 [{0}] +no.create.permission=您没有创建数据的权限,请联系管理员添加权限 [{0}] +no.update.permission=您没有修改数据的权限,请联系管理员添加权限 [{0}] +no.delete.permission=您没有删除数据的权限,请联系管理员添加权限 [{0}] +no.export.permission=您没有导出数据的权限,请联系管理员添加权限 [{0}] +no.view.permission=您没有查看数据的权限,请联系管理员添加权限 [{0}] diff --git a/dc-app/src/main/resources/logback-spring.xml b/dc-app/src/main/resources/logback-spring.xml new file mode 100644 index 0000000..aca3b77 --- /dev/null +++ b/dc-app/src/main/resources/logback-spring.xml @@ -0,0 +1,108 @@ +<?xml version="1.0" encoding="UTF-8"?> +<configuration> + <springProperty scope="context" name="logPath" source="logging.file.path" defaultValue="logs"/> + <!-- 日志存放路径 --> + <property name="log.path" value="${logPath}" /> + + <!--0. 日志格式和颜色渲染 --> + <!-- 彩色日志依赖的渲染类 --> + <conversionRule conversionWord="clr" converterClass="org.springframework.boot.logging.logback.ColorConverter" /> + <conversionRule conversionWord="wex" converterClass="org.springframework.boot.logging.logback.WhitespaceThrowableProxyConverter" /> + <conversionRule conversionWord="wEx" converterClass="org.springframework.boot.logging.logback.ExtendedWhitespaceThrowableProxyConverter" /> + <!-- 彩色日志格式 --> + <property name="CONSOLE_LOG_PATTERN" value="${CONSOLE_LOG_PATTERN:-%clr(%d{yyyy-MM-dd HH:mm:ss.SSS}){faint} %clr(${LOG_LEVEL_PATTERN:-%5p}) %clr(${PID:- }){magenta} %clr(---){faint} %clr([%15.15t]){faint} %clr(%-40.40logger{39}){cyan} %clr(:){faint} %m%n${LOG_EXCEPTION_CONVERSION_WORD:-%wEx}}" /> + <!-- 日志输出格式 --> + <property name="log.pattern" value="%d{HH:mm:ss.SSS} [%thread] %-5level %logger{20} - [%method,%line] - %msg%n" /> + + <!-- 控制台输出 --> + <appender name="console" class="ch.qos.logback.core.ConsoleAppender"> + <!-- 此日志appender是为开发使用,只配置最底级别,控制台输出的日志级别是大于或等于此级别的日志信息 --> + <filter class="ch.qos.logback.classic.filter.ThresholdFilter"> + <level>debug</level> + </filter> + <encoder> + <Pattern>${CONSOLE_LOG_PATTERN}</Pattern> + <!-- 设置字符集 --> + <charset>UTF-8</charset> + </encoder> + </appender> + + <!-- 系统日志输出 --> + <appender name="file_info" class="ch.qos.logback.core.rolling.RollingFileAppender"> + <file>${log.path}/sys-info.log</file> + <!-- 循环政策:基于时间创建日志文件 --> + <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy"> + <!-- 日志文件名格式 --> + <fileNamePattern>${log.path}/sys-info.%d{yyyy-MM-dd}.log</fileNamePattern> + <!-- 日志最大的历史 60天 --> + <maxHistory>60</maxHistory> + </rollingPolicy> + <encoder> + <pattern>${log.pattern}</pattern> + </encoder> + <filter class="ch.qos.logback.classic.filter.LevelFilter"> + <!-- 过滤的级别 --> + <level>INFO</level> + <!-- 匹配时的操作:接收(记录) --> + <onMatch>ACCEPT</onMatch> + <!-- 不匹配时的操作:拒绝(不记录) --> + <onMismatch>DENY</onMismatch> + </filter> + </appender> + + <appender name="file_error" class="ch.qos.logback.core.rolling.RollingFileAppender"> + <file>${log.path}/sys-error.log</file> + <!-- 循环政策:基于时间创建日志文件 --> + <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy"> + <!-- 日志文件名格式 --> + <fileNamePattern>${log.path}/sys-error.%d{yyyy-MM-dd}.log</fileNamePattern> + <!-- 日志最大的历史 60天 --> + <maxHistory>60</maxHistory> + </rollingPolicy> + <encoder> + <pattern>${log.pattern}</pattern> + </encoder> + <filter class="ch.qos.logback.classic.filter.LevelFilter"> + <!-- 过滤的级别 --> + <level>ERROR</level> + <!-- 匹配时的操作:接收(记录) --> + <onMatch>ACCEPT</onMatch> + <!-- 不匹配时的操作:拒绝(不记录) --> + <onMismatch>DENY</onMismatch> + </filter> + </appender> + + <!-- 用户访问日志输出 --> + <appender name="sys-user" class="ch.qos.logback.core.rolling.RollingFileAppender"> + <file>${log.path}/sys-user.log</file> + <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy"> + <!-- 按天回滚 daily --> + <fileNamePattern>${log.path}/sys-user.%d{yyyy-MM-dd}.log</fileNamePattern> + <!-- 日志最大的历史 60天 --> + <maxHistory>60</maxHistory> + </rollingPolicy> + <encoder> + <pattern>${log.pattern}</pattern> + </encoder> + </appender> + + <!-- 系统模块日志级别控制 --> + <logger name="com.hc" level="info" /> + <!-- Spring日志级别控制 --> + <logger name="org.springframework" level="warn" /> + + <root level="error"> + <appender-ref ref="console" /> + </root> + + <!--系统操作日志--> + <root level="info"> + <appender-ref ref="file_info" /> + <appender-ref ref="file_error" /> + </root> + + <!--系统用户操作日志--> + <logger name="sys-user" level="info"> + <appender-ref ref="sys-user"/> + </logger> +</configuration> \ No newline at end of file diff --git a/dc-common/pom.xml b/dc-common/pom.xml new file mode 100644 index 0000000..8ea9813 --- /dev/null +++ b/dc-common/pom.xml @@ -0,0 +1,146 @@ +<?xml version="1.0" encoding="UTF-8"?> +<project xmlns="http://maven.apache.org/POM/4.0.0" + xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" + xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> + <parent> + <artifactId>dc</artifactId> + <groupId>com.dc</groupId> + <version>1.0.0</version> + </parent> + <modelVersion>4.0.0</modelVersion> + + <artifactId>dc-common</artifactId> + + <description> + common通用工具 + </description> + + <dependencies> + + <!-- Spring框架基本的核心工具 --> + <dependency> + <groupId>org.springframework</groupId> + <artifactId>spring-context-support</artifactId> + </dependency> + + <!-- SpringWeb模块 --> + <dependency> + <groupId>org.springframework</groupId> + <artifactId>spring-web</artifactId> + </dependency> + + <!-- spring security 安全认证 --> + <dependency> + <groupId>org.springframework.boot</groupId> + <artifactId>spring-boot-starter-security</artifactId> + </dependency> + + <!-- pagehelper 分页插件 --> + <dependency> + <groupId>com.github.pagehelper</groupId> + <artifactId>pagehelper-spring-boot-starter</artifactId> + </dependency> + + <!-- 自定义验证注解 --> + <dependency> + <groupId>org.springframework.boot</groupId> + <artifactId>spring-boot-starter-validation</artifactId> + </dependency> + + <!--常用工具类 --> + <dependency> + <groupId>org.apache.commons</groupId> + <artifactId>commons-lang3</artifactId> + </dependency> + + <!-- JSON工具类 --> + <dependency> + <groupId>com.fasterxml.jackson.core</groupId> + <artifactId>jackson-databind</artifactId> + </dependency> + + <!-- 阿里JSON解析器 --> + <dependency> + <groupId>com.alibaba.fastjson2</groupId> + <artifactId>fastjson2</artifactId> + </dependency> + + <!-- io常用工具类 --> + <dependency> + <groupId>commons-io</groupId> + <artifactId>commons-io</artifactId> + </dependency> + + <!-- 文件上传工具类 --> + <dependency> + <groupId>commons-fileupload</groupId> + <artifactId>commons-fileupload</artifactId> + </dependency> + + <!-- excel工具 --> + <dependency> + <groupId>org.apache.poi</groupId> + <artifactId>poi-ooxml</artifactId> + </dependency> + + <!-- yml解析器 --> + <dependency> + <groupId>org.yaml</groupId> + <artifactId>snakeyaml</artifactId> + </dependency> + + <!-- Token生成与解析--> + <dependency> + <groupId>io.jsonwebtoken</groupId> + <artifactId>jjwt</artifactId> + </dependency> + + <!-- Jaxb --> + <dependency> + <groupId>javax.xml.bind</groupId> + <artifactId>jaxb-api</artifactId> + </dependency> + + <!-- redis 缓存操作 --> + <dependency> + <groupId>org.springframework.boot</groupId> + <artifactId>spring-boot-starter-data-redis</artifactId> + </dependency> + + <!-- pool 对象池 --> + <dependency> + <groupId>org.apache.commons</groupId> + <artifactId>commons-pool2</artifactId> + </dependency> + + <!-- 解析客户端操作系统、浏览器等 --> + <dependency> + <groupId>eu.bitwalker</groupId> + <artifactId>UserAgentUtils</artifactId> + </dependency> + + <!-- servlet包 --> + <dependency> + <groupId>javax.servlet</groupId> + <artifactId>javax.servlet-api</artifactId> + </dependency> + + <!-- 动态数据源 --> + <dependency> + <groupId>com.baomidou</groupId> + <artifactId>dynamic-datasource-spring-boot-starter</artifactId> + </dependency> + + <dependency> + <groupId>com.baomidou</groupId> + <artifactId>mybatis-plus-boot-starter</artifactId> + </dependency> + + <dependency> + <groupId>com.baomidou</groupId> + <artifactId>mybatis-plus-extension</artifactId> + </dependency> + + </dependencies> + +</project> \ No newline at end of file diff --git a/dc-common/src/main/java/com/dc/common/annotation/Anonymous.java b/dc-common/src/main/java/com/dc/common/annotation/Anonymous.java new file mode 100644 index 0000000..37a8a2e --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/annotation/Anonymous.java @@ -0,0 +1,19 @@ +package com.dc.common.annotation; + +import java.lang.annotation.Documented; +import java.lang.annotation.ElementType; +import java.lang.annotation.Retention; +import java.lang.annotation.RetentionPolicy; +import java.lang.annotation.Target; + +/** + * 匿名访问不鉴权注解 + * + * @author win + */ +@Target({ ElementType.METHOD, ElementType.TYPE }) +@Retention(RetentionPolicy.RUNTIME) +@Documented +public @interface Anonymous +{ +} diff --git a/dc-common/src/main/java/com/dc/common/annotation/DataScope.java b/dc-common/src/main/java/com/dc/common/annotation/DataScope.java new file mode 100644 index 0000000..a772bdb --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/annotation/DataScope.java @@ -0,0 +1,33 @@ +package com.dc.common.annotation; + +import java.lang.annotation.Documented; +import java.lang.annotation.ElementType; +import java.lang.annotation.Retention; +import java.lang.annotation.RetentionPolicy; +import java.lang.annotation.Target; + +/** + * 数据权限过滤注解 + * + * @author win + */ +@Target(ElementType.METHOD) +@Retention(RetentionPolicy.RUNTIME) +@Documented +public @interface DataScope +{ + /** + * 部门表的别名 + */ + public String deptAlias() default ""; + + /** + * 用户表的别名 + */ + public String userAlias() default ""; + + /** + * 权限字符(用于多个角色匹配符合要求的权限)默认根据权限注解@ss获取,多个权限用逗号分隔开来 + */ + public String permission() default ""; +} diff --git a/dc-common/src/main/java/com/dc/common/annotation/DataScopeCommon.java b/dc-common/src/main/java/com/dc/common/annotation/DataScopeCommon.java new file mode 100644 index 0000000..c6c7508 --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/annotation/DataScopeCommon.java @@ -0,0 +1,23 @@ +package com.dc.common.annotation; + +import java.lang.annotation.*; + +@Target(ElementType.METHOD) +@Retention(RetentionPolicy.RUNTIME) +@Documented +public @interface DataScopeCommon { + /** + * 部门表的别名 + */ + public String deptAlias() default ""; + + /** + * 用户表的别名 + */ + public String userAlias() default ""; + + /** + * 权限字符(用于多个角色匹配符合要求的权限)默认根据权限注解@ss获取,多个权限用逗号分隔开来 + */ + public String permission() default ""; +} diff --git a/dc-common/src/main/java/com/dc/common/annotation/Excel.java b/dc-common/src/main/java/com/dc/common/annotation/Excel.java new file mode 100644 index 0000000..785662c --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/annotation/Excel.java @@ -0,0 +1,188 @@ +package com.dc.common.annotation; + +import java.lang.annotation.ElementType; +import java.lang.annotation.Retention; +import java.lang.annotation.RetentionPolicy; +import java.lang.annotation.Target; +import java.math.BigDecimal; + +import com.dc.common.utils.poi.ExcelHandlerAdapter; +import org.apache.poi.ss.usermodel.HorizontalAlignment; +import org.apache.poi.ss.usermodel.IndexedColors; + +/** + * 自定义导出Excel数据注解 + * + * @author win + */ +@Retention(RetentionPolicy.RUNTIME) +@Target(ElementType.FIELD) +public @interface Excel +{ + /** + * 导出时在excel中排序 + */ + public int sort() default Integer.MAX_VALUE; + + /** + * 导出到Excel中的名字. + */ + public String name() default ""; + + /** + * 日期格式, 如: yyyy-MM-dd + */ + public String dateFormat() default ""; + + /** + * 如果是字典类型,请设置字典的type值 (如: sys_user_sex) + */ + public String dictType() default ""; + + /** + * 读取内容转表达式 (如: 0=男,1=女,2=未知) + */ + public String readConverterExp() default ""; + + /** + * 分隔符,读取字符串组内容 + */ + public String separator() default ","; + + /** + * BigDecimal 精度 默认:-1(默认不开启BigDecimal格式化) + */ + public int scale() default -1; + + /** + * BigDecimal 舍入规则 默认:BigDecimal.ROUND_HALF_EVEN + */ + public int roundingMode() default BigDecimal.ROUND_HALF_EVEN; + + /** + * 导出时在excel中每个列的高度 单位为字符 + */ + public double height() default 14; + + /** + * 导出时在excel中每个列的宽 单位为字符 + */ + public double width() default 16; + + /** + * 文字后缀,如% 90 变成90% + */ + public String suffix() default ""; + + /** + * 当值为空时,字段的默认值 + */ + public String defaultValue() default ""; + + /** + * 提示信息 + */ + public String prompt() default ""; + + /** + * 设置只能选择不能输入的列内容. + */ + public String[] combo() default {}; + + /** + * 是否需要纵向合并单元格,应对需求:含有list集合单元格) + */ + public boolean needMerge() default false; + + /** + * 是否导出数据,应对需求:有时我们需要导出一份模板,这是标题需要但内容需要用户手工填写. + */ + public boolean isExport() default true; + + /** + * 另一个类中的属性名称,支持多级获取,以小数点隔开 + */ + public String targetAttr() default ""; + + /** + * 是否自动统计数据,在最后追加一行统计数据总和 + */ + public boolean isStatistics() default false; + + /** + * 导出类型(0数字 1字符串 2图片) + */ + public ColumnType cellType() default ColumnType.STRING; + + /** + * 导出列头背景色 + */ + public IndexedColors headerBackgroundColor() default IndexedColors.GREY_50_PERCENT; + + /** + * 导出列头字体颜色 + */ + public IndexedColors headerColor() default IndexedColors.WHITE; + + /** + * 导出单元格背景色 + */ + public IndexedColors backgroundColor() default IndexedColors.WHITE; + + /** + * 导出单元格字体颜色 + */ + public IndexedColors color() default IndexedColors.BLACK; + + /** + * 导出字段对齐方式 + */ + public HorizontalAlignment align() default HorizontalAlignment.CENTER; + + /** + * 自定义数据处理器 + */ + public Class<?> handler() default ExcelHandlerAdapter.class; + + /** + * 自定义数据处理器参数 + */ + public String[] args() default {}; + + /** + * 字段类型(0:导出导入;1:仅导出;2:仅导入) + */ + Type type() default Type.ALL; + + public enum Type + { + ALL(0), EXPORT(1), IMPORT(2); + private final int value; + + Type(int value) + { + this.value = value; + } + + public int value() + { + return this.value; + } + } + + public enum ColumnType + { + NUMERIC(0), STRING(1), IMAGE(2); + private final int value; + + ColumnType(int value) + { + this.value = value; + } + + public int value() + { + return this.value; + } + } +} \ No newline at end of file diff --git a/dc-common/src/main/java/com/dc/common/annotation/Excels.java b/dc-common/src/main/java/com/dc/common/annotation/Excels.java new file mode 100644 index 0000000..f6ab3dd --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/annotation/Excels.java @@ -0,0 +1,18 @@ +package com.dc.common.annotation; + +import java.lang.annotation.ElementType; +import java.lang.annotation.Retention; +import java.lang.annotation.RetentionPolicy; +import java.lang.annotation.Target; + +/** + * Excel注解集 + * + * @author win + */ +@Target(ElementType.FIELD) +@Retention(RetentionPolicy.RUNTIME) +public @interface Excels +{ + public Excel[] value(); +} diff --git a/dc-common/src/main/java/com/dc/common/annotation/Log.java b/dc-common/src/main/java/com/dc/common/annotation/Log.java new file mode 100644 index 0000000..304fd40 --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/annotation/Log.java @@ -0,0 +1,45 @@ +package com.dc.common.annotation; + +import com.dc.common.enums.BusinessType; +import com.dc.common.enums.OperatorType; + +import java.lang.annotation.*; + +/** + * 自定义操作日志记录注解 + * + * @author win + * + */ +@Target({ ElementType.PARAMETER, ElementType.METHOD }) +@Retention(RetentionPolicy.RUNTIME) +@Documented +public @interface Log +{ + /** + * 模块 + */ + public String title() default ""; + + /** + * 功能 + */ + public BusinessType businessType() default BusinessType.OTHER; + + /** + * 操作人类别 + */ + public OperatorType operatorType() default OperatorType.MANAGE; + + /** + * 是否保存请求的参数 + */ + public boolean isSaveRequestData() default true; + + /** + * 是否保存响应的参数 + */ + public boolean isSaveResponseData() default true; + + public boolean isManager() default true; +} diff --git a/dc-common/src/main/java/com/dc/common/annotation/RateLimiter.java b/dc-common/src/main/java/com/dc/common/annotation/RateLimiter.java new file mode 100644 index 0000000..9d5f545 --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/annotation/RateLimiter.java @@ -0,0 +1,37 @@ +package com.dc.common.annotation; + +import com.dc.common.constant.CacheConstants; +import com.dc.common.enums.LimitType; + +import java.lang.annotation.*; + +/** + * 限流注解 + * + * @author win + */ +@Target(ElementType.METHOD) +@Retention(RetentionPolicy.RUNTIME) +@Documented +public @interface RateLimiter +{ + /** + * 限流key + */ + public String key() default CacheConstants.RATE_LIMIT_KEY; + + /** + * 限流时间,单位秒 + */ + public int time() default 60; + + /** + * 限流次数 + */ + public int count() default 100; + + /** + * 限流类型 + */ + public LimitType limitType() default LimitType.DEFAULT; +} diff --git a/dc-common/src/main/java/com/dc/common/annotation/RepeatSubmit.java b/dc-common/src/main/java/com/dc/common/annotation/RepeatSubmit.java new file mode 100644 index 0000000..b797893 --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/annotation/RepeatSubmit.java @@ -0,0 +1,31 @@ +package com.dc.common.annotation; + +import java.lang.annotation.Documented; +import java.lang.annotation.ElementType; +import java.lang.annotation.Inherited; +import java.lang.annotation.Retention; +import java.lang.annotation.RetentionPolicy; +import java.lang.annotation.Target; + +/** + * 自定义注解防止表单重复提交 + * + * @author win + * + */ +@Inherited +@Target(ElementType.METHOD) +@Retention(RetentionPolicy.RUNTIME) +@Documented +public @interface RepeatSubmit +{ + /** + * 间隔时间(ms),小于此时间视为重复提交 + */ + public int interval() default 5000; + + /** + * 提示消息 + */ + public String message() default "不允许重复提交,请稍候再试"; +} diff --git a/dc-common/src/main/java/com/dc/common/config/WinConfig.java b/dc-common/src/main/java/com/dc/common/config/WinConfig.java new file mode 100644 index 0000000..d16b5da --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/config/WinConfig.java @@ -0,0 +1,135 @@ +package com.dc.common.config; + +import org.springframework.boot.context.properties.ConfigurationProperties; +import org.springframework.stereotype.Component; + +/** + * 读取项目相关配置 + * + * @author win + */ +@Component +@ConfigurationProperties(prefix = "dccenter") +public class WinConfig +{ + /** 项目名称 */ + private String name; + + /** 版本 */ + private String version; + + /** 版权年份 */ + private String copyrightYear; + + /** 实例演示开关 */ + private boolean demoEnabled; + + /** 上传路径 */ + private static String profile; + + /** 获取地址开关 */ + private static boolean addressEnabled; + + /** 验证码类型 */ + private static String captchaType; + + public String getName() + { + return name; + } + + public void setName(String name) + { + this.name = name; + } + + public String getVersion() + { + return version; + } + + public void setVersion(String version) + { + this.version = version; + } + + public String getCopyrightYear() + { + return copyrightYear; + } + + public void setCopyrightYear(String copyrightYear) + { + this.copyrightYear = copyrightYear; + } + + public boolean isDemoEnabled() + { + return demoEnabled; + } + + public void setDemoEnabled(boolean demoEnabled) + { + this.demoEnabled = demoEnabled; + } + + public static String getProfile() + { + return profile; + } + + public void setProfile(String profile) + { + WinConfig.profile = profile; + } + + public static boolean isAddressEnabled() + { + return addressEnabled; + } + + public void setAddressEnabled(boolean addressEnabled) + { + WinConfig.addressEnabled = addressEnabled; + } + + public static String getCaptchaType() { + return captchaType; + } + + public void setCaptchaType(String captchaType) { + WinConfig.captchaType = captchaType; + } + + /** + * 获取导入上传路径 + */ + public static String getImportPath() + { + return getProfile() + "/import"; + } + + /** + * 获取头像上传路径 + */ + public static String getAvatarPath() + { + return getProfile() + "/avatar"; + } + + /** + * 获取下载路径 + */ + public static String getDownloadPath() + { + return getProfile() + "/download/"; + } + + /** + * 获取上传路径 + */ + public static String getUploadPath() + { + return getProfile() + "/upload"; + } +} diff --git a/dc-common/src/main/java/com/dc/common/constant/CacheConstants.java b/dc-common/src/main/java/com/dc/common/constant/CacheConstants.java new file mode 100644 index 0000000..8a867b4 --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/constant/CacheConstants.java @@ -0,0 +1,44 @@ +package com.dc.common.constant; + +/** + * 缓存的key 常量 + * + * @author win + */ +public class CacheConstants +{ + /** + * 登录用户 redis key + */ + public static final String LOGIN_TOKEN_KEY = "login_tokens:"; + + /** + * 验证码 redis key + */ + public static final String CAPTCHA_CODE_KEY = "captcha_codes:"; + + /** + * 参数管理 cache key + */ + public static final String SYS_CONFIG_KEY = "sys_config:"; + + /** + * 字典管理 cache key + */ + public static final String SYS_DICT_KEY = "sys_dict:"; + + /** + * 防重提交 redis key + */ + public static final String REPEAT_SUBMIT_KEY = "repeat_submit:"; + + /** + * 限流 redis key + */ + public static final String RATE_LIMIT_KEY = "rate_limit:"; + + /** + * 登录账户密码错误次数 redis key + */ + public static final String PWD_ERR_CNT_KEY = "pwd_err_cnt:"; +} diff --git a/dc-common/src/main/java/com/dc/common/constant/Constants.java b/dc-common/src/main/java/com/dc/common/constant/Constants.java new file mode 100644 index 0000000..828b051 --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/constant/Constants.java @@ -0,0 +1,148 @@ +package com.dc.common.constant; + +import io.jsonwebtoken.Claims; + +/** + * 通用常量信息 + * + * @author win + */ +public class Constants +{ + /** + * UTF-8 字符集 + */ + public static final String UTF8 = "UTF-8"; + + /** + * GBK 字符集 + */ + public static final String GBK = "GBK"; + + /** + * www主域 + */ + public static final String WWW = "www."; + + /** + * http请求 + */ + public static final String HTTP = "http://"; + + /** + * https请求 + */ + public static final String HTTPS = "https://"; + + /** + * 通用成功标识 + */ + public static final String SUCCESS = "0"; + + /** + * 通用失败标识 + */ + public static final String FAIL = "1"; + + /** + * 登录成功 + */ + public static final String LOGIN_SUCCESS = "Success"; + + /** + * 注销 + */ + public static final String LOGOUT = "Logout"; + + /** + * 注册 + */ + public static final String REGISTER = "Register"; + + /** + * 登录失败 + */ + public static final String LOGIN_FAIL = "Error"; + + /** + * 验证码有效期(分钟) + */ + public static final Integer CAPTCHA_EXPIRATION = 2; + + /** + * 令牌 + */ + public static final String TOKEN = "token"; + + /** + * 令牌前缀 + */ + public static final String TOKEN_PREFIX = "Bearer "; + + /** + * 令牌前缀 + */ + public static final String LOGIN_USER_KEY = "login_user_key"; + + /** + * 用户ID + */ + public static final String JWT_USERID = "userid"; + + /** + * 用户名称 + */ + public static final String JWT_USERNAME = Claims.SUBJECT; + + /** + * 用户头像 + */ + public static final String JWT_AVATAR = "avatar"; + + /** + * 创建时间 + */ + public static final String JWT_CREATED = "created"; + + /** + * 用户权限 + */ + public static final String JWT_AUTHORITIES = "authorities"; + + /** + * 资源映射路径 前缀 + */ + public static final String RESOURCE_PREFIX = "/profile"; + + /** + * RMI 远程方法调用 + */ + public static final String LOOKUP_RMI = "rmi:"; + + /** + * LDAP 远程方法调用 + */ + public static final String LOOKUP_LDAP = "ldap:"; + + /** + * LDAPS 远程方法调用 + */ + public static final String LOOKUP_LDAPS = "ldaps:"; + + /** + * 定时任务白名单配置(仅允许访问的包名,如其他需要可以自行添加) + */ + public static final String[] JOB_WHITELIST_STR = { "com.dc" }; + + /** + * 定时任务违规的字符 + */ + public static final String[] JOB_ERROR_STR = { "java.net.URL", "javax.naming.InitialContext", "org.yaml.snakeyaml", + "org.springframework", "org.apache", "com.dc.common.utils.file", "com.dc.common.config" }; + + /** + * 登录用户编号 redis key + */ + public static final String LOGIN_USERID_KEY = "login_userid:"; + +} diff --git a/dc-common/src/main/java/com/dc/common/constant/DBConstants.java b/dc-common/src/main/java/com/dc/common/constant/DBConstants.java new file mode 100644 index 0000000..e0630da --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/constant/DBConstants.java @@ -0,0 +1,9 @@ +package com.dc.common.constant; + +public class DBConstants { + + public static final String SHARDING = "sharding"; + + public static final String GIS = "gis"; + +} diff --git a/dc-common/src/main/java/com/dc/common/constant/GenConstants.java b/dc-common/src/main/java/com/dc/common/constant/GenConstants.java new file mode 100644 index 0000000..1fe76e5 --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/constant/GenConstants.java @@ -0,0 +1,117 @@ +package com.dc.common.constant; + +/** + * 代码生成通用常量 + * + * @author win + */ +public class GenConstants +{ + /** 单表(增删改查) */ + public static final String TPL_CRUD = "crud"; + + /** 树表(增删改查) */ + public static final String TPL_TREE = "tree"; + + /** 主子表(增删改查) */ + public static final String TPL_SUB = "sub"; + + /** 树编码字段 */ + public static final String TREE_CODE = "treeCode"; + + /** 树父编码字段 */ + public static final String TREE_PARENT_CODE = "treeParentCode"; + + /** 树名称字段 */ + public static final String TREE_NAME = "treeName"; + + /** 上级菜单ID字段 */ + public static final String PARENT_MENU_ID = "parentMenuId"; + + /** 上级菜单名称字段 */ + public static final String PARENT_MENU_NAME = "parentMenuName"; + + /** 数据库字符串类型 */ + public static final String[] COLUMNTYPE_STR = { "char", "varchar", "nvarchar", "varchar2" }; + + /** 数据库文本类型 */ + public static final String[] COLUMNTYPE_TEXT = { "tinytext", "text", "mediumtext", "longtext" }; + + /** 数据库时间类型 */ + public static final String[] COLUMNTYPE_TIME = { "datetime", "time", "date", "timestamp" }; + + /** 数据库数字类型 */ + public static final String[] COLUMNTYPE_NUMBER = { "tinyint", "smallint", "mediumint", "int", "number", "integer", + "bit", "bigint", "float", "double", "decimal" }; + + /** 页面不需要编辑字段 */ + public static final String[] COLUMNNAME_NOT_EDIT = { "id", "create_by", "create_time", "del_flag" }; + + /** 页面不需要显示的列表字段 */ + public static final String[] COLUMNNAME_NOT_LIST = { "id", "create_by", "create_time", "del_flag", "update_by", + "update_time" }; + + /** 页面不需要查询字段 */ + public static final String[] COLUMNNAME_NOT_QUERY = { "id", "create_by", "create_time", "del_flag", "update_by", + "update_time", "remark" }; + + /** Entity基类字段 */ + public static final String[] BASE_ENTITY = { "createBy", "createTime", "updateBy", "updateTime", "remark" }; + + /** Tree基类字段 */ + public static final String[] TREE_ENTITY = { "parentName", "parentId", "orderNum", "ancestors", "children" }; + + /** 文本框 */ + public static final String HTML_INPUT = "input"; + + /** 文本域 */ + public static final String HTML_TEXTAREA = "textarea"; + + /** 下拉框 */ + public static final String HTML_SELECT = "select"; + + /** 单选框 */ + public static final String HTML_RADIO = "radio"; + + /** 复选框 */ + public static final String HTML_CHECKBOX = "checkbox"; + + /** 日期控件 */ + public static final String HTML_DATETIME = "datetime"; + + /** 图片上传控件 */ + public static final String HTML_IMAGE_UPLOAD = "imageUpload"; + + /** 文件上传控件 */ + public static final String HTML_FILE_UPLOAD = "fileUpload"; + + /** 富文本控件 */ + public static final String HTML_EDITOR = "editor"; + + /** 字符串类型 */ + public static final String TYPE_STRING = "String"; + + /** 整型 */ + public static final String TYPE_INTEGER = "Integer"; + + /** 长整型 */ + public static final String TYPE_LONG = "Long"; + + /** 浮点型 */ + public static final String TYPE_DOUBLE = "Double"; + + /** 高精度计算类型 */ + public static final String TYPE_BIGDECIMAL = "BigDecimal"; + + /** 时间类型 */ + public static final String TYPE_DATE = "Date"; + + /** 模糊查询 */ + public static final String QUERY_LIKE = "LIKE"; + + /** 相等查询 */ + public static final String QUERY_EQ = "EQ"; + + /** 需要 */ + public static final String REQUIRE = "1"; +} diff --git a/dc-common/src/main/java/com/dc/common/constant/HttpStatus.java b/dc-common/src/main/java/com/dc/common/constant/HttpStatus.java new file mode 100644 index 0000000..e29e85f --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/constant/HttpStatus.java @@ -0,0 +1,94 @@ +package com.dc.common.constant; + +/** + * 返回状态码 + * + * @author win + */ +public class HttpStatus +{ + /** + * 操作成功 + */ + public static final int SUCCESS = 200; + + /** + * 对象创建成功 + */ + public static final int CREATED = 201; + + /** + * 请求已经被接受 + */ + public static final int ACCEPTED = 202; + + /** + * 操作已经执行成功,但是没有返回数据 + */ + public static final int NO_CONTENT = 204; + + /** + * 资源已被移除 + */ + public static final int MOVED_PERM = 301; + + /** + * 重定向 + */ + public static final int SEE_OTHER = 303; + + /** + * 资源没有被修改 + */ + public static final int NOT_MODIFIED = 304; + + /** + * 参数列表错误(缺少,格式不匹配) + */ + public static final int BAD_REQUEST = 400; + + /** + * 未授权 + */ + public static final int UNAUTHORIZED = 401; + + /** + * 访问受限,授权过期 + */ + public static final int FORBIDDEN = 403; + + /** + * 资源,服务未找到 + */ + public static final int NOT_FOUND = 404; + + /** + * 不允许的http方法 + */ + public static final int BAD_METHOD = 405; + + /** + * 资源冲突,或者资源被锁 + */ + public static final int CONFLICT = 409; + + /** + * 不支持的数据,媒体类型 + */ + public static final int UNSUPPORTED_TYPE = 415; + + /** + * 系统内部错误 + */ + public static final int ERROR = 500; + + /** + * 接口未实现 + */ + public static final int NOT_IMPLEMENTED = 501; + + /** + * 系统警告消息 + */ + public static final int WARN = 601; +} diff --git a/dc-common/src/main/java/com/dc/common/constant/ScheduleConstants.java b/dc-common/src/main/java/com/dc/common/constant/ScheduleConstants.java new file mode 100644 index 0000000..48ec0b6 --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/constant/ScheduleConstants.java @@ -0,0 +1,50 @@ +package com.dc.common.constant; + +/** + * 任务调度通用常量 + * + * @author win + */ +public class ScheduleConstants +{ + public static final String TASK_CLASS_NAME = "TASK_CLASS_NAME"; + + /** 执行目标key */ + public static final String TASK_PROPERTIES = "TASK_PROPERTIES"; + + /** 默认 */ + public static final String MISFIRE_DEFAULT = "0"; + + /** 立即触发执行 */ + public static final String MISFIRE_IGNORE_MISFIRES = "1"; + + /** 触发一次执行 */ + public static final String MISFIRE_FIRE_AND_PROCEED = "2"; + + /** 不触发立即执行 */ + public static final String MISFIRE_DO_NOTHING = "3"; + + public enum Status + { + /** + * 正常 + */ + NORMAL("0"), + /** + * 暂停 + */ + PAUSE("1"); + + private String value; + + private Status(String value) + { + this.value = value; + } + + public String getValue() + { + return value; + } + } +} diff --git a/dc-common/src/main/java/com/dc/common/constant/UserConstants.java b/dc-common/src/main/java/com/dc/common/constant/UserConstants.java new file mode 100644 index 0000000..642f9bf --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/constant/UserConstants.java @@ -0,0 +1,78 @@ +package com.dc.common.constant; + +/** + * 用户常量信息 + * + * @author win + */ +public class UserConstants +{ + /** + * 平台内系统用户的唯一标志 + */ + public static final String SYS_USER = "SYS_USER"; + + /** 正常状态 */ + public static final String NORMAL = "0"; + + /** 异常状态 */ + public static final String EXCEPTION = "1"; + + /** 用户封禁状态 */ + public static final String USER_DISABLE = "1"; + + /** 角色封禁状态 */ + public static final String ROLE_DISABLE = "1"; + + /** 部门正常状态 */ + public static final String DEPT_NORMAL = "0"; + + /** 部门停用状态 */ + public static final String DEPT_DISABLE = "1"; + + /** 字典正常状态 */ + public static final String DICT_NORMAL = "0"; + + /** 是否为系统默认(是) */ + public static final String YES = "Y"; + + /** 是否菜单外链(是) */ + public static final String YES_FRAME = "0"; + + /** 是否菜单外链(否) */ + public static final String NO_FRAME = "1"; + + /** 菜单类型(目录) */ + public static final String TYPE_DIR = "M"; + + /** 菜单类型(菜单) */ + public static final String TYPE_MENU = "C"; + + /** 菜单类型(按钮) */ + public static final String TYPE_BUTTON = "F"; + + /** Layout组件标识 */ + public final static String LAYOUT = "Layout"; + + /** ParentView组件标识 */ + public final static String PARENT_VIEW = "ParentView"; + + /** InnerLink组件标识 */ + public final static String INNER_LINK = "InnerLink"; + + /** 校验返回结果码 */ + public final static String UNIQUE = "0"; + public final static String NOT_UNIQUE = "1"; + + /** + * 用户名长度限制 + */ + public static final int USERNAME_MIN_LENGTH = 2; + public static final int USERNAME_MAX_LENGTH = 20; + + /** + * 密码长度限制 + */ + public static final int PASSWORD_MIN_LENGTH = 5; + public static final int PASSWORD_MAX_LENGTH = 20; +} diff --git a/dc-common/src/main/java/com/dc/common/context/DataScopeHolder.java b/dc-common/src/main/java/com/dc/common/context/DataScopeHolder.java new file mode 100644 index 0000000..9dbbf32 --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/context/DataScopeHolder.java @@ -0,0 +1,28 @@ +package com.dc.common.context; + +/** + * @ClassName TableAliasHolder + * @Description TODO + * @Author longlongxiaogege + * @Date 2023/6/27 13:32 + * @Version 1.0 + */ +public class DataScopeHolder { + + private static ThreadLocal<Object> dataScopeSql = new ThreadLocal<>(); + + public static void addDataScopeSql(Object sql){ + if(dataScopeSql.get() == null){ + dataScopeSql.set(sql); + } + } + + public static Object getDataScopeSql(){ + return dataScopeSql.get(); + } + + public static void removeDataScopeSql() { + dataScopeSql.remove(); + } + +} diff --git a/dc-common/src/main/java/com/dc/common/core/controller/BaseController.java b/dc-common/src/main/java/com/dc/common/core/controller/BaseController.java new file mode 100644 index 0000000..f1c76e4 --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/core/controller/BaseController.java @@ -0,0 +1,213 @@ +package com.dc.common.core.controller; + +import com.github.pagehelper.PageHelper; +import com.github.pagehelper.PageInfo; +import com.dc.common.constant.HttpStatus; +import com.dc.common.context.DataScopeHolder; +import com.dc.common.core.domain.AjaxResult; +import com.dc.common.core.domain.model.LoginUser; +import com.dc.common.core.page.PageDomain; +import com.dc.common.core.page.TableDataInfo; +import com.dc.common.core.page.TableSupport; +import com.dc.common.utils.DateUtils; +import com.dc.common.utils.PageUtils; +import com.dc.common.utils.SecurityUtils; +import com.dc.common.utils.StringUtils; +import com.dc.common.utils.sql.SqlUtil; +import org.slf4j.Logger; +import org.slf4j.LoggerFactory; +import org.springframework.web.bind.WebDataBinder; +import org.springframework.web.bind.annotation.InitBinder; + +import java.beans.PropertyEditorSupport; +import java.util.Date; +import java.util.List; + +/** + * web层通用数据处理 + * + * @author win + */ +public class BaseController +{ + protected final Logger logger = LoggerFactory.getLogger(this.getClass()); + + /** + * 将前台传递过来的日期格式的字符串,自动转化为Date类型 + */ + @InitBinder + public void initBinder(WebDataBinder binder) + { + // Date 类型转换 + binder.registerCustomEditor(Date.class, new PropertyEditorSupport() + { + @Override + public void setAsText(String text) + { + setValue(DateUtils.parseDate(text)); + } + }); + } + + /** + * 设置请求分页数据 + */ + protected void startPage() + { + PageUtils.startPage(); + } + + /** + * 设置请求排序数据 + */ + protected void startOrderBy() + { + PageDomain pageDomain = TableSupport.buildPageRequest(); + if (StringUtils.isNotEmpty(pageDomain.getOrderBy())) + { + String orderBy = SqlUtil.escapeOrderBySql(pageDomain.getOrderBy()); + PageHelper.orderBy(orderBy); + } + } + + /** + * 清理分页的线程变量 + */ + protected void clearPage() + { + PageUtils.clearPage(); + } + + /** + * 响应请求分页数据 + */ + @SuppressWarnings({ "rawtypes", "unchecked" }) + protected TableDataInfo getDataTable(List<?> list) + { + TableDataInfo rspData = new TableDataInfo(); + rspData.setCode(HttpStatus.SUCCESS); + rspData.setMsg("查询成功"); + rspData.setRows(list); + rspData.setTotal(new PageInfo(list).getTotal()); + return rspData; + } + + /** + * 返回成功 + */ + public AjaxResult success() + { + return AjaxResult.success(); + } + + /** + * 返回失败消息 + */ + public AjaxResult error() + { + return AjaxResult.error(); + } + + /** + * 返回成功消息 + */ + public AjaxResult success(String message) + { + return AjaxResult.success(message); + } + + /** + * 返回成功消息 + */ + public AjaxResult success(Object data) + { + return AjaxResult.success(data); + } + + /** + * 返回失败消息 + */ + public AjaxResult error(String message) + { + return AjaxResult.error(message); + } + + /** + * 返回警告消息 + */ + public AjaxResult warn(String message) + { + return AjaxResult.warn(message); + } + + /** + * 响应返回结果 + * + * @param rows 影响行数 + * @return 操作结果 + */ + protected AjaxResult toAjax(int rows) + { + return rows > 0 ? AjaxResult.success() : AjaxResult.error(); + } + + /** + * 响应返回结果 + * + * @param result 结果 + * @return 操作结果 + */ + protected AjaxResult toAjax(boolean result) + { + return result ? success() : error(); + } + + /** + * 页面跳转 + */ + public String redirect(String url) + { + return StringUtils.format("redirect:{}", url); + } + + /** + * 获取用户缓存信息 + */ + public LoginUser getLoginUser() + { + return SecurityUtils.getLoginUser(); + } + + /** + * 获取登录用户id + */ + public Long getUserId() + { + return getLoginUser().getUserId(); + } + + /** + * 获取登录部门id + */ + public Long getDeptId() + { + return getLoginUser().getDeptId(); + } + + /** + * 获取登录用户名 + */ + public String getUsername() + { + return getLoginUser().getUsername(); + } + + /** + * 获取移动端unionId + * @return + */ + public String getOpenId() { + return SecurityUtils.getOpenId(); + } + +} diff --git a/dc-common/src/main/java/com/dc/common/core/domain/AjaxResult.java b/dc-common/src/main/java/com/dc/common/core/domain/AjaxResult.java new file mode 100644 index 0000000..a1a7981 --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/core/domain/AjaxResult.java @@ -0,0 +1,186 @@ +package com.dc.common.core.domain; + +import com.dc.common.constant.HttpStatus; +import com.dc.common.utils.StringUtils; + +import java.util.HashMap; + +/** + * 操作消息提醒 + * + * @author win + */ +public class AjaxResult extends HashMap<String, Object> +{ + private static final long serialVersionUID = 1L; + + /** 状态码 */ + public static final String CODE_TAG = "code"; + + /** 返回内容 */ + public static final String MSG_TAG = "msg"; + + /** 数据对象 */ + public static final String DATA_TAG = "data"; + + /** + * 初始化一个新创建的 AjaxResult 对象,使其表示一个空消息。 + */ + public AjaxResult() + { + } + + /** + * 初始化一个新创建的 AjaxResult 对象 + * + * @param code 状态码 + * @param msg 返回内容 + */ + public AjaxResult(int code, String msg) + { + super.put(CODE_TAG, code); + super.put(MSG_TAG, msg); + } + + /** + * 初始化一个新创建的 AjaxResult 对象 + * + * @param code 状态码 + * @param msg 返回内容 + * @param data 数据对象 + */ + public AjaxResult(int code, String msg, Object data) + { + super.put(CODE_TAG, code); + super.put(MSG_TAG, msg); + if (StringUtils.isNotNull(data)) + { + super.put(DATA_TAG, data); + } + } + + /** + * 返回成功消息 + * + * @return 成功消息 + */ + public static AjaxResult success() + { + return AjaxResult.success("操作成功"); + } + + /** + * 返回成功数据 + * + * @return 成功消息 + */ + public static AjaxResult success(Object data) + { + return AjaxResult.success("操作成功", data); + } + + /** + * 返回成功消息 + * + * @param msg 返回内容 + * @return 成功消息 + */ + public static AjaxResult success(String msg) + { + return AjaxResult.success(msg, null); + } + + /** + * 返回成功消息 + * + * @param msg 返回内容 + * @param data 数据对象 + * @return 成功消息 + */ + public static AjaxResult success(String msg, Object data) + { + return new AjaxResult(HttpStatus.SUCCESS, msg, data); + } + + /** + * 返回警告消息 + * + * @param msg 返回内容 + * @return 警告消息 + */ + public static AjaxResult warn(String msg) + { + return AjaxResult.warn(msg, null); + } + + /** + * 返回警告消息 + * + * @param msg 返回内容 + * @param data 数据对象 + * @return 警告消息 + */ + public static AjaxResult warn(String msg, Object data) + { + return new AjaxResult(HttpStatus.WARN, msg, data); + } + + /** + * 返回错误消息 + * + * @return 错误消息 + */ + public static AjaxResult error() + { + return AjaxResult.error("操作失败"); + } + + /** + * 返回错误消息 + * + * @param msg 返回内容 + * @return 错误消息 + */ + public static AjaxResult error(String msg) + { + return AjaxResult.error(msg, null); + } + + /** + * 返回错误消息 + * + * @param msg 返回内容 + * @param data 数据对象 + * @return 错误消息 + */ + public static AjaxResult error(String msg, Object data) + { + return new AjaxResult(HttpStatus.ERROR, msg, data); + } + + /** + * 返回错误消息 + * + * @param code 状态码 + * @param msg 返回内容 + * @return 错误消息 + */ + public static AjaxResult error(int code, String msg) + { + return new AjaxResult(code, msg, null); + } + + /** + * 方便链式调用 + * + * @param key 键 + * @param value 值 + * @return 数据对象 + */ + @Override + public AjaxResult put(String key, Object value) + { + super.put(key, value); + return this; + } +} diff --git a/dc-common/src/main/java/com/dc/common/core/domain/BaseEntity.java b/dc-common/src/main/java/com/dc/common/core/domain/BaseEntity.java new file mode 100644 index 0000000..832104d --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/core/domain/BaseEntity.java @@ -0,0 +1,82 @@ +package com.dc.common.core.domain; + +import com.baomidou.mybatisplus.annotation.*; +import com.baomidou.mybatisplus.extension.activerecord.Model; +import com.fasterxml.jackson.annotation.JsonFormat; +import com.fasterxml.jackson.annotation.JsonIgnore; +import com.dc.common.annotation.Excel; +import lombok.*; +import lombok.experimental.Accessors; +import org.springframework.format.annotation.DateTimeFormat; + +import java.time.LocalDateTime; + +@Data +@Accessors(chain = true) +public abstract class BaseEntity<T extends Model<?>> extends Model<T> { + + /** + * id + */ + @TableId(type = IdType.AUTO) + private Long id; + + /** + * 部门id + */ + @JsonIgnore + private Long deptId; + + /** + * 部门id + */ + @JsonIgnore + private Long userId; + + /** + * 版本号,乐观锁 + */ + @Version + @TableField("`version`") + private Integer version; + + /** + * 创建人 + */ + @JsonIgnore + private Long createBy; + + /** + * 创建时间 + */ + @Excel(name = "创建时间", type = Excel.Type.EXPORT, dateFormat = "yyyy-MM-dd HH:mm:ss", sort = 100) + @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss") + @DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss") + private LocalDateTime createTime; + + /** + * 修改人 + */ + @JsonIgnore + private Long updateBy; + + /** + * 修改时间 + */ + @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss") + private LocalDateTime updateTime; + + /** + * 删除人 + */ + @JsonIgnore + private Long deleteBy; + + /** + * 删除时间 + */ + @JsonIgnore + @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss") + private LocalDateTime deleteTime; + +} diff --git a/dc-common/src/main/java/com/dc/common/core/domain/IdEntity.java b/dc-common/src/main/java/com/dc/common/core/domain/IdEntity.java new file mode 100644 index 0000000..a363f97 --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/core/domain/IdEntity.java @@ -0,0 +1,62 @@ +package com.dc.common.core.domain; + +import com.baomidou.mybatisplus.annotation.IdType; +import com.baomidou.mybatisplus.annotation.TableId; +import lombok.Getter; +import lombok.Setter; +import lombok.experimental.Accessors; + +@Setter +@Getter +@Accessors(chain = true) +public abstract class IdEntity<T extends BaseEntity<?>> extends BaseEntity<T> { + + /** + * id + */ + //@JsonIgnore + @TableId(type = IdType.AUTO) + private Long id; +// public Long getId() { +// return id; +// } +// public void setId(Long id) { +// this.id = id; +// genIdStr(); +// } + /** + * id + */ +// @JsonProperty("id") +// @TableField(exist = false) +// private String idStr; +// public String getIdStr() { +// return idStr; +// } +// public void setIdStr(String idStr) { +// this.idStr = idStr; +// genId(); +// } + + /** + * 根据 id 给 _id 赋值 + */ +// private void genIdStr() { +// if (StringUtils.isEmpty(idStr) && null != id) { +// idStr = IdEncodes.encode(id); //; +// } +// } + + /** + * 根据_id 给 id 赋值 + */ +// private void genId() { +// if ((null == id || 0 == id) && StringUtils.isNotEmpty(idStr)) { +// Long id = IdEncodes.decode(idStr); +// if (null != id && id > 0) { +// this.id = id; +// } +// } +// } + +} diff --git a/dc-common/src/main/java/com/dc/common/core/domain/R.java b/dc-common/src/main/java/com/dc/common/core/domain/R.java new file mode 100644 index 0000000..8acd555 --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/core/domain/R.java @@ -0,0 +1,116 @@ +package com.dc.common.core.domain; + +import com.dc.common.constant.HttpStatus; + +import java.io.Serializable; + +/** + * 响应信息主体 + * + * @author win + */ +public class R<T> implements Serializable +{ + private static final long serialVersionUID = 1L; + + /** 成功 */ + public static final int SUCCESS = HttpStatus.SUCCESS; + + /** 失败 */ + public static final int FAIL = HttpStatus.ERROR; + + private int code; + + private String msg; + + private T data; + + public static <T> R<T> ok() + { + return restResult(null, SUCCESS, "操作成功"); + } + + public static <T> R<T> ok(T data) + { + return restResult(data, SUCCESS, "操作成功"); + } + + public static <T> R<T> ok(T data, String msg) + { + return restResult(data, SUCCESS, msg); + } + + public static <T> R<T> fail() + { + return restResult(null, FAIL, "操作失败"); + } + + public static <T> R<T> fail(String msg) + { + return restResult(null, FAIL, msg); + } + + public static <T> R<T> fail(T data) + { + return restResult(data, FAIL, "操作失败"); + } + + public static <T> R<T> fail(T data, String msg) + { + return restResult(data, FAIL, msg); + } + + public static <T> R<T> fail(int code, String msg) + { + return restResult(null, code, msg); + } + + private static <T> R<T> restResult(T data, int code, String msg) + { + R<T> apiResult = new R<>(); + apiResult.setCode(code); + apiResult.setData(data); + apiResult.setMsg(msg); + return apiResult; + } + + public int getCode() + { + return code; + } + + public void setCode(int code) + { + this.code = code; + } + + public String getMsg() + { + return msg; + } + + public void setMsg(String msg) + { + this.msg = msg; + } + + public T getData() + { + return data; + } + + public void setData(T data) + { + this.data = data; + } + + public static <T> Boolean isError(R<T> ret) + { + return !isSuccess(ret); + } + + public static <T> Boolean isSuccess(R<T> ret) + { + return R.SUCCESS == ret.getCode(); + } +} diff --git a/dc-common/src/main/java/com/dc/common/core/domain/TreeEntity.java b/dc-common/src/main/java/com/dc/common/core/domain/TreeEntity.java new file mode 100644 index 0000000..4969fda --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/core/domain/TreeEntity.java @@ -0,0 +1,79 @@ +package com.dc.common.core.domain; + +import java.util.ArrayList; +import java.util.List; + +/** + * Tree基类 + * + * @author win + */ +public class TreeEntity extends WinBaseEntity +{ + private static final long serialVersionUID = 1L; + + /** 父菜单名称 */ + private String parentName; + + /** 父菜单ID */ + private Long parentId; + + /** 显示顺序 */ + private Integer orderNum; + + /** 祖级列表 */ + private String ancestors; + + /** 子部门 */ + private List<?> children = new ArrayList<>(); + + public String getParentName() + { + return parentName; + } + + public void setParentName(String parentName) + { + this.parentName = parentName; + } + + public Long getParentId() + { + return parentId; + } + + public void setParentId(Long parentId) + { + this.parentId = parentId; + } + + public Integer getOrderNum() + { + return orderNum; + } + + public void setOrderNum(Integer orderNum) + { + this.orderNum = orderNum; + } + + public String getAncestors() + { + return ancestors; + } + + public void setAncestors(String ancestors) + { + this.ancestors = ancestors; + } + + public List<?> getChildren() + { + return children; + } + + public void setChildren(List<?> children) + { + this.children = children; + } +} diff --git a/dc-common/src/main/java/com/dc/common/core/domain/TreeSelect.java b/dc-common/src/main/java/com/dc/common/core/domain/TreeSelect.java new file mode 100644 index 0000000..9f7e9d3 --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/core/domain/TreeSelect.java @@ -0,0 +1,78 @@ +package com.dc.common.core.domain; + +import com.fasterxml.jackson.annotation.JsonInclude; +import com.dc.common.core.domain.entity.SysDept; +import com.dc.common.core.domain.entity.SysMenu; + +import java.io.Serializable; +import java.util.List; +import java.util.stream.Collectors; + +/** + * Treeselect树结构实体类 + * + * @author win + */ +public class TreeSelect implements Serializable +{ + private static final long serialVersionUID = 1L; + + /** 节点ID */ + private Long id; + + /** 节点名称 */ + private String label; + + /** 子节点 */ + @JsonInclude(JsonInclude.Include.NON_EMPTY) + private List<TreeSelect> children; + + public TreeSelect() + { + + } + + public TreeSelect(SysDept dept) + { + this.id = dept.getDeptId(); + this.label = dept.getDeptName(); + this.children = dept.getChildren().stream().map(TreeSelect::new).collect(Collectors.toList()); + } + + public TreeSelect(SysMenu menu) + { + this.id = menu.getMenuId(); + this.label = menu.getMenuName(); + this.children = menu.getChildren().stream().map(TreeSelect::new).collect(Collectors.toList()); + } + + public Long getId() + { + return id; + } + + public void setId(Long id) + { + this.id = id; + } + + public String getLabel() + { + return label; + } + + public void setLabel(String label) + { + this.label = label; + } + + public List<TreeSelect> getChildren() + { + return children; + } + + public void setChildren(List<TreeSelect> children) + { + this.children = children; + } +} diff --git a/dc-common/src/main/java/com/dc/common/core/domain/WinBaseEntity.java b/dc-common/src/main/java/com/dc/common/core/domain/WinBaseEntity.java new file mode 100644 index 0000000..27f796b --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/core/domain/WinBaseEntity.java @@ -0,0 +1,119 @@ +package com.dc.common.core.domain; + +import com.fasterxml.jackson.annotation.JsonFormat; +import com.fasterxml.jackson.annotation.JsonIgnore; +import com.fasterxml.jackson.annotation.JsonInclude; + +import java.io.Serializable; +import java.util.Date; +import java.util.HashMap; +import java.util.Map; + +/** + * Entity基类 + * + * @author win + */ +public class WinBaseEntity implements Serializable +{ + private static final long serialVersionUID = 1L; + + /** 搜索值 */ + @JsonIgnore + private String searchValue; + + /** 创建者 */ + private String createBy; + + /** 创建时间 */ + @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss") + private Date createTime; + + /** 更新者 */ + private String updateBy; + + /** 更新时间 */ + @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss") + private Date updateTime; + + /** 备注 */ + private String remark; + + /** 请求参数 */ + @JsonInclude(JsonInclude.Include.NON_EMPTY) + private Map<String, Object> params; + + public String getSearchValue() + { + return searchValue; + } + + public void setSearchValue(String searchValue) + { + this.searchValue = searchValue; + } + + public String getCreateBy() + { + return createBy; + } + + public void setCreateBy(String createBy) + { + this.createBy = createBy; + } + + public Date getCreateTime() + { + return createTime; + } + + public void setCreateTime(Date createTime) + { + this.createTime = createTime; + } + + public String getUpdateBy() + { + return updateBy; + } + + public void setUpdateBy(String updateBy) + { + this.updateBy = updateBy; + } + + public Date getUpdateTime() + { + return updateTime; + } + + public void setUpdateTime(Date updateTime) + { + this.updateTime = updateTime; + } + + public String getRemark() + { + return remark; + } + + public void setRemark(String remark) + { + this.remark = remark; + } + + public Map<String, Object> getParams() + { + if (params == null) + { + params = new HashMap<>(); + } + return params; + } + + public void setParams(Map<String, Object> params) + { + this.params = params; + } +} diff --git a/dc-common/src/main/java/com/dc/common/core/domain/entity/SysDept.java b/dc-common/src/main/java/com/dc/common/core/domain/entity/SysDept.java new file mode 100644 index 0000000..133cf9a --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/core/domain/entity/SysDept.java @@ -0,0 +1,207 @@ +package com.dc.common.core.domain.entity; + +import com.baomidou.mybatisplus.annotation.IdType; +import com.baomidou.mybatisplus.annotation.TableId; +import com.dc.common.core.domain.WinBaseEntity; +import org.apache.commons.lang3.builder.ToStringBuilder; +import org.apache.commons.lang3.builder.ToStringStyle; + +import javax.validation.constraints.Email; +import javax.validation.constraints.NotBlank; +import javax.validation.constraints.NotNull; +import javax.validation.constraints.Size; +import java.util.ArrayList; +import java.util.List; + +/** + * 部门表 sys_dept + * + * @author win + */ +public class SysDept extends WinBaseEntity +{ + private static final long serialVersionUID = 1L; + + /** 部门ID */ + @TableId(type = IdType.AUTO) + private Long deptId; + + /** 父部门ID */ + private Long parentId; + + /** 祖级列表 */ + private String ancestors; + + /** 部门名称 */ + private String deptName; + + /** 显示顺序 */ + private Integer orderNum; + + /** 负责人 */ + private String leader; + + /** 联系电话 */ + private String phone; + + /** 邮箱 */ + private String email; + + /** 部门状态:0正常,1停用 */ + private String status; + + /** 删除标志(0代表存在 2代表删除) */ + private String delFlag; + + /** 父部门名称 */ + private String parentName; + + /** 子部门 */ + private List<SysDept> children = new ArrayList<SysDept>(); + + public Long getDeptId() + { + return deptId; + } + + public void setDeptId(Long deptId) + { + this.deptId = deptId; + } + + public Long getParentId() + { + return parentId; + } + + public void setParentId(Long parentId) + { + this.parentId = parentId; + } + + public String getAncestors() + { + return ancestors; + } + + public void setAncestors(String ancestors) + { + this.ancestors = ancestors; + } + + @NotBlank(message = "部门名称不能为空") + @Size(min = 0, max = 30, message = "部门名称长度不能超过30个字符") + public String getDeptName() + { + return deptName; + } + + public void setDeptName(String deptName) + { + this.deptName = deptName; + } + + @NotNull(message = "显示顺序不能为空") + public Integer getOrderNum() + { + return orderNum; + } + + public void setOrderNum(Integer orderNum) + { + this.orderNum = orderNum; + } + + public String getLeader() + { + return leader; + } + + public void setLeader(String leader) + { + this.leader = leader; + } + + @Size(min = 0, max = 11, message = "联系电话长度不能超过11个字符") + public String getPhone() + { + return phone; + } + + public void setPhone(String phone) + { + this.phone = phone; + } + + @Email(message = "邮箱格式不正确") + @Size(min = 0, max = 50, message = "邮箱长度不能超过50个字符") + public String getEmail() + { + return email; + } + + public void setEmail(String email) + { + this.email = email; + } + + public String getStatus() + { + return status; + } + + public void setStatus(String status) + { + this.status = status; + } + + public String getDelFlag() + { + return delFlag; + } + + public void setDelFlag(String delFlag) + { + this.delFlag = delFlag; + } + + public String getParentName() + { + return parentName; + } + + public void setParentName(String parentName) + { + this.parentName = parentName; + } + + public List<SysDept> getChildren() + { + return children; + } + + public void setChildren(List<SysDept> children) + { + this.children = children; + } + + @Override + public String toString() { + return new ToStringBuilder(this,ToStringStyle.MULTI_LINE_STYLE) + .append("deptId", getDeptId()) + .append("parentId", getParentId()) + .append("ancestors", getAncestors()) + .append("deptName", getDeptName()) + .append("orderNum", getOrderNum()) + .append("leader", getLeader()) + .append("phone", getPhone()) + .append("email", getEmail()) + .append("status", getStatus()) + .append("delFlag", getDelFlag()) + .append("createBy", getCreateBy()) + .append("createTime", getCreateTime()) + .append("updateBy", getUpdateBy()) + .append("updateTime", getUpdateTime()) + .toString(); + } +} diff --git a/dc-common/src/main/java/com/dc/common/core/domain/entity/SysDictData.java b/dc-common/src/main/java/com/dc/common/core/domain/entity/SysDictData.java new file mode 100644 index 0000000..7047cc6 --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/core/domain/entity/SysDictData.java @@ -0,0 +1,179 @@ +package com.dc.common.core.domain.entity; + +import com.baomidou.mybatisplus.annotation.IdType; +import com.baomidou.mybatisplus.annotation.TableId; +import com.dc.common.annotation.Excel; +import com.dc.common.constant.UserConstants; +import com.dc.common.core.domain.WinBaseEntity; +import org.apache.commons.lang3.builder.ToStringBuilder; +import org.apache.commons.lang3.builder.ToStringStyle; + +import javax.validation.constraints.NotBlank; +import javax.validation.constraints.Size; + +/** + * 字典数据表 sys_dict_data + * + * @author win + */ +public class SysDictData extends WinBaseEntity +{ + private static final long serialVersionUID = 1L; + + /** 字典编码 */ + @Excel(name = "字典编码", cellType = Excel.ColumnType.NUMERIC) + @TableId(type = IdType.AUTO) + private Long dictCode; + + /** 字典排序 */ + @Excel(name = "字典排序", cellType = Excel.ColumnType.NUMERIC) + private Long dictSort; + + /** 字典标签 */ + @Excel(name = "字典标签") + private String dictLabel; + + /** 字典键值 */ + @Excel(name = "字典键值") + private String dictValue; + + /** 字典类型 */ + @Excel(name = "字典类型") + private String dictType; + + /** 样式属性(其他样式扩展) */ + private String cssClass; + + /** 表格字典样式 */ + private String listClass; + + /** 是否默认(Y是 N否) */ + @Excel(name = "是否默认", readConverterExp = "Y=是,N=否") + private String isDefault; + + /** 状态(0正常 1停用) */ + @Excel(name = "状态", readConverterExp = "0=正常,1=停用") + private String status; + + public Long getDictCode() + { + return dictCode; + } + + public void setDictCode(Long dictCode) + { + this.dictCode = dictCode; + } + + public Long getDictSort() + { + return dictSort; + } + + public void setDictSort(Long dictSort) + { + this.dictSort = dictSort; + } + + @NotBlank(message = "字典标签不能为空") + @Size(min = 0, max = 100, message = "字典标签长度不能超过100个字符") + public String getDictLabel() + { + return dictLabel; + } + + public void setDictLabel(String dictLabel) + { + this.dictLabel = dictLabel; + } + + @NotBlank(message = "字典键值不能为空") + @Size(min = 0, max = 100, message = "字典键值长度不能超过100个字符") + public String getDictValue() + { + return dictValue; + } + + public void setDictValue(String dictValue) + { + this.dictValue = dictValue; + } + + @NotBlank(message = "字典类型不能为空") + @Size(min = 0, max = 100, message = "字典类型长度不能超过100个字符") + public String getDictType() + { + return dictType; + } + + public void setDictType(String dictType) + { + this.dictType = dictType; + } + + @Size(min = 0, max = 100, message = "样式属性长度不能超过100个字符") + public String getCssClass() + { + return cssClass; + } + + public void setCssClass(String cssClass) + { + this.cssClass = cssClass; + } + + public String getListClass() + { + return listClass; + } + + public void setListClass(String listClass) + { + this.listClass = listClass; + } + + public boolean getDefault() + { + return UserConstants.YES.equals(this.isDefault); + } + + public String getIsDefault() + { + return isDefault; + } + + public void setIsDefault(String isDefault) + { + this.isDefault = isDefault; + } + + public String getStatus() + { + return status; + } + + public void setStatus(String status) + { + this.status = status; + } + + @Override + public String toString() { + return new ToStringBuilder(this,ToStringStyle.MULTI_LINE_STYLE) + .append("dictCode", getDictCode()) + .append("dictSort", getDictSort()) + .append("dictLabel", getDictLabel()) + .append("dictValue", getDictValue()) + .append("dictType", getDictType()) + .append("cssClass", getCssClass()) + .append("listClass", getListClass()) + .append("isDefault", getIsDefault()) + .append("status", getStatus()) + .append("createBy", getCreateBy()) + .append("createTime", getCreateTime()) + .append("updateBy", getUpdateBy()) + .append("updateTime", getUpdateTime()) + .append("remark", getRemark()) + .toString(); + } +} diff --git a/dc-common/src/main/java/com/dc/common/core/domain/entity/SysDictType.java b/dc-common/src/main/java/com/dc/common/core/domain/entity/SysDictType.java new file mode 100644 index 0000000..5f6bfe2 --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/core/domain/entity/SysDictType.java @@ -0,0 +1,99 @@ +package com.dc.common.core.domain.entity; + +import com.baomidou.mybatisplus.annotation.IdType; +import com.baomidou.mybatisplus.annotation.TableId; +import com.dc.common.annotation.Excel; +import com.dc.common.core.domain.WinBaseEntity; +import org.apache.commons.lang3.builder.ToStringBuilder; +import org.apache.commons.lang3.builder.ToStringStyle; + +import javax.validation.constraints.NotBlank; +import javax.validation.constraints.Pattern; +import javax.validation.constraints.Size; + +/** + * 字典类型表 sys_dict_type + * + * @author win + */ +public class SysDictType extends WinBaseEntity +{ + private static final long serialVersionUID = 1L; + + /** 字典主键 */ + @Excel(name = "字典主键", cellType = Excel.ColumnType.NUMERIC) + @TableId(type = IdType.AUTO) + private Long dictId; + + /** 字典名称 */ + @Excel(name = "字典名称") + private String dictName; + + /** 字典类型 */ + @Excel(name = "字典类型") + private String dictType; + + /** 状态(0正常 1停用) */ + @Excel(name = "状态", readConverterExp = "0=正常,1=停用") + private String status; + + public Long getDictId() + { + return dictId; + } + + public void setDictId(Long dictId) + { + this.dictId = dictId; + } + + @NotBlank(message = "字典名称不能为空") + @Size(min = 0, max = 100, message = "字典类型名称长度不能超过100个字符") + public String getDictName() + { + return dictName; + } + + public void setDictName(String dictName) + { + this.dictName = dictName; + } + + @NotBlank(message = "字典类型不能为空") + @Size(min = 0, max = 100, message = "字典类型类型长度不能超过100个字符") + @Pattern(regexp = "^[a-z][a-z0-9_]*$", message = "字典类型必须以字母开头,且只能为(小写字母,数字,下滑线)") + public String getDictType() + { + return dictType; + } + + public void setDictType(String dictType) + { + this.dictType = dictType; + } + + public String getStatus() + { + return status; + } + + public void setStatus(String status) + { + this.status = status; + } + + @Override + public String toString() { + return new ToStringBuilder(this,ToStringStyle.MULTI_LINE_STYLE) + .append("dictId", getDictId()) + .append("dictName", getDictName()) + .append("dictType", getDictType()) + .append("status", getStatus()) + .append("createBy", getCreateBy()) + .append("createTime", getCreateTime()) + .append("updateBy", getUpdateBy()) + .append("updateTime", getUpdateTime()) + .append("remark", getRemark()) + .toString(); + } +} diff --git a/dc-common/src/main/java/com/dc/common/core/domain/entity/SysMenu.java b/dc-common/src/main/java/com/dc/common/core/domain/entity/SysMenu.java new file mode 100644 index 0000000..d238699 --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/core/domain/entity/SysMenu.java @@ -0,0 +1,264 @@ +package com.dc.common.core.domain.entity; + +import com.baomidou.mybatisplus.annotation.IdType; +import com.baomidou.mybatisplus.annotation.TableId; +import com.dc.common.core.domain.WinBaseEntity; +import org.apache.commons.lang3.builder.ToStringBuilder; +import org.apache.commons.lang3.builder.ToStringStyle; + +import javax.validation.constraints.NotBlank; +import javax.validation.constraints.NotNull; +import javax.validation.constraints.Size; +import java.util.ArrayList; +import java.util.List; + +/** + * 菜单权限表 sys_menu + * + * @author win + * + */ +public class SysMenu extends WinBaseEntity +{ + private static final long serialVersionUID = 1L; + + /** 菜单ID */ + @TableId(type = IdType.AUTO) + private Long menuId; + + /** 菜单名称 */ + private String menuName; + + /** 父菜单名称 */ + private String parentName; + + /** 父菜单ID */ + private Long parentId; + + /** 显示顺序 */ + private Integer orderNum; + + /** 路由地址 */ + private String path; + + /** 组件路径 */ + private String component; + + /** 路由参数 */ + private String query; + + /** 是否为外链(0是 1否) */ + private String isFrame; + + /** 是否缓存(0缓存 1不缓存) */ + private String isCache; + + /** 类型(M目录 C菜单 F按钮) */ + private String menuType; + + /** 显示状态(0显示 1隐藏) */ + private String visible; + + /** 菜单状态(0正常 1停用) */ + private String status; + + /** 权限字符串 */ + private String perms; + + /** 菜单图标 */ + private String icon; + + /** 子菜单 */ + private List<SysMenu> children = new ArrayList<SysMenu>(); + + public Long getMenuId() + { + return menuId; + } + + public void setMenuId(Long menuId) + { + this.menuId = menuId; + } + + @NotBlank(message = "菜单名称不能为空") + @Size(min = 0, max = 50, message = "菜单名称长度不能超过50个字符") + public String getMenuName() + { + return menuName; + } + + public void setMenuName(String menuName) + { + this.menuName = menuName; + } + + public String getParentName() + { + return parentName; + } + + public void setParentName(String parentName) + { + this.parentName = parentName; + } + + public Long getParentId() + { + return parentId; + } + + public void setParentId(Long parentId) + { + this.parentId = parentId; + } + + @NotNull(message = "显示顺序不能为空") + public Integer getOrderNum() + { + return orderNum; + } + + public void setOrderNum(Integer orderNum) + { + this.orderNum = orderNum; + } + + @Size(min = 0, max = 200, message = "路由地址不能超过200个字符") + public String getPath() + { + return path; + } + + public void setPath(String path) + { + this.path = path; + } + + @Size(min = 0, max = 200, message = "组件路径不能超过255个字符") + public String getComponent() + { + return component; + } + + public void setComponent(String component) + { + this.component = component; + } + + public String getQuery() + { + return query; + } + + public void setQuery(String query) + { + this.query = query; + } + + public String getIsFrame() + { + return isFrame; + } + + public void setIsFrame(String isFrame) + { + this.isFrame = isFrame; + } + + public String getIsCache() + { + return isCache; + } + + public void setIsCache(String isCache) + { + this.isCache = isCache; + } + + @NotBlank(message = "菜单类型不能为空") + public String getMenuType() + { + return menuType; + } + + public void setMenuType(String menuType) + { + this.menuType = menuType; + } + + public String getVisible() + { + return visible; + } + + public void setVisible(String visible) + { + this.visible = visible; + } + + public String getStatus() + { + return status; + } + + public void setStatus(String status) + { + this.status = status; + } + + @Size(min = 0, max = 100, message = "权限标识长度不能超过100个字符") + public String getPerms() + { + return perms; + } + + public void setPerms(String perms) + { + this.perms = perms; + } + + public String getIcon() + { + return icon; + } + + public void setIcon(String icon) + { + this.icon = icon; + } + + public List<SysMenu> getChildren() + { + return children; + } + + public void setChildren(List<SysMenu> children) + { + this.children = children; + } + + @Override + public String toString() { + return new ToStringBuilder(this,ToStringStyle.MULTI_LINE_STYLE) + .append("menuId", getMenuId()) + .append("menuName", getMenuName()) + .append("parentId", getParentId()) + .append("orderNum", getOrderNum()) + .append("path", getPath()) + .append("component", getComponent()) + .append("isFrame", getIsFrame()) + .append("IsCache", getIsCache()) + .append("menuType", getMenuType()) + .append("visible", getVisible()) + .append("status ", getStatus()) + .append("perms", getPerms()) + .append("icon", getIcon()) + .append("createBy", getCreateBy()) + .append("createTime", getCreateTime()) + .append("updateBy", getUpdateBy()) + .append("updateTime", getUpdateTime()) + .append("remark", getRemark()) + .toString(); + } +} diff --git a/dc-common/src/main/java/com/dc/common/core/domain/entity/SysRole.java b/dc-common/src/main/java/com/dc/common/core/domain/entity/SysRole.java new file mode 100644 index 0000000..a8d629f --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/core/domain/entity/SysRole.java @@ -0,0 +1,244 @@ +package com.dc.common.core.domain.entity; + +import com.baomidou.mybatisplus.annotation.IdType; +import com.baomidou.mybatisplus.annotation.TableId; +import com.dc.common.annotation.Excel; +import com.dc.common.core.domain.WinBaseEntity; +import org.apache.commons.lang3.builder.ToStringBuilder; +import org.apache.commons.lang3.builder.ToStringStyle; + +import javax.validation.constraints.NotBlank; +import javax.validation.constraints.NotNull; +import javax.validation.constraints.Size; +import java.util.Set; + +/** + * 角色表 sys_role + * + * @author win + */ +public class SysRole extends WinBaseEntity +{ + private static final long serialVersionUID = 1L; + + /** 角色ID */ + @Excel(name = "角色序号", cellType = Excel.ColumnType.NUMERIC) + @TableId(type = IdType.AUTO) + private Long roleId; + + /** 角色名称 */ + @Excel(name = "角色名称") + private String roleName; + + /** 角色权限 */ + @Excel(name = "角色权限") + private String roleKey; + + /** 角色排序 */ + @Excel(name = "角色排序") + private Integer roleSort; + + /** 数据范围(1:所有数据权限;2:自定义数据权限;3:本部门数据权限;4:本部门及以下数据权限;5:仅本人数据权限) */ + @Excel(name = "数据范围", readConverterExp = "1=所有数据权限,2=自定义数据权限,3=本部门数据权限,4=本部门及以下数据权限,5=仅本人数据权限") + private String dataScope; + + /** 菜单树选择项是否关联显示( 0:父子不互相关联显示 1:父子互相关联显示) */ + private boolean menuCheckStrictly; + + /** 部门树选择项是否关联显示(0:父子不互相关联显示 1:父子互相关联显示 ) */ + private boolean deptCheckStrictly; + + /** 角色状态(0正常 1停用) */ + @Excel(name = "角色状态", readConverterExp = "0=正常,1=停用") + private String status; + + /** 删除标志(0代表存在 2代表删除) */ + private String delFlag; + + /** 用户是否存在此角色标识 默认不存在 */ + private boolean flag = false; + + /** 菜单组 */ + private Long[] menuIds; + + /** 部门组(数据权限) */ + private Long[] deptIds; + + /** 角色菜单权限 */ + private Set<String> permissions; + + public SysRole() + { + + } + + public SysRole(Long roleId) + { + this.roleId = roleId; + } + + public Long getRoleId() + { + return roleId; + } + + public void setRoleId(Long roleId) + { + this.roleId = roleId; + } + + public boolean isAdmin() + { + return isAdmin(this.roleId); + } + + public static boolean isAdmin(Long roleId) + { + return roleId != null && 1L == roleId; + } + + @NotBlank(message = "角色名称不能为空") + @Size(min = 0, max = 30, message = "角色名称长度不能超过30个字符") + public String getRoleName() + { + return roleName; + } + + public void setRoleName(String roleName) + { + this.roleName = roleName; + } + + @NotBlank(message = "权限字符不能为空") + @Size(min = 0, max = 100, message = "权限字符长度不能超过100个字符") + public String getRoleKey() + { + return roleKey; + } + + public void setRoleKey(String roleKey) + { + this.roleKey = roleKey; + } + + @NotNull(message = "显示顺序不能为空") + public Integer getRoleSort() + { + return roleSort; + } + + public void setRoleSort(Integer roleSort) + { + this.roleSort = roleSort; + } + + public String getDataScope() + { + return dataScope; + } + + public void setDataScope(String dataScope) + { + this.dataScope = dataScope; + } + + public boolean isMenuCheckStrictly() + { + return menuCheckStrictly; + } + + public void setMenuCheckStrictly(boolean menuCheckStrictly) + { + this.menuCheckStrictly = menuCheckStrictly; + } + + public boolean isDeptCheckStrictly() + { + return deptCheckStrictly; + } + + public void setDeptCheckStrictly(boolean deptCheckStrictly) + { + this.deptCheckStrictly = deptCheckStrictly; + } + + public String getStatus() + { + return status; + } + + public void setStatus(String status) + { + this.status = status; + } + + public String getDelFlag() + { + return delFlag; + } + + public void setDelFlag(String delFlag) + { + this.delFlag = delFlag; + } + + public boolean isFlag() + { + return flag; + } + + public void setFlag(boolean flag) + { + this.flag = flag; + } + + public Long[] getMenuIds() + { + return menuIds; + } + + public void setMenuIds(Long[] menuIds) + { + this.menuIds = menuIds; + } + + public Long[] getDeptIds() + { + return deptIds; + } + + public void setDeptIds(Long[] deptIds) + { + this.deptIds = deptIds; + } + + public Set<String> getPermissions() + { + return permissions; + } + + public void setPermissions(Set<String> permissions) + { + this.permissions = permissions; + } + + @Override + public String toString() { + return new ToStringBuilder(this,ToStringStyle.MULTI_LINE_STYLE) + .append("roleId", getRoleId()) + .append("roleName", getRoleName()) + .append("roleKey", getRoleKey()) + .append("roleSort", getRoleSort()) + .append("dataScope", getDataScope()) + .append("menuCheckStrictly", isMenuCheckStrictly()) + .append("deptCheckStrictly", isDeptCheckStrictly()) + .append("status", getStatus()) + .append("delFlag", getDelFlag()) + .append("createBy", getCreateBy()) + .append("createTime", getCreateTime()) + .append("updateBy", getUpdateBy()) + .append("updateTime", getUpdateTime()) + .append("remark", getRemark()) + .toString(); + } +} diff --git a/dc-common/src/main/java/com/dc/common/core/domain/entity/SysUser.java b/dc-common/src/main/java/com/dc/common/core/domain/entity/SysUser.java new file mode 100644 index 0000000..b964d27 --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/core/domain/entity/SysUser.java @@ -0,0 +1,334 @@ +package com.dc.common.core.domain.entity; + +import com.baomidou.mybatisplus.annotation.IdType; +import com.baomidou.mybatisplus.annotation.TableField; +import com.baomidou.mybatisplus.annotation.TableId; +import com.dc.common.xss.Xss; +import com.dc.common.annotation.Excel; +import com.dc.common.annotation.Excels; +import com.dc.common.core.domain.WinBaseEntity; +import org.apache.commons.lang3.builder.ToStringBuilder; +import org.apache.commons.lang3.builder.ToStringStyle; + +import javax.validation.constraints.Email; +import javax.validation.constraints.NotBlank; +import javax.validation.constraints.Size; +import java.util.Date; +import java.util.List; + +/** + * 用户对象 sys_user + * + * @author win + */ +public class SysUser extends WinBaseEntity +{ + private static final long serialVersionUID = 1L; + + /** 用户ID */ + @Excel(name = "用户序号", cellType = Excel.ColumnType.NUMERIC, prompt = "用户编号") + @TableId(type = IdType.AUTO) + private Long userId; + + /** 部门ID */ + @Excel(name = "部门编号", type = Excel.Type.IMPORT) + private Long deptId; + + /** 用户账号 */ + @Excel(name = "登录名称") + private String userName; + + /** 用户昵称 */ + @Excel(name = "用户名称") + private String nickName; + + /** 用户邮箱 */ + @Excel(name = "用户邮箱") + private String email; + + /** 手机号码 */ + @Excel(name = "手机号码") + private String phonenumber; + + /** 用户性别 */ + @Excel(name = "用户性别", readConverterExp = "0=男,1=女,2=未知") + private String sex; + + /** 用户头像 */ + private String avatar; + + /** 密码 */ + private String password; + + /** 帐号状态(0正常 1停用) */ + @Excel(name = "帐号状态", readConverterExp = "0=正常,1=停用") + private String status; + + /** 删除标志(0代表存在 2代表删除) */ + private String delFlag; + + /** 最后登录IP */ + @Excel(name = "最后登录IP", type = Excel.Type.EXPORT) + private String loginIp; + + /** 最后登录时间 */ + @Excel(name = "最后登录时间", width = 30, dateFormat = "yyyy-MM-dd HH:mm:ss", type = Excel.Type.EXPORT) + private Date loginDate; + + /** 部门对象 */ + @Excels({ + @Excel(name = "部门名称", targetAttr = "deptName", type = Excel.Type.EXPORT), + @Excel(name = "部门负责人", targetAttr = "leader", type = Excel.Type.EXPORT) + }) + @TableField(exist = false) + private SysDept dept; + + /** 角色对象 */ + @TableField(exist = false) + private List<SysRole> roles; + + /** 角色组 */ + @TableField(exist = false) + private Long[] roleIds; + + /** 岗位组 */ + @TableField(exist = false) + private Long[] postIds; + + /** 角色ID */ + @TableField(exist = false) + private Long roleId; + + public SysUser() + { + + } + + public SysUser(Long userId) + { + this.userId = userId; + } + + public Long getUserId() + { + return userId; + } + + public void setUserId(Long userId) + { + this.userId = userId; + } + + public boolean isAdmin() + { + return isAdmin(this.userId); + } + + public static boolean isAdmin(Long userId) + { + return userId != null && 1L == userId; + } + + public Long getDeptId() + { + return deptId; + } + + public void setDeptId(Long deptId) + { + this.deptId = deptId; + } + + @Xss(message = "用户昵称不能包含脚本字符") + @Size(min = 0, max = 30, message = "用户昵称长度不能超过30个字符") + public String getNickName() + { + return nickName; + } + + public void setNickName(String nickName) + { + this.nickName = nickName; + } + + @Xss(message = "用户账号不能包含脚本字符") + @NotBlank(message = "用户账号不能为空") + @Size(min = 0, max = 30, message = "用户账号长度不能超过30个字符") + public String getUserName() + { + return userName; + } + + public void setUserName(String userName) + { + this.userName = userName; + } + + @Email(message = "邮箱格式不正确") + @Size(min = 0, max = 50, message = "邮箱长度不能超过50个字符") + public String getEmail() + { + return email; + } + + public void setEmail(String email) + { + this.email = email; + } + + @Size(min = 0, max = 11, message = "手机号码长度不能超过11个字符") + public String getPhonenumber() + { + return phonenumber; + } + + public void setPhonenumber(String phonenumber) + { + this.phonenumber = phonenumber; + } + + public String getSex() + { + return sex; + } + + public void setSex(String sex) + { + this.sex = sex; + } + + public String getAvatar() + { + return avatar; + } + + public void setAvatar(String avatar) + { + this.avatar = avatar; + } + + public String getPassword() + { + return password; + } + + public void setPassword(String password) + { + this.password = password; + } + + public String getStatus() + { + return status; + } + + public void setStatus(String status) + { + this.status = status; + } + + public String getDelFlag() + { + return delFlag; + } + + public void setDelFlag(String delFlag) + { + this.delFlag = delFlag; + } + + public String getLoginIp() + { + return loginIp; + } + + public void setLoginIp(String loginIp) + { + this.loginIp = loginIp; + } + + public Date getLoginDate() + { + return loginDate; + } + + public void setLoginDate(Date loginDate) + { + this.loginDate = loginDate; + } + + public SysDept getDept() + { + return dept; + } + + public void setDept(SysDept dept) + { + this.dept = dept; + } + + public List<SysRole> getRoles() + { + return roles; + } + + public void setRoles(List<SysRole> roles) + { + this.roles = roles; + } + + public Long[] getRoleIds() + { + return roleIds; + } + + public void setRoleIds(Long[] roleIds) + { + this.roleIds = roleIds; + } + + public Long[] getPostIds() + { + return postIds; + } + + public void setPostIds(Long[] postIds) + { + this.postIds = postIds; + } + + public Long getRoleId() + { + return roleId; + } + + public void setRoleId(Long roleId) + { + this.roleId = roleId; + } + + @Override + public String toString() { + return new ToStringBuilder(this,ToStringStyle.MULTI_LINE_STYLE) + .append("userId", getUserId()) + .append("deptId", getDeptId()) + .append("userName", getUserName()) + .append("nickName", getNickName()) + .append("email", getEmail()) + .append("phonenumber", getPhonenumber()) + .append("sex", getSex()) + .append("avatar", getAvatar()) + .append("password", getPassword()) + .append("status", getStatus()) + .append("delFlag", getDelFlag()) + .append("loginIp", getLoginIp()) + .append("loginDate", getLoginDate()) + .append("createBy", getCreateBy()) + .append("createTime", getCreateTime()) + .append("updateBy", getUpdateBy()) + .append("updateTime", getUpdateTime()) + .append("remark", getRemark()) + .append("dept", getDept()) + .toString(); + } +} diff --git a/dc-common/src/main/java/com/dc/common/core/domain/model/LoginBody.java b/dc-common/src/main/java/com/dc/common/core/domain/model/LoginBody.java new file mode 100644 index 0000000..2ddb7d2 --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/core/domain/model/LoginBody.java @@ -0,0 +1,69 @@ +package com.dc.common.core.domain.model; + +/** + * 用户登录对象 + * + * @author win + */ +public class LoginBody +{ + /** + * 用户名 + */ + private String username; + + /** + * 用户密码 + */ + private String password; + + /** + * 验证码 + */ + private String code; + + /** + * 唯一标识 + */ + private String uuid; + + public String getUsername() + { + return username; + } + + public void setUsername(String username) + { + this.username = username; + } + + public String getPassword() + { + return password; + } + + public void setPassword(String password) + { + this.password = password; + } + + public String getCode() + { + return code; + } + + public void setCode(String code) + { + this.code = code; + } + + public String getUuid() + { + return uuid; + } + + public void setUuid(String uuid) + { + this.uuid = uuid; + } +} diff --git a/dc-common/src/main/java/com/dc/common/core/domain/model/LoginUser.java b/dc-common/src/main/java/com/dc/common/core/domain/model/LoginUser.java new file mode 100644 index 0000000..8fab750 --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/core/domain/model/LoginUser.java @@ -0,0 +1,267 @@ +package com.dc.common.core.domain.model; + +import java.util.Collection; +import java.util.Set; + +import com.dc.common.core.domain.entity.SysUser; +import org.springframework.security.core.GrantedAuthority; +import org.springframework.security.core.userdetails.UserDetails; +import com.alibaba.fastjson2.annotation.JSONField; + +/** + * 登录用户身份权限 + * + * @author win + */ +public class LoginUser implements UserDetails +{ + private static final long serialVersionUID = 1L; + + /** + * 用户ID + */ + private Long userId; + + /** + * 部门ID + */ + private Long deptId; + + /** + * 用户唯一标识 + */ + private String token; + + /** + * 登录时间 + */ + private Long loginTime; + + /** + * 过期时间 + */ + private Long expireTime; + + /** + * 登录IP地址 + */ + private String ipaddr; + + /** + * 登录地点 + */ + private String loginLocation; + + /** + * 浏览器类型 + */ + private String browser; + + /** + * 操作系统 + */ + private String os; + + /** + * 权限列表 + */ + private Set<String> permissions; + + /** + * 用户信息 + */ + private SysUser user; + + public Long getUserId() + { + return userId; + } + + public void setUserId(Long userId) + { + this.userId = userId; + } + + public Long getDeptId() + { + return deptId; + } + + public void setDeptId(Long deptId) + { + this.deptId = deptId; + } + + public String getToken() + { + return token; + } + + public void setToken(String token) + { + this.token = token; + } + + public LoginUser() + { + } + + public LoginUser(SysUser user, Set<String> permissions) + { + this.user = user; + this.permissions = permissions; + } + + public LoginUser(Long userId, Long deptId, SysUser user, Set<String> permissions) + { + this.userId = userId; + this.deptId = deptId; + this.user = user; + this.permissions = permissions; + } + + @JSONField(serialize = false) + @Override + public String getPassword() + { + return user.getPassword(); + } + + @Override + public String getUsername() + { + return user.getUserName(); + } + + /** + * 账户是否未过期,过期无法验证 + */ + @JSONField(serialize = false) + @Override + public boolean isAccountNonExpired() + { + return true; + } + + /** + * 指定用户是否解锁,锁定的用户无法进行身份验证 + * + * @return + */ + @JSONField(serialize = false) + @Override + public boolean isAccountNonLocked() + { + return true; + } + + /** + * 指示是否已过期的用户的凭据(密码),过期的凭据防止认证 + * + * @return + */ + @JSONField(serialize = false) + @Override + public boolean isCredentialsNonExpired() + { + return true; + } + + /** + * 是否可用 ,禁用的用户不能身份验证 + * + * @return + */ + @JSONField(serialize = false) + @Override + public boolean isEnabled() + { + return true; + } + + public Long getLoginTime() + { + return loginTime; + } + + public void setLoginTime(Long loginTime) + { + this.loginTime = loginTime; + } + + public String getIpaddr() + { + return ipaddr; + } + + public void setIpaddr(String ipaddr) + { + this.ipaddr = ipaddr; + } + + public String getLoginLocation() + { + return loginLocation; + } + + public void setLoginLocation(String loginLocation) + { + this.loginLocation = loginLocation; + } + + public String getBrowser() + { + return browser; + } + + public void setBrowser(String browser) + { + this.browser = browser; + } + + public String getOs() + { + return os; + } + + public void setOs(String os) + { + this.os = os; + } + + public Long getExpireTime() + { + return expireTime; + } + + public void setExpireTime(Long expireTime) + { + this.expireTime = expireTime; + } + + public Set<String> getPermissions() + { + return permissions; + } + + public void setPermissions(Set<String> permissions) + { + this.permissions = permissions; + } + + public SysUser getUser() + { + return user; + } + + public void setUser(SysUser user) + { + this.user = user; + } + + @Override + public Collection<? extends GrantedAuthority> getAuthorities() + { + return null; + } +} diff --git a/dc-common/src/main/java/com/dc/common/core/domain/model/RegisterBody.java b/dc-common/src/main/java/com/dc/common/core/domain/model/RegisterBody.java new file mode 100644 index 0000000..bf4089e --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/core/domain/model/RegisterBody.java @@ -0,0 +1,11 @@ +package com.dc.common.core.domain.model; + +/** + * 用户注册对象 + * + * @author win + */ +public class RegisterBody extends LoginBody +{ + +} diff --git a/dc-common/src/main/java/com/dc/common/core/page/PageDomain.java b/dc-common/src/main/java/com/dc/common/core/page/PageDomain.java new file mode 100644 index 0000000..29a2c2f --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/core/page/PageDomain.java @@ -0,0 +1,101 @@ +package com.dc.common.core.page; + +import com.dc.common.utils.StringUtils; + +/** + * 分页数据 + * + * @author win + */ +public class PageDomain +{ + /** 当前记录起始索引 */ + private Integer pageNum; + + /** 每页显示记录数 */ + private Integer pageSize; + + /** 排序列 */ + private String orderByColumn; + + /** 排序的方向desc或者asc */ + private String isAsc = "asc"; + + /** 分页参数合理化 */ + private Boolean reasonable = true; + + public String getOrderBy() + { + if (StringUtils.isEmpty(orderByColumn)) + { + return ""; + } + return StringUtils.toUnderScoreCase(orderByColumn) + " " + isAsc; + } + + public Integer getPageNum() + { + return pageNum; + } + + public void setPageNum(Integer pageNum) + { + this.pageNum = pageNum; + } + + public Integer getPageSize() + { + return pageSize; + } + + public void setPageSize(Integer pageSize) + { + this.pageSize = pageSize; + } + + public String getOrderByColumn() + { + return orderByColumn; + } + + public void setOrderByColumn(String orderByColumn) + { + this.orderByColumn = orderByColumn; + } + + public String getIsAsc() + { + return isAsc; + } + + public void setIsAsc(String isAsc) + { + if (StringUtils.isNotEmpty(isAsc)) + { + // 兼容前端排序类型 + if ("ascending".equals(isAsc)) + { + isAsc = "asc"; + } + else if ("descending".equals(isAsc)) + { + isAsc = "desc"; + } + this.isAsc = isAsc; + } + } + + public Boolean getReasonable() + { + if (StringUtils.isNull(reasonable)) + { + return Boolean.TRUE; + } + return reasonable; + } + + public void setReasonable(Boolean reasonable) + { + this.reasonable = reasonable; + } +} diff --git a/dc-common/src/main/java/com/dc/common/core/page/TableDataInfo.java b/dc-common/src/main/java/com/dc/common/core/page/TableDataInfo.java new file mode 100644 index 0000000..8d17f65 --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/core/page/TableDataInfo.java @@ -0,0 +1,85 @@ +package com.dc.common.core.page; + +import java.io.Serializable; +import java.util.List; + +/** + * 表格分页数据对象 + * + * @author win + */ +public class TableDataInfo implements Serializable +{ + private static final long serialVersionUID = 1L; + + /** 总记录数 */ + private long total; + + /** 列表数据 */ + private List<?> rows; + + /** 消息状态码 */ + private int code; + + /** 消息内容 */ + private String msg; + + /** + * 表格数据对象 + */ + public TableDataInfo() + { + } + + /** + * 分页 + * + * @param list 列表数据 + * @param total 总记录数 + */ + public TableDataInfo(List<?> list, int total) + { + this.rows = list; + this.total = total; + } + + public long getTotal() + { + return total; + } + + public void setTotal(long total) + { + this.total = total; + } + + public List<?> getRows() + { + return rows; + } + + public void setRows(List<?> rows) + { + this.rows = rows; + } + + public int getCode() + { + return code; + } + + public void setCode(int code) + { + this.code = code; + } + + public String getMsg() + { + return msg; + } + + public void setMsg(String msg) + { + this.msg = msg; + } +} diff --git a/dc-common/src/main/java/com/dc/common/core/page/TableSupport.java b/dc-common/src/main/java/com/dc/common/core/page/TableSupport.java new file mode 100644 index 0000000..2b129e8 --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/core/page/TableSupport.java @@ -0,0 +1,56 @@ +package com.dc.common.core.page; + +import com.dc.common.core.text.Convert; +import com.dc.common.utils.ServletUtils; + +/** + * 表格数据处理 + * + * @author win + */ +public class TableSupport +{ + /** + * 当前记录起始索引 + */ + public static final String PAGE_NUM = "pageNum"; + + /** + * 每页显示记录数 + */ + public static final String PAGE_SIZE = "pageSize"; + + /** + * 排序列 + */ + public static final String ORDER_BY_COLUMN = "orderByColumn"; + + /** + * 排序的方向 "desc" 或者 "asc". + */ + public static final String IS_ASC = "isAsc"; + + /** + * 分页参数合理化 + */ + public static final String REASONABLE = "reasonable"; + + /** + * 封装分页对象 + */ + public static PageDomain getPageDomain() + { + PageDomain pageDomain = new PageDomain(); + pageDomain.setPageNum(Convert.toInt(ServletUtils.getParameter(PAGE_NUM), 1)); + pageDomain.setPageSize(Convert.toInt(ServletUtils.getParameter(PAGE_SIZE), 10)); + pageDomain.setOrderByColumn(ServletUtils.getParameter(ORDER_BY_COLUMN)); + pageDomain.setIsAsc(ServletUtils.getParameter(IS_ASC)); + pageDomain.setReasonable(ServletUtils.getParameterToBool(REASONABLE)); + return pageDomain; + } + + public static PageDomain buildPageRequest() + { + return getPageDomain(); + } +} diff --git a/dc-common/src/main/java/com/dc/common/core/redis/RedisCache.java b/dc-common/src/main/java/com/dc/common/core/redis/RedisCache.java new file mode 100644 index 0000000..37c1c16 --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/core/redis/RedisCache.java @@ -0,0 +1,282 @@ +package com.dc.common.core.redis; + +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.data.redis.core.BoundSetOperations; +import org.springframework.data.redis.core.HashOperations; +import org.springframework.data.redis.core.RedisTemplate; +import org.springframework.data.redis.core.ValueOperations; +import org.springframework.data.redis.support.atomic.RedisAtomicLong; +import org.springframework.stereotype.Component; + +import java.util.*; +import java.util.concurrent.TimeUnit; + +/** + * spring redis 工具类 + * + * @author win + **/ +@SuppressWarnings(value = { "unchecked", "rawtypes" }) +@Component +public class RedisCache +{ + @Autowired + public RedisTemplate redisTemplate; + + /** + * 缓存基本的对象,Integer、String、实体类等 + * + * @param key 缓存的键值 + * @param value 缓存的值 + */ + public <T> void setCacheObject(final String key, final T value) + { + redisTemplate.opsForValue().set(key, value); + } + + /** + * 缓存基本的对象,Integer、String、实体类等 + * + * @param key 缓存的键值 + * @param value 缓存的值 + * @param timeout 时间 + * @param timeUnit 时间颗粒度 + */ + public <T> void setCacheObject(final String key, final T value, final Integer timeout, final TimeUnit timeUnit) + { + redisTemplate.opsForValue().set(key, value, timeout, timeUnit); + } + + /** + * 设置有效时间 + * + * @param key Redis键 + * @param timeout 超时时间 + * @return true=设置成功;false=设置失败 + */ + public boolean expire(final String key, final long timeout) + { + return expire(key, timeout, TimeUnit.SECONDS); + } + + /** + * 设置有效时间 + * + * @param key Redis键 + * @param timeout 超时时间 + * @param unit 时间单位 + * @return true=设置成功;false=设置失败 + */ + public boolean expire(final String key, final long timeout, final TimeUnit unit) + { + return redisTemplate.expire(key, timeout, unit); + } + + /** + * 获取有效时间 + * + * @param key Redis键 + * @return 有效时间 + */ + public long getExpire(final String key) + { + return redisTemplate.getExpire(key); + } + + /** + * 判断 key是否存在 + * + * @param key 键 + * @return true 存在 false不存在 + */ + public Boolean hasKey(String key) + { + return redisTemplate.hasKey(key); + } + + /** + * 获得缓存的基本对象。 + * + * @param key 缓存键值 + * @return 缓存键值对应的数据 + */ + public <T> T getCacheObject(final String key) + { + ValueOperations<String, T> operation = redisTemplate.opsForValue(); + return operation.get(key); + } + + /** + * 删除单个对象 + * + * @param key + */ + public boolean deleteObject(final String key) + { + return redisTemplate.delete(key); + } + + /** + * 删除集合对象 + * + * @param collection 多个对象 + * @return + */ + public boolean deleteObject(final Collection collection) + { + return redisTemplate.delete(collection) > 0; + } + + /** + * 缓存List数据 + * + * @param key 缓存的键值 + * @param dataList 待缓存的List数据 + * @return 缓存的对象 + */ + public <T> long setCacheList(final String key, final List<T> dataList) + { + Long count = redisTemplate.opsForList().rightPushAll(key, dataList); + return count == null ? 0 : count; + } + + /** + * 获得缓存的list对象 + * + * @param key 缓存的键值 + * @return 缓存键值对应的数据 + */ + public <T> List<T> getCacheList(final String key) + { + return redisTemplate.opsForList().range(key, 0, -1); + } + + /** + * 缓存Set + * + * @param key 缓存键值 + * @param dataSet 缓存的数据 + * @return 缓存数据的对象 + */ + public <T> BoundSetOperations<String, T> setCacheSet(final String key, final Set<T> dataSet) + { + BoundSetOperations<String, T> setOperation = redisTemplate.boundSetOps(key); + Iterator<T> it = dataSet.iterator(); + while (it.hasNext()) + { + setOperation.add(it.next()); + } + return setOperation; + } + + /** + * 获得缓存的set + * + * @param key + * @return + */ + public <T> Set<T> getCacheSet(final String key) + { + return redisTemplate.opsForSet().members(key); + } + + /** + * 缓存Map + * + * @param key + * @param dataMap + */ + public <T> void setCacheMap(final String key, final Map<String, T> dataMap) + { + if (dataMap != null) { + redisTemplate.opsForHash().putAll(key, dataMap); + } + } + + /** + * 获得缓存的Map + * + * @param key + * @return + */ + public <T> Map<String, T> getCacheMap(final String key) + { + return redisTemplate.opsForHash().entries(key); + } + + /** + * 往Hash中存入数据 + * + * @param key Redis键 + * @param hKey Hash键 + * @param value 值 + */ + public <T> void setCacheMapValue(final String key, final String hKey, final T value) + { + redisTemplate.opsForHash().put(key, hKey, value); + } + + /** + * 获取Hash中的数据 + * + * @param key Redis键 + * @param hKey Hash键 + * @return Hash中的对象 + */ + public <T> T getCacheMapValue(final String key, final String hKey) + { + HashOperations<String, String, T> opsForHash = redisTemplate.opsForHash(); + return opsForHash.get(key, hKey); + } + + /** + * 获取多个Hash中的数据 + * + * @param key Redis键 + * @param hKeys Hash键集合 + * @return Hash对象集合 + */ + public <T> List<T> getMultiCacheMapValue(final String key, final Collection<Object> hKeys) + { + return redisTemplate.opsForHash().multiGet(key, hKeys); + } + + /** + * 删除Hash中的某条数据 + * + * @param key Redis键 + * @param hKey Hash键 + * @return 是否成功 + */ + public boolean deleteCacheMapValue(final String key, final String hKey) + { + return redisTemplate.opsForHash().delete(key, hKey) > 0; + } + + /** + * 获得缓存的基本对象列表 + * + * @param pattern 字符串前缀 + * @return 对象列表 + */ + public Collection<String> keys(final String pattern) + { + return redisTemplate.keys(pattern); + } + + /** + * 获取自增数 + * @param key + * @param liveTime 过期分钟 + * @return + */ + public Long incr(String key, long liveTime) { + ValueOperations<String, Object> ops = redisTemplate.opsForValue(); + Long increment = ops.increment(key, 1); + if ((null == increment || increment.longValue() == 0) && liveTime > 0) { + expire(key, liveTime); + } + return increment; + } + +} diff --git a/dc-common/src/main/java/com/dc/common/core/text/CharsetKit.java b/dc-common/src/main/java/com/dc/common/core/text/CharsetKit.java new file mode 100644 index 0000000..7ce6861 --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/core/text/CharsetKit.java @@ -0,0 +1,87 @@ +package com.dc.common.core.text; + +import com.dc.common.utils.StringUtils; + +import java.nio.charset.Charset; +import java.nio.charset.StandardCharsets; + +/** + * 字符集工具类 + * + * @author win + */ +public class CharsetKit +{ + /** ISO-8859-1 */ + public static final String ISO_8859_1 = "ISO-8859-1"; + /** UTF-8 */ + public static final String UTF_8 = "UTF-8"; + /** GBK */ + public static final String GBK = "GBK"; + + /** ISO-8859-1 */ + public static final Charset CHARSET_ISO_8859_1 = Charset.forName(ISO_8859_1); + /** UTF-8 */ + public static final Charset CHARSET_UTF_8 = Charset.forName(UTF_8); + /** GBK */ + public static final Charset CHARSET_GBK = Charset.forName(GBK); + + /** + * 转换为Charset对象 + * + * @param charset 字符集,为空则返回默认字符集 + * @return Charset + */ + public static Charset charset(String charset) + { + return StringUtils.isEmpty(charset) ? Charset.defaultCharset() : Charset.forName(charset); + } + + /** + * 转换字符串的字符集编码 + * + * @param source 字符串 + * @param srcCharset 源字符集,默认ISO-8859-1 + * @param destCharset 目标字符集,默认UTF-8 + * @return 转换后的字符集 + */ + public static String convert(String source, String srcCharset, String destCharset) + { + return convert(source, Charset.forName(srcCharset), Charset.forName(destCharset)); + } + + /** + * 转换字符串的字符集编码 + * + * @param source 字符串 + * @param srcCharset 源字符集,默认ISO-8859-1 + * @param destCharset 目标字符集,默认UTF-8 + * @return 转换后的字符集 + */ + public static String convert(String source, Charset srcCharset, Charset destCharset) + { + if (null == srcCharset) + { + srcCharset = StandardCharsets.ISO_8859_1; + } + + if (null == destCharset) + { + destCharset = StandardCharsets.UTF_8; + } + + if (StringUtils.isEmpty(source) || srcCharset.equals(destCharset)) + { + return source; + } + return new String(source.getBytes(srcCharset), destCharset); + } + + /** + * @return 系统字符集编码 + */ + public static String systemCharset() + { + return Charset.defaultCharset().name(); + } +} diff --git a/dc-common/src/main/java/com/dc/common/core/text/Convert.java b/dc-common/src/main/java/com/dc/common/core/text/Convert.java new file mode 100644 index 0000000..a78990c --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/core/text/Convert.java @@ -0,0 +1,1001 @@ +package com.dc.common.core.text; + +import com.dc.common.utils.StringUtils; +import org.apache.commons.lang3.ArrayUtils; + +import java.math.BigDecimal; +import java.math.BigInteger; +import java.nio.ByteBuffer; +import java.nio.charset.Charset; +import java.text.NumberFormat; +import java.util.Set; + +/** + * 类型转换器 + * + * @author win + */ +public class Convert +{ + /** + * 转换为字符串<br> + * 如果给定的值为null,或者转换失败,返回默认值<br> + * 转换失败不会报错 + * + * @param value 被转换的值 + * @param defaultValue 转换错误时的默认值 + * @return 结果 + */ + public static String toStr(Object value, String defaultValue) + { + if (null == value) + { + return defaultValue; + } + if (value instanceof String) + { + return (String) value; + } + return value.toString(); + } + + /** + * 转换为字符串<br> + * 如果给定的值为<code>null</code>,或者转换失败,返回默认值<code>null</code><br> + * 转换失败不会报错 + * + * @param value 被转换的值 + * @return 结果 + */ + public static String toStr(Object value) + { + return toStr(value, null); + } + + /** + * 转换为字符<br> + * 如果给定的值为null,或者转换失败,返回默认值<br> + * 转换失败不会报错 + * + * @param value 被转换的值 + * @param defaultValue 转换错误时的默认值 + * @return 结果 + */ + public static Character toChar(Object value, Character defaultValue) + { + if (null == value) + { + return defaultValue; + } + if (value instanceof Character) + { + return (Character) value; + } + + final String valueStr = toStr(value, null); + return StringUtils.isEmpty(valueStr) ? defaultValue : valueStr.charAt(0); + } + + /** + * 转换为字符<br> + * 如果给定的值为<code>null</code>,或者转换失败,返回默认值<code>null</code><br> + * 转换失败不会报错 + * + * @param value 被转换的值 + * @return 结果 + */ + public static Character toChar(Object value) + { + return toChar(value, null); + } + + /** + * 转换为byte<br> + * 如果给定的值为<code>null</code>,或者转换失败,返回默认值<br> + * 转换失败不会报错 + * + * @param value 被转换的值 + * @param defaultValue 转换错误时的默认值 + * @return 结果 + */ + public static Byte toByte(Object value, Byte defaultValue) + { + if (value == null) + { + return defaultValue; + } + if (value instanceof Byte) + { + return (Byte) value; + } + if (value instanceof Number) + { + return ((Number) value).byteValue(); + } + final String valueStr = toStr(value, null); + if (StringUtils.isEmpty(valueStr)) + { + return defaultValue; + } + try + { + return Byte.parseByte(valueStr); + } + catch (Exception e) + { + return defaultValue; + } + } + + /** + * 转换为byte<br> + * 如果给定的值为<code>null</code>,或者转换失败,返回默认值<code>null</code><br> + * 转换失败不会报错 + * + * @param value 被转换的值 + * @return 结果 + */ + public static Byte toByte(Object value) + { + return toByte(value, null); + } + + /** + * 转换为Short<br> + * 如果给定的值为<code>null</code>,或者转换失败,返回默认值<br> + * 转换失败不会报错 + * + * @param value 被转换的值 + * @param defaultValue 转换错误时的默认值 + * @return 结果 + */ + public static Short toShort(Object value, Short defaultValue) + { + if (value == null) + { + return defaultValue; + } + if (value instanceof Short) + { + return (Short) value; + } + if (value instanceof Number) + { + return ((Number) value).shortValue(); + } + final String valueStr = toStr(value, null); + if (StringUtils.isEmpty(valueStr)) + { + return defaultValue; + } + try + { + return Short.parseShort(valueStr.trim()); + } + catch (Exception e) + { + return defaultValue; + } + } + + /** + * 转换为Short<br> + * 如果给定的值为<code>null</code>,或者转换失败,返回默认值<code>null</code><br> + * 转换失败不会报错 + * + * @param value 被转换的值 + * @return 结果 + */ + public static Short toShort(Object value) + { + return toShort(value, null); + } + + /** + * 转换为Number<br> + * 如果给定的值为空,或者转换失败,返回默认值<br> + * 转换失败不会报错 + * + * @param value 被转换的值 + * @param defaultValue 转换错误时的默认值 + * @return 结果 + */ + public static Number toNumber(Object value, Number defaultValue) + { + if (value == null) + { + return defaultValue; + } + if (value instanceof Number) + { + return (Number) value; + } + final String valueStr = toStr(value, null); + if (StringUtils.isEmpty(valueStr)) + { + return defaultValue; + } + try + { + return NumberFormat.getInstance().parse(valueStr); + } + catch (Exception e) + { + return defaultValue; + } + } + + /** + * 转换为Number<br> + * 如果给定的值为空,或者转换失败,返回默认值<code>null</code><br> + * 转换失败不会报错 + * + * @param value 被转换的值 + * @return 结果 + */ + public static Number toNumber(Object value) + { + return toNumber(value, null); + } + + /** + * 转换为int<br> + * 如果给定的值为空,或者转换失败,返回默认值<br> + * 转换失败不会报错 + * + * @param value 被转换的值 + * @param defaultValue 转换错误时的默认值 + * @return 结果 + */ + public static Integer toInt(Object value, Integer defaultValue) + { + if (value == null) + { + return defaultValue; + } + if (value instanceof Integer) + { + return (Integer) value; + } + if (value instanceof Number) + { + return ((Number) value).intValue(); + } + final String valueStr = toStr(value, null); + if (StringUtils.isEmpty(valueStr)) + { + return defaultValue; + } + try + { + return Integer.parseInt(valueStr.trim()); + } + catch (Exception e) + { + return defaultValue; + } + } + + /** + * 转换为int<br> + * 如果给定的值为<code>null</code>,或者转换失败,返回默认值<code>null</code><br> + * 转换失败不会报错 + * + * @param value 被转换的值 + * @return 结果 + */ + public static Integer toInt(Object value) + { + return toInt(value, null); + } + + /** + * 转换为Integer数组<br> + * + * @param str 被转换的值 + * @return 结果 + */ + public static Integer[] toIntArray(String str) + { + return toIntArray(",", str); + } + + /** + * 转换为Long数组<br> + * + * @param str 被转换的值 + * @return 结果 + */ + public static Long[] toLongArray(String str) + { + return toLongArray(",", str); + } + + /** + * 转换为Integer数组<br> + * + * @param split 分隔符 + * @param split 被转换的值 + * @return 结果 + */ + public static Integer[] toIntArray(String split, String str) + { + if (StringUtils.isEmpty(str)) + { + return new Integer[] {}; + } + String[] arr = str.split(split); + final Integer[] ints = new Integer[arr.length]; + for (int i = 0; i < arr.length; i++) + { + final Integer v = toInt(arr[i], 0); + ints[i] = v; + } + return ints; + } + + /** + * 转换为Long数组<br> + * + * @param split 分隔符 + * @param str 被转换的值 + * @return 结果 + */ + public static Long[] toLongArray(String split, String str) + { + if (StringUtils.isEmpty(str)) + { + return new Long[] {}; + } + String[] arr = str.split(split); + final Long[] longs = new Long[arr.length]; + for (int i = 0; i < arr.length; i++) + { + final Long v = toLong(arr[i], null); + longs[i] = v; + } + return longs; + } + + /** + * 转换为String数组<br> + * + * @param str 被转换的值 + * @return 结果 + */ + public static String[] toStrArray(String str) + { + return toStrArray(",", str); + } + + /** + * 转换为String数组<br> + * + * @param split 分隔符 + * @param split 被转换的值 + * @return 结果 + */ + public static String[] toStrArray(String split, String str) + { + return str.split(split); + } + + /** + * 转换为long<br> + * 如果给定的值为空,或者转换失败,返回默认值<br> + * 转换失败不会报错 + * + * @param value 被转换的值 + * @param defaultValue 转换错误时的默认值 + * @return 结果 + */ + public static Long toLong(Object value, Long defaultValue) + { + if (value == null) + { + return defaultValue; + } + if (value instanceof Long) + { + return (Long) value; + } + if (value instanceof Number) + { + return ((Number) value).longValue(); + } + final String valueStr = toStr(value, null); + if (StringUtils.isEmpty(valueStr)) + { + return defaultValue; + } + try + { + // 支持科学计数法 + return new BigDecimal(valueStr.trim()).longValue(); + } + catch (Exception e) + { + return defaultValue; + } + } + + /** + * 转换为long<br> + * 如果给定的值为<code>null</code>,或者转换失败,返回默认值<code>null</code><br> + * 转换失败不会报错 + * + * @param value 被转换的值 + * @return 结果 + */ + public static Long toLong(Object value) + { + return toLong(value, null); + } + + /** + * 转换为double<br> + * 如果给定的值为空,或者转换失败,返回默认值<br> + * 转换失败不会报错 + * + * @param value 被转换的值 + * @param defaultValue 转换错误时的默认值 + * @return 结果 + */ + public static Double toDouble(Object value, Double defaultValue) + { + if (value == null) + { + return defaultValue; + } + if (value instanceof Double) + { + return (Double) value; + } + if (value instanceof Number) + { + return ((Number) value).doubleValue(); + } + final String valueStr = toStr(value, null); + if (StringUtils.isEmpty(valueStr)) + { + return defaultValue; + } + try + { + // 支持科学计数法 + return new BigDecimal(valueStr.trim()).doubleValue(); + } + catch (Exception e) + { + return defaultValue; + } + } + + /** + * 转换为double<br> + * 如果给定的值为空,或者转换失败,返回默认值<code>null</code><br> + * 转换失败不会报错 + * + * @param value 被转换的值 + * @return 结果 + */ + public static Double toDouble(Object value) + { + return toDouble(value, null); + } + + /** + * 转换为Float<br> + * 如果给定的值为空,或者转换失败,返回默认值<br> + * 转换失败不会报错 + * + * @param value 被转换的值 + * @param defaultValue 转换错误时的默认值 + * @return 结果 + */ + public static Float toFloat(Object value, Float defaultValue) + { + if (value == null) + { + return defaultValue; + } + if (value instanceof Float) + { + return (Float) value; + } + if (value instanceof Number) + { + return ((Number) value).floatValue(); + } + final String valueStr = toStr(value, null); + if (StringUtils.isEmpty(valueStr)) + { + return defaultValue; + } + try + { + return Float.parseFloat(valueStr.trim()); + } + catch (Exception e) + { + return defaultValue; + } + } + + /** + * 转换为Float<br> + * 如果给定的值为空,或者转换失败,返回默认值<code>null</code><br> + * 转换失败不会报错 + * + * @param value 被转换的值 + * @return 结果 + */ + public static Float toFloat(Object value) + { + return toFloat(value, null); + } + + /** + * 转换为boolean<br> + * String支持的值为:true、false、yes、ok、no,1,0 如果给定的值为空,或者转换失败,返回默认值<br> + * 转换失败不会报错 + * + * @param value 被转换的值 + * @param defaultValue 转换错误时的默认值 + * @return 结果 + */ + public static Boolean toBool(Object value, Boolean defaultValue) + { + if (value == null) + { + return defaultValue; + } + if (value instanceof Boolean) + { + return (Boolean) value; + } + String valueStr = toStr(value, null); + if (StringUtils.isEmpty(valueStr)) + { + return defaultValue; + } + valueStr = valueStr.trim().toLowerCase(); + switch (valueStr) + { + case "true": + case "yes": + case "ok": + case "1": + return true; + case "false": + case "no": + case "0": + return false; + default: + return defaultValue; + } + } + + /** + * 转换为boolean<br> + * 如果给定的值为空,或者转换失败,返回默认值<code>null</code><br> + * 转换失败不会报错 + * + * @param value 被转换的值 + * @return 结果 + */ + public static Boolean toBool(Object value) + { + return toBool(value, null); + } + + /** + * 转换为Enum对象<br> + * 如果给定的值为空,或者转换失败,返回默认值<br> + * + * @param clazz Enum的Class + * @param value 值 + * @param defaultValue 默认值 + * @return Enum + */ + public static <E extends Enum<E>> E toEnum(Class<E> clazz, Object value, E defaultValue) + { + if (value == null) + { + return defaultValue; + } + if (clazz.isAssignableFrom(value.getClass())) + { + @SuppressWarnings("unchecked") + E myE = (E) value; + return myE; + } + final String valueStr = toStr(value, null); + if (StringUtils.isEmpty(valueStr)) + { + return defaultValue; + } + try + { + return Enum.valueOf(clazz, valueStr); + } + catch (Exception e) + { + return defaultValue; + } + } + + /** + * 转换为Enum对象<br> + * 如果给定的值为空,或者转换失败,返回默认值<code>null</code><br> + * + * @param clazz Enum的Class + * @param value 值 + * @return Enum + */ + public static <E extends Enum<E>> E toEnum(Class<E> clazz, Object value) + { + return toEnum(clazz, value, null); + } + + /** + * 转换为BigInteger<br> + * 如果给定的值为空,或者转换失败,返回默认值<br> + * 转换失败不会报错 + * + * @param value 被转换的值 + * @param defaultValue 转换错误时的默认值 + * @return 结果 + */ + public static BigInteger toBigInteger(Object value, BigInteger defaultValue) + { + if (value == null) + { + return defaultValue; + } + if (value instanceof BigInteger) + { + return (BigInteger) value; + } + if (value instanceof Long) + { + return BigInteger.valueOf((Long) value); + } + final String valueStr = toStr(value, null); + if (StringUtils.isEmpty(valueStr)) + { + return defaultValue; + } + try + { + return new BigInteger(valueStr); + } + catch (Exception e) + { + return defaultValue; + } + } + + /** + * 转换为BigInteger<br> + * 如果给定的值为空,或者转换失败,返回默认值<code>null</code><br> + * 转换失败不会报错 + * + * @param value 被转换的值 + * @return 结果 + */ + public static BigInteger toBigInteger(Object value) + { + return toBigInteger(value, null); + } + + /** + * 转换为BigDecimal<br> + * 如果给定的值为空,或者转换失败,返回默认值<br> + * 转换失败不会报错 + * + * @param value 被转换的值 + * @param defaultValue 转换错误时的默认值 + * @return 结果 + */ + public static BigDecimal toBigDecimal(Object value, BigDecimal defaultValue) + { + if (value == null) + { + return defaultValue; + } + if (value instanceof BigDecimal) + { + return (BigDecimal) value; + } + if (value instanceof Long) + { + return new BigDecimal((Long) value); + } + if (value instanceof Double) + { + return BigDecimal.valueOf((Double) value); + } + if (value instanceof Integer) + { + return new BigDecimal((Integer) value); + } + final String valueStr = toStr(value, null); + if (StringUtils.isEmpty(valueStr)) + { + return defaultValue; + } + try + { + return new BigDecimal(valueStr); + } + catch (Exception e) + { + return defaultValue; + } + } + + /** + * 转换为BigDecimal<br> + * 如果给定的值为空,或者转换失败,返回默认值<br> + * 转换失败不会报错 + * + * @param value 被转换的值 + * @return 结果 + */ + public static BigDecimal toBigDecimal(Object value) + { + return toBigDecimal(value, null); + } + + /** + * 将对象转为字符串<br> + * 1、Byte数组和ByteBuffer会被转换为对应字符串的数组 2、对象数组会调用Arrays.toString方法 + * + * @param obj 对象 + * @return 字符串 + */ + public static String utf8Str(Object obj) + { + return str(obj, CharsetKit.CHARSET_UTF_8); + } + + /** + * 将对象转为字符串<br> + * 1、Byte数组和ByteBuffer会被转换为对应字符串的数组 2、对象数组会调用Arrays.toString方法 + * + * @param obj 对象 + * @param charsetName 字符集 + * @return 字符串 + */ + public static String str(Object obj, String charsetName) + { + return str(obj, Charset.forName(charsetName)); + } + + /** + * 将对象转为字符串<br> + * 1、Byte数组和ByteBuffer会被转换为对应字符串的数组 2、对象数组会调用Arrays.toString方法 + * + * @param obj 对象 + * @param charset 字符集 + * @return 字符串 + */ + public static String str(Object obj, Charset charset) + { + if (null == obj) + { + return null; + } + + if (obj instanceof String) + { + return (String) obj; + } + else if (obj instanceof byte[]) + { + return str((byte[]) obj, charset); + } + else if (obj instanceof Byte[]) + { + byte[] bytes = ArrayUtils.toPrimitive((Byte[]) obj); + return str(bytes, charset); + } + else if (obj instanceof ByteBuffer) + { + return str((ByteBuffer) obj, charset); + } + return obj.toString(); + } + + /** + * 将byte数组转为字符串 + * + * @param bytes byte数组 + * @param charset 字符集 + * @return 字符串 + */ + public static String str(byte[] bytes, String charset) + { + return str(bytes, StringUtils.isEmpty(charset) ? Charset.defaultCharset() : Charset.forName(charset)); + } + + /** + * 解码字节码 + * + * @param data 字符串 + * @param charset 字符集,如果此字段为空,则解码的结果取决于平台 + * @return 解码后的字符串 + */ + public static String str(byte[] data, Charset charset) + { + if (data == null) + { + return null; + } + + if (null == charset) + { + return new String(data); + } + return new String(data, charset); + } + + /** + * 将编码的byteBuffer数据转换为字符串 + * + * @param data 数据 + * @param charset 字符集,如果为空使用当前系统字符集 + * @return 字符串 + */ + public static String str(ByteBuffer data, String charset) + { + if (data == null) + { + return null; + } + + return str(data, Charset.forName(charset)); + } + + /** + * 将编码的byteBuffer数据转换为字符串 + * + * @param data 数据 + * @param charset 字符集,如果为空使用当前系统字符集 + * @return 字符串 + */ + public static String str(ByteBuffer data, Charset charset) + { + if (null == charset) + { + charset = Charset.defaultCharset(); + } + return charset.decode(data).toString(); + } + + // ----------------------------------------------------------------------- 全角半角转换 + /** + * 半角转全角 + * + * @param input String. + * @return 全角字符串. + */ + public static String toSBC(String input) + { + return toSBC(input, null); + } + + /** + * 半角转全角 + * + * @param input String + * @param notConvertSet 不替换的字符集合 + * @return 全角字符串. + */ + public static String toSBC(String input, Set<Character> notConvertSet) + { + char[] c = input.toCharArray(); + for (int i = 0; i < c.length; i++) + { + if (null != notConvertSet && notConvertSet.contains(c[i])) + { + // 跳过不替换的字符 + continue; + } + + if (c[i] == ' ') + { + c[i] = '\u3000'; + } + else if (c[i] < '\177') + { + c[i] = (char) (c[i] + 65248); + + } + } + return new String(c); + } + + /** + * 全角转半角 + * + * @param input String. + * @return 半角字符串 + */ + public static String toDBC(String input) + { + return toDBC(input, null); + } + + /** + * 替换全角为半角 + * + * @param text 文本 + * @param notConvertSet 不替换的字符集合 + * @return 替换后的字符 + */ + public static String toDBC(String text, Set<Character> notConvertSet) + { + char[] c = text.toCharArray(); + for (int i = 0; i < c.length; i++) + { + if (null != notConvertSet && notConvertSet.contains(c[i])) + { + // 跳过不替换的字符 + continue; + } + + if (c[i] == '\u3000') + { + c[i] = ' '; + } + else if (c[i] > '\uFF00' && c[i] < '\uFF5F') + { + c[i] = (char) (c[i] - 65248); + } + } + String returnString = new String(c); + + return returnString; + } + + /** + * 数字金额大写转换 先写个完整的然后将如零拾替换成零 + * + * @param n 数字 + * @return 中文大写数字 + */ + public static String digitUppercase(double n) + { + String[] fraction = { "角", "分" }; + String[] digit = { "零", "壹", "贰", "叁", "肆", "伍", "陆", "柒", "捌", "玖" }; + String[][] unit = { { "元", "万", "亿" }, { "", "拾", "佰", "仟" } }; + + String head = n < 0 ? "负" : ""; + n = Math.abs(n); + + String s = ""; + for (int i = 0; i < fraction.length; i++) + { + s += (digit[(int) (Math.floor(n * 10 * Math.pow(10, i)) % 10)] + fraction[i]).replaceAll("(零.)+", ""); + } + if (s.length() < 1) + { + s = "整"; + } + int integerPart = (int) Math.floor(n); + + for (int i = 0; i < unit[0].length && integerPart > 0; i++) + { + String p = ""; + for (int j = 0; j < unit[1].length && n > 0; j++) + { + p = digit[integerPart % 10] + unit[1][j] + p; + integerPart = integerPart / 10; + } + s = p.replaceAll("(零.)*零$", "").replaceAll("^$", "零") + unit[0][i] + s; + } + return head + s.replaceAll("(零.)*零元", "元").replaceFirst("(零.)+", "").replaceAll("(零.)+", "零").replaceAll("^整$", "零元整"); + } +} diff --git a/dc-common/src/main/java/com/dc/common/core/text/StrFormatter.java b/dc-common/src/main/java/com/dc/common/core/text/StrFormatter.java new file mode 100644 index 0000000..db74497 --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/core/text/StrFormatter.java @@ -0,0 +1,92 @@ +package com.dc.common.core.text; + +import com.dc.common.utils.StringUtils; + +/** + * 字符串格式化 + * + * @author win + */ +public class StrFormatter +{ + public static final String EMPTY_JSON = "{}"; + public static final char C_BACKSLASH = '\\'; + public static final char C_DELIM_START = '{'; + public static final char C_DELIM_END = '}'; + + /** + * 格式化字符串<br> + * 此方法只是简单将占位符 {} 按照顺序替换为参数<br> + * 如果想输出 {} 使用 \\转义 { 即可,如果想输出 {} 之前的 \ 使用双转义符 \\\\ 即可<br> + * 例:<br> + * 通常使用:format("this is {} for {}", "a", "b") -> this is a for b<br> + * 转义{}: format("this is \\{} for {}", "a", "b") -> this is \{} for a<br> + * 转义\: format("this is \\\\{} for {}", "a", "b") -> this is \a for b<br> + * + * @param strPattern 字符串模板 + * @param argArray 参数列表 + * @return 结果 + */ + public static String format(final String strPattern, final Object... argArray) + { + if (StringUtils.isEmpty(strPattern) || StringUtils.isEmpty(argArray)) + { + return strPattern; + } + final int strPatternLength = strPattern.length(); + + // 初始化定义好的长度以获得更好的性能 + StringBuilder sbuf = new StringBuilder(strPatternLength + 50); + + int handledPosition = 0; + int delimIndex;// 占位符所在位置 + for (int argIndex = 0; argIndex < argArray.length; argIndex++) + { + delimIndex = strPattern.indexOf(EMPTY_JSON, handledPosition); + if (delimIndex == -1) + { + if (handledPosition == 0) + { + return strPattern; + } + else + { // 字符串模板剩余部分不再包含占位符,加入剩余部分后返回结果 + sbuf.append(strPattern, handledPosition, strPatternLength); + return sbuf.toString(); + } + } + else + { + if (delimIndex > 0 && strPattern.charAt(delimIndex - 1) == C_BACKSLASH) + { + if (delimIndex > 1 && strPattern.charAt(delimIndex - 2) == C_BACKSLASH) + { + // 转义符之前还有一个转义符,占位符依旧有效 + sbuf.append(strPattern, handledPosition, delimIndex - 1); + sbuf.append(Convert.utf8Str(argArray[argIndex])); + handledPosition = delimIndex + 2; + } + else + { + // 占位符被转义 + argIndex--; + sbuf.append(strPattern, handledPosition, delimIndex - 1); + sbuf.append(C_DELIM_START); + handledPosition = delimIndex + 1; + } + } + else + { + // 正常占位符 + sbuf.append(strPattern, handledPosition, delimIndex); + sbuf.append(Convert.utf8Str(argArray[argIndex])); + handledPosition = delimIndex + 2; + } + } + } + // 加入最后一个占位符后所有的字符 + sbuf.append(strPattern, handledPosition, strPattern.length()); + + return sbuf.toString(); + } +} diff --git a/dc-common/src/main/java/com/dc/common/enums/AccessoryType.java b/dc-common/src/main/java/com/dc/common/enums/AccessoryType.java new file mode 100644 index 0000000..82f21d3 --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/enums/AccessoryType.java @@ -0,0 +1,40 @@ +package com.dc.common.enums; + +/** + * 附件类型 + * + * @author win + * + */ +public enum AccessoryType { + + PICK(1, "司机提货"), + DELIVERY(2, "司机交货"), + EVENT_LOG(3, "在途事件"), + AGREEMENT(4, "合同附件"), + DRIVER_AVATAR(5, "司机头像"), + FEEDBACK(6, "问题反馈"), + BASE_INFO(7, "基本信息"), + ID_CARD1(8, "身份证正面"), + ID_CARD2(9, "身份证反面"), + LICENSE(10, "驾驶证"), + VEHICLE(11, "车辆行驶证"), + SERVICE(12, "车辆营运证"); + + private final int code; + private final String info; + + AccessoryType(int code, String info) { + this.code = code; + this.info = info; + } + + public int getCode() { + return code; + } + + public String getInfo() { + return info; + } + +} diff --git a/dc-common/src/main/java/com/dc/common/enums/BusinessStatus.java b/dc-common/src/main/java/com/dc/common/enums/BusinessStatus.java new file mode 100644 index 0000000..71087dd --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/enums/BusinessStatus.java @@ -0,0 +1,20 @@ +package com.dc.common.enums; + +/** + * 操作状态 + * + * @author win + * + */ +public enum BusinessStatus +{ + /** + * 成功 + */ + SUCCESS, + + /** + * 失败 + */ + FAIL, +} diff --git a/dc-common/src/main/java/com/dc/common/enums/BusinessType.java b/dc-common/src/main/java/com/dc/common/enums/BusinessType.java new file mode 100644 index 0000000..b3588ba --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/enums/BusinessType.java @@ -0,0 +1,59 @@ +package com.dc.common.enums; + +/** + * 业务操作类型 + * + * @author win + */ +public enum BusinessType +{ + /** + * 其它 + */ + OTHER, + + /** + * 新增 + */ + INSERT, + + /** + * 修改 + */ + UPDATE, + + /** + * 删除 + */ + DELETE, + + /** + * 授权 + */ + GRANT, + + /** + * 导出 + */ + EXPORT, + + /** + * 导入 + */ + IMPORT, + + /** + * 强退 + */ + FORCE, + + /** + * 生成代码 + */ + GENCODE, + + /** + * 清空数据 + */ + CLEAN, +} diff --git a/dc-common/src/main/java/com/dc/common/enums/DataSourceType.java b/dc-common/src/main/java/com/dc/common/enums/DataSourceType.java new file mode 100644 index 0000000..ffdc331 --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/enums/DataSourceType.java @@ -0,0 +1,19 @@ +package com.dc.common.enums; + +/** + * 数据源 + * + * @author win + */ +public enum DataSourceType +{ + /** + * 主库 + */ + MASTER, + + /** + * 从库 + */ + SLAVE +} diff --git a/dc-common/src/main/java/com/dc/common/enums/HttpMethod.java b/dc-common/src/main/java/com/dc/common/enums/HttpMethod.java new file mode 100644 index 0000000..3c8ad08 --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/enums/HttpMethod.java @@ -0,0 +1,37 @@ +package com.dc.common.enums; + +import org.springframework.lang.Nullable; + +import java.util.HashMap; +import java.util.Map; + +/** + * 请求方式 + * + * @author win + */ +public enum HttpMethod +{ + GET, HEAD, POST, PUT, PATCH, DELETE, OPTIONS, TRACE; + + private static final Map<String, HttpMethod> mappings = new HashMap<>(16); + + static + { + for (HttpMethod httpMethod : values()) + { + mappings.put(httpMethod.name(), httpMethod); + } + } + + @Nullable + public static HttpMethod resolve(@Nullable String method) + { + return (method != null ? mappings.get(method) : null); + } + + public boolean matches(String method) + { + return (this == resolve(method)); + } +} diff --git a/dc-common/src/main/java/com/dc/common/enums/LimitType.java b/dc-common/src/main/java/com/dc/common/enums/LimitType.java new file mode 100644 index 0000000..1101c30 --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/enums/LimitType.java @@ -0,0 +1,20 @@ +package com.dc.common.enums; + +/** + * 限流类型 + * + * @author win + */ + +public enum LimitType +{ + /** + * 默认策略全局限流 + */ + DEFAULT, + + /** + * 根据请求者IP进行限流 + */ + IP +} diff --git a/dc-common/src/main/java/com/dc/common/enums/OperatorType.java b/dc-common/src/main/java/com/dc/common/enums/OperatorType.java new file mode 100644 index 0000000..421001c --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/enums/OperatorType.java @@ -0,0 +1,24 @@ +package com.dc.common.enums; + +/** + * 操作人类别 + * + * @author win + */ +public enum OperatorType +{ + /** + * 其它 + */ + OTHER, + + /** + * 后台用户 + */ + MANAGE, + + /** + * 手机端用户 + */ + MOBILE +} diff --git a/dc-common/src/main/java/com/dc/common/enums/UserStatus.java b/dc-common/src/main/java/com/dc/common/enums/UserStatus.java new file mode 100644 index 0000000..22607a8 --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/enums/UserStatus.java @@ -0,0 +1,30 @@ +package com.dc.common.enums; + +/** + * 用户状态 + * + * @author win + */ +public enum UserStatus +{ + OK("0", "正常"), DISABLE("1", "停用"), DELETED("2", "删除"); + + private final String code; + private final String info; + + UserStatus(String code, String info) + { + this.code = code; + this.info = info; + } + + public String getCode() + { + return code; + } + + public String getInfo() + { + return info; + } +} diff --git a/dc-common/src/main/java/com/dc/common/exception/CustomException.java b/dc-common/src/main/java/com/dc/common/exception/CustomException.java new file mode 100644 index 0000000..233b7e3 --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/exception/CustomException.java @@ -0,0 +1,37 @@ +package com.dc.common.exception; + +/** + * 自定义异常 + * + * @author ruoyi + */ +public class CustomException extends RuntimeException { + private static final long serialVersionUID = 1L; + + private Integer code; + + private String message; + + public CustomException(String message) { + this.message = message; + } + + public CustomException(String message, Integer code) { + this.message = message; + this.code = code; + } + + public CustomException(String message, Throwable e) { + super(message, e); + this.message = message; + } + + @Override + public String getMessage() { + return message; + } + + public Integer getCode() { + return code; + } +} diff --git a/dc-common/src/main/java/com/dc/common/exception/DatabaseException.java b/dc-common/src/main/java/com/dc/common/exception/DatabaseException.java new file mode 100644 index 0000000..0328e98 --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/exception/DatabaseException.java @@ -0,0 +1,74 @@ +package com.dc.common.exception; + +/** + * 数据库异常 + * + * @author win + */ +public final class DatabaseException extends RuntimeException +{ + private static final long serialVersionUID = 1L; + + /** + * 错误码 + */ + private Integer code; + + /** + * 错误提示 + */ + private String message; + + /** + * 错误明细,内部调试错误 + * + * 和 {@link CommonResult#getDetailMessage()} 一致的设计 + */ + private String detailMessage; + + /** + * 空构造方法,避免反序列化问题 + */ + public DatabaseException() + { + } + + public DatabaseException(String message) + { + this.message = message; + } + + public DatabaseException(String message, Integer code) + { + this.message = message; + this.code = code; + } + + public String getDetailMessage() + { + return detailMessage; + } + + @Override + public String getMessage() + { + return message; + } + + public Integer getCode() + { + return code; + } + + public DatabaseException setMessage(String message) + { + this.message = message; + return this; + } + + public DatabaseException setDetailMessage(String detailMessage) + { + this.detailMessage = detailMessage; + return this; + } +} \ No newline at end of file diff --git a/dc-common/src/main/java/com/dc/common/exception/DemoModeException.java b/dc-common/src/main/java/com/dc/common/exception/DemoModeException.java new file mode 100644 index 0000000..33bc75d --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/exception/DemoModeException.java @@ -0,0 +1,15 @@ +package com.dc.common.exception; + +/** + * 演示模式异常 + * + * @author win + */ +public class DemoModeException extends RuntimeException +{ + private static final long serialVersionUID = 1L; + + public DemoModeException() + { + } +} diff --git a/dc-common/src/main/java/com/dc/common/exception/GlobalException.java b/dc-common/src/main/java/com/dc/common/exception/GlobalException.java new file mode 100644 index 0000000..b3a5848 --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/exception/GlobalException.java @@ -0,0 +1,58 @@ +package com.dc.common.exception; + +/** + * 全局异常 + * + * @author win + */ +public class GlobalException extends RuntimeException +{ + private static final long serialVersionUID = 1L; + + /** + * 错误提示 + */ + private String message; + + /** + * 错误明细,内部调试错误 + * + * 和 {@link CommonResult#getDetailMessage()} 一致的设计 + */ + private String detailMessage; + + /** + * 空构造方法,避免反序列化问题 + */ + public GlobalException() + { + } + + public GlobalException(String message) + { + this.message = message; + } + + public String getDetailMessage() + { + return detailMessage; + } + + public GlobalException setDetailMessage(String detailMessage) + { + this.detailMessage = detailMessage; + return this; + } + + @Override + public String getMessage() + { + return message; + } + + public GlobalException setMessage(String message) + { + this.message = message; + return this; + } +} \ No newline at end of file diff --git a/dc-common/src/main/java/com/dc/common/exception/NotExistsException.java b/dc-common/src/main/java/com/dc/common/exception/NotExistsException.java new file mode 100644 index 0000000..42988ef --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/exception/NotExistsException.java @@ -0,0 +1,59 @@ +package com.dc.common.exception; + +/** + * 数据不存在异常 + * + * @author win + */ +public final class NotExistsException extends RuntimeException +{ + private static final long serialVersionUID = 1L; + + /** + * 错误码 + */ + private Integer code; + + /** + * 错误提示 + */ + private String message; + + /** + * 错误明细,内部调试错误 + */ + private String detailMessage; + + public NotExistsException(String message) + { + this.message = message; + } + + public NotExistsException(String message, Integer code) { + this.message = message; + this.code = code; + } + + public String getDetailMessage() { + return detailMessage; + } + + @Override + public String getMessage() { + return message; + } + + public Integer getCode() { + return code; + } + + public NotExistsException setMessage(String message) { + this.message = message; + return this; + } + + public NotExistsException setDetailMessage(String detailMessage) { + this.detailMessage = detailMessage; + return this; + } +} \ No newline at end of file diff --git a/dc-common/src/main/java/com/dc/common/exception/ServiceException.java b/dc-common/src/main/java/com/dc/common/exception/ServiceException.java new file mode 100644 index 0000000..6fdfbdd --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/exception/ServiceException.java @@ -0,0 +1,74 @@ +package com.dc.common.exception; + +/** + * 业务异常 + * + * @author win + */ +public final class ServiceException extends RuntimeException +{ + private static final long serialVersionUID = 1L; + + /** + * 错误码 + */ + private Integer code; + + /** + * 错误提示 + */ + private String message; + + /** + * 错误明细,内部调试错误 + * + * 和 {@link CommonResult#getDetailMessage()} 一致的设计 + */ + private String detailMessage; + + /** + * 空构造方法,避免反序列化问题 + */ + public ServiceException() + { + } + + public ServiceException(String message) + { + this.message = message; + } + + public ServiceException(String message, Integer code) + { + this.message = message; + this.code = code; + } + + public String getDetailMessage() + { + return detailMessage; + } + + @Override + public String getMessage() + { + return message; + } + + public Integer getCode() + { + return code; + } + + public ServiceException setMessage(String message) + { + this.message = message; + return this; + } + + public ServiceException setDetailMessage(String detailMessage) + { + this.detailMessage = detailMessage; + return this; + } +} \ No newline at end of file diff --git a/dc-common/src/main/java/com/dc/common/exception/UtilException.java b/dc-common/src/main/java/com/dc/common/exception/UtilException.java new file mode 100644 index 0000000..e3799c7 --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/exception/UtilException.java @@ -0,0 +1,26 @@ +package com.dc.common.exception; + +/** + * 工具类异常 + * + * @author win + */ +public class UtilException extends RuntimeException +{ + private static final long serialVersionUID = 8247610319171014183L; + + public UtilException(Throwable e) + { + super(e.getMessage(), e); + } + + public UtilException(String message) + { + super(message); + } + + public UtilException(String message, Throwable throwable) + { + super(message, throwable); + } +} diff --git a/dc-common/src/main/java/com/dc/common/exception/base/BaseException.java b/dc-common/src/main/java/com/dc/common/exception/base/BaseException.java new file mode 100644 index 0000000..f3f277a --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/exception/base/BaseException.java @@ -0,0 +1,97 @@ +package com.dc.common.exception.base; + +import com.dc.common.utils.MessageUtils; +import com.dc.common.utils.StringUtils; + +/** + * 基础异常 + * + * @author win + */ +public class BaseException extends RuntimeException +{ + private static final long serialVersionUID = 1L; + + /** + * 所属模块 + */ + private String module; + + /** + * 错误码 + */ + private String code; + + /** + * 错误码对应的参数 + */ + private Object[] args; + + /** + * 错误消息 + */ + private 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) + { + this(module, code, args, null); + } + + public BaseException(String module, String defaultMessage) + { + this(module, null, null, defaultMessage); + } + + public BaseException(String code, Object[] args) + { + this(null, code, args, null); + } + + public BaseException(String defaultMessage) + { + this(null, null, null, defaultMessage); + } + + @Override + public String getMessage() + { + String message = null; + if (!StringUtils.isEmpty(code)) + { + message = MessageUtils.message(code, args); + } + 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; + } +} diff --git a/dc-common/src/main/java/com/dc/common/exception/file/FileException.java b/dc-common/src/main/java/com/dc/common/exception/file/FileException.java new file mode 100644 index 0000000..5b8379c --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/exception/file/FileException.java @@ -0,0 +1,19 @@ +package com.dc.common.exception.file; + +import com.dc.common.exception.base.BaseException; + +/** + * 文件信息异常类 + * + * @author win + */ +public class FileException extends BaseException +{ + private static final long serialVersionUID = 1L; + + public FileException(String code, Object[] args) + { + super("file", code, args, null); + } + +} diff --git a/dc-common/src/main/java/com/dc/common/exception/file/FileNameLengthLimitExceededException.java b/dc-common/src/main/java/com/dc/common/exception/file/FileNameLengthLimitExceededException.java new file mode 100644 index 0000000..fb1b3ba --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/exception/file/FileNameLengthLimitExceededException.java @@ -0,0 +1,16 @@ +package com.dc.common.exception.file; + +/** + * 文件名称超长限制异常类 + * + * @author ruoyi + */ +public class FileNameLengthLimitExceededException extends FileException +{ + private static final long serialVersionUID = 1L; + + public FileNameLengthLimitExceededException(int defaultFileNameLength) + { + super("upload.filename.exceed.length", new Object[] { defaultFileNameLength }); + } +} diff --git a/dc-common/src/main/java/com/dc/common/exception/file/FileSizeLimitExceededException.java b/dc-common/src/main/java/com/dc/common/exception/file/FileSizeLimitExceededException.java new file mode 100644 index 0000000..ff95949 --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/exception/file/FileSizeLimitExceededException.java @@ -0,0 +1,16 @@ +package com.dc.common.exception.file; + +/** + * 文件名大小限制异常类 + * + * @author ruoyi + */ +public class FileSizeLimitExceededException extends FileException +{ + private static final long serialVersionUID = 1L; + + public FileSizeLimitExceededException(long defaultMaxSize) + { + super("upload.exceed.maxSize", new Object[] { defaultMaxSize }); + } +} diff --git a/dc-common/src/main/java/com/dc/common/exception/file/InvalidExtensionException.java b/dc-common/src/main/java/com/dc/common/exception/file/InvalidExtensionException.java new file mode 100644 index 0000000..8d3a435 --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/exception/file/InvalidExtensionException.java @@ -0,0 +1,81 @@ +package com.dc.common.exception.file; + +import java.util.Arrays; +import org.apache.commons.fileupload.FileUploadException; + +/** + * 文件上传 误异常类 + * + * @author ruoyi + */ +public class InvalidExtensionException extends FileUploadException +{ + private static final long serialVersionUID = 1L; + + private String[] allowedExtension; + private String extension; + private String filename; + + public InvalidExtensionException(String[] allowedExtension, String extension, String filename) + { + super("文件[" + filename + "]后缀[" + extension + "]不正确,请上传" + Arrays.toString(allowedExtension) + "格式"); + this.allowedExtension = allowedExtension; + this.extension = extension; + this.filename = filename; + } + + public String[] getAllowedExtension() + { + return allowedExtension; + } + + public String getExtension() + { + return extension; + } + + public String getFilename() + { + return filename; + } + + public static class InvalidImageExtensionException extends InvalidExtensionException + { + private static final long serialVersionUID = 1L; + + public InvalidImageExtensionException(String[] allowedExtension, String extension, String filename) + { + super(allowedExtension, extension, filename); + } + } + + public static class InvalidFlashExtensionException extends InvalidExtensionException + { + private static final long serialVersionUID = 1L; + + public InvalidFlashExtensionException(String[] allowedExtension, String extension, String filename) + { + super(allowedExtension, extension, filename); + } + } + + public static class InvalidMediaExtensionException extends InvalidExtensionException + { + private static final long serialVersionUID = 1L; + + public InvalidMediaExtensionException(String[] allowedExtension, String extension, String filename) + { + super(allowedExtension, extension, filename); + } + } + + public static class InvalidVideoExtensionException extends InvalidExtensionException + { + private static final long serialVersionUID = 1L; + + public InvalidVideoExtensionException(String[] allowedExtension, String extension, String filename) + { + super(allowedExtension, extension, filename); + } + } +} diff --git a/dc-common/src/main/java/com/dc/common/exception/job/TaskException.java b/dc-common/src/main/java/com/dc/common/exception/job/TaskException.java new file mode 100644 index 0000000..2584422 --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/exception/job/TaskException.java @@ -0,0 +1,34 @@ +package com.dc.common.exception.job; + +/** + * 计划策略异常 + * + * @author win + */ +public class TaskException extends Exception +{ + private static final long serialVersionUID = 1L; + + private Code code; + + public TaskException(String msg, Code code) + { + this(msg, code, null); + } + + public TaskException(String msg, Code code, Exception nestedEx) + { + super(msg, nestedEx); + this.code = code; + } + + public Code getCode() + { + return code; + } + + public enum Code + { + TASK_EXISTS, NO_TASK_EXISTS, TASK_ALREADY_STARTED, UNKNOWN, CONFIG_ERROR, TASK_NODE_NOT_AVAILABLE + } +} \ No newline at end of file diff --git a/dc-common/src/main/java/com/dc/common/exception/user/CaptchaException.java b/dc-common/src/main/java/com/dc/common/exception/user/CaptchaException.java new file mode 100644 index 0000000..0187a16 --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/exception/user/CaptchaException.java @@ -0,0 +1,16 @@ +package com.dc.common.exception.user; + +/** + * 验证码错误异常类 + * + * @author win + */ +public class CaptchaException extends UserException +{ + private static final long serialVersionUID = 1L; + + public CaptchaException() + { + super("user.jcaptcha.error", null); + } +} diff --git a/dc-common/src/main/java/com/dc/common/exception/user/CaptchaExpireException.java b/dc-common/src/main/java/com/dc/common/exception/user/CaptchaExpireException.java new file mode 100644 index 0000000..1d3ca8d --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/exception/user/CaptchaExpireException.java @@ -0,0 +1,16 @@ +package com.dc.common.exception.user; + +/** + * 验证码失效异常类 + * + * @author win + */ +public class CaptchaExpireException extends UserException +{ + private static final long serialVersionUID = 1L; + + public CaptchaExpireException() + { + super("user.jcaptcha.expire", null); + } +} diff --git a/dc-common/src/main/java/com/dc/common/exception/user/UserException.java b/dc-common/src/main/java/com/dc/common/exception/user/UserException.java new file mode 100644 index 0000000..89790b4 --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/exception/user/UserException.java @@ -0,0 +1,18 @@ +package com.dc.common.exception.user; + +import com.dc.common.exception.base.BaseException; + +/** + * 用户信息异常类 + * + * @author win + */ +public class UserException extends BaseException +{ + private static final long serialVersionUID = 1L; + + public UserException(String code, Object[] args) + { + super("user", code, args, null); + } +} diff --git a/dc-common/src/main/java/com/dc/common/exception/user/UserPasswordNotMatchException.java b/dc-common/src/main/java/com/dc/common/exception/user/UserPasswordNotMatchException.java new file mode 100644 index 0000000..1e6f8af --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/exception/user/UserPasswordNotMatchException.java @@ -0,0 +1,16 @@ +package com.dc.common.exception.user; + +/** + * 用户密码不正确或不符合规范异常类 + * + * @author ruoyi + */ +public class UserPasswordNotMatchException extends UserException +{ + private static final long serialVersionUID = 1L; + + public UserPasswordNotMatchException() + { + super("user.password.not.match", null); + } +} diff --git a/dc-common/src/main/java/com/dc/common/exception/user/UserPasswordRetryLimitExceedException.java b/dc-common/src/main/java/com/dc/common/exception/user/UserPasswordRetryLimitExceedException.java new file mode 100644 index 0000000..e7c516d --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/exception/user/UserPasswordRetryLimitExceedException.java @@ -0,0 +1,16 @@ +package com.dc.common.exception.user; + +/** + * 用户错误最大次数异常类 + * + * @author ruoyi + */ +public class UserPasswordRetryLimitExceedException extends UserException +{ + private static final long serialVersionUID = 1L; + + public UserPasswordRetryLimitExceedException(int retryLimitCount, int lockTime) + { + super("user.password.retry.limit.exceed", new Object[] { retryLimitCount, lockTime }); + } +} diff --git a/dc-common/src/main/java/com/dc/common/extension/MpSqlInjector.java b/dc-common/src/main/java/com/dc/common/extension/MpSqlInjector.java new file mode 100644 index 0000000..d4edb85 --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/extension/MpSqlInjector.java @@ -0,0 +1,19 @@ +package com.dc.common.extension; +import com.baomidou.mybatisplus.core.injector.AbstractMethod; +import com.baomidou.mybatisplus.core.injector.DefaultSqlInjector; +import com.baomidou.mybatisplus.core.metadata.TableInfo; +import com.baomidou.mybatisplus.extension.injector.methods.InsertBatchSomeColumn; +import java.util.List; + +/** + * 扩展默认的数据方法 + **/ +public class MpSqlInjector extends DefaultSqlInjector { + + @Override + public List<AbstractMethod> getMethodList(Class<?> mapperClass, TableInfo tableInfo) { + List<AbstractMethod> methodList = super.getMethodList(mapperClass,tableInfo); + methodList.add(new InsertBatchSomeColumn()); + return methodList; + } +} \ No newline at end of file diff --git a/dc-common/src/main/java/com/dc/common/filter/PropertyPreExcludeFilter.java b/dc-common/src/main/java/com/dc/common/filter/PropertyPreExcludeFilter.java new file mode 100644 index 0000000..a923253 --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/filter/PropertyPreExcludeFilter.java @@ -0,0 +1,24 @@ +package com.dc.common.filter; + +import com.alibaba.fastjson2.filter.SimplePropertyPreFilter; + +/** + * 排除JSON敏感属性 + * + * @author win + */ +public class PropertyPreExcludeFilter extends SimplePropertyPreFilter +{ + public PropertyPreExcludeFilter() + { + } + + public PropertyPreExcludeFilter addExcludes(String... filters) + { + for (int i = 0; i < filters.length; i++) + { + this.getExcludes().add(filters[i]); + } + return this; + } +} diff --git a/dc-common/src/main/java/com/dc/common/filter/RepeatableFilter.java b/dc-common/src/main/java/com/dc/common/filter/RepeatableFilter.java new file mode 100644 index 0000000..fdddbf9 --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/filter/RepeatableFilter.java @@ -0,0 +1,48 @@ +package com.dc.common.filter; + +import com.dc.common.utils.StringUtils; +import org.springframework.http.MediaType; + +import javax.servlet.*; +import javax.servlet.http.HttpServletRequest; +import java.io.IOException; + +/** + * Repeatable 过滤器 + * + * @author win + */ +public class RepeatableFilter implements Filter +{ + @Override + public void init(FilterConfig filterConfig) throws ServletException + { + + } + + @Override + public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) + throws IOException, ServletException + { + ServletRequest requestWrapper = null; + if (request instanceof HttpServletRequest + && StringUtils.startsWithIgnoreCase(request.getContentType(), MediaType.APPLICATION_JSON_VALUE)) + { + requestWrapper = new RepeatedlyRequestWrapper((HttpServletRequest) request, response); + } + if (null == requestWrapper) + { + chain.doFilter(request, response); + } + else + { + chain.doFilter(requestWrapper, response); + } + } + + @Override + public void destroy() + { + + } +} diff --git a/dc-common/src/main/java/com/dc/common/filter/RepeatedlyRequestWrapper.java b/dc-common/src/main/java/com/dc/common/filter/RepeatedlyRequestWrapper.java new file mode 100644 index 0000000..4c05e3e --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/filter/RepeatedlyRequestWrapper.java @@ -0,0 +1,77 @@ +package com.dc.common.filter; + +import com.dc.common.constant.Constants; +import com.dc.common.utils.http.HttpHelper; + +import javax.servlet.ReadListener; +import javax.servlet.ServletInputStream; +import javax.servlet.ServletResponse; +import javax.servlet.http.HttpServletRequest; +import javax.servlet.http.HttpServletRequestWrapper; +import java.io.BufferedReader; +import java.io.ByteArrayInputStream; +import java.io.IOException; +import java.io.InputStreamReader; + +/** + * 构建可重复读取inputStream的request + * + * @author win + */ +public class RepeatedlyRequestWrapper extends HttpServletRequestWrapper +{ + private final byte[] body; + + public RepeatedlyRequestWrapper(HttpServletRequest request, ServletResponse response) throws IOException + { + super(request); + request.setCharacterEncoding(Constants.UTF8); + response.setCharacterEncoding(Constants.UTF8); + + body = HttpHelper.getBodyString(request).getBytes(Constants.UTF8); + } + + @Override + public BufferedReader getReader() throws IOException + { + return new BufferedReader(new InputStreamReader(getInputStream())); + } + + @Override + public ServletInputStream getInputStream() throws IOException + { + final ByteArrayInputStream bais = new ByteArrayInputStream(body); + return new ServletInputStream() + { + @Override + public int read() throws IOException + { + return bais.read(); + } + + @Override + public int available() throws IOException + { + return body.length; + } + + @Override + public boolean isFinished() + { + return false; + } + + @Override + public boolean isReady() + { + return false; + } + + @Override + public void setReadListener(ReadListener readListener) + { + + } + }; + } +} diff --git a/dc-common/src/main/java/com/dc/common/filter/XssFilter.java b/dc-common/src/main/java/com/dc/common/filter/XssFilter.java new file mode 100644 index 0000000..85450e6 --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/filter/XssFilter.java @@ -0,0 +1,71 @@ +package com.dc.common.filter; + +import com.dc.common.enums.HttpMethod; +import com.dc.common.utils.StringUtils; + +import javax.servlet.*; +import javax.servlet.http.HttpServletRequest; +import javax.servlet.http.HttpServletResponse; +import java.io.IOException; +import java.util.ArrayList; +import java.util.List; + +/** + * 防止XSS攻击的过滤器 + * + * @author win + */ +public class XssFilter implements Filter +{ + /** + * 排除链接 + */ + public List<String> excludes = new ArrayList<>(); + + @Override + public void init(FilterConfig filterConfig) throws ServletException + { + String tempExcludes = filterConfig.getInitParameter("excludes"); + if (StringUtils.isNotEmpty(tempExcludes)) + { + String[] url = tempExcludes.split(","); + for (int i = 0; url != null && i < url.length; i++) + { + excludes.add(url[i]); + } + } + } + + @Override + public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) + throws IOException, ServletException + { + HttpServletRequest req = (HttpServletRequest) request; + HttpServletResponse resp = (HttpServletResponse) response; + if (handleExcludeURL(req, resp)) + { + chain.doFilter(request, response); + return; + } + XssHttpServletRequestWrapper xssRequest = new XssHttpServletRequestWrapper((HttpServletRequest) request); + chain.doFilter(xssRequest, response); + } + + private boolean handleExcludeURL(HttpServletRequest request, HttpServletResponse response) + { + String url = request.getServletPath(); + String method = request.getMethod(); + // GET DELETE 不过滤 + if (method == null || HttpMethod.GET.matches(method) || HttpMethod.DELETE.matches(method)) + { + return true; + } + return StringUtils.matches(url, excludes); + } + + @Override + public void destroy() + { + + } +} \ No newline at end of file diff --git a/dc-common/src/main/java/com/dc/common/filter/XssHttpServletRequestWrapper.java b/dc-common/src/main/java/com/dc/common/filter/XssHttpServletRequestWrapper.java new file mode 100644 index 0000000..9a47b45 --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/filter/XssHttpServletRequestWrapper.java @@ -0,0 +1,112 @@ +package com.dc.common.filter; + +import com.dc.common.utils.StringUtils; +import com.dc.common.utils.html.EscapeUtil; +import org.apache.commons.io.IOUtils; +import org.springframework.http.HttpHeaders; +import org.springframework.http.MediaType; + +import javax.servlet.ReadListener; +import javax.servlet.ServletInputStream; +import javax.servlet.http.HttpServletRequest; +import javax.servlet.http.HttpServletRequestWrapper; +import java.io.ByteArrayInputStream; +import java.io.IOException; + +/** + * XSS过滤处理 + * + * @author win + */ +public class XssHttpServletRequestWrapper extends HttpServletRequestWrapper +{ + /** + * @param request + */ + public XssHttpServletRequestWrapper(HttpServletRequest request) + { + super(request); + } + + @Override + public String[] getParameterValues(String name) + { + String[] values = super.getParameterValues(name); + if (values != null) + { + int length = values.length; + String[] escapesValues = new String[length]; + for (int i = 0; i < length; i++) + { + // 防xss攻击和过滤前后空格 + escapesValues[i] = EscapeUtil.clean(values[i]).trim(); + } + return escapesValues; + } + return super.getParameterValues(name); + } + + @Override + public ServletInputStream getInputStream() throws IOException + { + // 非json类型,直接返回 + if (!isJsonRequest()) + { + return super.getInputStream(); + } + + // 为空,直接返回 + String json = IOUtils.toString(super.getInputStream(), "utf-8"); + if (StringUtils.isEmpty(json)) + { + return super.getInputStream(); + } + + // xss过滤 + json = EscapeUtil.clean(json).trim(); + byte[] jsonBytes = json.getBytes("utf-8"); + final ByteArrayInputStream bis = new ByteArrayInputStream(jsonBytes); + return new ServletInputStream() + { + @Override + public boolean isFinished() + { + return true; + } + + @Override + public boolean isReady() + { + return true; + } + + @Override + public int available() throws IOException + { + return jsonBytes.length; + } + + @Override + public void setReadListener(ReadListener readListener) + { + } + + @Override + public int read() throws IOException + { + return bis.read(); + } + }; + } + + /** + * 是否是Json请求 + * + * @param request + */ + public boolean isJsonRequest() + { + String header = super.getHeader(HttpHeaders.CONTENT_TYPE); + return StringUtils.startsWithIgnoreCase(header, MediaType.APPLICATION_JSON_VALUE); + } +} \ No newline at end of file diff --git a/dc-common/src/main/java/com/dc/common/utils/AESKit.java b/dc-common/src/main/java/com/dc/common/utils/AESKit.java new file mode 100644 index 0000000..1fb29ee --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/utils/AESKit.java @@ -0,0 +1,139 @@ +package com.dc.common.utils; + +import org.apache.commons.codec.binary.Base64; +import org.apache.commons.lang3.StringUtils; + +import javax.crypto.Cipher; +import javax.crypto.spec.IvParameterSpec; +import javax.crypto.spec.SecretKeySpec; +import java.util.Date; + +public class AESKit { + public static final String IV = "0807060504030201"; + private static String DEFAULT_CIPHER_ALGORITHM = "AES/CBC/PKCS5Padding"; + + private static String ENCRYPT_TYPE = "AES"; + private static String DEFAULT_KEY = "w.bajiaoxing.com"; + private static SecretKeySpec keySpec = initKeySpec(DEFAULT_KEY); + + /******************************************************************* + * AES加密算法 + * @author moyun + * 加密用的Key 可以用26个字母和数字组成,最好不要用保留字符,虽然不会错,至于怎么裁决,个人看情况而定 此处使用AES-128-CBC加密模式,key需要为16位。 + * */ + public static String encrypt(String sSrc, SecretKeySpec keySpec) throws Exception { + //"算法/模式/补码方式" + Cipher cipher = Cipher.getInstance(DEFAULT_CIPHER_ALGORITHM); + //使用CBC模式,需要一个向量iv,可增加加密算法的强度 + IvParameterSpec iv = new IvParameterSpec(IV.getBytes()); + cipher.init(Cipher.ENCRYPT_MODE, keySpec, iv); + byte[] encrypted = cipher.doFinal(sSrc.getBytes()); + //此处使用BAES64.encodeBase64URLSafeString做转码功能,同时能起到2次加密的作用 + return Base64.encodeBase64URLSafeString(encrypted); + } + + /******************************************************************* + * AES加密算法 + * @author moyun + * 加密用的Key 可以用26个字母和数字组成,最好不要用保留字符,虽然不会错,至于怎么裁决,个人看情况而定 此处使用AES-128-CBC加密模式,key需要为16位。 + * */ + public static String encrypt(String sSrc, SecretKeySpec keySpec, String cipherString,String iv) throws Exception { + //"算法/模式/补码方式" + Cipher cipher = Cipher.getInstance(cipherString,"BC"); + //使用CBC模式,需要一个向量iv,可增加加密算法的强度 + cipher.init(Cipher.ENCRYPT_MODE, keySpec, new IvParameterSpec(iv.getBytes())); + byte[] encrypted = cipher.doFinal(sSrc.getBytes()); + //此处使用BAES64.encodeBase64URLSafeString做转码功能,同时能起到2次加密的作用 + return Base64.encodeBase64URLSafeString(encrypted); + } + + /** + * 解密 + * + * @param sSrc + * @param keySpec + * @return 解密字符串 + * @throws Exception + */ + public static String decrypt(String sSrc, SecretKeySpec keySpec) throws Exception { + Cipher cipher = Cipher.getInstance(DEFAULT_CIPHER_ALGORITHM); + IvParameterSpec iv = new IvParameterSpec(IV.getBytes()); + cipher.init(Cipher.DECRYPT_MODE, keySpec, iv); + //先用bAES64解密 + byte[] encrypted = Base64.decodeBase64(sSrc); + try { + byte[] original = cipher.doFinal(encrypted); + String originalString = new String(original); + return originalString; + } catch (Exception e) { + e.printStackTrace(); + return null; + } + } + + /** + * 解密 + * + * @param sSrc + * @param keySpec + * @param IV 偏移量 + * @return 解密字符串 + * @throws Exception + */ + public static String decrypt(String sSrc, SecretKeySpec keySpec, String IV) throws Exception { + Cipher cipher = Cipher.getInstance(DEFAULT_CIPHER_ALGORITHM); + IvParameterSpec iv = new IvParameterSpec(IV.getBytes()); + cipher.init(Cipher.DECRYPT_MODE, keySpec, iv); + //先用bAES64解密 + byte[] encrypted = Base64.decodeBase64(sSrc); + try { + byte[] original = cipher.doFinal(encrypted); + String originalString = new String(original); + return originalString; + } catch (Exception e) { + e.printStackTrace(); + return null; + } + } + + /** + * 初始化key + * + * @param sKey 暂不支持包含中文的key + * @return + */ + public static SecretKeySpec initKeySpec(String sKey) { + if (StringUtils.isEmpty(sKey)) { + sKey = DEFAULT_KEY; + } + int length = sKey.length(); + if (length < 16) { + sKey = sKey + DEFAULT_KEY.substring(length); + } else if (length > 16) { + sKey = sKey.substring(0, 15); + } + byte[] raw = sKey.getBytes(); + return new SecretKeySpec(raw, ENCRYPT_TYPE); + } + + + public static void main(String[] args) throws Exception { + String KEY = "123456"; + SecretKeySpec keySpec = initKeySpec(KEY); + Date time = new Date(); + for (Long i = 1000000000000000000l; i < 1000000000000100000l; i++) { + String decStr = encrypt("" + i, keySpec); + System.out.println("加密后数据:" + decStr); + decStr = decrypt(decStr, keySpec); + System.out.println("解密后数据: " + decStr); + long j = Long.valueOf(decStr); + if (i != j) { + System.out.println(false); + } + } + long l = new Date().getTime() - time.getTime(); + System.out.println(l); + System.out.println(decrypt("eTG4K8HyJiOf6zHECgz82lJ0EhbtsmvmqBtkx4mlM18", keySpec)); + } + +} diff --git a/dc-common/src/main/java/com/dc/common/utils/Arith.java b/dc-common/src/main/java/com/dc/common/utils/Arith.java new file mode 100644 index 0000000..5e7fe95 --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/utils/Arith.java @@ -0,0 +1,114 @@ +package com.dc.common.utils; + +import java.math.BigDecimal; +import java.math.RoundingMode; + +/** + * 精确的浮点数运算 + * + * @author win + */ +public class Arith +{ + + /** 默认除法运算精度 */ + private static final int DEF_DIV_SCALE = 10; + + /** 这个类不能实例化 */ + private Arith() + { + } + + /** + * 提供精确的加法运算。 + * @param v1 被加数 + * @param v2 加数 + * @return 两个参数的和 + */ + public static double add(double v1, double v2) + { + BigDecimal b1 = new BigDecimal(Double.toString(v1)); + BigDecimal b2 = new BigDecimal(Double.toString(v2)); + return b1.add(b2).doubleValue(); + } + + /** + * 提供精确的减法运算。 + * @param v1 被减数 + * @param v2 减数 + * @return 两个参数的差 + */ + public static double sub(double v1, double v2) + { + BigDecimal b1 = new BigDecimal(Double.toString(v1)); + BigDecimal b2 = new BigDecimal(Double.toString(v2)); + return b1.subtract(b2).doubleValue(); + } + + /** + * 提供精确的乘法运算。 + * @param v1 被乘数 + * @param v2 乘数 + * @return 两个参数的积 + */ + public static double mul(double v1, double v2) + { + BigDecimal b1 = new BigDecimal(Double.toString(v1)); + BigDecimal b2 = new BigDecimal(Double.toString(v2)); + return b1.multiply(b2).doubleValue(); + } + + /** + * 提供(相对)精确的除法运算,当发生除不尽的情况时,精确到 + * 小数点以后10位,以后的数字四舍五入。 + * @param v1 被除数 + * @param v2 除数 + * @return 两个参数的商 + */ + public static double div(double v1, double v2) + { + return div(v1, v2, DEF_DIV_SCALE); + } + + /** + * 提供(相对)精确的除法运算。当发生除不尽的情况时,由scale参数指 + * 定精度,以后的数字四舍五入。 + * @param v1 被除数 + * @param v2 除数 + * @param scale 表示表示需要精确到小数点以后几位。 + * @return 两个参数的商 + */ + public static double div(double v1, double v2, int scale) + { + if (scale < 0) + { + throw new IllegalArgumentException( + "The scale must be a positive integer or zero"); + } + BigDecimal b1 = new BigDecimal(Double.toString(v1)); + BigDecimal b2 = new BigDecimal(Double.toString(v2)); + if (b1.compareTo(BigDecimal.ZERO) == 0) + { + return BigDecimal.ZERO.doubleValue(); + } + return b1.divide(b2, scale, RoundingMode.HALF_UP).doubleValue(); + } + + /** + * 提供精确的小数位四舍五入处理。 + * @param v 需要四舍五入的数字 + * @param scale 小数点后保留几位 + * @return 四舍五入后的结果 + */ + public static double round(double v, int scale) + { + if (scale < 0) + { + throw new IllegalArgumentException( + "The scale must be a positive integer or zero"); + } + BigDecimal b = new BigDecimal(Double.toString(v)); + BigDecimal one = BigDecimal.ONE; + return b.divide(one, scale, RoundingMode.HALF_UP).doubleValue(); + } +} diff --git a/dc-common/src/main/java/com/dc/common/utils/DateUtils.java b/dc-common/src/main/java/com/dc/common/utils/DateUtils.java new file mode 100644 index 0000000..0037ba7 --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/utils/DateUtils.java @@ -0,0 +1,184 @@ +package com.dc.common.utils; + +import org.apache.commons.lang3.time.DateFormatUtils; + +import java.lang.management.ManagementFactory; +import java.text.ParseException; +import java.text.SimpleDateFormat; +import java.time.*; +import java.util.Date; + +/** + * 时间工具类 + * + * @author win + */ +public class DateUtils extends org.apache.commons.lang3.time.DateUtils +{ + public static String YYYY = "yyyy"; + + public static String YYYY_MM = "yyyy-MM"; + + public static String YYYY_MM_DD = "yyyy-MM-dd"; + + public static String YYYYMMDDHHMMSS = "yyyyMMddHHmmss"; + + public static String YYYY_MM_DD_HH_MM_SS = "yyyy-MM-dd HH:mm:ss"; + + private static String[] parsePatterns = { + "yyyy-MM-dd", "yyyy-MM-dd HH:mm:ss", "yyyy-MM-dd HH:mm", "yyyy-MM", + "yyyy/MM/dd", "yyyy/MM/dd HH:mm:ss", "yyyy/MM/dd HH:mm", "yyyy/MM", + "yyyy.MM.dd", "yyyy.MM.dd HH:mm:ss", "yyyy.MM.dd HH:mm", "yyyy.MM"}; + + /** + * 获取当前Date型日期 + * + * @return Date() 当前日期 + */ + public static Date getNowDate() + { + return new Date(); + } + + /** + * 获取当前日期, 默认格式为yyyy-MM-dd + * + * @return String + */ + public static String getDate() + { + return dateTimeNow(YYYY_MM_DD); + } + + public static final String getTime() + { + return dateTimeNow(YYYY_MM_DD_HH_MM_SS); + } + + public static final String dateTimeNow() + { + return dateTimeNow(YYYYMMDDHHMMSS); + } + + public static final String dateTimeNow(final String format) + { + return parseDateToStr(format, new Date()); + } + + public static final String dateTime(final Date date) + { + return parseDateToStr(YYYY_MM_DD, date); + } + + public static final String parseDateToStr(final String format, final Date date) + { + return new SimpleDateFormat(format).format(date); + } + + public static final Date dateTime(final String format, final String ts) + { + try + { + return new SimpleDateFormat(format).parse(ts); + } + catch (ParseException e) + { + throw new RuntimeException(e); + } + } + + /** + * 日期路径 即年/月/日 如2018/08/08 + */ + public static final String datePath() + { + Date now = new Date(); + return DateFormatUtils.format(now, "yyyy/MM/dd"); + } + + /** + * 日期路径 即年/月/日 如20180808 + */ + public static final String dateTime() + { + Date now = new Date(); + return DateFormatUtils.format(now, "yyyyMMdd"); + } + + /** + * 日期型字符串转化为日期 格式 + */ + public static Date parseDate(Object str) + { + if (str == null) + { + return null; + } + try + { + return parseDate(str.toString(), parsePatterns); + } + catch (ParseException e) + { + return null; + } + } + + /** + * 获取服务器启动时间 + */ + public static Date getServerStartDate() + { + long time = ManagementFactory.getRuntimeMXBean().getStartTime(); + return new Date(time); + } + + /** + * 计算相差天数 + */ + public static int differentDaysByMillisecond(Date date1, Date date2) + { + return Math.abs((int) ((date2.getTime() - date1.getTime()) / (1000 * 3600 * 24))); + } + + /** + * 计算两个时间差 + */ + public static String getDatePoor(Date endDate, Date nowDate) + { + long nd = 1000 * 24 * 60 * 60; + long nh = 1000 * 60 * 60; + long nm = 1000 * 60; + // long ns = 1000; + // 获得两个时间的毫秒时间差异 + long diff = endDate.getTime() - nowDate.getTime(); + // 计算差多少天 + long day = diff / nd; + // 计算差多少小时 + long hour = diff % nd / nh; + // 计算差多少分钟 + long min = diff % nd % nh / nm; + // 计算差多少秒//输出结果 + // long sec = diff % nd % nh % nm / ns; + return day + "天" + hour + "小时" + min + "分钟"; + } + + /** + * 增加 LocalDateTime ==> Date + */ + public static Date toDate(LocalDateTime temporalAccessor) + { + ZonedDateTime zdt = temporalAccessor.atZone(ZoneId.systemDefault()); + return Date.from(zdt.toInstant()); + } + + /** + * 增加 LocalDate ==> Date + */ + public static Date toDate(LocalDate temporalAccessor) + { + LocalDateTime localDateTime = LocalDateTime.of(temporalAccessor, LocalTime.of(0, 0, 0)); + ZonedDateTime zdt = localDateTime.atZone(ZoneId.systemDefault()); + return Date.from(zdt.toInstant()); + } +} diff --git a/dc-common/src/main/java/com/dc/common/utils/DictUtils.java b/dc-common/src/main/java/com/dc/common/utils/DictUtils.java new file mode 100644 index 0000000..549a965 --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/utils/DictUtils.java @@ -0,0 +1,159 @@ +package com.dc.common.utils; + +import com.alibaba.fastjson2.JSONArray; +import com.dc.common.core.domain.entity.SysDictData; +import com.dc.common.core.redis.RedisCache; +import com.dc.common.constant.CacheConstants; +import com.dc.common.utils.spring.SpringUtils; + +import java.util.Collection; +import java.util.List; + +/** + * 字典工具类 + * + * @author win + */ +public class DictUtils { + /** + * 分隔符 + */ + public static final String SEPARATOR = ","; + + /** + * 设置字典缓存 + * + * @param key 参数键 + * @param dictDatas 字典数据列表 + */ + public static void setDictCache(String key, List<SysDictData> dictDatas) { + SpringUtils.getBean(RedisCache.class).setCacheObject(getCacheKey(key), dictDatas); + } + + /** + * 获取字典缓存 + * + * @param key 参数键 + * @return dictDatas 字典数据列表 + */ + public static List<SysDictData> getDictCache(String key) { + JSONArray arrayCache = SpringUtils.getBean(RedisCache.class).getCacheObject(getCacheKey(key)); + if (StringUtils.isNotNull(arrayCache)) { + return arrayCache.toList(SysDictData.class); + } + return null; + } + + /** + * 根据字典类型和字典值获取字典标签 + * + * @param dictType 字典类型 + * @param dictValue 字典值 + * @return 字典标签 + */ + public static String getDictLabel(String dictType, String dictValue) { + return getDictLabel(dictType, dictValue, SEPARATOR); + } + + /** + * 根据字典类型和字典标签获取字典值 + * + * @param dictType 字典类型 + * @param dictLabel 字典标签 + * @return 字典值 + */ + public static String getDictValue(String dictType, String dictLabel) { + return getDictValue(dictType, dictLabel, SEPARATOR); + } + + /** + * 根据字典类型和字典值获取字典标签 + * + * @param dictType 字典类型 + * @param dictValue 字典值 + * @param separator 分隔符 + * @return 字典标签 + */ + public static String getDictLabel(String dictType, String dictValue, String separator) { + StringBuilder propertyString = new StringBuilder(); + List<SysDictData> datas = getDictCache(dictType); + + if (StringUtils.isNotNull(datas)) { + if (StringUtils.containsAny(separator, dictValue)) { + for (SysDictData dict : datas) { + for (String value : dictValue.split(separator)) { + if (value.equals(dict.getDictValue())) { + propertyString.append(dict.getDictLabel()).append(separator); + break; + } + } + } + } else { + for (SysDictData dict : datas) { + if (dictValue.equals(dict.getDictValue())) { + return dict.getDictLabel(); + } + } + } + } + return StringUtils.stripEnd(propertyString.toString(), separator); + } + + /** + * 根据字典类型和字典标签获取字典值 + * + * @param dictType 字典类型 + * @param dictLabel 字典标签 + * @param separator 分隔符 + * @return 字典值 + */ + public static String getDictValue(String dictType, String dictLabel, String separator) { + StringBuilder propertyString = new StringBuilder(); + List<SysDictData> datas = getDictCache(dictType); + + if (StringUtils.containsAny(separator, dictLabel) && StringUtils.isNotEmpty(datas)) { + for (SysDictData dict : datas) { + for (String label : dictLabel.split(separator)) { + if (label.equals(dict.getDictLabel())) { + propertyString.append(dict.getDictValue()).append(separator); + break; + } + } + } + } else { + for (SysDictData dict : datas) { + if (dictLabel.equals(dict.getDictLabel())) { + return dict.getDictValue(); + } + } + } + return StringUtils.stripEnd(propertyString.toString(), separator); + } + + /** + * 删除指定字典缓存 + * + * @param key 字典键 + */ + public static void removeDictCache(String key) { + SpringUtils.getBean(RedisCache.class).deleteObject(getCacheKey(key)); + } + + /** + * 清空字典缓存 + */ + public static void clearDictCache() { + Collection<String> keys = SpringUtils.getBean(RedisCache.class).keys(CacheConstants.SYS_DICT_KEY + "*"); + SpringUtils.getBean(RedisCache.class).deleteObject(keys); + } + + /** + * 设置cache key + * + * @param configKey 参数键 + * @return 缓存键key + */ + public static String getCacheKey(String configKey) { + return CacheConstants.SYS_DICT_KEY + configKey; + } +} diff --git a/dc-common/src/main/java/com/dc/common/utils/ExceptionUtil.java b/dc-common/src/main/java/com/dc/common/utils/ExceptionUtil.java new file mode 100644 index 0000000..bbf57d5 --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/utils/ExceptionUtil.java @@ -0,0 +1,40 @@ +package com.dc.common.utils; + +import org.apache.commons.lang3.exception.ExceptionUtils; + +import java.io.PrintWriter; +import java.io.StringWriter; + +/** + * 错误信息处理类。 + * + * @author win + */ +public class ExceptionUtil +{ + /** + * 获取exception的详细错误信息。 + */ + public static String getExceptionMessage(Throwable e) + { + StringWriter sw = new StringWriter(); + e.printStackTrace(new PrintWriter(sw, true)); + return sw.toString(); + } + + public static String getRootErrorMessage(Exception e) + { + Throwable root = ExceptionUtils.getRootCause(e); + root = (root == null ? e : root); + if (root == null) + { + return ""; + } + String msg = root.getMessage(); + if (msg == null) + { + return "null"; + } + return StringUtils.defaultString(msg); + } +} diff --git a/dc-common/src/main/java/com/dc/common/utils/IdEncodes.java b/dc-common/src/main/java/com/dc/common/utils/IdEncodes.java new file mode 100644 index 0000000..5c7880e --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/utils/IdEncodes.java @@ -0,0 +1,90 @@ +package com.dc.common.utils; + +import org.apache.commons.lang3.StringUtils; + +import javax.crypto.spec.SecretKeySpec; +import java.util.Base64; +import java.util.Date; + +/** + * Id加密解密工具类 使用AES + */ +//如果失败 则使用base64, 理论上加密失败解密也会失败,所以在失败的时候都用base64,看看具体情况再说 +//理论上只有在 Cipher.getInstance 和 KeyGenerator.getInstance 选择了不支持的方式时才会有异常 +//todo 暂时留下todo +public class IdEncodes { + //秘钥 + private static final SecretKeySpec keySpec = AESKit.initKeySpec("www.win-in.com"); + private static final Base64.Decoder decoder = Base64.getDecoder(); + private static final Base64.Encoder encoder = Base64.getEncoder(); + + public static String encode(Long id) { + String encodeId; + try { + encodeId = AESKit.encrypt(String.valueOf(id), keySpec); + } catch (Exception e) { + e.printStackTrace(); + encodeId = encoder.encodeToString(String.valueOf(id).getBytes()); + } + return encodeId; + } + + public static String encodeStr(String str) { + String encodeStr; + try { + encodeStr = AESKit.encrypt(str, keySpec); + } catch (Exception e) { + e.printStackTrace(); + encodeStr = encoder.encodeToString(str.getBytes()); + } + return encodeStr; + } + + public static Long decode(String id) { + if (StringUtils.isEmpty(id)) { + return 0L; + } + String isString; + try { + isString = AESKit.decrypt(id, keySpec); + } catch (Exception e) { + e.printStackTrace(); + isString = new String(decoder.decode(id)); + } + if (!StringUtils.isEmpty(isString) && StringUtils.isNumeric(isString)) { + return Long.valueOf(isString); + } else { + return null; + } + } + + public static String decodeStr(String str) { + if (StringUtils.isEmpty(str)) { + return ""; + } + String isString; + try { + isString = AESKit.decrypt(str, keySpec); + } catch (Exception e) { + e.printStackTrace(); + isString = new String(decoder.decode(str)); + } + if (!StringUtils.isEmpty(isString)) { + return isString; + } else { + return ""; + } + } + + public static void main(String[] args){ + long date = new Date().getTime(); + for (Long i = 100l; i < 110l; i++) { + String ids = encode(i); + System.out.println(ids); + Long id = decode(ids); + System.out.println(id); + } + long date1 = new Date().getTime() - date; + System.out.println(date1); + } +} diff --git a/dc-common/src/main/java/com/dc/common/utils/LogUtils.java b/dc-common/src/main/java/com/dc/common/utils/LogUtils.java new file mode 100644 index 0000000..f897e70 --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/utils/LogUtils.java @@ -0,0 +1,18 @@ +package com.dc.common.utils; + +/** + * 处理并记录日志文件 + * + * @author win + */ +public class LogUtils +{ + public static String getBlock(Object msg) + { + if (msg == null) + { + msg = ""; + } + return "[" + msg.toString() + "]"; + } +} diff --git a/dc-common/src/main/java/com/dc/common/utils/MessageUtils.java b/dc-common/src/main/java/com/dc/common/utils/MessageUtils.java new file mode 100644 index 0000000..b302768 --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/utils/MessageUtils.java @@ -0,0 +1,26 @@ +package com.dc.common.utils; + +import com.dc.common.utils.spring.SpringUtils; +import org.springframework.context.MessageSource; +import org.springframework.context.i18n.LocaleContextHolder; + +/** + * 获取i18n资源文件 + * + * @author win + */ +public class MessageUtils +{ + /** + * 根据消息键和参数 获取消息 委托给spring messageSource + * + * @param code 消息键 + * @param args 参数 + * @return 获取国际化翻译值 + */ + public static String message(String code, Object... args) + { + MessageSource messageSource = SpringUtils.getBean(MessageSource.class); + return messageSource.getMessage(code, args, LocaleContextHolder.getLocale()); + } +} diff --git a/dc-common/src/main/java/com/dc/common/utils/PageUtils.java b/dc-common/src/main/java/com/dc/common/utils/PageUtils.java new file mode 100644 index 0000000..d8e59fc --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/utils/PageUtils.java @@ -0,0 +1,35 @@ +package com.dc.common.utils; + +import com.github.pagehelper.PageHelper; +import com.dc.common.core.page.PageDomain; +import com.dc.common.core.page.TableSupport; +import com.dc.common.utils.sql.SqlUtil; + +/** + * 分页工具类 + * + * @author win + */ +public class PageUtils extends PageHelper +{ + /** + * 设置请求分页数据 + */ + public static void startPage() + { + PageDomain pageDomain = TableSupport.buildPageRequest(); + Integer pageNum = pageDomain.getPageNum(); + Integer pageSize = pageDomain.getPageSize(); + String orderBy = SqlUtil.escapeOrderBySql(pageDomain.getOrderBy()); + Boolean reasonable = pageDomain.getReasonable(); + PageHelper.startPage(pageNum, pageSize, orderBy).setReasonable(reasonable); + } + + /** + * 清理分页的线程变量 + */ + public static void clearPage() + { + PageHelper.clearPage(); + } +} diff --git a/dc-common/src/main/java/com/dc/common/utils/SecurityUtils.java b/dc-common/src/main/java/com/dc/common/utils/SecurityUtils.java new file mode 100644 index 0000000..89ffa51 --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/utils/SecurityUtils.java @@ -0,0 +1,144 @@ +package com.dc.common.utils; + +import com.dc.common.core.domain.model.LoginUser; +import com.dc.common.constant.HttpStatus; +import com.dc.common.exception.ServiceException; +import org.springframework.security.core.Authentication; +import org.springframework.security.core.context.SecurityContextHolder; +import org.springframework.security.crypto.bcrypt.BCryptPasswordEncoder; + +/** + * 安全服务工具类 + * + * @author win + */ +public class SecurityUtils +{ + private static ThreadLocal<String> unionIdThreadLocal = new ThreadLocal<>(); + + /** + * 用户ID + **/ + public static Long getUserId() + { + try + { + return getLoginUser().getUserId(); + } + catch (Exception e) + { + throw new ServiceException("获取用户ID异常", HttpStatus.UNAUTHORIZED); + } + } + + /** + * 获取部门ID + **/ + public static Long getDeptId() + { + try + { + return getLoginUser().getDeptId(); + } + catch (Exception e) + { + throw new ServiceException("获取部门ID异常", HttpStatus.UNAUTHORIZED); + } + } + + /** + * 获取用户账户 + **/ + public static String getUsername() + { + try + { + return getLoginUser().getUsername(); + } + catch (Exception e) + { + throw new ServiceException("获取用户账户异常", HttpStatus.UNAUTHORIZED); + } + } + + /** + * 获取用户 + **/ + public static LoginUser getLoginUser() + { + try + { + return (LoginUser) getAuthentication().getPrincipal(); + } + catch (Exception e) + { + throw new ServiceException("获取用户信息异常", HttpStatus.UNAUTHORIZED); + } + } + + /** + * 获取Authentication + */ + public static Authentication getAuthentication() + { + return SecurityContextHolder.getContext().getAuthentication(); + } + + /** + * 生成BCryptPasswordEncoder密码 + * + * @param password 密码 + * @return 加密字符串 + */ + public static String encryptPassword(String password) + { + BCryptPasswordEncoder passwordEncoder = new BCryptPasswordEncoder(); + return passwordEncoder.encode(password); + } + + /** + * 判断密码是否相同 + * + * @param rawPassword 真实密码 + * @param encodedPassword 加密后字符 + * @return 结果 + */ + public static boolean matchesPassword(String rawPassword, String encodedPassword) + { + BCryptPasswordEncoder passwordEncoder = new BCryptPasswordEncoder(); + return passwordEncoder.matches(rawPassword, encodedPassword); + } + + /** + * 是否为管理员 + * + * @param userId 用户ID + * @return 结果 + */ + public static boolean isAdmin(Long userId) + { + return userId != null && 1L == userId; + } + + /** + * 设置unionId + */ + public static void setOpenId(String openId) { + unionIdThreadLocal.set(openId); + } + + /** + * 获取unionId + */ + public static String getOpenId() { + return unionIdThreadLocal.get(); + } + + /** + * 删除unionId + */ + public static void removeOpenId() { + unionIdThreadLocal.remove(); + } + +} diff --git a/dc-common/src/main/java/com/dc/common/utils/ServletUtils.java b/dc-common/src/main/java/com/dc/common/utils/ServletUtils.java new file mode 100644 index 0000000..756c646 --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/utils/ServletUtils.java @@ -0,0 +1,219 @@ +package com.dc.common.utils; + +import com.dc.common.core.text.Convert; +import com.dc.common.constant.Constants; +import org.springframework.web.context.request.RequestAttributes; +import org.springframework.web.context.request.RequestContextHolder; +import org.springframework.web.context.request.ServletRequestAttributes; + +import javax.servlet.ServletRequest; +import javax.servlet.http.HttpServletRequest; +import javax.servlet.http.HttpServletResponse; +import javax.servlet.http.HttpSession; +import java.io.IOException; +import java.io.UnsupportedEncodingException; +import java.net.URLDecoder; +import java.net.URLEncoder; +import java.util.Collections; +import java.util.HashMap; +import java.util.Map; + +/** + * 客户端工具类 + * + * @author win + */ +public class ServletUtils +{ + /** + * 获取String参数 + */ + public static String getParameter(String name) + { + return getRequest().getParameter(name); + } + + /** + * 获取String参数 + */ + public static String getParameter(String name, String defaultValue) + { + return Convert.toStr(getRequest().getParameter(name), defaultValue); + } + + /** + * 获取Integer参数 + */ + public static Integer getParameterToInt(String name) + { + return Convert.toInt(getRequest().getParameter(name)); + } + + /** + * 获取Integer参数 + */ + public static Integer getParameterToInt(String name, Integer defaultValue) + { + return Convert.toInt(getRequest().getParameter(name), defaultValue); + } + + /** + * 获取Boolean参数 + */ + public static Boolean getParameterToBool(String name) + { + return Convert.toBool(getRequest().getParameter(name)); + } + + /** + * 获取Boolean参数 + */ + public static Boolean getParameterToBool(String name, Boolean defaultValue) + { + return Convert.toBool(getRequest().getParameter(name), defaultValue); + } + + /** + * 获得所有请求参数 + * + * @param request 请求对象{@link ServletRequest} + * @return Map + */ + public static Map<String, String[]> getParams(ServletRequest request) + { + final Map<String, String[]> map = request.getParameterMap(); + return Collections.unmodifiableMap(map); + } + + /** + * 获得所有请求参数 + * + * @param request 请求对象{@link ServletRequest} + * @return Map + */ + public static Map<String, String> getParamMap(ServletRequest request) + { + Map<String, String> params = new HashMap<>(); + for (Map.Entry<String, String[]> entry : getParams(request).entrySet()) + { + params.put(entry.getKey(), StringUtils.join(entry.getValue(), ",")); + } + return params; + } + + /** + * 获取request + */ + public static HttpServletRequest getRequest() + { + return getRequestAttributes().getRequest(); + } + + /** + * 获取response + */ + public static HttpServletResponse getResponse() + { + return getRequestAttributes().getResponse(); + } + + /** + * 获取session + */ + public static HttpSession getSession() + { + return getRequest().getSession(); + } + + public static ServletRequestAttributes getRequestAttributes() + { + RequestAttributes attributes = RequestContextHolder.getRequestAttributes(); + return (ServletRequestAttributes) attributes; + } + + /** + * 将字符串渲染到客户端 + * + * @param response 渲染对象 + * @param string 待渲染的字符串 + */ + public static void renderString(HttpServletResponse response, String string) + { + try + { + response.setStatus(200); + response.setContentType("application/json"); + response.setCharacterEncoding("utf-8"); + response.getWriter().print(string); + } + catch (IOException e) + { + e.printStackTrace(); + } + } + + /** + * 是否是Ajax异步请求 + * + * @param request + */ + public static boolean isAjaxRequest(HttpServletRequest request) + { + String accept = request.getHeader("accept"); + if (accept != null && accept.contains("application/json")) + { + return true; + } + + String xRequestedWith = request.getHeader("X-Requested-With"); + if (xRequestedWith != null && xRequestedWith.contains("XMLHttpRequest")) + { + return true; + } + + String uri = request.getRequestURI(); + if (StringUtils.inStringIgnoreCase(uri, ".json", ".xml")) + { + return true; + } + + String ajax = request.getParameter("__ajax"); + return StringUtils.inStringIgnoreCase(ajax, "json", "xml"); + } + + /** + * 内容编码 + * + * @param str 内容 + * @return 编码后的内容 + */ + public static String urlEncode(String str) + { + try + { + return URLEncoder.encode(str, Constants.UTF8); + } + catch (UnsupportedEncodingException e) + { + return StringUtils.EMPTY; + } + } + + /** + * 内容解码 + * + * @param str 内容 + * @return 解码后的内容 + */ + public static String urlDecode(String str) + { + try + { + return URLDecoder.decode(str, Constants.UTF8); + } + catch (UnsupportedEncodingException e) + { + return StringUtils.EMPTY; + } + } +} diff --git a/dc-common/src/main/java/com/dc/common/utils/StringUtils.java b/dc-common/src/main/java/com/dc/common/utils/StringUtils.java new file mode 100644 index 0000000..17c44d9 --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/utils/StringUtils.java @@ -0,0 +1,605 @@ +package com.dc.common.utils; + +import com.dc.common.core.text.StrFormatter; +import com.dc.common.constant.Constants; +import org.springframework.util.AntPathMatcher; + +import java.util.*; + +/** + * 字符串工具类 + * + * @author win + */ +public class StringUtils extends org.apache.commons.lang3.StringUtils +{ + /** 空字符串 */ + private static final String NULLSTR = ""; + + /** 下划线 */ + private static final char SEPARATOR = '_'; + + /** + * 获取参数不为空值 + * + * @param value defaultValue 要判断的value + * @return value 返回值 + */ + public static <T> T nvl(T value, T defaultValue) + { + return value != null ? value : defaultValue; + } + + /** + * * 判断一个Collection是否为空, 包含List,Set,Queue + * + * @param coll 要判断的Collection + * @return true:为空 false:非空 + */ + public static boolean isEmpty(Collection<?> coll) + { + return isNull(coll) || coll.isEmpty(); + } + + /** + * * 判断一个Collection是否非空,包含List,Set,Queue + * + * @param coll 要判断的Collection + * @return true:非空 false:空 + */ + public static boolean isNotEmpty(Collection<?> coll) + { + return !isEmpty(coll); + } + + /** + * * 判断一个对象数组是否为空 + * + * @param objects 要判断的对象数组 + ** @return true:为空 false:非空 + */ + public static boolean isEmpty(Object[] objects) + { + return isNull(objects) || (objects.length == 0); + } + + /** + * * 判断一个对象数组是否非空 + * + * @param objects 要判断的对象数组 + * @return true:非空 false:空 + */ + public static boolean isNotEmpty(Object[] objects) + { + return !isEmpty(objects); + } + + /** + * * 判断一个Map是否为空 + * + * @param map 要判断的Map + * @return true:为空 false:非空 + */ + public static boolean isEmpty(Map<?, ?> map) + { + return isNull(map) || map.isEmpty(); + } + + /** + * * 判断一个Map是否为空 + * + * @param map 要判断的Map + * @return true:非空 false:空 + */ + public static boolean isNotEmpty(Map<?, ?> map) + { + return !isEmpty(map); + } + + /** + * * 判断一个字符串是否为空串 + * + * @param str String + * @return true:为空 false:非空 + */ + public static boolean isEmpty(String str) + { + return isNull(str) || NULLSTR.equals(str.trim()); + } + + /** + * * 判断一个字符串是否为非空串 + * + * @param str String + * @return true:非空串 false:空串 + */ + public static boolean isNotEmpty(String str) + { + return !isEmpty(str); + } + + /** + * * 判断一个对象是否为空 + * + * @param object Object + * @return true:为空 false:非空 + */ + public static boolean isNull(Object object) + { + return object == null; + } + + /** + * * 判断一个对象是否非空 + * + * @param object Object + * @return true:非空 false:空 + */ + public static boolean isNotNull(Object object) + { + return !isNull(object); + } + + /** + * * 判断一个对象是否是数组类型(Java基本型别的数组) + * + * @param object 对象 + * @return true:是数组 false:不是数组 + */ + public static boolean isArray(Object object) + { + return isNotNull(object) && object.getClass().isArray(); + } + + /** + * 去空格 + */ + public static String trim(String str) + { + return (str == null ? "" : str.trim()); + } + + /** + * 截取字符串 + * + * @param str 字符串 + * @param start 开始 + * @return 结果 + */ + public static String substring(final String str, int start) + { + if (str == null) + { + return NULLSTR; + } + + if (start < 0) + { + start = str.length() + start; + } + + if (start < 0) + { + start = 0; + } + if (start > str.length()) + { + return NULLSTR; + } + + return str.substring(start); + } + + /** + * 截取字符串 + * + * @param str 字符串 + * @param start 开始 + * @param end 结束 + * @return 结果 + */ + public static String substring(final String str, int start, int end) + { + if (str == null) + { + return NULLSTR; + } + + if (end < 0) + { + end = str.length() + end; + } + if (start < 0) + { + start = str.length() + start; + } + + if (end > str.length()) + { + end = str.length(); + } + + if (start > end) + { + return NULLSTR; + } + + if (start < 0) + { + start = 0; + } + if (end < 0) + { + end = 0; + } + + return str.substring(start, end); + } + + /** + * 格式化文本, {} 表示占位符<br> + * 此方法只是简单将占位符 {} 按照顺序替换为参数<br> + * 如果想输出 {} 使用 \\转义 { 即可,如果想输出 {} 之前的 \ 使用双转义符 \\\\ 即可<br> + * 例:<br> + * 通常使用:format("this is {} for {}", "a", "b") -> this is a for b<br> + * 转义{}: format("this is \\{} for {}", "a", "b") -> this is \{} for a<br> + * 转义\: format("this is \\\\{} for {}", "a", "b") -> this is \a for b<br> + * + * @param template 文本模板,被替换的部分用 {} 表示 + * @param params 参数值 + * @return 格式化后的文本 + */ + public static String format(String template, Object... params) + { + if (isEmpty(params) || isEmpty(template)) + { + return template; + } + return StrFormatter.format(template, params); + } + + /** + * 是否为http(s)://开头 + * + * @param link 链接 + * @return 结果 + */ + public static boolean ishttp(String link) + { + return StringUtils.startsWithAny(link, Constants.HTTP, Constants.HTTPS); + } + + /** + * 字符串转set + * + * @param str 字符串 + * @param sep 分隔符 + * @return set集合 + */ + public static final Set<String> str2Set(String str, String sep) + { + return new HashSet<String>(str2List(str, sep, true, false)); + } + + /** + * 字符串转list + * + * @param str 字符串 + * @param sep 分隔符 + * @param filterBlank 过滤纯空白 + * @param trim 去掉首尾空白 + * @return list集合 + */ + public static final List<String> str2List(String str, String sep, boolean filterBlank, boolean trim) + { + List<String> list = new ArrayList<String>(); + if (StringUtils.isEmpty(str)) + { + return list; + } + + // 过滤空白字符串 + if (filterBlank && StringUtils.isBlank(str)) + { + return list; + } + String[] split = str.split(sep); + for (String string : split) + { + if (filterBlank && StringUtils.isBlank(string)) + { + continue; + } + if (trim) + { + string = string.trim(); + } + list.add(string); + } + + return list; + } + + /** + * 判断给定的set列表中是否包含数组array 判断给定的数组array中是否包含给定的元素value + * + * @param set 给定的集合 + * @param array 给定的数组 + * @return boolean 结果 + */ + public static boolean containsAny(Collection<String> collection, String... array) + { + if (isEmpty(collection) || isEmpty(array)) + { + return false; + } + else + { + for (String str : array) + { + if (collection.contains(str)) + { + return true; + } + } + return false; + } + } + + /** + * 查找指定字符串是否包含指定字符串列表中的任意一个字符串同时串忽略大小写 + * + * @param cs 指定字符串 + * @param searchCharSequences 需要检查的字符串数组 + * @return 是否包含任意一个字符串 + */ + public static boolean containsAnyIgnoreCase(CharSequence cs, CharSequence... searchCharSequences) + { + if (isEmpty(cs) || isEmpty(searchCharSequences)) + { + return false; + } + for (CharSequence testStr : searchCharSequences) + { + if (containsIgnoreCase(cs, testStr)) + { + return true; + } + } + return false; + } + + /** + * 驼峰转下划线命名 + */ + public static String toUnderScoreCase(String str) + { + if (str == null) + { + return null; + } + StringBuilder sb = new StringBuilder(); + // 前置字符是否大写 + boolean preCharIsUpperCase = true; + // 当前字符是否大写 + boolean curreCharIsUpperCase = true; + // 下一字符是否大写 + boolean nexteCharIsUpperCase = true; + for (int i = 0; i < str.length(); i++) + { + char c = str.charAt(i); + if (i > 0) + { + preCharIsUpperCase = Character.isUpperCase(str.charAt(i - 1)); + } + else + { + preCharIsUpperCase = false; + } + + curreCharIsUpperCase = Character.isUpperCase(c); + + if (i < (str.length() - 1)) + { + nexteCharIsUpperCase = Character.isUpperCase(str.charAt(i + 1)); + } + + if (preCharIsUpperCase && curreCharIsUpperCase && !nexteCharIsUpperCase) + { + sb.append(SEPARATOR); + } + else if ((i != 0 && !preCharIsUpperCase) && curreCharIsUpperCase) + { + sb.append(SEPARATOR); + } + sb.append(Character.toLowerCase(c)); + } + + return sb.toString(); + } + + /** + * 是否包含字符串 + * + * @param str 验证字符串 + * @param strs 字符串组 + * @return 包含返回true + */ + public static boolean inStringIgnoreCase(String str, String... strs) + { + if (str != null && strs != null) + { + for (String s : strs) + { + if (str.equalsIgnoreCase(trim(s))) + { + return true; + } + } + } + return false; + } + + /** + * 将下划线大写方式命名的字符串转换为驼峰式。如果转换前的下划线大写方式命名的字符串为空,则返回空字符串。 例如:HELLO_WORLD->HelloWorld + * + * @param name 转换前的下划线大写方式命名的字符串 + * @return 转换后的驼峰式命名的字符串 + */ + public static String convertToCamelCase(String name) + { + StringBuilder result = new StringBuilder(); + // 快速检查 + if (name == null || name.isEmpty()) + { + // 没必要转换 + return ""; + } + else if (!name.contains("_")) + { + // 不含下划线,仅将首字母大写 + return name.substring(0, 1).toUpperCase() + name.substring(1); + } + // 用下划线将原始字符串分割 + String[] camels = name.split("_"); + for (String camel : camels) + { + // 跳过原始字符串中开头、结尾的下换线或双重下划线 + if (camel.isEmpty()) + { + continue; + } + // 首字母大写 + result.append(camel.substring(0, 1).toUpperCase()); + result.append(camel.substring(1).toLowerCase()); + } + return result.toString(); + } + + /** + * 驼峰式命名法 例如:user_name->userName + */ + public static String toCamelCase(String s) + { + if (s == null) + { + return null; + } + s = s.toLowerCase(); + StringBuilder sb = new StringBuilder(s.length()); + boolean upperCase = false; + for (int i = 0; i < s.length(); i++) + { + char c = s.charAt(i); + + if (c == SEPARATOR) + { + upperCase = true; + } + else if (upperCase) + { + sb.append(Character.toUpperCase(c)); + upperCase = false; + } + else + { + sb.append(c); + } + } + return sb.toString(); + } + + /** + * 查找指定字符串是否匹配指定字符串列表中的任意一个字符串 + * + * @param str 指定字符串 + * @param strs 需要检查的字符串数组 + * @return 是否匹配 + */ + public static boolean matches(String str, List<String> strs) + { + if (isEmpty(str) || isEmpty(strs)) + { + return false; + } + for (String pattern : strs) + { + if (isMatch(pattern, str)) + { + return true; + } + } + return false; + } + + /** + * 判断url是否与规则配置: + * ? 表示单个字符; + * * 表示一层路径内的任意字符串,不可跨层级; + * ** 表示任意层路径; + * + * @param pattern 匹配规则 + * @param url 需要匹配的url + * @return + */ + public static boolean isMatch(String pattern, String url) + { + AntPathMatcher matcher = new AntPathMatcher(); + return matcher.match(pattern, url); + } + + @SuppressWarnings("unchecked") + public static <T> T cast(Object obj) + { + return (T) obj; + } + + /** + * 数字左边补齐0,使之达到指定长度。注意,如果数字转换为字符串后,长度大于size,则只保留 最后size个字符。 + * + * @param num 数字对象 + * @param size 字符串指定长度 + * @return 返回数字的字符串格式,该字符串为指定长度。 + */ + public static final String padl(final Number num, final int size) + { + return padl(num.toString(), size, '0'); + } + + /** + * 字符串左补齐。如果原始字符串s长度大于size,则只保留最后size个字符。 + * + * @param s 原始字符串 + * @param size 字符串指定长度 + * @param c 用于补齐的字符 + * @return 返回指定长度的字符串,由原字符串左补齐或截取得到。 + */ + public static final String padl(final String s, final int size, final char c) + { + final StringBuilder sb = new StringBuilder(size); + if (s != null) + { + final int len = s.length(); + if (s.length() <= size) + { + for (int i = size - len; i > 0; i--) + { + sb.append(c); + } + sb.append(s); + } + else + { + return s.substring(len - size, len); + } + } + else + { + for (int i = size; i > 0; i--) + { + sb.append(c); + } + } + return sb.toString(); + } +} \ No newline at end of file diff --git a/dc-common/src/main/java/com/dc/common/utils/Threads.java b/dc-common/src/main/java/com/dc/common/utils/Threads.java new file mode 100644 index 0000000..80eb2cc --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/utils/Threads.java @@ -0,0 +1,96 @@ +package com.dc.common.utils; + +import org.slf4j.Logger; +import org.slf4j.LoggerFactory; + +import java.util.concurrent.*; + +/** + * 线程相关工具类. + * + * @author win + */ +public class Threads +{ + private static final Logger logger = LoggerFactory.getLogger(Threads.class); + + /** + * sleep等待,单位为毫秒 + */ + public static void sleep(long milliseconds) + { + try + { + Thread.sleep(milliseconds); + } + catch (InterruptedException e) + { + return; + } + } + + /** + * 停止线程池 + * 先使用shutdown, 停止接收新任务并尝试完成所有已存在任务. + * 如果超时, 则调用shutdownNow, 取消在workQueue中Pending的任务,并中断所有阻塞函数. + * 如果仍然超時,則強制退出. + * 另对在shutdown时线程本身被调用中断做了处理. + */ + public static void shutdownAndAwaitTermination(ExecutorService pool) + { + if (pool != null && !pool.isShutdown()) + { + pool.shutdown(); + try + { + if (!pool.awaitTermination(120, TimeUnit.SECONDS)) + { + pool.shutdownNow(); + if (!pool.awaitTermination(120, TimeUnit.SECONDS)) + { + logger.info("Pool did not terminate"); + } + } + } + catch (InterruptedException ie) + { + pool.shutdownNow(); + Thread.currentThread().interrupt(); + } + } + } + + /** + * 打印线程异常信息 + */ + public static void printException(Runnable r, Throwable t) + { + if (t == null && r instanceof Future<?>) + { + try + { + Future<?> future = (Future<?>) r; + if (future.isDone()) + { + future.get(); + } + } + catch (CancellationException ce) + { + t = ce; + } + catch (ExecutionException ee) + { + t = ee.getCause(); + } + catch (InterruptedException ie) + { + Thread.currentThread().interrupt(); + } + } + if (t != null) + { + logger.error(t.getMessage(), t); + } + } +} diff --git a/dc-common/src/main/java/com/dc/common/utils/bean/BeanUtils.java b/dc-common/src/main/java/com/dc/common/utils/bean/BeanUtils.java new file mode 100644 index 0000000..120b9c9 --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/utils/bean/BeanUtils.java @@ -0,0 +1,110 @@ +package com.dc.common.utils.bean; + +import java.lang.reflect.Method; +import java.util.ArrayList; +import java.util.List; +import java.util.regex.Matcher; +import java.util.regex.Pattern; + +/** + * Bean 工具类 + * + * @author win + */ +public class BeanUtils extends org.springframework.beans.BeanUtils +{ + /** Bean方法名中属性名开始的下标 */ + private static final int BEAN_METHOD_PROP_INDEX = 3; + + /** * 匹配getter方法的正则表达式 */ + private static final Pattern GET_PATTERN = Pattern.compile("get(\\p{javaUpperCase}\\w*)"); + + /** * 匹配setter方法的正则表达式 */ + private static final Pattern SET_PATTERN = Pattern.compile("set(\\p{javaUpperCase}\\w*)"); + + /** + * Bean属性复制工具方法。 + * + * @param dest 目标对象 + * @param src 源对象 + */ + public static void copyBeanProp(Object dest, Object src) + { + try + { + copyProperties(src, dest); + } + catch (Exception e) + { + e.printStackTrace(); + } + } + + /** + * 获取对象的setter方法。 + * + * @param obj 对象 + * @return 对象的setter方法列表 + */ + public static List<Method> getSetterMethods(Object obj) + { + // setter方法列表 + List<Method> setterMethods = new ArrayList<Method>(); + + // 获取所有方法 + Method[] methods = obj.getClass().getMethods(); + + // 查找setter方法 + + for (Method method : methods) + { + Matcher m = SET_PATTERN.matcher(method.getName()); + if (m.matches() && (method.getParameterTypes().length == 1)) + { + setterMethods.add(method); + } + } + // 返回setter方法列表 + return setterMethods; + } + + /** + * 获取对象的getter方法。 + * + * @param obj 对象 + * @return 对象的getter方法列表 + */ + + public static List<Method> getGetterMethods(Object obj) + { + // getter方法列表 + List<Method> getterMethods = new ArrayList<Method>(); + // 获取所有方法 + Method[] methods = obj.getClass().getMethods(); + // 查找getter方法 + for (Method method : methods) + { + Matcher m = GET_PATTERN.matcher(method.getName()); + if (m.matches() && (method.getParameterTypes().length == 0)) + { + getterMethods.add(method); + } + } + // 返回getter方法列表 + return getterMethods; + } + + /** + * 检查Bean方法名中的属性名是否相等。<br> + * 如getName()和setName()属性名一样,getName()和setAge()属性名不一样。 + * + * @param m1 方法名1 + * @param m2 方法名2 + * @return 属性名一样返回true,否则返回false + */ + + public static boolean isMethodPropEquals(String m1, String m2) + { + return m1.substring(BEAN_METHOD_PROP_INDEX).equals(m2.substring(BEAN_METHOD_PROP_INDEX)); + } +} diff --git a/dc-common/src/main/java/com/dc/common/utils/bean/BeanValidators.java b/dc-common/src/main/java/com/dc/common/utils/bean/BeanValidators.java new file mode 100644 index 0000000..78b7102 --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/utils/bean/BeanValidators.java @@ -0,0 +1,24 @@ +package com.dc.common.utils.bean; + +import javax.validation.ConstraintViolation; +import javax.validation.ConstraintViolationException; +import javax.validation.Validator; +import java.util.Set; + +/** + * bean对象属性验证 + * + * @author win + */ +public class BeanValidators +{ + public static void validateWithException(Validator validator, Object object, Class<?>... groups) + throws ConstraintViolationException + { + Set<ConstraintViolation<Object>> constraintViolations = validator.validate(object, groups); + if (!constraintViolations.isEmpty()) + { + throw new ConstraintViolationException(constraintViolations); + } + } +} diff --git a/dc-common/src/main/java/com/dc/common/utils/file/FileTypeUtils.java b/dc-common/src/main/java/com/dc/common/utils/file/FileTypeUtils.java new file mode 100644 index 0000000..7180c0c --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/utils/file/FileTypeUtils.java @@ -0,0 +1,77 @@ +package com.dc.common.utils.file; + +import org.apache.commons.lang3.StringUtils; + +import java.io.File; + +/** + * 文件类型工具类 + * + * @author win + */ +public class FileTypeUtils +{ + /** + * 获取文件类型 + * <p> + * 例如: win.txt, 返回: txt + * + * @param file 文件名 + * @return 后缀(不含".") + */ + public static String getFileType(File file) + { + if (null == file) + { + return StringUtils.EMPTY; + } + return getFileType(file.getName()); + } + + /** + * 获取文件类型 + * <p> + * 例如: ruoyi.txt, 返回: txt + * + * @param fileName 文件名 + * @return 后缀(不含".") + */ + public static String getFileType(String fileName) + { + int separatorIndex = fileName.lastIndexOf("."); + if (separatorIndex < 0) + { + return ""; + } + return fileName.substring(separatorIndex + 1).toLowerCase(); + } + + /** + * 获取文件类型 + * + * @param photoByte 文件字节码 + * @return 后缀(不含".") + */ + public static String getFileExtendName(byte[] photoByte) + { + String strFileExtendName = "JPG"; + if ((photoByte[0] == 71) && (photoByte[1] == 73) && (photoByte[2] == 70) && (photoByte[3] == 56) + && ((photoByte[4] == 55) || (photoByte[4] == 57)) && (photoByte[5] == 97)) + { + strFileExtendName = "GIF"; + } + else if ((photoByte[6] == 74) && (photoByte[7] == 70) && (photoByte[8] == 73) && (photoByte[9] == 70)) + { + strFileExtendName = "JPG"; + } + else if ((photoByte[0] == 66) && (photoByte[1] == 77)) + { + strFileExtendName = "BMP"; + } + else if ((photoByte[1] == 80) && (photoByte[2] == 78) && (photoByte[3] == 71)) + { + strFileExtendName = "PNG"; + } + return strFileExtendName; + } +} \ No newline at end of file diff --git a/dc-common/src/main/java/com/dc/common/utils/file/FileUploadUtils.java b/dc-common/src/main/java/com/dc/common/utils/file/FileUploadUtils.java new file mode 100644 index 0000000..a9d562c --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/utils/file/FileUploadUtils.java @@ -0,0 +1,233 @@ +package com.dc.common.utils.file; + +import com.dc.common.utils.StringUtils; +import com.dc.common.utils.uuid.Seq; +import com.dc.common.config.WinConfig; +import com.dc.common.constant.Constants; +import com.dc.common.exception.file.FileNameLengthLimitExceededException; +import com.dc.common.exception.file.FileSizeLimitExceededException; +import com.dc.common.exception.file.InvalidExtensionException; +import com.dc.common.utils.DateUtils; +import org.apache.commons.io.FilenameUtils; +import org.springframework.web.multipart.MultipartFile; + +import java.io.File; +import java.io.IOException; +import java.nio.file.Paths; +import java.util.Objects; + +/** + * 文件上传工具类 + * + * @author win + */ +public class FileUploadUtils +{ + /** + * 默认大小 50M + */ + public static final long DEFAULT_MAX_SIZE = 50 * 1024 * 1024; + + /** + * 默认的文件名最大长度 100 + */ + public static final int DEFAULT_FILE_NAME_LENGTH = 100; + + /** + * 默认上传的地址 + */ + private static String defaultBaseDir = WinConfig.getProfile(); + + public static void setDefaultBaseDir(String defaultBaseDir) + { + FileUploadUtils.defaultBaseDir = defaultBaseDir; + } + + public static String getDefaultBaseDir() + { + return defaultBaseDir; + } + + /** + * 以默认配置进行文件上传 + * + * @param file 上传的文件 + * @return 文件名称 + * @throws Exception + */ + public static final String upload(MultipartFile file) throws IOException + { + try + { + return upload(getDefaultBaseDir(), file, MimeTypeUtils.DEFAULT_ALLOWED_EXTENSION); + } + catch (Exception e) + { + throw new IOException(e.getMessage(), e); + } + } + + /** + * 根据文件路径上传 + * + * @param baseDir 相对应用的基目录 + * @param file 上传的文件 + * @return 文件名称 + * @throws IOException + */ + public static final String upload(String baseDir, MultipartFile file) throws IOException + { + try + { + return upload(baseDir, file, MimeTypeUtils.DEFAULT_ALLOWED_EXTENSION); + } + catch (Exception e) + { + throw new IOException(e.getMessage(), e); + } + } + + /** + * 文件上传 + * + * @param baseDir 相对应用的基目录 + * @param file 上传的文件 + * @param allowedExtension 上传文件类型 + * @return 返回上传成功的文件名 + * @throws FileSizeLimitExceededException 如果超出最大大小 + * @throws FileNameLengthLimitExceededException 文件名太长 + * @throws IOException 比如读写文件出错时 + * @throws InvalidExtensionException 文件校验异常 + */ + public static final String upload(String baseDir, MultipartFile file, String[] allowedExtension) + throws FileSizeLimitExceededException, IOException, FileNameLengthLimitExceededException, + InvalidExtensionException + { + int fileNamelength = Objects.requireNonNull(file.getOriginalFilename()).length(); + if (fileNamelength > FileUploadUtils.DEFAULT_FILE_NAME_LENGTH) + { + throw new FileNameLengthLimitExceededException(FileUploadUtils.DEFAULT_FILE_NAME_LENGTH); + } + + assertAllowed(file, allowedExtension); + + String fileName = extractFilename(file); + + String absPath = getAbsoluteFile(baseDir, fileName).getAbsolutePath(); + file.transferTo(Paths.get(absPath)); + return getPathFileName(baseDir, fileName); + } + + /** + * 编码文件名 + */ + public static final String extractFilename(MultipartFile file) + { + return StringUtils.format("{}/{}_{}.{}", DateUtils.datePath(), + FilenameUtils.getBaseName(file.getOriginalFilename()), Seq.getId(Seq.uploadSeqType), getExtension(file)); + } + + public static final File getAbsoluteFile(String uploadDir, String fileName) throws IOException + { + File desc = new File(uploadDir + File.separator + fileName); + + if (!desc.exists()) + { + if (!desc.getParentFile().exists()) + { + desc.getParentFile().mkdirs(); + } + } + return desc; + } + + public static final String getPathFileName(String uploadDir, String fileName) throws IOException + { + int dirLastIndex = WinConfig.getProfile().length() + 1; + String currentDir = StringUtils.substring(uploadDir, dirLastIndex); + return Constants.RESOURCE_PREFIX + "/" + currentDir + "/" + fileName; + } + + /** + * 文件大小校验 + * + * @param file 上传的文件 + * @return + * @throws FileSizeLimitExceededException 如果超出最大大小 + * @throws InvalidExtensionException + */ + public static final void assertAllowed(MultipartFile file, String[] allowedExtension) + throws FileSizeLimitExceededException, InvalidExtensionException + { + long size = file.getSize(); + if (size > DEFAULT_MAX_SIZE) + { + throw new FileSizeLimitExceededException(DEFAULT_MAX_SIZE / 1024 / 1024); + } + + String fileName = file.getOriginalFilename(); + String extension = getExtension(file); + if (allowedExtension != null && !isAllowedExtension(extension, allowedExtension)) + { + if (allowedExtension == MimeTypeUtils.IMAGE_EXTENSION) + { + throw new InvalidExtensionException.InvalidImageExtensionException(allowedExtension, extension, + fileName); + } + else if (allowedExtension == MimeTypeUtils.FLASH_EXTENSION) + { + throw new InvalidExtensionException.InvalidFlashExtensionException(allowedExtension, extension, + fileName); + } + else if (allowedExtension == MimeTypeUtils.MEDIA_EXTENSION) + { + throw new InvalidExtensionException.InvalidMediaExtensionException(allowedExtension, extension, + fileName); + } + else if (allowedExtension == MimeTypeUtils.VIDEO_EXTENSION) + { + throw new InvalidExtensionException.InvalidVideoExtensionException(allowedExtension, extension, + fileName); + } + else + { + throw new InvalidExtensionException(allowedExtension, extension, fileName); + } + } + } + + /** + * 判断MIME类型是否是允许的MIME类型 + * + * @param extension + * @param allowedExtension + * @return + */ + public static final boolean isAllowedExtension(String extension, String[] allowedExtension) + { + for (String str : allowedExtension) + { + if (str.equalsIgnoreCase(extension)) + { + return true; + } + } + return false; + } + + /** + * 获取文件名的后缀 + * + * @param file 表单文件 + * @return 后缀名 + */ + public static final String getExtension(MultipartFile file) + { + String extension = FilenameUtils.getExtension(file.getOriginalFilename()); + if (StringUtils.isEmpty(extension)) + { + extension = MimeTypeUtils.getExtension(Objects.requireNonNull(file.getContentType())); + } + return extension; + } +} diff --git a/dc-common/src/main/java/com/dc/common/utils/file/FileUtils.java b/dc-common/src/main/java/com/dc/common/utils/file/FileUtils.java new file mode 100644 index 0000000..bd18dff --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/utils/file/FileUtils.java @@ -0,0 +1,286 @@ +package com.dc.common.utils.file; + +import com.dc.common.utils.StringUtils; +import com.dc.common.utils.uuid.IdUtils; +import com.dc.common.config.WinConfig; +import com.dc.common.utils.DateUtils; +import org.apache.commons.io.FilenameUtils; +import org.apache.commons.io.IOUtils; +import org.apache.commons.lang3.ArrayUtils; + +import javax.servlet.http.HttpServletRequest; +import javax.servlet.http.HttpServletResponse; +import java.io.*; +import java.net.URLEncoder; +import java.nio.charset.StandardCharsets; + +/** + * 文件处理工具类 + * + * @author win + */ +public class FileUtils +{ + public static String FILENAME_PATTERN = "[a-zA-Z0-9_\\-\\|\\.\\u4e00-\\u9fa5]+"; + + /** + * 输出指定文件的byte数组 + * + * @param filePath 文件路径 + * @param os 输出流 + * @return + */ + public static void writeBytes(String filePath, OutputStream os) throws IOException + { + FileInputStream fis = null; + try + { + File file = new File(filePath); + if (!file.exists()) + { + throw new FileNotFoundException(filePath); + } + fis = new FileInputStream(file); + byte[] b = new byte[1024]; + int length; + while ((length = fis.read(b)) > 0) + { + os.write(b, 0, length); + } + } + catch (IOException e) + { + throw e; + } + finally + { + IOUtils.close(os); + IOUtils.close(fis); + } + } + + /** + * 写数据到文件中 + * + * @param data 数据 + * @return 目标文件 + * @throws IOException IO异常 + */ + public static String writeImportBytes(byte[] data) throws IOException + { + return writeBytes(data, WinConfig.getImportPath()); + } + + /** + * 写数据到文件中 + * + * @param data 数据 + * @param uploadDir 目标文件 + * @return 目标文件 + * @throws IOException IO异常 + */ + public static String writeBytes(byte[] data, String uploadDir) throws IOException + { + FileOutputStream fos = null; + String pathName = ""; + try + { + String extension = getFileExtendName(data); + pathName = DateUtils.datePath() + "/" + IdUtils.fastUUID() + "." + extension; + File file = FileUploadUtils.getAbsoluteFile(uploadDir, pathName); + fos = new FileOutputStream(file); + fos.write(data); + } + finally + { + IOUtils.close(fos); + } + return FileUploadUtils.getPathFileName(uploadDir, pathName); + } + + /** + * 删除文件 + * + * @param filePath 文件 + * @return + */ + public static boolean deleteFile(String filePath) + { + boolean flag = false; + File file = new File(filePath); + // 路径为文件且不为空则进行删除 + if (file.isFile() && file.exists()) + { + flag = file.delete(); + } + return flag; + } + + /** + * 文件名称验证 + * + * @param filename 文件名称 + * @return true 正常 false 非法 + */ + public static boolean isValidFilename(String filename) + { + return filename.matches(FILENAME_PATTERN); + } + + /** + * 检查文件是否可下载 + * + * @param resource 需要下载的文件 + * @return true 正常 false 非法 + */ + public static boolean checkAllowDownload(String resource) + { + // 禁止目录上跳级别 + if (StringUtils.contains(resource, "..")) + { + return false; + } + + // 检查允许下载的文件规则 + if (ArrayUtils.contains(MimeTypeUtils.DEFAULT_ALLOWED_EXTENSION, FileTypeUtils.getFileType(resource))) + { + return true; + } + + // 不在允许下载的文件规则 + return false; + } + + /** + * 下载文件名重新编码 + * + * @param request 请求对象 + * @param fileName 文件名 + * @return 编码后的文件名 + */ + public static String setFileDownloadHeader(HttpServletRequest request, String fileName) throws UnsupportedEncodingException + { + final String agent = request.getHeader("USER-AGENT"); + String filename = fileName; + if (agent.contains("MSIE")) + { + // IE浏览器 + filename = URLEncoder.encode(filename, "utf-8"); + filename = filename.replace("+", " "); + } + else if (agent.contains("Firefox")) + { + // 火狐浏览器 + filename = new String(fileName.getBytes(), "ISO8859-1"); + } + else if (agent.contains("Chrome")) + { + // google浏览器 + filename = URLEncoder.encode(filename, "utf-8"); + } + else + { + // 其它浏览器 + filename = URLEncoder.encode(filename, "utf-8"); + } + return filename; + } + + /** + * 下载文件名重新编码 + * + * @param response 响应对象 + * @param realFileName 真实文件名 + */ + public static void setAttachmentResponseHeader(HttpServletResponse response, String realFileName) throws UnsupportedEncodingException + { + String percentEncodedFileName = percentEncode(realFileName); + + StringBuilder contentDispositionValue = new StringBuilder(); + contentDispositionValue.append("attachment; filename=") + .append(percentEncodedFileName) + .append(";") + .append("filename*=") + .append("utf-8''") + .append(percentEncodedFileName); + + response.addHeader("Access-Control-Expose-Headers", "Content-Disposition,download-filename"); + response.setHeader("Content-disposition", contentDispositionValue.toString()); + response.setHeader("download-filename", percentEncodedFileName); + } + + /** + * 百分号编码工具方法 + * + * @param s 需要百分号编码的字符串 + * @return 百分号编码后的字符串 + */ + public static String percentEncode(String s) throws UnsupportedEncodingException + { + String encode = URLEncoder.encode(s, StandardCharsets.UTF_8.toString()); + return encode.replaceAll("\\+", "%20"); + } + + /** + * 获取图像后缀 + * + * @param photoByte 图像数据 + * @return 后缀名 + */ + public static String getFileExtendName(byte[] photoByte) + { + String strFileExtendName = "jpg"; + if ((photoByte[0] == 71) && (photoByte[1] == 73) && (photoByte[2] == 70) && (photoByte[3] == 56) + && ((photoByte[4] == 55) || (photoByte[4] == 57)) && (photoByte[5] == 97)) + { + strFileExtendName = "gif"; + } + else if ((photoByte[6] == 74) && (photoByte[7] == 70) && (photoByte[8] == 73) && (photoByte[9] == 70)) + { + strFileExtendName = "jpg"; + } + else if ((photoByte[0] == 66) && (photoByte[1] == 77)) + { + strFileExtendName = "bmp"; + } + else if ((photoByte[1] == 80) && (photoByte[2] == 78) && (photoByte[3] == 71)) + { + strFileExtendName = "png"; + } + return strFileExtendName; + } + + /** + * 获取文件名称 /profile/upload/2022/04/16/ruoyi.png -- ruoyi.png + * + * @param fileName 路径名称 + * @return 没有文件路径的名称 + */ + public static String getName(String fileName) + { + if (fileName == null) + { + return null; + } + int lastUnixPos = fileName.lastIndexOf('/'); + int lastWindowsPos = fileName.lastIndexOf('\\'); + int index = Math.max(lastUnixPos, lastWindowsPos); + return fileName.substring(index + 1); + } + + /** + * 获取不带后缀文件名称 /profile/upload/2022/04/16/ruoyi.png -- ruoyi + * + * @param fileName 路径名称 + * @return 没有文件路径和后缀的名称 + */ + public static String getNameNotSuffix(String fileName) + { + if (fileName == null) + { + return null; + } + String baseName = FilenameUtils.getBaseName(fileName); + return baseName; + } +} diff --git a/dc-common/src/main/java/com/dc/common/utils/file/ImageUtils.java b/dc-common/src/main/java/com/dc/common/utils/file/ImageUtils.java new file mode 100644 index 0000000..9525815 --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/utils/file/ImageUtils.java @@ -0,0 +1,99 @@ +package com.dc.common.utils.file; + +import com.dc.common.utils.StringUtils; +import com.dc.common.config.WinConfig; +import com.dc.common.constant.Constants; +import org.apache.poi.util.IOUtils; +import org.slf4j.Logger; +import org.slf4j.LoggerFactory; + +import java.io.ByteArrayInputStream; +import java.io.FileInputStream; +import java.io.InputStream; +import java.net.URL; +import java.net.URLConnection; +import java.util.Arrays; + +/** + * 图片处理工具类 + * + * @author win + */ +public class ImageUtils +{ + private static final Logger log = LoggerFactory.getLogger(ImageUtils.class); + + public static byte[] getImage(String imagePath) + { + InputStream is = getFile(imagePath); + try + { + return IOUtils.toByteArray(is); + } + catch (Exception e) + { + log.error("图片加载异常 {}", e); + return null; + } + finally + { + IOUtils.closeQuietly(is); + } + } + + public static InputStream getFile(String imagePath) + { + try + { + byte[] result = readFile(imagePath); + result = Arrays.copyOf(result, result.length); + return new ByteArrayInputStream(result); + } + catch (Exception e) + { + log.error("获取图片异常 {}", e); + } + return null; + } + + /** + * 读取文件为字节数据 + * + * @param url 地址 + * @return 字节数据 + */ + public static byte[] readFile(String url) + { + InputStream in = null; + try + { + if (url.startsWith("http")) + { + // 网络地址 + URL urlObj = new URL(url); + URLConnection urlConnection = urlObj.openConnection(); + urlConnection.setConnectTimeout(30 * 1000); + urlConnection.setReadTimeout(60 * 1000); + urlConnection.setDoInput(true); + in = urlConnection.getInputStream(); + } + else + { + // 本机地址 + String localPath = WinConfig.getProfile(); + String downloadPath = localPath + StringUtils.substringAfter(url, Constants.RESOURCE_PREFIX); + in = new FileInputStream(downloadPath); + } + return IOUtils.toByteArray(in); + } + catch (Exception e) + { + log.error("获取文件路径异常 {}", e); + return null; + } + finally + { + IOUtils.closeQuietly(in); + } + } +} diff --git a/dc-common/src/main/java/com/dc/common/utils/file/MimeTypeUtils.java b/dc-common/src/main/java/com/dc/common/utils/file/MimeTypeUtils.java new file mode 100644 index 0000000..92ac020 --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/utils/file/MimeTypeUtils.java @@ -0,0 +1,59 @@ +package com.dc.common.utils.file; + +/** + * 媒体类型工具类 + * + * @author win + */ +public class MimeTypeUtils +{ + public static final String IMAGE_PNG = "image/png"; + + public static final String IMAGE_JPG = "image/jpg"; + + public static final String IMAGE_JPEG = "image/jpeg"; + + public static final String IMAGE_BMP = "image/bmp"; + + public static final String IMAGE_GIF = "image/gif"; + + public static final String[] IMAGE_EXTENSION = { "bmp", "gif", "jpg", "jpeg", "png" }; + + public static final String[] FLASH_EXTENSION = { "swf", "flv" }; + + public static final String[] MEDIA_EXTENSION = { "swf", "flv", "mp3", "wav", "wma", "wmv", "mid", "avi", "mpg", + "asf", "rm", "rmvb" }; + + public static final String[] VIDEO_EXTENSION = { "mp4", "avi", "rmvb" }; + + public static final String[] DEFAULT_ALLOWED_EXTENSION = { + // 图片 + "bmp", "gif", "jpg", "jpeg", "png", + // word excel powerpoint + "doc", "docx", "xls", "xlsx", "ppt", "pptx", "html", "htm", "txt", + // 压缩文件 + "rar", "zip", "gz", "bz2", + // 视频格式 + "mp4", "avi", "rmvb", + // pdf + "pdf" }; + + public static String getExtension(String prefix) + { + switch (prefix) + { + case IMAGE_PNG: + return "png"; + case IMAGE_JPG: + return "jpg"; + case IMAGE_JPEG: + return "jpeg"; + case IMAGE_BMP: + return "bmp"; + case IMAGE_GIF: + return "gif"; + default: + return ""; + } + } +} diff --git a/dc-common/src/main/java/com/dc/common/utils/html/EscapeUtil.java b/dc-common/src/main/java/com/dc/common/utils/html/EscapeUtil.java new file mode 100644 index 0000000..0e865f5 --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/utils/html/EscapeUtil.java @@ -0,0 +1,167 @@ +package com.dc.common.utils.html; + +import com.dc.common.utils.StringUtils; + +/** + * 转义和反转义工具类 + * + * @author win + */ +public class EscapeUtil +{ + public static final String RE_HTML_MARK = "(<[^<]*?>)|(<[\\s]*?/[^<]*?>)|(<[^<]*?/[\\s]*?>)"; + + private static final char[][] TEXT = new char[64][]; + + static + { + for (int i = 0; i < 64; i++) + { + TEXT[i] = new char[] { (char) i }; + } + + // special HTML characters + TEXT['\''] = "'".toCharArray(); // 单引号 + TEXT['"'] = """.toCharArray(); // 双引号 + TEXT['&'] = "&".toCharArray(); // &符 + TEXT['<'] = "<".toCharArray(); // 小于号 + TEXT['>'] = ">".toCharArray(); // 大于号 + } + + /** + * 转义文本中的HTML字符为安全的字符 + * + * @param text 被转义的文本 + * @return 转义后的文本 + */ + public static String escape(String text) + { + return encode(text); + } + + /** + * 还原被转义的HTML特殊字符 + * + * @param content 包含转义符的HTML内容 + * @return 转换后的字符串 + */ + public static String unescape(String content) + { + return decode(content); + } + + /** + * 清除所有HTML标签,但是不删除标签内的内容 + * + * @param content 文本 + * @return 清除标签后的文本 + */ + public static String clean(String content) + { + return new HTMLFilter().filter(content); + } + + /** + * Escape编码 + * + * @param text 被编码的文本 + * @return 编码后的字符 + */ + private static String encode(String text) + { + if (StringUtils.isEmpty(text)) + { + return StringUtils.EMPTY; + } + + final StringBuilder tmp = new StringBuilder(text.length() * 6); + char c; + for (int i = 0; i < text.length(); i++) + { + c = text.charAt(i); + if (c < 256) + { + tmp.append("%"); + if (c < 16) + { + tmp.append("0"); + } + tmp.append(Integer.toString(c, 16)); + } + else + { + tmp.append("%u"); + if (c <= 0xfff) + { + // issue#I49JU8@Gitee + tmp.append("0"); + } + tmp.append(Integer.toString(c, 16)); + } + } + return tmp.toString(); + } + + /** + * Escape解码 + * + * @param content 被转义的内容 + * @return 解码后的字符串 + */ + public static String decode(String content) + { + if (StringUtils.isEmpty(content)) + { + return content; + } + + StringBuilder tmp = new StringBuilder(content.length()); + int lastPos = 0, pos = 0; + char ch; + while (lastPos < content.length()) + { + pos = content.indexOf("%", lastPos); + if (pos == lastPos) + { + if (content.charAt(pos + 1) == 'u') + { + ch = (char) Integer.parseInt(content.substring(pos + 2, pos + 6), 16); + tmp.append(ch); + lastPos = pos + 6; + } + else + { + ch = (char) Integer.parseInt(content.substring(pos + 1, pos + 3), 16); + tmp.append(ch); + lastPos = pos + 3; + } + } + else + { + if (pos == -1) + { + tmp.append(content.substring(lastPos)); + lastPos = content.length(); + } + else + { + tmp.append(content.substring(lastPos, pos)); + lastPos = pos; + } + } + } + return tmp.toString(); + } + + public static void main(String[] args) + { + String html = "<script>alert(1);</script>"; + String escape = EscapeUtil.escape(html); + // String html = "<scr<script>ipt>alert(\"XSS\")</scr<script>ipt>"; + // String html = "<123"; + // String html = "123>"; + System.out.println("clean: " + EscapeUtil.clean(html)); + System.out.println("escape: " + escape); + System.out.println("unescape: " + EscapeUtil.unescape(escape)); + } +} diff --git a/dc-common/src/main/java/com/dc/common/utils/html/HTMLFilter.java b/dc-common/src/main/java/com/dc/common/utils/html/HTMLFilter.java new file mode 100644 index 0000000..498360c --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/utils/html/HTMLFilter.java @@ -0,0 +1,570 @@ +package com.dc.common.utils.html; + +import java.util.ArrayList; +import java.util.Collections; +import java.util.HashMap; +import java.util.List; +import java.util.Map; +import java.util.concurrent.ConcurrentHashMap; +import java.util.concurrent.ConcurrentMap; +import java.util.regex.Matcher; +import java.util.regex.Pattern; + +/** + * HTML过滤器,用于去除XSS漏洞隐患。 + * + * @author win + */ +public final class HTMLFilter +{ + /** + * regex flag union representing /si modifiers in php + **/ + private static final int REGEX_FLAGS_SI = Pattern.CASE_INSENSITIVE | Pattern.DOTALL; + private static final Pattern P_COMMENTS = Pattern.compile("<!--(.*?)-->", Pattern.DOTALL); + private static final Pattern P_COMMENT = Pattern.compile("^!--(.*)--$", REGEX_FLAGS_SI); + private static final Pattern P_TAGS = Pattern.compile("<(.*?)>", Pattern.DOTALL); + private static final Pattern P_END_TAG = Pattern.compile("^/([a-z0-9]+)", REGEX_FLAGS_SI); + private static final Pattern P_START_TAG = Pattern.compile("^([a-z0-9]+)(.*?)(/?)$", REGEX_FLAGS_SI); + private static final Pattern P_QUOTED_ATTRIBUTES = Pattern.compile("([a-z0-9]+)=([\"'])(.*?)\\2", REGEX_FLAGS_SI); + private static final Pattern P_UNQUOTED_ATTRIBUTES = Pattern.compile("([a-z0-9]+)(=)([^\"\\s']+)", REGEX_FLAGS_SI); + private static final Pattern P_PROTOCOL = Pattern.compile("^([^:]+):", REGEX_FLAGS_SI); + private static final Pattern P_ENTITY = Pattern.compile("&#(\\d+);?"); + private static final Pattern P_ENTITY_UNICODE = Pattern.compile("&#x([0-9a-f]+);?"); + private static final Pattern P_ENCODE = Pattern.compile("%([0-9a-f]{2});?"); + private static final Pattern P_VALID_ENTITIES = Pattern.compile("&([^&;]*)(?=(;|&|$))"); + private static final Pattern P_VALID_QUOTES = Pattern.compile("(>|^)([^<]+?)(<|$)", Pattern.DOTALL); + private static final Pattern P_END_ARROW = Pattern.compile("^>"); + private static final Pattern P_BODY_TO_END = Pattern.compile("<([^>]*?)(?=<|$)"); + private static final Pattern P_XML_CONTENT = Pattern.compile("(^|>)([^<]*?)(?=>)"); + private static final Pattern P_STRAY_LEFT_ARROW = Pattern.compile("<([^>]*?)(?=<|$)"); + private static final Pattern P_STRAY_RIGHT_ARROW = Pattern.compile("(^|>)([^<]*?)(?=>)"); + private static final Pattern P_AMP = Pattern.compile("&"); + private static final Pattern P_QUOTE = Pattern.compile("\""); + private static final Pattern P_LEFT_ARROW = Pattern.compile("<"); + private static final Pattern P_RIGHT_ARROW = Pattern.compile(">"); + private static final Pattern P_BOTH_ARROWS = Pattern.compile("<>"); + + // @xxx could grow large... maybe use sesat's ReferenceMap + private static final ConcurrentMap<String, Pattern> P_REMOVE_PAIR_BLANKS = new ConcurrentHashMap<>(); + private static final ConcurrentMap<String, Pattern> P_REMOVE_SELF_BLANKS = new ConcurrentHashMap<>(); + + /** + * set of allowed html elements, along with allowed attributes for each element + **/ + private final Map<String, List<String>> vAllowed; + /** + * counts of open tags for each (allowable) html element + **/ + private final Map<String, Integer> vTagCounts = new HashMap<>(); + + /** + * html elements which must always be self-closing (e.g. "<img />") + **/ + private final String[] vSelfClosingTags; + /** + * html elements which must always have separate opening and closing tags (e.g. "<b></b>") + **/ + private final String[] vNeedClosingTags; + /** + * set of disallowed html elements + **/ + private final String[] vDisallowed; + /** + * attributes which should be checked for valid protocols + **/ + private final String[] vProtocolAtts; + /** + * allowed protocols + **/ + private final String[] vAllowedProtocols; + /** + * tags which should be removed if they contain no content (e.g. "<b></b>" or "<b />") + **/ + private final String[] vRemoveBlanks; + /** + * entities allowed within html markup + **/ + private final String[] vAllowedEntities; + /** + * flag determining whether comments are allowed in input String. + */ + private final boolean stripComment; + private final boolean encodeQuotes; + /** + * flag determining whether to try to make tags when presented with "unbalanced" angle brackets (e.g. "<b text </b>" + * becomes "<b> text </b>"). If set to false, unbalanced angle brackets will be html escaped. + */ + private final boolean alwaysMakeTags; + + /** + * Default constructor. + */ + public HTMLFilter() + { + vAllowed = new HashMap<>(); + + final ArrayList<String> a_atts = new ArrayList<>(); + a_atts.add("href"); + a_atts.add("target"); + vAllowed.put("a", a_atts); + + final ArrayList<String> img_atts = new ArrayList<>(); + img_atts.add("src"); + img_atts.add("width"); + img_atts.add("height"); + img_atts.add("alt"); + vAllowed.put("img", img_atts); + + final ArrayList<String> no_atts = new ArrayList<>(); + vAllowed.put("b", no_atts); + vAllowed.put("strong", no_atts); + vAllowed.put("i", no_atts); + vAllowed.put("em", no_atts); + + vSelfClosingTags = new String[] { "img" }; + vNeedClosingTags = new String[] { "a", "b", "strong", "i", "em" }; + vDisallowed = new String[] {}; + vAllowedProtocols = new String[] { "http", "mailto", "https" }; // no ftp. + vProtocolAtts = new String[] { "src", "href" }; + vRemoveBlanks = new String[] { "a", "b", "strong", "i", "em" }; + vAllowedEntities = new String[] { "amp", "gt", "lt", "quot" }; + stripComment = true; + encodeQuotes = true; + alwaysMakeTags = false; + } + + /** + * Map-parameter configurable constructor. + * + * @param conf map containing configuration. keys match field names. + */ + @SuppressWarnings("unchecked") + public HTMLFilter(final Map<String, Object> conf) + { + + assert conf.containsKey("vAllowed") : "configuration requires vAllowed"; + assert conf.containsKey("vSelfClosingTags") : "configuration requires vSelfClosingTags"; + assert conf.containsKey("vNeedClosingTags") : "configuration requires vNeedClosingTags"; + assert conf.containsKey("vDisallowed") : "configuration requires vDisallowed"; + assert conf.containsKey("vAllowedProtocols") : "configuration requires vAllowedProtocols"; + assert conf.containsKey("vProtocolAtts") : "configuration requires vProtocolAtts"; + assert conf.containsKey("vRemoveBlanks") : "configuration requires vRemoveBlanks"; + assert conf.containsKey("vAllowedEntities") : "configuration requires vAllowedEntities"; + + vAllowed = Collections.unmodifiableMap((HashMap<String, List<String>>) conf.get("vAllowed")); + vSelfClosingTags = (String[]) conf.get("vSelfClosingTags"); + vNeedClosingTags = (String[]) conf.get("vNeedClosingTags"); + vDisallowed = (String[]) conf.get("vDisallowed"); + vAllowedProtocols = (String[]) conf.get("vAllowedProtocols"); + vProtocolAtts = (String[]) conf.get("vProtocolAtts"); + vRemoveBlanks = (String[]) conf.get("vRemoveBlanks"); + vAllowedEntities = (String[]) conf.get("vAllowedEntities"); + stripComment = conf.containsKey("stripComment") ? (Boolean) conf.get("stripComment") : true; + encodeQuotes = conf.containsKey("encodeQuotes") ? (Boolean) conf.get("encodeQuotes") : true; + alwaysMakeTags = conf.containsKey("alwaysMakeTags") ? (Boolean) conf.get("alwaysMakeTags") : true; + } + + private void reset() + { + vTagCounts.clear(); + } + + // --------------------------------------------------------------- + // my versions of some PHP library functions + public static String chr(final int decimal) + { + return String.valueOf((char) decimal); + } + + public static String htmlSpecialChars(final String s) + { + String result = s; + result = regexReplace(P_AMP, "&", result); + result = regexReplace(P_QUOTE, """, result); + result = regexReplace(P_LEFT_ARROW, "<", result); + result = regexReplace(P_RIGHT_ARROW, ">", result); + return result; + } + + // --------------------------------------------------------------- + + /** + * given a user submitted input String, filter out any invalid or restricted html. + * + * @param input text (i.e. submitted by a user) than may contain html + * @return "clean" version of input, with only valid, whitelisted html elements allowed + */ + public String filter(final String input) + { + reset(); + String s = input; + + s = escapeComments(s); + + s = balanceHTML(s); + + s = checkTags(s); + + s = processRemoveBlanks(s); + + // s = validateEntities(s); + + return s; + } + + public boolean isAlwaysMakeTags() + { + return alwaysMakeTags; + } + + public boolean isStripComments() + { + return stripComment; + } + + private String escapeComments(final String s) + { + final Matcher m = P_COMMENTS.matcher(s); + final StringBuffer buf = new StringBuffer(); + if (m.find()) + { + final String match = m.group(1); // (.*?) + m.appendReplacement(buf, Matcher.quoteReplacement("<!--" + htmlSpecialChars(match) + "-->")); + } + m.appendTail(buf); + + return buf.toString(); + } + + private String balanceHTML(String s) + { + if (alwaysMakeTags) + { + // + // try and form html + // + s = regexReplace(P_END_ARROW, "", s); + // 不追加结束标签 + s = regexReplace(P_BODY_TO_END, "<$1>", s); + s = regexReplace(P_XML_CONTENT, "$1<$2", s); + + } + else + { + // + // escape stray brackets + // + s = regexReplace(P_STRAY_LEFT_ARROW, "<$1", s); + s = regexReplace(P_STRAY_RIGHT_ARROW, "$1$2><", s); + + // + // the last regexp causes '<>' entities to appear + // (we need to do a lookahead assertion so that the last bracket can + // be used in the next pass of the regexp) + // + s = regexReplace(P_BOTH_ARROWS, "", s); + } + + return s; + } + + private String checkTags(String s) + { + Matcher m = P_TAGS.matcher(s); + + final StringBuffer buf = new StringBuffer(); + while (m.find()) + { + String replaceStr = m.group(1); + replaceStr = processTag(replaceStr); + m.appendReplacement(buf, Matcher.quoteReplacement(replaceStr)); + } + m.appendTail(buf); + + // these get tallied in processTag + // (remember to reset before subsequent calls to filter method) + final StringBuilder sBuilder = new StringBuilder(buf.toString()); + for (String key : vTagCounts.keySet()) + { + for (int ii = 0; ii < vTagCounts.get(key); ii++) + { + sBuilder.append("</").append(key).append(">"); + } + } + s = sBuilder.toString(); + + return s; + } + + private String processRemoveBlanks(final String s) + { + String result = s; + for (String tag : vRemoveBlanks) + { + if (!P_REMOVE_PAIR_BLANKS.containsKey(tag)) + { + P_REMOVE_PAIR_BLANKS.putIfAbsent(tag, Pattern.compile("<" + tag + "(\\s[^>]*)?></" + tag + ">")); + } + result = regexReplace(P_REMOVE_PAIR_BLANKS.get(tag), "", result); + if (!P_REMOVE_SELF_BLANKS.containsKey(tag)) + { + P_REMOVE_SELF_BLANKS.putIfAbsent(tag, Pattern.compile("<" + tag + "(\\s[^>]*)?/>")); + } + result = regexReplace(P_REMOVE_SELF_BLANKS.get(tag), "", result); + } + + return result; + } + + private static String regexReplace(final Pattern regex_pattern, final String replacement, final String s) + { + Matcher m = regex_pattern.matcher(s); + return m.replaceAll(replacement); + } + + private String processTag(final String s) + { + // ending tags + Matcher m = P_END_TAG.matcher(s); + if (m.find()) + { + final String name = m.group(1).toLowerCase(); + if (allowed(name)) + { + if (!inArray(name, vSelfClosingTags)) + { + if (vTagCounts.containsKey(name)) + { + vTagCounts.put(name, vTagCounts.get(name) - 1); + return "</" + name + ">"; + } + } + } + } + + // starting tags + m = P_START_TAG.matcher(s); + if (m.find()) + { + final String name = m.group(1).toLowerCase(); + final String body = m.group(2); + String ending = m.group(3); + + // debug( "in a starting tag, name='" + name + "'; body='" + body + "'; ending='" + ending + "'" ); + if (allowed(name)) + { + final StringBuilder params = new StringBuilder(); + + final Matcher m2 = P_QUOTED_ATTRIBUTES.matcher(body); + final Matcher m3 = P_UNQUOTED_ATTRIBUTES.matcher(body); + final List<String> paramNames = new ArrayList<>(); + final List<String> paramValues = new ArrayList<>(); + while (m2.find()) + { + paramNames.add(m2.group(1)); // ([a-z0-9]+) + paramValues.add(m2.group(3)); // (.*?) + } + while (m3.find()) + { + paramNames.add(m3.group(1)); // ([a-z0-9]+) + paramValues.add(m3.group(3)); // ([^\"\\s']+) + } + + String paramName, paramValue; + for (int ii = 0; ii < paramNames.size(); ii++) + { + paramName = paramNames.get(ii).toLowerCase(); + paramValue = paramValues.get(ii); + + // debug( "paramName='" + paramName + "'" ); + // debug( "paramValue='" + paramValue + "'" ); + // debug( "allowed? " + vAllowed.get( name ).contains( paramName ) ); + + if (allowedAttribute(name, paramName)) + { + if (inArray(paramName, vProtocolAtts)) + { + paramValue = processParamProtocol(paramValue); + } + params.append(' ').append(paramName).append("=\\\"").append(paramValue).append("\\\""); + } + } + + if (inArray(name, vSelfClosingTags)) + { + ending = " /"; + } + + if (inArray(name, vNeedClosingTags)) + { + ending = ""; + } + + if (ending == null || ending.length() < 1) + { + if (vTagCounts.containsKey(name)) + { + vTagCounts.put(name, vTagCounts.get(name) + 1); + } + else + { + vTagCounts.put(name, 1); + } + } + else + { + ending = " /"; + } + return "<" + name + params + ending + ">"; + } + else + { + return ""; + } + } + + // comments + m = P_COMMENT.matcher(s); + if (!stripComment && m.find()) + { + return "<" + m.group() + ">"; + } + + return ""; + } + + private String processParamProtocol(String s) + { + s = decodeEntities(s); + final Matcher m = P_PROTOCOL.matcher(s); + if (m.find()) + { + final String protocol = m.group(1); + if (!inArray(protocol, vAllowedProtocols)) + { + // bad protocol, turn into local anchor link instead + s = "#" + s.substring(protocol.length() + 1); + if (s.startsWith("#//")) + { + s = "#" + s.substring(3); + } + } + } + + return s; + } + + private String decodeEntities(String s) + { + StringBuffer buf = new StringBuffer(); + + Matcher m = P_ENTITY.matcher(s); + while (m.find()) + { + final String match = m.group(1); + final int decimal = Integer.decode(match).intValue(); + m.appendReplacement(buf, Matcher.quoteReplacement(chr(decimal))); + } + m.appendTail(buf); + s = buf.toString(); + + buf = new StringBuffer(); + m = P_ENTITY_UNICODE.matcher(s); + while (m.find()) + { + final String match = m.group(1); + final int decimal = Integer.valueOf(match, 16).intValue(); + m.appendReplacement(buf, Matcher.quoteReplacement(chr(decimal))); + } + m.appendTail(buf); + s = buf.toString(); + + buf = new StringBuffer(); + m = P_ENCODE.matcher(s); + while (m.find()) + { + final String match = m.group(1); + final int decimal = Integer.valueOf(match, 16).intValue(); + m.appendReplacement(buf, Matcher.quoteReplacement(chr(decimal))); + } + m.appendTail(buf); + s = buf.toString(); + + s = validateEntities(s); + return s; + } + + private String validateEntities(final String s) + { + StringBuffer buf = new StringBuffer(); + + // validate entities throughout the string + Matcher m = P_VALID_ENTITIES.matcher(s); + while (m.find()) + { + final String one = m.group(1); // ([^&;]*) + final String two = m.group(2); // (?=(;|&|$)) + m.appendReplacement(buf, Matcher.quoteReplacement(checkEntity(one, two))); + } + m.appendTail(buf); + + return encodeQuotes(buf.toString()); + } + + private String encodeQuotes(final String s) + { + if (encodeQuotes) + { + StringBuffer buf = new StringBuffer(); + Matcher m = P_VALID_QUOTES.matcher(s); + while (m.find()) + { + final String one = m.group(1); // (>|^) + final String two = m.group(2); // ([^<]+?) + final String three = m.group(3); // (<|$) + // 不替换双引号为",防止json格式无效 regexReplace(P_QUOTE, """, two) + m.appendReplacement(buf, Matcher.quoteReplacement(one + two + three)); + } + m.appendTail(buf); + return buf.toString(); + } + else + { + return s; + } + } + + private String checkEntity(final String preamble, final String term) + { + + return ";".equals(term) && isValidEntity(preamble) ? '&' + preamble : "&" + preamble; + } + + private boolean isValidEntity(final String entity) + { + return inArray(entity, vAllowedEntities); + } + + private static boolean inArray(final String s, final String[] array) + { + for (String item : array) + { + if (item != null && item.equals(s)) + { + return true; + } + } + return false; + } + + private boolean allowed(final String name) + { + return (vAllowed.isEmpty() || vAllowed.containsKey(name)) && !inArray(name, vDisallowed); + } + + private boolean allowedAttribute(final String name, final String paramName) + { + return allowed(name) && (vAllowed.isEmpty() || vAllowed.get(name).contains(paramName)); + } +} \ No newline at end of file diff --git a/dc-common/src/main/java/com/dc/common/utils/http/HttpHelper.java b/dc-common/src/main/java/com/dc/common/utils/http/HttpHelper.java new file mode 100644 index 0000000..a5356e7 --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/utils/http/HttpHelper.java @@ -0,0 +1,56 @@ +package com.dc.common.utils.http; + +import org.apache.commons.lang3.exception.ExceptionUtils; +import org.slf4j.Logger; +import org.slf4j.LoggerFactory; + +import javax.servlet.ServletRequest; +import java.io.BufferedReader; +import java.io.IOException; +import java.io.InputStream; +import java.io.InputStreamReader; +import java.nio.charset.StandardCharsets; + +/** + * 通用http工具封装 + * + * @author win + */ +public class HttpHelper +{ + private static final Logger LOGGER = LoggerFactory.getLogger(HttpHelper.class); + + public static String getBodyString(ServletRequest request) + { + StringBuilder sb = new StringBuilder(); + BufferedReader reader = null; + try (InputStream inputStream = request.getInputStream()) + { + reader = new BufferedReader(new InputStreamReader(inputStream, StandardCharsets.UTF_8)); + String line = ""; + while ((line = reader.readLine()) != null) + { + sb.append(line); + } + } + catch (IOException e) + { + LOGGER.warn("getBodyString出现问题!"); + } + finally + { + if (reader != null) + { + try + { + reader.close(); + } + catch (IOException e) + { + LOGGER.error(ExceptionUtils.getMessage(e)); + } + } + } + return sb.toString(); + } +} diff --git a/dc-common/src/main/java/com/dc/common/utils/http/HttpUtils.java b/dc-common/src/main/java/com/dc/common/utils/http/HttpUtils.java new file mode 100644 index 0000000..83512d0 --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/utils/http/HttpUtils.java @@ -0,0 +1,266 @@ +package com.dc.common.utils.http; + +import com.dc.common.utils.StringUtils; +import com.dc.common.constant.Constants; +import org.slf4j.Logger; +import org.slf4j.LoggerFactory; + +import javax.net.ssl.*; +import java.io.*; +import java.net.ConnectException; +import java.net.SocketTimeoutException; +import java.net.URL; +import java.net.URLConnection; +import java.nio.charset.StandardCharsets; +import java.security.cert.X509Certificate; + +/** + * 通用http发送方法 + * + * @author win + */ +public class HttpUtils +{ + private static final Logger log = LoggerFactory.getLogger(HttpUtils.class); + + /** + * 向指定 URL 发送GET方法的请求 + * + * @param url 发送请求的 URL + * @return 所代表远程资源的响应结果 + */ + public static String sendGet(String url) + { + return sendGet(url, StringUtils.EMPTY); + } + + /** + * 向指定 URL 发送GET方法的请求 + * + * @param url 发送请求的 URL + * @param param 请求参数,请求参数应该是 name1=value1&name2=value2 的形式。 + * @return 所代表远程资源的响应结果 + */ + public static String sendGet(String url, String param) + { + return sendGet(url, param, Constants.UTF8); + } + + /** + * 向指定 URL 发送GET方法的请求 + * + * @param url 发送请求的 URL + * @param param 请求参数,请求参数应该是 name1=value1&name2=value2 的形式。 + * @param contentType 编码类型 + * @return 所代表远程资源的响应结果 + */ + public static String sendGet(String url, String param, String contentType) + { + StringBuilder result = new StringBuilder(); + BufferedReader in = null; + try + { + String urlNameString = StringUtils.isNotBlank(param) ? url + "?" + param : url; + log.info("sendGet - {}", urlNameString); + URL realUrl = new URL(urlNameString); + URLConnection connection = realUrl.openConnection(); + connection.setRequestProperty("accept", "*/*"); + connection.setRequestProperty("connection", "Keep-Alive"); + connection.setRequestProperty("user-agent", "Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1;SV1)"); + connection.connect(); + in = new BufferedReader(new InputStreamReader(connection.getInputStream(), contentType)); + String line; + while ((line = in.readLine()) != null) + { + result.append(line); + } + log.info("recv - {}", result); + } + catch (ConnectException e) + { + log.error("调用HttpUtils.sendGet ConnectException, url=" + url + ",param=" + param, e); + } + catch (SocketTimeoutException e) + { + log.error("调用HttpUtils.sendGet SocketTimeoutException, url=" + url + ",param=" + param, e); + } + catch (IOException e) + { + log.error("调用HttpUtils.sendGet IOException, url=" + url + ",param=" + param, e); + } + catch (Exception e) + { + log.error("调用HttpsUtil.sendGet Exception, url=" + url + ",param=" + param, e); + } + finally + { + try + { + if (in != null) + { + in.close(); + } + } + catch (Exception ex) + { + log.error("调用in.close Exception, url=" + url + ",param=" + param, ex); + } + } + return result.toString(); + } + + /** + * 向指定 URL 发送POST方法的请求 + * + * @param url 发送请求的 URL + * @param param 请求参数,请求参数应该是 name1=value1&name2=value2 的形式。 + * @return 所代表远程资源的响应结果 + */ + public static String sendPost(String url, String param) + { + PrintWriter out = null; + BufferedReader in = null; + StringBuilder result = new StringBuilder(); + try + { + log.info("sendPost - {}", url); + URL realUrl = new URL(url); + URLConnection conn = realUrl.openConnection(); + conn.setRequestProperty("accept", "*/*"); + conn.setRequestProperty("connection", "Keep-Alive"); + conn.setRequestProperty("user-agent", "Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1;SV1)"); + conn.setRequestProperty("Accept-Charset", "utf-8"); + conn.setRequestProperty("contentType", "utf-8"); + conn.setDoOutput(true); + conn.setDoInput(true); + out = new PrintWriter(conn.getOutputStream()); + out.print(param); + out.flush(); + in = new BufferedReader(new InputStreamReader(conn.getInputStream(), StandardCharsets.UTF_8)); + String line; + while ((line = in.readLine()) != null) + { + result.append(line); + } + log.info("recv - {}", result); + } + catch (ConnectException e) + { + log.error("调用HttpUtils.sendPost ConnectException, url=" + url + ",param=" + param, e); + } + catch (SocketTimeoutException e) + { + log.error("调用HttpUtils.sendPost SocketTimeoutException, url=" + url + ",param=" + param, e); + } + catch (IOException e) + { + log.error("调用HttpUtils.sendPost IOException, url=" + url + ",param=" + param, e); + } + catch (Exception e) + { + log.error("调用HttpsUtil.sendPost Exception, url=" + url + ",param=" + param, e); + } + finally + { + try + { + if (out != null) + { + out.close(); + } + if (in != null) + { + in.close(); + } + } + catch (IOException ex) + { + log.error("调用in.close Exception, url=" + url + ",param=" + param, ex); + } + } + return result.toString(); + } + + public static String sendSSLPost(String url, String param) + { + StringBuilder result = new StringBuilder(); + String urlNameString = url + "?" + param; + try + { + log.info("sendSSLPost - {}", urlNameString); + SSLContext sc = SSLContext.getInstance("SSL"); + sc.init(null, new TrustManager[] { new TrustAnyTrustManager() }, new java.security.SecureRandom()); + URL console = new URL(urlNameString); + HttpsURLConnection conn = (HttpsURLConnection) console.openConnection(); + conn.setRequestProperty("accept", "*/*"); + conn.setRequestProperty("connection", "Keep-Alive"); + conn.setRequestProperty("user-agent", "Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1;SV1)"); + conn.setRequestProperty("Accept-Charset", "utf-8"); + conn.setRequestProperty("contentType", "utf-8"); + conn.setDoOutput(true); + conn.setDoInput(true); + + conn.setSSLSocketFactory(sc.getSocketFactory()); + conn.setHostnameVerifier(new TrustAnyHostnameVerifier()); + conn.connect(); + InputStream is = conn.getInputStream(); + BufferedReader br = new BufferedReader(new InputStreamReader(is)); + String ret = ""; + while ((ret = br.readLine()) != null) + { + if (ret != null && !"".equals(ret.trim())) + { + result.append(new String(ret.getBytes(StandardCharsets.ISO_8859_1), StandardCharsets.UTF_8)); + } + } + log.info("recv - {}", result); + conn.disconnect(); + br.close(); + } + catch (ConnectException e) + { + log.error("调用HttpUtils.sendSSLPost ConnectException, url=" + url + ",param=" + param, e); + } + catch (SocketTimeoutException e) + { + log.error("调用HttpUtils.sendSSLPost SocketTimeoutException, url=" + url + ",param=" + param, e); + } + catch (IOException e) + { + log.error("调用HttpUtils.sendSSLPost IOException, url=" + url + ",param=" + param, e); + } + catch (Exception e) + { + log.error("调用HttpsUtil.sendSSLPost Exception, url=" + url + ",param=" + param, e); + } + return result.toString(); + } + + private static class TrustAnyTrustManager implements X509TrustManager + { + @Override + public void checkClientTrusted(X509Certificate[] chain, String authType) + { + } + + @Override + public void checkServerTrusted(X509Certificate[] chain, String authType) + { + } + + @Override + public X509Certificate[] getAcceptedIssuers() + { + return new X509Certificate[] {}; + } + } + + private static class TrustAnyHostnameVerifier implements HostnameVerifier + { + @Override + public boolean verify(String hostname, SSLSession session) + { + return true; + } + } +} \ No newline at end of file diff --git a/dc-common/src/main/java/com/dc/common/utils/ip/AddressUtils.java b/dc-common/src/main/java/com/dc/common/utils/ip/AddressUtils.java new file mode 100644 index 0000000..59331bb --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/utils/ip/AddressUtils.java @@ -0,0 +1,56 @@ +package com.dc.common.utils.ip; + +import com.dc.common.utils.StringUtils; +import com.dc.common.utils.http.HttpUtils; +import com.dc.common.config.WinConfig; +import com.dc.common.constant.Constants; +import org.slf4j.Logger; +import org.slf4j.LoggerFactory; +import com.alibaba.fastjson2.JSON; +import com.alibaba.fastjson2.JSONObject; + +/** + * 获取地址类 + * + * @author win + */ +public class AddressUtils +{ + private static final Logger log = LoggerFactory.getLogger(AddressUtils.class); + + // IP地址查询 + public static final String IP_URL = "http://whois.pconline.com.cn/ipJson.jsp"; + + // 未知地址 + public static final String UNKNOWN = "XX XX"; + + public static String getRealAddressByIP(String ip) + { + // 内网不查询 + if (IpUtils.internalIp(ip)) + { + return "内网IP"; + } + if (WinConfig.isAddressEnabled()) + { + try + { + String rspStr = HttpUtils.sendGet(IP_URL, "ip=" + ip + "&json=true", Constants.GBK); + if (StringUtils.isEmpty(rspStr)) + { + log.error("获取地理位置异常 {}", ip); + return UNKNOWN; + } + JSONObject obj = JSON.parseObject(rspStr); + String region = obj.getString("pro"); + String city = obj.getString("city"); + return String.format("%s %s", region, city); + } + catch (Exception e) + { + log.error("获取地理位置异常 {}", ip); + } + } + return UNKNOWN; + } +} diff --git a/dc-common/src/main/java/com/dc/common/utils/ip/IpUtils.java b/dc-common/src/main/java/com/dc/common/utils/ip/IpUtils.java new file mode 100644 index 0000000..52d0dec --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/utils/ip/IpUtils.java @@ -0,0 +1,265 @@ +package com.dc.common.utils.ip; + +import com.dc.common.utils.StringUtils; + +import javax.servlet.http.HttpServletRequest; +import java.net.InetAddress; +import java.net.UnknownHostException; + +/** + * 获取IP方法 + * + * @author win + */ +public class IpUtils +{ + /** + * 获取客户端IP + * + * @param request 请求对象 + * @return IP地址 + */ + public static String getIpAddr(HttpServletRequest request) + { + if (request == null) + { + return "unknown"; + } + String ip = request.getHeader("x-forwarded-for"); + if (ip == null || ip.length() == 0 || "unknown".equalsIgnoreCase(ip)) + { + ip = request.getHeader("Proxy-Client-IP"); + } + if (ip == null || ip.length() == 0 || "unknown".equalsIgnoreCase(ip)) + { + ip = request.getHeader("X-Forwarded-For"); + } + if (ip == null || ip.length() == 0 || "unknown".equalsIgnoreCase(ip)) + { + ip = request.getHeader("WL-Proxy-Client-IP"); + } + if (ip == null || ip.length() == 0 || "unknown".equalsIgnoreCase(ip)) + { + ip = request.getHeader("X-Real-IP"); + } + + if (ip == null || ip.length() == 0 || "unknown".equalsIgnoreCase(ip)) + { + ip = request.getRemoteAddr(); + } + + return "0:0:0:0:0:0:0:1".equals(ip) ? "127.0.0.1" : getMultistageReverseProxyIp(ip); + } + + /** + * 检查是否为内部IP地址 + * + * @param ip IP地址 + * @return 结果 + */ + public static boolean internalIp(String ip) + { + byte[] addr = textToNumericFormatV4(ip); + return internalIp(addr) || "127.0.0.1".equals(ip); + } + + /** + * 检查是否为内部IP地址 + * + * @param addr byte地址 + * @return 结果 + */ + private static boolean internalIp(byte[] addr) + { + if (StringUtils.isNull(addr) || addr.length < 2) + { + return true; + } + final byte b0 = addr[0]; + final byte b1 = addr[1]; + // 10.x.x.x/8 + final byte SECTION_1 = 0x0A; + // 172.16.x.x/12 + final byte SECTION_2 = (byte) 0xAC; + final byte SECTION_3 = (byte) 0x10; + final byte SECTION_4 = (byte) 0x1F; + // 192.168.x.x/16 + final byte SECTION_5 = (byte) 0xC0; + final byte SECTION_6 = (byte) 0xA8; + switch (b0) + { + case SECTION_1: + return true; + case SECTION_2: + if (b1 >= SECTION_3 && b1 <= SECTION_4) + { + return true; + } + case SECTION_5: + switch (b1) + { + case SECTION_6: + return true; + } + default: + return false; + } + } + + /** + * 将IPv4地址转换成字节 + * + * @param text IPv4地址 + * @return byte 字节 + */ + public static byte[] textToNumericFormatV4(String text) + { + if (text.length() == 0) + { + return null; + } + + byte[] bytes = new byte[4]; + String[] elements = text.split("\\.", -1); + try + { + long l; + int i; + switch (elements.length) + { + case 1: + l = Long.parseLong(elements[0]); + if ((l < 0L) || (l > 4294967295L)) + { + return null; + } + bytes[0] = (byte) (int) (l >> 24 & 0xFF); + bytes[1] = (byte) (int) ((l & 0xFFFFFF) >> 16 & 0xFF); + bytes[2] = (byte) (int) ((l & 0xFFFF) >> 8 & 0xFF); + bytes[3] = (byte) (int) (l & 0xFF); + break; + case 2: + l = Integer.parseInt(elements[0]); + if ((l < 0L) || (l > 255L)) + { + return null; + } + bytes[0] = (byte) (int) (l & 0xFF); + l = Integer.parseInt(elements[1]); + if ((l < 0L) || (l > 16777215L)) + { + return null; + } + bytes[1] = (byte) (int) (l >> 16 & 0xFF); + bytes[2] = (byte) (int) ((l & 0xFFFF) >> 8 & 0xFF); + bytes[3] = (byte) (int) (l & 0xFF); + break; + case 3: + for (i = 0; i < 2; ++i) + { + l = Integer.parseInt(elements[i]); + if ((l < 0L) || (l > 255L)) + { + return null; + } + bytes[i] = (byte) (int) (l & 0xFF); + } + l = Integer.parseInt(elements[2]); + if ((l < 0L) || (l > 65535L)) + { + return null; + } + bytes[2] = (byte) (int) (l >> 8 & 0xFF); + bytes[3] = (byte) (int) (l & 0xFF); + break; + case 4: + for (i = 0; i < 4; ++i) + { + l = Integer.parseInt(elements[i]); + if ((l < 0L) || (l > 255L)) + { + return null; + } + bytes[i] = (byte) (int) (l & 0xFF); + } + break; + default: + return null; + } + } + catch (NumberFormatException e) + { + return null; + } + return bytes; + } + + /** + * 获取IP地址 + * + * @return 本地IP地址 + */ + public static String getHostIp() + { + try + { + return InetAddress.getLocalHost().getHostAddress(); + } + catch (UnknownHostException e) + { + } + return "127.0.0.1"; + } + + /** + * 获取主机名 + * + * @return 本地主机名 + */ + public static String getHostName() + { + try + { + return InetAddress.getLocalHost().getHostName(); + } + catch (UnknownHostException e) + { + } + return "未知"; + } + + /** + * 从多级反向代理中获得第一个非unknown IP地址 + * + * @param ip 获得的IP地址 + * @return 第一个非unknown IP地址 + */ + public static String getMultistageReverseProxyIp(String ip) + { + // 多级反向代理检测 + if (ip != null && ip.indexOf(",") > 0) + { + final String[] ips = ip.trim().split(","); + for (String subIp : ips) + { + if (false == isUnknown(subIp)) + { + ip = subIp; + break; + } + } + } + return ip; + } + + /** + * 检测给定字符串是否为未知,多用于检测HTTP请求相关 + * + * @param checkString 被检测的字符串 + * @return 是否未知 + */ + public static boolean isUnknown(String checkString) + { + return StringUtils.isBlank(checkString) || "unknown".equalsIgnoreCase(checkString); + } +} \ No newline at end of file diff --git a/dc-common/src/main/java/com/dc/common/utils/poi/ExcelHandlerAdapter.java b/dc-common/src/main/java/com/dc/common/utils/poi/ExcelHandlerAdapter.java new file mode 100644 index 0000000..5a50dc4 --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/utils/poi/ExcelHandlerAdapter.java @@ -0,0 +1,17 @@ +package com.dc.common.utils.poi; + +/** + * Excel数据格式处理适配器 + * + * @author win + */ +public interface ExcelHandlerAdapter { + /** + * 格式化 + * + * @param value 单元格数据值 + * @param args excel注解args参数组 + * @return 处理后的值 + */ + Object format(Object value, String[] args); +} diff --git a/dc-common/src/main/java/com/dc/common/utils/poi/ExcelUtil.java b/dc-common/src/main/java/com/dc/common/utils/poi/ExcelUtil.java new file mode 100644 index 0000000..34a6a26 --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/utils/poi/ExcelUtil.java @@ -0,0 +1,1511 @@ +package com.dc.common.utils.poi; + +import java.io.File; +import java.io.FileOutputStream; +import java.io.IOException; +import java.io.InputStream; +import java.io.OutputStream; +import java.lang.reflect.Field; +import java.lang.reflect.Method; +import java.lang.reflect.ParameterizedType; +import java.math.BigDecimal; +import java.text.DecimalFormat; +import java.time.LocalDate; +import java.time.LocalDateTime; +import java.time.ZoneId; +import java.time.format.DateTimeFormatter; +import java.util.ArrayList; +import java.util.Arrays; +import java.util.Collection; +import java.util.Comparator; +import java.util.Date; +import java.util.HashMap; +import java.util.List; +import java.util.Map; +import java.util.Set; +import java.util.UUID; +import java.util.stream.Collectors; +import javax.servlet.http.HttpServletResponse; + +import com.dc.common.annotation.Excel; +import com.dc.common.annotation.Excels; +import com.dc.common.config.WinConfig; +import com.dc.common.core.domain.AjaxResult; +import com.dc.common.core.domain.entity.SysDictData; +import com.dc.common.core.text.Convert; +import com.dc.common.exception.UtilException; +import com.dc.common.utils.DateUtils; +import com.dc.common.utils.DictUtils; +import com.dc.common.utils.StringUtils; +import com.dc.common.utils.file.FileTypeUtils; +import com.dc.common.utils.file.FileUtils; +import com.dc.common.utils.file.ImageUtils; +import com.dc.common.utils.reflect.ReflectUtils; +import org.apache.commons.lang3.ArrayUtils; +import org.apache.commons.lang3.RegExUtils; +import org.apache.commons.lang3.reflect.FieldUtils; +import org.apache.poi.hssf.usermodel.HSSFClientAnchor; +import org.apache.poi.hssf.usermodel.HSSFPicture; +import org.apache.poi.hssf.usermodel.HSSFPictureData; +import org.apache.poi.hssf.usermodel.HSSFShape; +import org.apache.poi.hssf.usermodel.HSSFSheet; +import org.apache.poi.hssf.usermodel.HSSFWorkbook; +import org.apache.poi.ooxml.POIXMLDocumentPart; +import org.apache.poi.ss.usermodel.BorderStyle; +import org.apache.poi.ss.usermodel.Cell; +import org.apache.poi.ss.usermodel.CellStyle; +import org.apache.poi.ss.usermodel.CellType; +import org.apache.poi.ss.usermodel.ClientAnchor; +import org.apache.poi.ss.usermodel.DataValidation; +import org.apache.poi.ss.usermodel.DataValidationConstraint; +import org.apache.poi.ss.usermodel.DataValidationHelper; +import org.apache.poi.ss.usermodel.DateUtil; +import org.apache.poi.ss.usermodel.Drawing; +import org.apache.poi.ss.usermodel.FillPatternType; +import org.apache.poi.ss.usermodel.Font; +import org.apache.poi.ss.usermodel.HorizontalAlignment; +import org.apache.poi.ss.usermodel.IndexedColors; +import org.apache.poi.ss.usermodel.Name; +import org.apache.poi.ss.usermodel.PictureData; +import org.apache.poi.ss.usermodel.Row; +import org.apache.poi.ss.usermodel.Sheet; +import org.apache.poi.ss.usermodel.VerticalAlignment; +import org.apache.poi.ss.usermodel.Workbook; +import org.apache.poi.ss.usermodel.WorkbookFactory; +import org.apache.poi.ss.util.CellRangeAddress; +import org.apache.poi.ss.util.CellRangeAddressList; +import org.apache.poi.util.IOUtils; +import org.apache.poi.xssf.streaming.SXSSFWorkbook; +import org.apache.poi.xssf.usermodel.XSSFClientAnchor; +import org.apache.poi.xssf.usermodel.XSSFDataValidation; +import org.apache.poi.xssf.usermodel.XSSFDrawing; +import org.apache.poi.xssf.usermodel.XSSFPicture; +import org.apache.poi.xssf.usermodel.XSSFShape; +import org.apache.poi.xssf.usermodel.XSSFSheet; +import org.apache.poi.xssf.usermodel.XSSFWorkbook; +import org.openxmlformats.schemas.drawingml.x2006.spreadsheetDrawing.CTMarker; +import org.slf4j.Logger; +import org.slf4j.LoggerFactory; + +/** + * Excel相关处理 + * + * @author ruoyi + */ +public class ExcelUtil<T> { + + private static final Logger log = LoggerFactory.getLogger(ExcelUtil.class); + + public static final String FORMULA_REGEX_STR = "=|-|\\+|@"; + + public static final String[] FORMULA_STR = {"=", "-", "+", "@"}; + + /** + * Excel sheet最大行数,默认65536 + */ + public static final int sheetSize = 65536; + + /** + * 工作表名称 + */ + protected String sheetName; + + /** + * 导出类型(EXPORT:导出数据;IMPORT:导入模板) + */ + protected Excel.Type type; + + /** + * 工作薄对象 + */ + protected Workbook wb; + + /** + * 工作表对象 + */ + protected Sheet sheet; + + /** + * 样式列表 + */ + protected Map<String, CellStyle> styles; + + /** + * 导入导出数据列表 + */ + protected List<T> list; + + /** + * 注解列表 + */ + protected List<Object[]> fields; + + /** + * 当前行号 + */ + protected int rownum; + + /** + * 标题 + */ + protected String[] titles; + + /** + * 最大高度 + */ + protected short maxHeight; + + /** + * 合并后最后行数 + */ + protected int subMergedLastRowNum = 0; + + /** + * 合并后开始行数 + */ + protected int subMergedFirstRowNum = 1; + + /** + * 对象的子列表方法 + */ + protected Method subMethod; + + /** + * 对象的子列表属性 + */ + protected List<Field> subFields; + + /** + * 统计列表 + */ + protected Map<Integer, Double> statistics = new HashMap<Integer, Double>(); + + /** + * 数字格式 + */ + protected static final DecimalFormat DOUBLE_FORMAT = new DecimalFormat("######0.00"); + + /** + * 实体对象 + */ + protected Class<T> clazz; + + /** + * 需要排除列属性 + */ + public String[] excludeFields; + + public ExcelUtil(Class<T> clazz) { + this.clazz = clazz; + } + + /** + * 隐藏Excel中列属性 + * + * @param fields 列属性名 示例[单个"name"/多个"id","name"] + * @throws Exception + */ + public void hideColumn(String... fields) { + this.excludeFields = fields; + } + + public void init(List<T> list, String sheetName, String[] titles, Excel.Type type) { + if (list == null) { + list = new ArrayList<T>(); + } + this.subMergedFirstRowNum = 1; + this.subMergedLastRowNum = 0; + this.rownum = 0; + this.list = list; + this.sheetName = sheetName; + this.type = type; + this.titles = titles; + createExcelField(); + createWorkbook(); + createTitle(); + createSubHead(); + } + + public void init(List<T> list, String sheetName, String title, Excel.Type type) { + if (list == null) { + list = new ArrayList<T>(); + } + this.subMergedFirstRowNum = 1; + this.subMergedLastRowNum = 0; + this.rownum = 0; + this.list = list; + this.sheetName = sheetName; + this.type = type; + this.titles = titles; + createExcelField(); + createWorkbook(); + createTitle(); + createSubHead(); + } + + /** + * 创建excel第一行标题 + */ + public void createTitle() { + if (StringUtils.isNotEmpty(titles)) { + for (String title : this.titles) { + subMergedFirstRowNum++; + subMergedLastRowNum++; + int titleLastCol = this.fields.size() - 1; + if (isSubList()) { + titleLastCol = titleLastCol + subFields.size() - 1; + } + Row titleRow = sheet.createRow(rownum >= 0 ? rownum++ : 0); + titleRow.setHeightInPoints(30); + Cell titleCell = titleRow.createCell(0); + titleCell.setCellStyle(styles.get("title")); + titleCell.setCellValue(title); + sheet.addMergedRegion(new CellRangeAddress(titleRow.getRowNum(), titleRow.getRowNum(), 0, titleLastCol)); + } + } + } + + /** + * 创建对象的子列表名称 + */ + public void createSubHead() { + if (isSubList()) { + subMergedFirstRowNum++; + subMergedLastRowNum++; + Row subRow = sheet.createRow(rownum); + int excelNum = 0; + for (Object[] objects : fields) { + Excel attr = (Excel) objects[1]; + Cell headCell1 = subRow.createCell(excelNum); + headCell1.setCellValue(attr.name()); + headCell1.setCellStyle(styles.get(StringUtils.format("header_{}_{}", attr.headerColor(), attr.headerBackgroundColor()))); + excelNum++; + } + int headFirstRow = excelNum - 1; + int headLastRow = headFirstRow + subFields.size() - 1; + if (headLastRow > headFirstRow) { + sheet.addMergedRegion(new CellRangeAddress(rownum, rownum, headFirstRow, headLastRow)); + } + rownum++; + } + } + + /** + * 对excel表单默认第一个索引名转换成list + * + * @param is 输入流 + * @return 转换后集合 + */ + public List<T> importExcel(InputStream is) throws Exception { + return importExcel(is, 0); + } + + /** + * 对excel表单默认第一个索引名转换成list + * + * @param is 输入流 + * @param titleNum 标题占用行数 + * @return 转换后集合 + */ + public List<T> importExcel(InputStream is, int titleNum) throws Exception { + return importExcel(StringUtils.EMPTY, is, titleNum); + } + + /** + * 对excel表单指定表格索引名转换成list + * + * @param sheetName 表格索引名 + * @param titleNum 标题占用行数 + * @param is 输入流 + * @return 转换后集合 + */ + public List<T> importExcel(String sheetName, InputStream is, int titleNum) throws Exception { + this.type = Excel.Type.IMPORT; + this.wb = WorkbookFactory.create(is); + List<T> list = new ArrayList<T>(); + // 如果指定sheet名,则取指定sheet中的内容 否则默认指向第1个sheet + Sheet sheet = StringUtils.isNotEmpty(sheetName) ? wb.getSheet(sheetName) : wb.getSheetAt(0); + if (sheet == null) { + throw new IOException("文件sheet不存在"); + } + boolean isXSSFWorkbook = !(wb instanceof HSSFWorkbook); + Map<String, PictureData> pictures; + if (isXSSFWorkbook) { + pictures = getSheetPictures07((XSSFSheet) sheet, (XSSFWorkbook) wb); + } else { + pictures = getSheetPictures03((HSSFSheet) sheet, (HSSFWorkbook) wb); + } + // 获取最后一个非空行的行下标,比如总行数为n,则返回的为n-1 + int rows = sheet.getLastRowNum(); + + if (rows > 0) { + // 定义一个map用于存放excel列的序号和field. + Map<String, Integer> cellMap = new HashMap<String, Integer>(); + // 获取表头 + Row heard = sheet.getRow(titleNum); + for (int i = 0; i < heard.getPhysicalNumberOfCells(); i++) { + Cell cell = heard.getCell(i); + if (StringUtils.isNotNull(cell)) { + String value = this.getCellValue(heard, i).toString(); + cellMap.put(value, i); + } else { + cellMap.put(null, i); + } + } + // 有数据时才处理 得到类的所有field. + List<Object[]> fields = this.getFields(); + Map<Integer, Object[]> fieldsMap = new HashMap<Integer, Object[]>(); + for (Object[] objects : fields) { + Excel attr = (Excel) objects[1]; + Integer column = cellMap.get(attr.name()); + if (column != null) { + fieldsMap.put(column, objects); + } + } + for (int i = titleNum + 1; i <= rows; i++) { + // 从第2行开始取数据,默认第一行是表头. + Row row = sheet.getRow(i); + // 判断当前行是否是空行 + if (isRowEmpty(row)) { + continue; + } + T entity = null; + for (Map.Entry<Integer, Object[]> entry : fieldsMap.entrySet()) { + Object val = this.getCellValue(row, entry.getKey()); + + // 如果不存在实例则新建. + entity = (entity == null ? clazz.newInstance() : entity); + // 从map中得到对应列的field. + Field field = (Field) entry.getValue()[0]; + Excel attr = (Excel) entry.getValue()[1]; + // 取得类型,并根据对象类型设置值. + Class<?> fieldType = field.getType(); + if (String.class == fieldType) { + String s = Convert.toStr(val); + if (StringUtils.endsWith(s, ".0")) { + val = StringUtils.substringBefore(s, ".0"); + } else { + String dateFormat = field.getAnnotation(Excel.class).dateFormat(); + if (StringUtils.isNotEmpty(dateFormat)) { + val = parseDateToStr(dateFormat, val); + } else { + val = Convert.toStr(val); + } + } + } else if ((Integer.TYPE == fieldType || Integer.class == fieldType) && StringUtils.isNumeric(Convert.toStr(val))) { + val = Convert.toInt(val); + } else if ((Long.TYPE == fieldType || Long.class == fieldType) && StringUtils.isNumeric(Convert.toStr(val))) { + val = Convert.toLong(val); + } else if (Double.TYPE == fieldType || Double.class == fieldType) { + val = Convert.toDouble(val); + } else if (Float.TYPE == fieldType || Float.class == fieldType) { + val = Convert.toFloat(val); + } else if (BigDecimal.class == fieldType) { + val = Convert.toBigDecimal(val); + } else if (Date.class == fieldType) { + if (val instanceof String) { + val = DateUtils.parseDate(val); + } else if (val instanceof Double) { + val = DateUtil.getJavaDate((Double) val); + } + } else if (LocalDate.class == fieldType) { + if (val.toString().equals("")) { + val = null; + } else { + if (val instanceof String) { + DateTimeFormatter df = DateTimeFormatter.ofPattern("yyyy-MM-dd"); + val = LocalDate.parse(String.valueOf(val), df); + } else if (val instanceof Double || val instanceof Date) { + val = ((Date) val).toInstant().atZone(ZoneId.systemDefault()).toLocalDate(); + } + } + } else if (LocalDateTime.class == fieldType) { + if (val.toString().equals("")) { + val = null; + } else { + if (val instanceof String) { + DateTimeFormatter df = DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss"); + val = LocalDateTime.parse(String.valueOf(val), df); + } else if (val instanceof Double || val instanceof Date) { + val = ((Date) val).toInstant().atZone(ZoneId.systemDefault()).toLocalDateTime(); + } + } + } +// else if (Boolean.TYPE == fieldType || Boolean.class == fieldType) +// { +// val = Convert.toBool(val, false); +// } + if (StringUtils.isNotNull(fieldType)) { + String propertyName = field.getName(); + if (StringUtils.isNotEmpty(attr.targetAttr())) { + propertyName = field.getName() + "." + attr.targetAttr(); + } else if (StringUtils.isNotEmpty(attr.readConverterExp())) { + val = reverseByExp(Convert.toStr(val), attr.readConverterExp(), attr.separator()); + } else if (StringUtils.isNotEmpty(attr.dictType())) { + val = reverseDictByExp(Convert.toStr(val), attr.dictType(), attr.separator()); + } else if (!attr.handler().equals(ExcelHandlerAdapter.class)) { + val = dataFormatHandlerAdapter(val, attr); + } else if (Excel.ColumnType.IMAGE == attr.cellType() && StringUtils.isNotEmpty(pictures)) { + PictureData image = pictures.get(row.getRowNum() + "_" + entry.getKey()); + if (image == null) { + val = ""; + } else { + byte[] data = image.getData(); + val = FileUtils.writeImportBytes(data); + } + } + ReflectUtils.invokeSetter(entity, propertyName, val); + } + } + list.add(entity); + } + } + return list; + } + + /** + * 对list数据源将其里面的数据导入到excel表单 + * + * @param list 导出数据集合 + * @param sheetName 工作表的名称 + * @return 结果 + */ + public AjaxResult exportExcel(List<T> list, String sheetName) { + return exportExcel(list, sheetName, null); + } + + /** + * 对list数据源将其里面的数据导入到excel表单 + * + * @param list 导出数据集合 + * @param sheetName 工作表的名称 + * @param titles 标题 + * @return 结果 + */ + public AjaxResult exportExcel(List<T> list, String sheetName, String[] titles) { + this.init(list, sheetName, titles, Excel.Type.EXPORT); + return exportExcel(); + } + + /** + * 对list数据源将其里面的数据导入到excel表单 + * + * @param response 返回数据 + * @param list 导出数据集合 + * @param sheetName 工作表的名称 + * @return 结果 + */ + public void exportExcel(HttpServletResponse response, List<T> list, String sheetName) { + exportExcel(response, list, sheetName, null); + } + + /** + * 对list数据源将其里面的数据导入到excel表单 + * + * @param response 返回数据 + * @param list 导出数据集合 + * @param sheetName 工作表的名称 + * @param titles 标题 + * @return 结果 + */ + public void exportExcel(HttpServletResponse response, List<T> list, String sheetName, String[] titles) { + response.setContentType("application/vnd.openxmlformats-officedocument.spreadsheetml.sheet"); + response.setCharacterEncoding("utf-8"); + this.init(list, sheetName, titles, Excel.Type.EXPORT); + exportExcel(response); + } + + /** + * 对list数据源将其里面的数据导入到excel表单 + * + * @param sheetName 工作表的名称 + * @return 结果 + */ + public AjaxResult importTemplateExcel(String sheetName) { + return importTemplateExcel(sheetName, null); + } + + /** + * 对list数据源将其里面的数据导入到excel表单 + * + * @param sheetName 工作表的名称 + * @param titles 标题 + * @return 结果 + */ + public AjaxResult importTemplateExcel(String sheetName, String[] titles) { + this.init(null, sheetName, titles, Excel.Type.IMPORT); + return exportExcel(); + } + + /** + * 对list数据源将其里面的数据导入到excel表单 + * + * @param sheetName 工作表的名称 + * @return 结果 + */ + public void importTemplateExcel(HttpServletResponse response, String sheetName) { + importTemplateExcel(response, sheetName, null); + } + + /** + * 对list数据源将其里面的数据导入到excel表单 + * + * @param sheetName 工作表的名称 + * @param titles 标题 + * @return 结果 + */ + public void importTemplateExcel(HttpServletResponse response, String sheetName, String[] titles) { + response.setContentType("application/vnd.openxmlformats-officedocument.spreadsheetml.sheet"); + response.setCharacterEncoding("utf-8"); + this.init(null, sheetName, titles, Excel.Type.IMPORT); + exportExcel(response); + } + + /** + * 对list数据源将其里面的数据导入到excel表单 + * + * @return 结果 + */ + public void exportExcel(HttpServletResponse response) { + try { + writeSheet(); + wb.write(response.getOutputStream()); + } catch (Exception e) { + log.error("导出Excel异常{}", e.getMessage()); + } finally { + IOUtils.closeQuietly(wb); + } + } + + /** + * 对list数据源将其里面的数据导入到excel表单 + * + * @return 结果 + */ + public AjaxResult exportExcel() { + OutputStream out = null; + try { + writeSheet(); + String filename = encodingFilename(sheetName); + out = new FileOutputStream(getAbsoluteFile(filename)); + wb.write(out); + return AjaxResult.success(filename); + } catch (Exception e) { + log.error("导出Excel异常{}", e.getMessage()); + throw new UtilException("导出Excel失败,请联系网站管理员!"); + } finally { + IOUtils.closeQuietly(wb); + IOUtils.closeQuietly(out); + } + } + + /** + * 创建写入数据到Sheet + */ + public void writeSheet() { + // 取出一共有多少个sheet. + int sheetNo = Math.max(1, (int) Math.ceil(list.size() * 1.0 / sheetSize)); + for (int index = 0; index < sheetNo; index++) { + createSheet(sheetNo, index); + // 产生一行 + Row row = sheet.createRow(rownum); + int column = 0; + // 写入各个字段的列头名称 + for (Object[] os : fields) { + Field field = (Field) os[0]; + Excel excel = (Excel) os[1]; + if (Collection.class.isAssignableFrom(field.getType())) { + for (Field subField : subFields) { + Excel subExcel = subField.getAnnotation(Excel.class); + this.createHeadCell(subExcel, row, column++); + } + } else { + this.createHeadCell(excel, row, column++); + } + } + if (Excel.Type.EXPORT.equals(type)) { + fillExcelData(index, row); + addStatisticsRow(); + } + } + } + + /** + * 填充excel数据 + * + * @param index 序号 + * @param row 单元格行 + */ + @SuppressWarnings("unchecked") + public void fillExcelData(int index, Row row) { + int startNo = index * sheetSize; + int endNo = Math.min(startNo + sheetSize, list.size()); + int rowNo = (1 + rownum) - startNo; + for (int i = startNo; i < endNo; i++) { + rowNo = isSubList() ? (i > 1 ? rowNo + 1 : rowNo + i) : i + 1 + rownum - startNo; + row = sheet.createRow(rowNo); + // 得到导出对象. + T vo = (T) list.get(i); + Collection<?> subList = null; + if (isSubList()) { + if (isSubListValue(vo)) { + subList = getListCellValue(vo); + subMergedLastRowNum = subMergedLastRowNum + subList.size(); + } else { + subMergedFirstRowNum++; + subMergedLastRowNum++; + } + } + int column = 0; + for (Object[] os : fields) { + Field field = (Field) os[0]; + Excel excel = (Excel) os[1]; + if (Collection.class.isAssignableFrom(field.getType()) && StringUtils.isNotNull(subList)) { + boolean subFirst = false; + for (Object obj : subList) { + if (subFirst) { + rowNo++; + row = sheet.createRow(rowNo); + } + List<Field> subFields = FieldUtils.getFieldsListWithAnnotation(obj.getClass(), Excel.class); + int subIndex = 0; + for (Field subField : subFields) { + if (subField.isAnnotationPresent(Excel.class)) { + subField.setAccessible(true); + Excel attr = subField.getAnnotation(Excel.class); + this.addCell(attr, row, (T) obj, subField, column + subIndex); + } + subIndex++; + } + subFirst = true; + } + this.subMergedFirstRowNum = this.subMergedFirstRowNum + subList.size(); + } else { + this.addCell(excel, row, vo, field, column++); + } + } + } + } + + /** + * 创建表格样式 + * + * @param wb 工作薄对象 + * @return 样式列表 + */ + private Map<String, CellStyle> createStyles(Workbook wb) { + // 写入各条记录,每条记录对应excel表中的一行 + Map<String, CellStyle> styles = new HashMap<String, CellStyle>(); + CellStyle style = wb.createCellStyle(); + style.setAlignment(HorizontalAlignment.CENTER); + style.setVerticalAlignment(VerticalAlignment.CENTER); + Font titleFont = wb.createFont(); + titleFont.setFontName("Arial"); + titleFont.setFontHeightInPoints((short) 16); + titleFont.setBold(true); + style.setFont(titleFont); + styles.put("title", style); + + style = wb.createCellStyle(); + style.setAlignment(HorizontalAlignment.CENTER); + style.setVerticalAlignment(VerticalAlignment.CENTER); + style.setBorderRight(BorderStyle.THIN); + style.setRightBorderColor(IndexedColors.GREY_50_PERCENT.getIndex()); + style.setBorderLeft(BorderStyle.THIN); + style.setLeftBorderColor(IndexedColors.GREY_50_PERCENT.getIndex()); + style.setBorderTop(BorderStyle.THIN); + style.setTopBorderColor(IndexedColors.GREY_50_PERCENT.getIndex()); + style.setBorderBottom(BorderStyle.THIN); + style.setBottomBorderColor(IndexedColors.GREY_50_PERCENT.getIndex()); + Font dataFont = wb.createFont(); + dataFont.setFontName("Arial"); + dataFont.setFontHeightInPoints((short) 10); + style.setFont(dataFont); + styles.put("data", style); + + style = wb.createCellStyle(); + style.setAlignment(HorizontalAlignment.CENTER); + style.setVerticalAlignment(VerticalAlignment.CENTER); + Font totalFont = wb.createFont(); + totalFont.setFontName("Arial"); + totalFont.setFontHeightInPoints((short) 10); + style.setFont(totalFont); + styles.put("total", style); + + styles.putAll(annotationHeaderStyles(wb, styles)); + + styles.putAll(annotationDataStyles(wb)); + + return styles; + } + + /** + * 根据Excel注解创建表格头样式 + * + * @param wb 工作薄对象 + * @return 自定义样式列表 + */ + private Map<String, CellStyle> annotationHeaderStyles(Workbook wb, Map<String, CellStyle> styles) { + Map<String, CellStyle> headerStyles = new HashMap<String, CellStyle>(); + for (Object[] os : fields) { + Excel excel = (Excel) os[1]; + String key = StringUtils.format("header_{}_{}", excel.headerColor(), excel.headerBackgroundColor()); + if (!headerStyles.containsKey(key)) { + CellStyle style = wb.createCellStyle(); + style.cloneStyleFrom(styles.get("data")); + style.setAlignment(HorizontalAlignment.CENTER); + style.setVerticalAlignment(VerticalAlignment.CENTER); + style.setFillForegroundColor(excel.headerBackgroundColor().index); + style.setFillPattern(FillPatternType.SOLID_FOREGROUND); + Font headerFont = wb.createFont(); + headerFont.setFontName("Arial"); + headerFont.setFontHeightInPoints((short) 10); + headerFont.setBold(true); + headerFont.setColor(excel.headerColor().index); + style.setFont(headerFont); + headerStyles.put(key, style); + } + } + return headerStyles; + } + + /** + * 根据Excel注解创建表格列样式 + * + * @param wb 工作薄对象 + * @return 自定义样式列表 + */ + private Map<String, CellStyle> annotationDataStyles(Workbook wb) { + Map<String, CellStyle> styles = new HashMap<String, CellStyle>(); + for (Object[] os : fields) { + Excel excel = (Excel) os[1]; + String key = StringUtils.format("data_{}_{}_{}", excel.align(), excel.color(), excel.backgroundColor()); + if (!styles.containsKey(key)) { + CellStyle style = wb.createCellStyle(); + style.setAlignment(excel.align()); + style.setVerticalAlignment(VerticalAlignment.CENTER); + style.setBorderRight(BorderStyle.THIN); + style.setRightBorderColor(IndexedColors.GREY_50_PERCENT.getIndex()); + style.setBorderLeft(BorderStyle.THIN); + style.setLeftBorderColor(IndexedColors.GREY_50_PERCENT.getIndex()); + style.setBorderTop(BorderStyle.THIN); + style.setTopBorderColor(IndexedColors.GREY_50_PERCENT.getIndex()); + style.setBorderBottom(BorderStyle.THIN); + style.setBottomBorderColor(IndexedColors.GREY_50_PERCENT.getIndex()); + style.setFillPattern(FillPatternType.SOLID_FOREGROUND); + style.setFillForegroundColor(excel.backgroundColor().getIndex()); + Font dataFont = wb.createFont(); + dataFont.setFontName("Arial"); + dataFont.setFontHeightInPoints((short) 10); + dataFont.setColor(excel.color().index); + style.setFont(dataFont); + styles.put(key, style); + } + } + return styles; + } + + /** + * 创建单元格 + */ + public Cell createHeadCell(Excel attr, Row row, int column) { + // 创建列 + Cell cell = row.createCell(column); + // 写入列信息 + cell.setCellValue(attr.name()); + setDataValidation(attr, row, column); + cell.setCellStyle(styles.get(StringUtils.format("header_{}_{}", attr.headerColor(), attr.headerBackgroundColor()))); + if (isSubList()) { + // 填充默认样式,防止合并单元格样式失效 + sheet.setDefaultColumnStyle(column, styles.get(StringUtils.format("data_{}_{}_{}", attr.align(), attr.color(), attr.backgroundColor()))); + if (attr.needMerge()) { + sheet.addMergedRegion(new CellRangeAddress(rownum - 1, rownum, column, column)); + } + } + return cell; + } + + /** + * 设置单元格信息 + * + * @param value 单元格值 + * @param attr 注解相关 + * @param cell 单元格信息 + */ + public void setCellVo(Object value, Excel attr, Cell cell) { + if (Excel.ColumnType.STRING == attr.cellType()) { + String cellValue = Convert.toStr(value); + // 对于任何以表达式触发字符 =-+@开头的单元格,直接使用tab字符作为前缀,防止CSV注入。 + if (StringUtils.startsWithAny(cellValue, FORMULA_STR)) { + cellValue = RegExUtils.replaceFirst(cellValue, FORMULA_REGEX_STR, "\t$0"); + } + if (value instanceof Collection && StringUtils.equals("[]", cellValue)) { + cellValue = StringUtils.EMPTY; + } + cell.setCellValue(StringUtils.isNull(cellValue) ? attr.defaultValue() : cellValue + attr.suffix()); + } else if (Excel.ColumnType.NUMERIC == attr.cellType()) { + if (StringUtils.isNotNull(value)) { + cell.setCellValue(StringUtils.contains(Convert.toStr(value), ".") ? Convert.toDouble(value) : Convert.toInt(value)); + } + } else if (Excel.ColumnType.IMAGE == attr.cellType()) { + ClientAnchor anchor = new XSSFClientAnchor(0, 0, 0, 0, (short) cell.getColumnIndex(), cell.getRow().getRowNum(), (short) (cell.getColumnIndex() + 1), cell.getRow().getRowNum() + 1); + String imagePath = Convert.toStr(value); + if (StringUtils.isNotEmpty(imagePath)) { + byte[] data = ImageUtils.getImage(imagePath); + getDrawingPatriarch(cell.getSheet()).createPicture(anchor, + cell.getSheet().getWorkbook().addPicture(data, getImageType(data))); + } + } + } + + /** + * 获取画布 + */ + public static Drawing<?> getDrawingPatriarch(Sheet sheet) { + if (sheet.getDrawingPatriarch() == null) { + sheet.createDrawingPatriarch(); + } + return sheet.getDrawingPatriarch(); + } + + /** + * 获取图片类型,设置图片插入类型 + */ + public int getImageType(byte[] value) { + String type = FileTypeUtils.getFileExtendName(value); + if ("JPG".equalsIgnoreCase(type)) { + return Workbook.PICTURE_TYPE_JPEG; + } else if ("PNG".equalsIgnoreCase(type)) { + return Workbook.PICTURE_TYPE_PNG; + } + return Workbook.PICTURE_TYPE_JPEG; + } + + /** + * 创建表格样式 + */ + public void setDataValidation(Excel attr, Row row, int column) { + if (attr.name().indexOf("注:") >= 0) { + sheet.setColumnWidth(column, 6000); + } else { + // 设置列宽 + sheet.setColumnWidth(column, (int) ((attr.width() + 0.72) * 256)); + } + if(attr.dictType() != null && !attr.dictType().equals("")) { + List<SysDictData> sysDictDataList = DictUtils.getDictCache(attr.dictType()); + String[] combo = new String[sysDictDataList.size()]; + for(int i = 0; i < sysDictDataList.size(); i++) { + combo[i] = sysDictDataList.get(i).getDictLabel(); + } + setXSSFValidationWithHidden(sheet, combo, attr.prompt(), 1, 100, column, column); + } + if (StringUtils.isNotEmpty(attr.prompt()) || attr.combo().length > 0) { + if (attr.combo().length > 15 || StringUtils.join(attr.combo()).length() > 255) { + // 如果下拉数大于15或字符串长度大于255,则使用一个新sheet存储,避免生成的模板下拉值获取不到 + setXSSFValidationWithHidden(sheet, attr.combo(), attr.prompt(), 1, 100, column, column); + } else { + // 提示信息或只能选择不能输入的列内容. + setPromptOrValidation(sheet, attr.combo(), attr.prompt(), 1, 100, column, column); + } + } + } + + /** + * 添加单元格 + */ + public Cell addCell(Excel attr, Row row, T vo, Field field, int column) { + Cell cell = null; + try { + // 设置行高 + row.setHeight(maxHeight); + // 根据Excel中设置情况决定是否导出,有些情况需要保持为空,希望用户填写这一列. + if (attr.isExport()) { + // 创建cell + cell = row.createCell(column); + if (isSubListValue(vo) && getListCellValue(vo).size() > 1 && attr.needMerge()) { + CellRangeAddress cellAddress = new CellRangeAddress(subMergedFirstRowNum, subMergedLastRowNum, column, column); + sheet.addMergedRegion(cellAddress); + } + cell.setCellStyle(styles.get(StringUtils.format("data_{}_{}_{}", attr.align(), attr.color(), attr.backgroundColor()))); + + // 用于读取对象中的属性 + Object value = getTargetValue(vo, field, attr); + String dateFormat = attr.dateFormat(); + String readConverterExp = attr.readConverterExp(); + String separator = attr.separator(); + String dictType = attr.dictType(); + if (StringUtils.isNotEmpty(dateFormat) && StringUtils.isNotNull(value)) { + cell.setCellValue(parseDateToStr(dateFormat, value)); + } else if (StringUtils.isNotEmpty(readConverterExp) && StringUtils.isNotNull(value)) { + cell.setCellValue(convertByExp(Convert.toStr(value), readConverterExp, separator)); + } else if (StringUtils.isNotEmpty(dictType) && StringUtils.isNotNull(value)) { + cell.setCellValue(convertDictByExp(Convert.toStr(value), dictType, separator)); + } else if (value instanceof BigDecimal && -1 != attr.scale()) { + cell.setCellValue((((BigDecimal) value).setScale(attr.scale(), attr.roundingMode())).doubleValue()); + } else if (!attr.handler().equals(ExcelHandlerAdapter.class)) { + cell.setCellValue(dataFormatHandlerAdapter(value, attr)); + } else { + // 设置列类型 + setCellVo(value, attr, cell); + } + addStatisticsData(column, Convert.toStr(value), attr); + } + } catch (Exception e) { + log.error("导出Excel失败{}", e); + } + return cell; + } + + /** + * 设置 POI XSSFSheet 单元格提示或选择框 + * + * @param sheet 表单 + * @param textlist 下拉框显示的内容 + * @param promptContent 提示内容 + * @param firstRow 开始行 + * @param endRow 结束行 + * @param firstCol 开始列 + * @param endCol 结束列 + */ + public void setPromptOrValidation(Sheet sheet, String[] textlist, String promptContent, int firstRow, int endRow, + int firstCol, int endCol) { + DataValidationHelper helper = sheet.getDataValidationHelper(); + DataValidationConstraint constraint = textlist.length > 0 ? helper.createExplicitListConstraint(textlist) : helper.createCustomConstraint("DD1"); + CellRangeAddressList regions = new CellRangeAddressList(firstRow, endRow, firstCol, endCol); + DataValidation dataValidation = helper.createValidation(constraint, regions); + if (StringUtils.isNotEmpty(promptContent)) { + // 如果设置了提示信息则鼠标放上去提示 + dataValidation.createPromptBox("", promptContent); + dataValidation.setShowPromptBox(true); + } + // 处理Excel兼容性问题 + if (dataValidation instanceof XSSFDataValidation) { + dataValidation.setSuppressDropDownArrow(true); + dataValidation.setShowErrorBox(true); + } else { + dataValidation.setSuppressDropDownArrow(false); + } + sheet.addValidationData(dataValidation); + } + + /** + * 设置某些列的值只能输入预制的数据,显示下拉框(兼容超出一定数量的下拉框). + * + * @param sheet 要设置的sheet. + * @param textlist 下拉框显示的内容 + * @param promptContent 提示内容 + * @param firstRow 开始行 + * @param endRow 结束行 + * @param firstCol 开始列 + * @param endCol 结束列 + */ + public void setXSSFValidationWithHidden(Sheet sheet, String[] textlist, String promptContent, int firstRow, int endRow, int firstCol, int endCol) { + String hideSheetName = "combo_" + firstCol + "_" + endCol; + Sheet hideSheet = wb.createSheet(hideSheetName); // 用于存储 下拉菜单数据 + for (int i = 0; i < textlist.length; i++) { + hideSheet.createRow(i).createCell(0).setCellValue(textlist[i]); + } + // 创建名称,可被其他单元格引用 + Name name = wb.createName(); + name.setNameName(hideSheetName + "_data"); + name.setRefersToFormula(hideSheetName + "!$A$1:$A$" + textlist.length); + DataValidationHelper helper = sheet.getDataValidationHelper(); + // 加载下拉列表内容 + DataValidationConstraint constraint = helper.createFormulaListConstraint(hideSheetName + "_data"); + // 设置数据有效性加载在哪个单元格上,四个参数分别是:起始行、终止行、起始列、终止列 + CellRangeAddressList regions = new CellRangeAddressList(firstRow, endRow, firstCol, endCol); + // 数据有效性对象 + DataValidation dataValidation = helper.createValidation(constraint, regions); + if (StringUtils.isNotEmpty(promptContent)) { + // 如果设置了提示信息则鼠标放上去提示 + dataValidation.createPromptBox("", promptContent); + dataValidation.setShowPromptBox(true); + } + // 处理Excel兼容性问题 + if (dataValidation instanceof XSSFDataValidation) { + dataValidation.setSuppressDropDownArrow(true); + dataValidation.setShowErrorBox(true); + } else { + dataValidation.setSuppressDropDownArrow(false); + } + + sheet.addValidationData(dataValidation); + // 设置hiddenSheet隐藏 + wb.setSheetHidden(wb.getSheetIndex(hideSheet), true); + } + + /** + * 解析导出值 0=男,1=女,2=未知 + * + * @param propertyValue 参数值 + * @param converterExp 翻译注解 + * @param separator 分隔符 + * @return 解析后值 + */ + public static String convertByExp(String propertyValue, String converterExp, String separator) { + StringBuilder propertyString = new StringBuilder(); + String[] convertSource = converterExp.split(","); + for (String item : convertSource) { + String[] itemArray = item.split("="); + if (StringUtils.containsAny(propertyValue, separator)) { + for (String value : propertyValue.split(separator)) { + if (itemArray[0].equals(value)) { + propertyString.append(itemArray[1] + separator); + break; + } + } + } else { + if (itemArray[0].equals(propertyValue)) { + return itemArray[1]; + } + } + } + return StringUtils.stripEnd(propertyString.toString(), separator); + } + + /** + * 反向解析值 男=0,女=1,未知=2 + * + * @param propertyValue 参数值 + * @param converterExp 翻译注解 + * @param separator 分隔符 + * @return 解析后值 + */ + public static String reverseByExp(String propertyValue, String converterExp, String separator) { + StringBuilder propertyString = new StringBuilder(); + String[] convertSource = converterExp.split(","); + for (String item : convertSource) { + String[] itemArray = item.split("="); + if (StringUtils.containsAny(propertyValue, separator)) { + for (String value : propertyValue.split(separator)) { + if (itemArray[1].equals(value)) { + propertyString.append(itemArray[0] + separator); + break; + } + } + } else { + if (itemArray[1].equals(propertyValue)) { + return itemArray[0]; + } + } + } + return StringUtils.stripEnd(propertyString.toString(), separator); + } + + /** + * 解析字典值 + * + * @param dictValue 字典值 + * @param dictType 字典类型 + * @param separator 分隔符 + * @return 字典标签 + */ + public static String convertDictByExp(String dictValue, String dictType, String separator) { + return DictUtils.getDictLabel(dictType, dictValue, separator); + } + + /** + * 反向解析值字典值 + * + * @param dictLabel 字典标签 + * @param dictType 字典类型 + * @param separator 分隔符 + * @return 字典值 + */ + public static String reverseDictByExp(String dictLabel, String dictType, String separator) { + return DictUtils.getDictValue(dictType, dictLabel, separator); + } + + /** + * 数据处理器 + * + * @param value 数据值 + * @param excel 数据注解 + * @return + */ + public String dataFormatHandlerAdapter(Object value, Excel excel) { + try { + Object instance = excel.handler().newInstance(); + Method formatMethod = excel.handler().getMethod("format", new Class[]{Object.class, String[].class}); + value = formatMethod.invoke(instance, value, excel.args()); + } catch (Exception e) { + log.error("不能格式化数据 " + excel.handler(), e.getMessage()); + } + return Convert.toStr(value); + } + + /** + * 合计统计信息 + */ + private void addStatisticsData(Integer index, String text, Excel entity) { + if (entity != null && entity.isStatistics()) { + Double temp = 0D; + if (!statistics.containsKey(index)) { + statistics.put(index, temp); + } + try { + temp = Double.valueOf(text); + } catch (NumberFormatException e) { + } + statistics.put(index, statistics.get(index) + temp); + } + } + + /** + * 创建统计行 + */ + public void addStatisticsRow() { + if (statistics.size() > 0) { + Row row = sheet.createRow(sheet.getLastRowNum() + 1); + Set<Integer> keys = statistics.keySet(); + Cell cell = row.createCell(0); + cell.setCellStyle(styles.get("total")); + cell.setCellValue("合计"); + + for (Integer key : keys) { + cell = row.createCell(key); + cell.setCellStyle(styles.get("total")); + cell.setCellValue(DOUBLE_FORMAT.format(statistics.get(key))); + } + statistics.clear(); + } + } + + /** + * 编码文件名 + */ + public String encodingFilename(String filename) { + filename = UUID.randomUUID().toString() + "_" + filename + ".xlsx"; + return filename; + } + + /** + * 获取下载路径 + * + * @param filename 文件名称 + */ + public String getAbsoluteFile(String filename) { + String downloadPath = WinConfig.getDownloadPath() + filename; + File desc = new File(downloadPath); + if (!desc.getParentFile().exists()) { + desc.getParentFile().mkdirs(); + } + return downloadPath; + } + + /** + * 获取bean中的属性值 + * + * @param vo 实体对象 + * @param field 字段 + * @param excel 注解 + * @return 最终的属性值 + * @throws Exception + */ + private Object getTargetValue(T vo, Field field, Excel excel) throws Exception { + Object o = field.get(vo); + if (StringUtils.isNotEmpty(excel.targetAttr())) { + String target = excel.targetAttr(); + if (target.contains(".")) { + String[] targets = target.split("[.]"); + for (String name : targets) { + o = getValue(o, name); + } + } else { + o = getValue(o, target); + } + } + return o; + } + + /** + * 以类的属性的get方法方法形式获取值 + * + * @param o + * @param name + * @return value + * @throws Exception + */ + private Object getValue(Object o, String name) throws Exception { + if (StringUtils.isNotNull(o) && StringUtils.isNotEmpty(name)) { + Class<?> clazz = o.getClass(); + Field field = clazz.getDeclaredField(name); + field.setAccessible(true); + o = field.get(o); + } + return o; + } + + /** + * 得到所有定义字段 + */ + protected void createExcelField() { + this.fields = getFields(); + this.fields = this.fields.stream().sorted(Comparator.comparing(objects -> ((Excel) objects[1]).sort())).collect(Collectors.toList()); + this.maxHeight = getRowHeight(); + } + + /** + * 获取字段注解信息 + */ + public List<Object[]> getFields() { + List<Object[]> fields = new ArrayList<Object[]>(); + List<Field> tempFields = new ArrayList<>(); + tempFields.addAll(Arrays.asList(clazz.getSuperclass().getDeclaredFields())); + tempFields.addAll(Arrays.asList(clazz.getDeclaredFields())); + for (Field field : tempFields) { + if (!ArrayUtils.contains(this.excludeFields, field.getName())) { + // 单注解 + if (field.isAnnotationPresent(Excel.class)) { + Excel attr = field.getAnnotation(Excel.class); + if (attr != null && (attr.type() == Excel.Type.ALL || attr.type() == type)) { + field.setAccessible(true); + fields.add(new Object[]{field, attr}); + } + if (Collection.class.isAssignableFrom(field.getType())) { + subMethod = getSubMethod(field.getName(), clazz); + ParameterizedType pt = (ParameterizedType) field.getGenericType(); + Class<?> subClass = (Class<?>) pt.getActualTypeArguments()[0]; + this.subFields = FieldUtils.getFieldsListWithAnnotation(subClass, Excel.class); + } + } + + // 多注解 + if (field.isAnnotationPresent(Excels.class)) { + Excels attrs = field.getAnnotation(Excels.class); + Excel[] excels = attrs.value(); + for (Excel attr : excels) { + if (attr != null && (attr.type() == Excel.Type.ALL || attr.type() == type)) { + field.setAccessible(true); + fields.add(new Object[]{field, attr}); + } + } + } + } + } + return fields; + } + + /** + * 根据注解获取最大行高 + */ + public short getRowHeight() { + double maxHeight = 0; + for (Object[] os : this.fields) { + Excel excel = (Excel) os[1]; + maxHeight = Math.max(maxHeight, excel.height()); + } + return (short) (maxHeight * 20); + } + + /** + * 创建一个工作簿 + */ + public void createWorkbook() { + this.wb = new SXSSFWorkbook(500); + this.sheet = wb.createSheet(); + wb.setSheetName(0, sheetName); + this.styles = createStyles(wb); + } + + /** + * 创建工作表 + * + * @param sheetNo sheet数量 + * @param index 序号 + */ + public void createSheet(int sheetNo, int index) { + // 设置工作表的名称. + if (sheetNo > 1 && index > 0) { + this.sheet = wb.createSheet(); + this.createTitle(); + wb.setSheetName(index, sheetName + index); + } + } + + /** + * 获取单元格值 + * + * @param row 获取的行 + * @param column 获取单元格列号 + * @return 单元格值 + */ + public Object getCellValue(Row row, int column) { + if (row == null) { + return row; + } + Object val = ""; + try { + Cell cell = row.getCell(column); + if (StringUtils.isNotNull(cell)) { + if (cell.getCellType() == CellType.NUMERIC || cell.getCellType() == CellType.FORMULA) { + val = cell.getNumericCellValue(); + if (DateUtil.isCellDateFormatted(cell)) { + val = DateUtil.getJavaDate((Double) val); // POI Excel 日期格式转换 + } else { + if ((Double) val % 1 != 0) { + val = new BigDecimal(val.toString()); + } else { + val = new DecimalFormat("0").format(val); + } + } + } else if (cell.getCellType() == CellType.STRING) { + val = cell.getStringCellValue(); + } else if (cell.getCellType() == CellType.BOOLEAN) { + val = cell.getBooleanCellValue(); + } else if (cell.getCellType() == CellType.ERROR) { + val = cell.getErrorCellValue(); + } + + } + } catch (Exception e) { + return val; + } + return val; + } + + /** + * 判断是否是空行 + * + * @param row 判断的行 + * @return + */ + private boolean isRowEmpty(Row row) { + if (row == null) { + return true; + } + for (int i = row.getFirstCellNum(); i < row.getLastCellNum(); i++) { + Cell cell = row.getCell(i); + if (cell != null && cell.getCellType() != CellType.BLANK) { + return false; + } + } + return true; + } + + /** + * 获取Excel2003图片 + * + * @param sheet 当前sheet对象 + * @param workbook 工作簿对象 + * @return Map key:图片单元格索引(1_1)String,value:图片流PictureData + */ + public static Map<String, PictureData> getSheetPictures03(HSSFSheet sheet, HSSFWorkbook workbook) { + Map<String, PictureData> sheetIndexPicMap = new HashMap<String, PictureData>(); + List<HSSFPictureData> pictures = workbook.getAllPictures(); + if (!pictures.isEmpty()) { + for (HSSFShape shape : sheet.getDrawingPatriarch().getChildren()) { + HSSFClientAnchor anchor = (HSSFClientAnchor) shape.getAnchor(); + if (shape instanceof HSSFPicture) { + HSSFPicture pic = (HSSFPicture) shape; + int pictureIndex = pic.getPictureIndex() - 1; + HSSFPictureData picData = pictures.get(pictureIndex); + String picIndex = String.valueOf(anchor.getRow1()) + "_" + String.valueOf(anchor.getCol1()); + sheetIndexPicMap.put(picIndex, picData); + } + } + return sheetIndexPicMap; + } else { + return sheetIndexPicMap; + } + } + + /** + * 获取Excel2007图片 + * + * @param sheet 当前sheet对象 + * @param workbook 工作簿对象 + * @return Map key:图片单元格索引(1_1)String,value:图片流PictureData + */ + public static Map<String, PictureData> getSheetPictures07(XSSFSheet sheet, XSSFWorkbook workbook) { + Map<String, PictureData> sheetIndexPicMap = new HashMap<String, PictureData>(); + for (POIXMLDocumentPart dr : sheet.getRelations()) { + if (dr instanceof XSSFDrawing) { + XSSFDrawing drawing = (XSSFDrawing) dr; + List<XSSFShape> shapes = drawing.getShapes(); + for (XSSFShape shape : shapes) { + if (shape instanceof XSSFPicture) { + XSSFPicture pic = (XSSFPicture) shape; + XSSFClientAnchor anchor = pic.getPreferredSize(); + CTMarker ctMarker = anchor.getFrom(); + String picIndex = ctMarker.getRow() + "_" + ctMarker.getCol(); + sheetIndexPicMap.put(picIndex, pic.getPictureData()); + } + } + } + } + return sheetIndexPicMap; + } + + /** + * 格式化不同类型的日期对象 + * + * @param dateFormat 日期格式 + * @param val 被格式化的日期对象 + * @return 格式化后的日期字符 + */ + public String parseDateToStr(String dateFormat, Object val) { + if (val == null) { + return ""; + } + String str; + if (val instanceof Date) { + str = DateUtils.parseDateToStr(dateFormat, (Date) val); + } else if (val instanceof LocalDateTime) { + str = DateUtils.parseDateToStr(dateFormat, DateUtils.toDate((LocalDateTime) val)); + } else if (val instanceof LocalDate) { + str = DateUtils.parseDateToStr(dateFormat, DateUtils.toDate((LocalDate) val)); + } else { + str = val.toString(); + } + return str; + } + + /** + * 是否有对象的子列表 + */ + public boolean isSubList() { + return StringUtils.isNotNull(subFields) && subFields.size() > 0; + } + + /** + * 是否有对象的子列表,集合不为空 + */ + public boolean isSubListValue(T vo) { + return StringUtils.isNotNull(subFields) && subFields.size() > 0 && StringUtils.isNotNull(getListCellValue(vo)) && getListCellValue(vo).size() > 0; + } + + /** + * 获取集合的值 + */ + public Collection<?> getListCellValue(Object obj) { + Object value; + try { + value = subMethod.invoke(obj, new Object[]{}); + } catch (Exception e) { + return new ArrayList<Object>(); + } + return (Collection<?>) value; + } + + /** + * 获取对象的子列表方法 + * + * @param name 名称 + * @param pojoClass 类对象 + * @return 子列表方法 + */ + public Method getSubMethod(String name, Class<?> pojoClass) { + StringBuffer getMethodName = new StringBuffer("get"); + getMethodName.append(name.substring(0, 1).toUpperCase()); + getMethodName.append(name.substring(1)); + Method method = null; + try { + method = pojoClass.getMethod(getMethodName.toString(), new Class[]{}); + } catch (Exception e) { + log.error("获取对象异常{}", e.getMessage()); + } + return method; + } + +} diff --git a/dc-common/src/main/java/com/dc/common/utils/reflect/ReflectUtils.java b/dc-common/src/main/java/com/dc/common/utils/reflect/ReflectUtils.java new file mode 100644 index 0000000..a2ee7ca --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/utils/reflect/ReflectUtils.java @@ -0,0 +1,406 @@ +package com.dc.common.utils.reflect; + +import com.dc.common.core.text.Convert; +import com.dc.common.utils.DateUtils; +import org.apache.commons.lang3.StringUtils; +import org.apache.commons.lang3.Validate; +import org.apache.poi.ss.usermodel.DateUtil; +import org.slf4j.Logger; +import org.slf4j.LoggerFactory; + +import java.lang.reflect.*; +import java.util.Date; + +/** + * 反射工具类. 提供调用getter/setter方法, 访问私有变量, 调用私有方法, 获取泛型类型Class, 被AOP过的真实类等工具函数. + * + * @author win + */ +@SuppressWarnings("rawtypes") +public class ReflectUtils +{ + private static final String SETTER_PREFIX = "set"; + + private static final String GETTER_PREFIX = "get"; + + private static final String CGLIB_CLASS_SEPARATOR = "$$"; + + private static Logger logger = LoggerFactory.getLogger(ReflectUtils.class); + + /** + * 调用Getter方法. + * 支持多级,如:对象名.对象名.方法 + */ + @SuppressWarnings("unchecked") + public static <E> E invokeGetter(Object obj, String propertyName) + { + Object object = obj; + for (String name : StringUtils.split(propertyName, ".")) + { + String getterMethodName = GETTER_PREFIX + StringUtils.capitalize(name); + object = invokeMethod(object, getterMethodName, new Class[] {}, new Object[] {}); + } + return (E) object; + } + + /** + * 调用Setter方法, 仅匹配方法名。 + * 支持多级,如:对象名.对象名.方法 + */ + public static <E> void invokeSetter(Object obj, String propertyName, E value) + { + Object object = obj; + String[] names = StringUtils.split(propertyName, "."); + for (int i = 0; i < names.length; i++) + { + if (i < names.length - 1) + { + String getterMethodName = GETTER_PREFIX + StringUtils.capitalize(names[i]); + object = invokeMethod(object, getterMethodName, new Class[] {}, new Object[] {}); + } + else + { + String setterMethodName = SETTER_PREFIX + StringUtils.capitalize(names[i]); + invokeMethodByName(object, setterMethodName, new Object[] { value }); + } + } + } + + /** + * 直接读取对象属性值, 无视private/protected修饰符, 不经过getter函数. + */ + @SuppressWarnings("unchecked") + public static <E> E getFieldValue(final Object obj, final String fieldName) + { + Field field = getAccessibleField(obj, fieldName); + if (field == null) + { + logger.debug("在 [" + obj.getClass() + "] 中,没有找到 [" + fieldName + "] 字段 "); + return null; + } + E result = null; + try + { + result = (E) field.get(obj); + } + catch (IllegalAccessException e) + { + logger.error("不可能抛出的异常{}", e.getMessage()); + } + return result; + } + + /** + * 直接设置对象属性值, 无视private/protected修饰符, 不经过setter函数. + */ + public static <E> void setFieldValue(final Object obj, final String fieldName, final E value) + { + Field field = getAccessibleField(obj, fieldName); + if (field == null) + { + // throw new IllegalArgumentException("在 [" + obj.getClass() + "] 中,没有找到 [" + fieldName + "] 字段 "); + logger.debug("在 [" + obj.getClass() + "] 中,没有找到 [" + fieldName + "] 字段 "); + return; + } + try + { + field.set(obj, value); + } + catch (IllegalAccessException e) + { + logger.error("不可能抛出的异常: {}", e.getMessage()); + } + } + + /** + * 直接调用对象方法, 无视private/protected修饰符. + * 用于一次性调用的情况,否则应使用getAccessibleMethod()函数获得Method后反复调用. + * 同时匹配方法名+参数类型, + */ + @SuppressWarnings("unchecked") + public static <E> E invokeMethod(final Object obj, final String methodName, final Class<?>[] parameterTypes, + final Object[] args) + { + if (obj == null || methodName == null) + { + return null; + } + Method method = getAccessibleMethod(obj, methodName, parameterTypes); + if (method == null) + { + logger.debug("在 [" + obj.getClass() + "] 中,没有找到 [" + methodName + "] 方法 "); + return null; + } + try + { + return (E) method.invoke(obj, args); + } + catch (Exception e) + { + String msg = "method: " + method + ", obj: " + obj + ", args: " + args + ""; + throw convertReflectionExceptionToUnchecked(msg, e); + } + } + + /** + * 直接调用对象方法, 无视private/protected修饰符, + * 用于一次性调用的情况,否则应使用getAccessibleMethodByName()函数获得Method后反复调用. + * 只匹配函数名,如果有多个同名函数调用第一个。 + */ + @SuppressWarnings("unchecked") + public static <E> E invokeMethodByName(final Object obj, final String methodName, final Object[] args) + { + Method method = getAccessibleMethodByName(obj, methodName, args.length); + if (method == null) + { + // 如果为空不报错,直接返回空。 + logger.debug("在 [" + obj.getClass() + "] 中,没有找到 [" + methodName + "] 方法 "); + return null; + } + try + { + // 类型转换(将参数数据类型转换为目标方法参数类型) + Class<?>[] cs = method.getParameterTypes(); + for (int i = 0; i < cs.length; i++) + { + if (args[i] != null && !args[i].getClass().equals(cs[i])) + { + if (cs[i] == String.class) + { + args[i] = Convert.toStr(args[i]); + if (StringUtils.endsWith((String) args[i], ".0")) + { + args[i] = StringUtils.substringBefore((String) args[i], ".0"); + } + } + else if (cs[i] == Integer.class) + { + args[i] = Convert.toInt(args[i]); + } + else if (cs[i] == Long.class) + { + args[i] = Convert.toLong(args[i]); + } + else if (cs[i] == Double.class) + { + args[i] = Convert.toDouble(args[i]); + } + else if (cs[i] == Float.class) + { + args[i] = Convert.toFloat(args[i]); + } + else if (cs[i] == Date.class) + { + if (args[i] instanceof String) + { + args[i] = DateUtils.parseDate(args[i]); + } + else + { + args[i] = DateUtil.getJavaDate((Double) args[i]); + } + } + else if (cs[i] == boolean.class || cs[i] == Boolean.class) + { + args[i] = Convert.toBool(args[i]); + } + } + } + return (E) method.invoke(obj, args); + } + catch (Exception e) + { + String msg = "method: " + method + ", obj: " + obj + ", args: " + args + ""; + throw convertReflectionExceptionToUnchecked(msg, e); + } + } + + /** + * 循环向上转型, 获取对象的DeclaredField, 并强制设置为可访问. + * 如向上转型到Object仍无法找到, 返回null. + */ + public static Field getAccessibleField(final Object obj, final String fieldName) + { + // 为空不报错。直接返回 null + if (obj == null) + { + return null; + } + Validate.notBlank(fieldName, "fieldName can't be blank"); + for (Class<?> superClass = obj.getClass(); superClass != Object.class; superClass = superClass.getSuperclass()) + { + try + { + Field field = superClass.getDeclaredField(fieldName); + makeAccessible(field); + return field; + } + catch (NoSuchFieldException e) + { + continue; + } + } + return null; + } + + /** + * 循环向上转型, 获取对象的DeclaredMethod,并强制设置为可访问. + * 如向上转型到Object仍无法找到, 返回null. + * 匹配函数名+参数类型。 + * 用于方法需要被多次调用的情况. 先使用本函数先取得Method,然后调用Method.invoke(Object obj, Object... args) + */ + public static Method getAccessibleMethod(final Object obj, final String methodName, + final Class<?>... parameterTypes) + { + // 为空不报错。直接返回 null + if (obj == null) + { + return null; + } + Validate.notBlank(methodName, "methodName can't be blank"); + for (Class<?> searchType = obj.getClass(); searchType != Object.class; searchType = searchType.getSuperclass()) + { + try + { + Method method = searchType.getDeclaredMethod(methodName, parameterTypes); + makeAccessible(method); + return method; + } + catch (NoSuchMethodException e) + { + continue; + } + } + return null; + } + + /** + * 循环向上转型, 获取对象的DeclaredMethod,并强制设置为可访问. + * 如向上转型到Object仍无法找到, 返回null. + * 只匹配函数名。 + * 用于方法需要被多次调用的情况. 先使用本函数先取得Method,然后调用Method.invoke(Object obj, Object... args) + */ + public static Method getAccessibleMethodByName(final Object obj, final String methodName, int argsNum) + { + // 为空不报错。直接返回 null + if (obj == null) + { + return null; + } + Validate.notBlank(methodName, "methodName can't be blank"); + for (Class<?> searchType = obj.getClass(); searchType != Object.class; searchType = searchType.getSuperclass()) + { + Method[] methods = searchType.getDeclaredMethods(); + for (Method method : methods) + { + if (method.getName().equals(methodName) && method.getParameterTypes().length == argsNum) + { + makeAccessible(method); + return method; + } + } + } + return null; + } + + /** + * 改变private/protected的方法为public,尽量不调用实际改动的语句,避免JDK的SecurityManager抱怨。 + */ + public static void makeAccessible(Method method) + { + if ((!Modifier.isPublic(method.getModifiers()) || !Modifier.isPublic(method.getDeclaringClass().getModifiers())) + && !method.isAccessible()) + { + method.setAccessible(true); + } + } + + /** + * 改变private/protected的成员变量为public,尽量不调用实际改动的语句,避免JDK的SecurityManager抱怨。 + */ + public static void makeAccessible(Field field) + { + if ((!Modifier.isPublic(field.getModifiers()) || !Modifier.isPublic(field.getDeclaringClass().getModifiers()) + || Modifier.isFinal(field.getModifiers())) && !field.isAccessible()) + { + field.setAccessible(true); + } + } + + /** + * 通过反射, 获得Class定义中声明的泛型参数的类型, 注意泛型必须定义在父类处 + * 如无法找到, 返回Object.class. + */ + @SuppressWarnings("unchecked") + public static <T> Class<T> getClassGenricType(final Class clazz) + { + return getClassGenricType(clazz, 0); + } + + /** + * 通过反射, 获得Class定义中声明的父类的泛型参数的类型. + * 如无法找到, 返回Object.class. + */ + public static Class getClassGenricType(final Class clazz, final int index) + { + Type genType = clazz.getGenericSuperclass(); + + if (!(genType instanceof ParameterizedType)) + { + logger.debug(clazz.getSimpleName() + "'s superclass not ParameterizedType"); + return Object.class; + } + + Type[] params = ((ParameterizedType) genType).getActualTypeArguments(); + + if (index >= params.length || index < 0) + { + logger.debug("Index: " + index + ", Size of " + clazz.getSimpleName() + "'s Parameterized Type: " + + params.length); + return Object.class; + } + if (!(params[index] instanceof Class)) + { + logger.debug(clazz.getSimpleName() + " not set the actual class on superclass generic parameter"); + return Object.class; + } + + return (Class) params[index]; + } + + public static Class<?> getUserClass(Object instance) + { + if (instance == null) + { + throw new RuntimeException("Instance must not be null"); + } + Class clazz = instance.getClass(); + if (clazz != null && clazz.getName().contains(CGLIB_CLASS_SEPARATOR)) + { + Class<?> superClass = clazz.getSuperclass(); + if (superClass != null && !Object.class.equals(superClass)) + { + return superClass; + } + } + return clazz; + + } + + /** + * 将反射时的checked exception转换为unchecked exception. + */ + public static RuntimeException convertReflectionExceptionToUnchecked(String msg, Exception e) + { + if (e instanceof IllegalAccessException || e instanceof IllegalArgumentException + || e instanceof NoSuchMethodException) + { + return new IllegalArgumentException(msg, e); + } + else if (e instanceof InvocationTargetException) + { + return new RuntimeException(msg, ((InvocationTargetException) e).getTargetException()); + } + return new RuntimeException(msg, e); + } +} diff --git a/dc-common/src/main/java/com/dc/common/utils/sign/Base64.java b/dc-common/src/main/java/com/dc/common/utils/sign/Base64.java new file mode 100644 index 0000000..104064a --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/utils/sign/Base64.java @@ -0,0 +1,291 @@ +package com.dc.common.utils.sign; + +/** + * Base64工具类 + * + * @author win + */ +public final class Base64 +{ + static private final int BASELENGTH = 128; + static private final int LOOKUPLENGTH = 64; + static private final int TWENTYFOURBITGROUP = 24; + static private final int EIGHTBIT = 8; + static private final int SIXTEENBIT = 16; + static private final int FOURBYTE = 4; + static private final int SIGN = -128; + static private final char PAD = '='; + static final private byte[] base64Alphabet = new byte[BASELENGTH]; + static final private char[] lookUpBase64Alphabet = new char[LOOKUPLENGTH]; + + static + { + for (int i = 0; i < BASELENGTH; ++i) + { + base64Alphabet[i] = -1; + } + for (int i = 'Z'; i >= 'A'; i--) + { + base64Alphabet[i] = (byte) (i - 'A'); + } + for (int i = 'z'; i >= 'a'; i--) + { + base64Alphabet[i] = (byte) (i - 'a' + 26); + } + + for (int i = '9'; i >= '0'; i--) + { + base64Alphabet[i] = (byte) (i - '0' + 52); + } + + base64Alphabet['+'] = 62; + base64Alphabet['/'] = 63; + + for (int i = 0; i <= 25; i++) + { + lookUpBase64Alphabet[i] = (char) ('A' + i); + } + + for (int i = 26, j = 0; i <= 51; i++, j++) + { + lookUpBase64Alphabet[i] = (char) ('a' + j); + } + + for (int i = 52, j = 0; i <= 61; i++, j++) + { + lookUpBase64Alphabet[i] = (char) ('0' + j); + } + lookUpBase64Alphabet[62] = (char) '+'; + lookUpBase64Alphabet[63] = (char) '/'; + } + + private static boolean isWhiteSpace(char octect) + { + return (octect == 0x20 || octect == 0xd || octect == 0xa || octect == 0x9); + } + + private static boolean isPad(char octect) + { + return (octect == PAD); + } + + private static boolean isData(char octect) + { + return (octect < BASELENGTH && base64Alphabet[octect] != -1); + } + + /** + * Encodes hex octects into Base64 + * + * @param binaryData Array containing binaryData + * @return Encoded Base64 array + */ + public static String encode(byte[] binaryData) + { + if (binaryData == null) + { + return null; + } + + int lengthDataBits = binaryData.length * EIGHTBIT; + if (lengthDataBits == 0) + { + return ""; + } + + int fewerThan24bits = lengthDataBits % TWENTYFOURBITGROUP; + int numberTriplets = lengthDataBits / TWENTYFOURBITGROUP; + int numberQuartet = fewerThan24bits != 0 ? numberTriplets + 1 : numberTriplets; + char encodedData[] = null; + + encodedData = new char[numberQuartet * 4]; + + byte k = 0, l = 0, b1 = 0, b2 = 0, b3 = 0; + + int encodedIndex = 0; + int dataIndex = 0; + + for (int i = 0; i < numberTriplets; i++) + { + b1 = binaryData[dataIndex++]; + b2 = binaryData[dataIndex++]; + b3 = binaryData[dataIndex++]; + + l = (byte) (b2 & 0x0f); + k = (byte) (b1 & 0x03); + + byte val1 = ((b1 & SIGN) == 0) ? (byte) (b1 >> 2) : (byte) ((b1) >> 2 ^ 0xc0); + byte val2 = ((b2 & SIGN) == 0) ? (byte) (b2 >> 4) : (byte) ((b2) >> 4 ^ 0xf0); + byte val3 = ((b3 & SIGN) == 0) ? (byte) (b3 >> 6) : (byte) ((b3) >> 6 ^ 0xfc); + + encodedData[encodedIndex++] = lookUpBase64Alphabet[val1]; + encodedData[encodedIndex++] = lookUpBase64Alphabet[val2 | (k << 4)]; + encodedData[encodedIndex++] = lookUpBase64Alphabet[(l << 2) | val3]; + encodedData[encodedIndex++] = lookUpBase64Alphabet[b3 & 0x3f]; + } + + // form integral number of 6-bit groups + if (fewerThan24bits == EIGHTBIT) + { + b1 = binaryData[dataIndex]; + k = (byte) (b1 & 0x03); + byte val1 = ((b1 & SIGN) == 0) ? (byte) (b1 >> 2) : (byte) ((b1) >> 2 ^ 0xc0); + encodedData[encodedIndex++] = lookUpBase64Alphabet[val1]; + encodedData[encodedIndex++] = lookUpBase64Alphabet[k << 4]; + encodedData[encodedIndex++] = PAD; + encodedData[encodedIndex++] = PAD; + } + else if (fewerThan24bits == SIXTEENBIT) + { + b1 = binaryData[dataIndex]; + b2 = binaryData[dataIndex + 1]; + l = (byte) (b2 & 0x0f); + k = (byte) (b1 & 0x03); + + byte val1 = ((b1 & SIGN) == 0) ? (byte) (b1 >> 2) : (byte) ((b1) >> 2 ^ 0xc0); + byte val2 = ((b2 & SIGN) == 0) ? (byte) (b2 >> 4) : (byte) ((b2) >> 4 ^ 0xf0); + + encodedData[encodedIndex++] = lookUpBase64Alphabet[val1]; + encodedData[encodedIndex++] = lookUpBase64Alphabet[val2 | (k << 4)]; + encodedData[encodedIndex++] = lookUpBase64Alphabet[l << 2]; + encodedData[encodedIndex++] = PAD; + } + return new String(encodedData); + } + + /** + * Decodes Base64 data into octects + * + * @param encoded string containing Base64 data + * @return Array containind decoded data. + */ + public static byte[] decode(String encoded) + { + if (encoded == null) + { + return null; + } + + char[] base64Data = encoded.toCharArray(); + // remove white spaces + int len = removeWhiteSpace(base64Data); + + if (len % FOURBYTE != 0) + { + return null;// should be divisible by four + } + + int numberQuadruple = (len / FOURBYTE); + + if (numberQuadruple == 0) + { + return new byte[0]; + } + + byte decodedData[] = null; + byte b1 = 0, b2 = 0, b3 = 0, b4 = 0; + char d1 = 0, d2 = 0, d3 = 0, d4 = 0; + + int i = 0; + int encodedIndex = 0; + int dataIndex = 0; + decodedData = new byte[(numberQuadruple) * 3]; + + for (; i < numberQuadruple - 1; i++) + { + + if (!isData((d1 = base64Data[dataIndex++])) || !isData((d2 = base64Data[dataIndex++])) + || !isData((d3 = base64Data[dataIndex++])) || !isData((d4 = base64Data[dataIndex++]))) + { + return null; + } // if found "no data" just return null + + b1 = base64Alphabet[d1]; + b2 = base64Alphabet[d2]; + b3 = base64Alphabet[d3]; + b4 = base64Alphabet[d4]; + + decodedData[encodedIndex++] = (byte) (b1 << 2 | b2 >> 4); + decodedData[encodedIndex++] = (byte) (((b2 & 0xf) << 4) | ((b3 >> 2) & 0xf)); + decodedData[encodedIndex++] = (byte) (b3 << 6 | b4); + } + + if (!isData((d1 = base64Data[dataIndex++])) || !isData((d2 = base64Data[dataIndex++]))) + { + return null;// if found "no data" just return null + } + + b1 = base64Alphabet[d1]; + b2 = base64Alphabet[d2]; + + d3 = base64Data[dataIndex++]; + d4 = base64Data[dataIndex++]; + if (!isData((d3)) || !isData((d4))) + {// Check if they are PAD characters + if (isPad(d3) && isPad(d4)) + { + if ((b2 & 0xf) != 0)// last 4 bits should be zero + { + return null; + } + byte[] tmp = new byte[i * 3 + 1]; + System.arraycopy(decodedData, 0, tmp, 0, i * 3); + tmp[encodedIndex] = (byte) (b1 << 2 | b2 >> 4); + return tmp; + } + else if (!isPad(d3) && isPad(d4)) + { + b3 = base64Alphabet[d3]; + if ((b3 & 0x3) != 0)// last 2 bits should be zero + { + return null; + } + byte[] tmp = new byte[i * 3 + 2]; + System.arraycopy(decodedData, 0, tmp, 0, i * 3); + tmp[encodedIndex++] = (byte) (b1 << 2 | b2 >> 4); + tmp[encodedIndex] = (byte) (((b2 & 0xf) << 4) | ((b3 >> 2) & 0xf)); + return tmp; + } + else + { + return null; + } + } + else + { // No PAD e.g 3cQl + b3 = base64Alphabet[d3]; + b4 = base64Alphabet[d4]; + decodedData[encodedIndex++] = (byte) (b1 << 2 | b2 >> 4); + decodedData[encodedIndex++] = (byte) (((b2 & 0xf) << 4) | ((b3 >> 2) & 0xf)); + decodedData[encodedIndex++] = (byte) (b3 << 6 | b4); + + } + return decodedData; + } + + /** + * remove WhiteSpace from MIME containing encoded Base64 data. + * + * @param data the byte array of base64 data (with WS) + * @return the new length + */ + private static int removeWhiteSpace(char[] data) + { + if (data == null) + { + return 0; + } + + // count characters that's not whitespace + int newSize = 0; + int len = data.length; + for (int i = 0; i < len; i++) + { + if (!isWhiteSpace(data[i])) + { + data[newSize++] = data[i]; + } + } + return newSize; + } +} diff --git a/dc-common/src/main/java/com/dc/common/utils/sign/Md5Utils.java b/dc-common/src/main/java/com/dc/common/utils/sign/Md5Utils.java new file mode 100644 index 0000000..c7e1c32 --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/utils/sign/Md5Utils.java @@ -0,0 +1,68 @@ +package com.dc.common.utils.sign; + +import org.slf4j.Logger; +import org.slf4j.LoggerFactory; + +import java.nio.charset.StandardCharsets; +import java.security.MessageDigest; + +/** + * Md5加密方法 + * + * @author win + */ +public class Md5Utils +{ + private static final Logger log = LoggerFactory.getLogger(Md5Utils.class); + + private static byte[] md5(String s) + { + MessageDigest algorithm; + try + { + algorithm = MessageDigest.getInstance("MD5"); + algorithm.reset(); + algorithm.update(s.getBytes("UTF-8")); + byte[] messageDigest = algorithm.digest(); + return messageDigest; + } + catch (Exception e) + { + log.error("MD5 Error...", e); + } + return null; + } + + private static final String toHex(byte hash[]) + { + if (hash == null) + { + return null; + } + StringBuffer buf = new StringBuffer(hash.length * 2); + int i; + + for (i = 0; i < hash.length; i++) + { + if ((hash[i] & 0xff) < 0x10) + { + buf.append("0"); + } + buf.append(Long.toString(hash[i] & 0xff, 16)); + } + return buf.toString(); + } + + public static String hash(String s) + { + try + { + return new String(toHex(md5(s)).getBytes(StandardCharsets.UTF_8), StandardCharsets.UTF_8); + } + catch (Exception e) + { + log.error("not supported charset...{}", e); + return s; + } + } +} diff --git a/dc-common/src/main/java/com/dc/common/utils/spring/SpringUtils.java b/dc-common/src/main/java/com/dc/common/utils/spring/SpringUtils.java new file mode 100644 index 0000000..1cdf380 --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/utils/spring/SpringUtils.java @@ -0,0 +1,158 @@ +package com.dc.common.utils.spring; + +import com.dc.common.utils.StringUtils; +import org.springframework.aop.framework.AopContext; +import org.springframework.beans.BeansException; +import org.springframework.beans.factory.NoSuchBeanDefinitionException; +import org.springframework.beans.factory.config.BeanFactoryPostProcessor; +import org.springframework.beans.factory.config.ConfigurableListableBeanFactory; +import org.springframework.context.ApplicationContext; +import org.springframework.context.ApplicationContextAware; +import org.springframework.stereotype.Component; + +/** + * spring工具类 方便在非spring管理环境中获取bean + * + * @author win + */ +@Component +public final class SpringUtils implements BeanFactoryPostProcessor, ApplicationContextAware +{ + /** Spring应用上下文环境 */ + private static ConfigurableListableBeanFactory beanFactory; + + private static ApplicationContext applicationContext; + + @Override + public void postProcessBeanFactory(ConfigurableListableBeanFactory beanFactory) throws BeansException + { + SpringUtils.beanFactory = beanFactory; + } + + @Override + public void setApplicationContext(ApplicationContext applicationContext) throws BeansException + { + SpringUtils.applicationContext = applicationContext; + } + + /** + * 获取对象 + * + * @param name + * @return Object 一个以所给名字注册的bean的实例 + * @throws BeansException + * + */ + @SuppressWarnings("unchecked") + public static <T> T getBean(String name) throws BeansException + { + return (T) beanFactory.getBean(name); + } + + /** + * 获取类型为requiredType的对象 + * + * @param clz + * @return + * @throws BeansException + * + */ + public static <T> T getBean(Class<T> clz) throws BeansException + { + T result = (T) beanFactory.getBean(clz); + return result; + } + + /** + * 如果BeanFactory包含一个与所给名称匹配的bean定义,则返回true + * + * @param name + * @return boolean + */ + public static boolean containsBean(String name) + { + return beanFactory.containsBean(name); + } + + /** + * 判断以给定名字注册的bean定义是一个singleton还是一个prototype。 如果与给定名字相应的bean定义没有被找到,将会抛出一个异常(NoSuchBeanDefinitionException) + * + * @param name + * @return boolean + * @throws NoSuchBeanDefinitionException + * + */ + public static boolean isSingleton(String name) throws NoSuchBeanDefinitionException + { + return beanFactory.isSingleton(name); + } + + /** + * @param name + * @return Class 注册对象的类型 + * @throws NoSuchBeanDefinitionException + * + */ + public static Class<?> getType(String name) throws NoSuchBeanDefinitionException + { + return beanFactory.getType(name); + } + + /** + * 如果给定的bean名字在bean定义中有别名,则返回这些别名 + * + * @param name + * @return + * @throws NoSuchBeanDefinitionException + * + */ + public static String[] getAliases(String name) throws NoSuchBeanDefinitionException + { + return beanFactory.getAliases(name); + } + + /** + * 获取aop代理对象 + * + * @param invoker + * @return + */ + @SuppressWarnings("unchecked") + public static <T> T getAopProxy(T invoker) + { + return (T) AopContext.currentProxy(); + } + + /** + * 获取当前的环境配置,无配置返回null + * + * @return 当前的环境配置 + */ + public static String[] getActiveProfiles() + { + return applicationContext.getEnvironment().getActiveProfiles(); + } + + /** + * 获取当前的环境配置,当有多个环境配置时,只获取第一个 + * + * @return 当前的环境配置 + */ + public static String getActiveProfile() + { + final String[] activeProfiles = getActiveProfiles(); + return StringUtils.isNotEmpty(activeProfiles) ? activeProfiles[2] : null; + } + + /** + * 获取配置文件中的值 + * + * @param key 配置文件的key + * @return 当前的配置文件的值 + * + */ + public static String getRequiredProperty(String key) + { + return applicationContext.getEnvironment().getRequiredProperty(key); + } +} diff --git a/dc-common/src/main/java/com/dc/common/utils/sql/SqlUtil.java b/dc-common/src/main/java/com/dc/common/utils/sql/SqlUtil.java new file mode 100644 index 0000000..db43c0c --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/utils/sql/SqlUtil.java @@ -0,0 +1,61 @@ +package com.dc.common.utils.sql; + +import com.dc.common.utils.StringUtils; +import com.dc.common.exception.UtilException; + +/** + * sql操作工具类 + * + * @author win + */ +public class SqlUtil +{ + /** + * 定义常用的 sql关键字 + */ + public static String SQL_REGEX = "and |extractvalue|updatexml|exec |insert |select |delete |update |drop |count |chr |mid |master |truncate |char |declare |or |+|user()"; + + /** + * 仅支持字母、数字、下划线、空格、逗号、小数点(支持多个字段排序) + */ + public static String SQL_PATTERN = "[a-zA-Z0-9_\\ \\,\\.]+"; + + /** + * 检查字符,防止注入绕过 + */ + public static String escapeOrderBySql(String value) + { + if (StringUtils.isNotEmpty(value) && !isValidOrderBySql(value)) + { + throw new UtilException("参数不符合规范,不能进行查询"); + } + return value; + } + + /** + * 验证 order by 语法是否符合规范 + */ + public static boolean isValidOrderBySql(String value) + { + return value.matches(SQL_PATTERN); + } + + /** + * SQL关键字检查 + */ + public static void filterKeyword(String value) + { + if (StringUtils.isEmpty(value)) + { + return; + } + String[] sqlKeywords = StringUtils.split(SQL_REGEX, "\\|"); + for (String sqlKeyword : sqlKeywords) + { + if (StringUtils.indexOfIgnoreCase(value, sqlKeyword) > -1) + { + throw new UtilException("参数存在SQL注入风险"); + } + } + } +} diff --git a/dc-common/src/main/java/com/dc/common/utils/uuid/IdUtils.java b/dc-common/src/main/java/com/dc/common/utils/uuid/IdUtils.java new file mode 100644 index 0000000..3da08fa --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/utils/uuid/IdUtils.java @@ -0,0 +1,49 @@ +package com.dc.common.utils.uuid; + +/** + * ID生成器工具类 + * + * @author win + */ +public class IdUtils +{ + /** + * 获取随机UUID + * + * @return 随机UUID + */ + public static String randomUUID() + { + return UUID.randomUUID().toString(); + } + + /** + * 简化的UUID,去掉了横线 + * + * @return 简化的UUID,去掉了横线 + */ + public static String simpleUUID() + { + return UUID.randomUUID().toString(true); + } + + /** + * 获取随机UUID,使用性能更好的ThreadLocalRandom生成UUID + * + * @return 随机UUID + */ + public static String fastUUID() + { + return UUID.fastUUID().toString(); + } + + /** + * 简化的UUID,去掉了横线,使用性能更好的ThreadLocalRandom生成UUID + * + * @return 简化的UUID,去掉了横线 + */ + public static String fastSimpleUUID() + { + return UUID.fastUUID().toString(true); + } +} diff --git a/dc-common/src/main/java/com/dc/common/utils/uuid/Seq.java b/dc-common/src/main/java/com/dc/common/utils/uuid/Seq.java new file mode 100644 index 0000000..0ab7434 --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/utils/uuid/Seq.java @@ -0,0 +1,87 @@ +package com.dc.common.utils.uuid; + +import com.dc.common.utils.StringUtils; +import com.dc.common.utils.DateUtils; + +import java.util.concurrent.atomic.AtomicInteger; + +/** + * @author win 序列生成类 + */ +public class Seq +{ + // 通用序列类型 + public static final String commSeqType = "COMMON"; + + // 上传序列类型 + public static final String uploadSeqType = "UPLOAD"; + + // 通用接口序列数 + private static AtomicInteger commSeq = new AtomicInteger(1); + + // 上传接口序列数 + private static AtomicInteger uploadSeq = new AtomicInteger(1); + + // 机器标识 + private static String machineCode = "A"; + + /** + * 获取通用序列号 + * + * @return 序列值 + */ + public static String getId() + { + return getId(commSeqType); + } + + /** + * 默认16位序列号 yyMMddHHmmss + 一位机器标识 + 3长度循环递增字符串 + * + * @return 序列值 + */ + public static String getId(String type) + { + AtomicInteger atomicInt = commSeq; + if (uploadSeqType.equals(type)) + { + atomicInt = uploadSeq; + } + return getId(atomicInt, 3); + } + + /** + * 通用接口序列号 yyMMddHHmmss + 一位机器标识 + length长度循环递增字符串 + * + * @param atomicInt 序列数 + * @param length 数值长度 + * @return 序列值 + */ + public static String getId(AtomicInteger atomicInt, int length) + { + String result = DateUtils.dateTimeNow(); + result += machineCode; + result += getSeq(atomicInt, length); + return result; + } + + /** + * 序列循环递增字符串[1, 10 的 (length)幂次方), 用0左补齐length位数 + * + * @return 序列值 + */ + private synchronized static String getSeq(AtomicInteger atomicInt, int length) + { + // 先取值再+1 + int value = atomicInt.getAndIncrement(); + + // 如果更新后值>=10 的 (length)幂次方则重置为1 + int maxSeq = (int) Math.pow(10, length); + if (atomicInt.get() >= maxSeq) + { + atomicInt.set(1); + } + // 转字符串,用0左补齐 + return StringUtils.padl(value, length); + } +} diff --git a/dc-common/src/main/java/com/dc/common/utils/uuid/UUID.java b/dc-common/src/main/java/com/dc/common/utils/uuid/UUID.java new file mode 100644 index 0000000..8603728 --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/utils/uuid/UUID.java @@ -0,0 +1,485 @@ +package com.dc.common.utils.uuid; + +import com.dc.common.exception.UtilException; + +import java.security.MessageDigest; +import java.security.NoSuchAlgorithmException; +import java.security.SecureRandom; +import java.util.Random; +import java.util.concurrent.ThreadLocalRandom; + +/** + * 提供通用唯一识别码(universally unique identifier)(UUID)实现 + * + * @author win + */ +public final class UUID implements java.io.Serializable, Comparable<UUID> +{ + private static final long serialVersionUID = -1185015143654744140L; + + /** + * SecureRandom 的单例 + * + */ + private static class Holder + { + static final SecureRandom numberGenerator = getSecureRandom(); + } + + /** 此UUID的最高64有效位 */ + private final long mostSigBits; + + /** 此UUID的最低64有效位 */ + private final long leastSigBits; + + /** + * 私有构造 + * + * @param data 数据 + */ + private UUID(byte[] data) + { + long msb = 0; + long lsb = 0; + assert data.length == 16 : "data must be 16 bytes in length"; + for (int i = 0; i < 8; i++) + { + msb = (msb << 8) | (data[i] & 0xff); + } + for (int i = 8; i < 16; i++) + { + lsb = (lsb << 8) | (data[i] & 0xff); + } + this.mostSigBits = msb; + this.leastSigBits = lsb; + } + + /** + * 使用指定的数据构造新的 UUID。 + * + * @param mostSigBits 用于 {@code UUID} 的最高有效 64 位 + * @param leastSigBits 用于 {@code UUID} 的最低有效 64 位 + */ + public UUID(long mostSigBits, long leastSigBits) + { + this.mostSigBits = mostSigBits; + this.leastSigBits = leastSigBits; + } + + /** + * 获取类型 4(伪随机生成的)UUID 的静态工厂。 使用加密的本地线程伪随机数生成器生成该 UUID。 + * + * @return 随机生成的 {@code UUID} + */ + public static UUID fastUUID() + { + return randomUUID(false); + } + + /** + * 获取类型 4(伪随机生成的)UUID 的静态工厂。 使用加密的强伪随机数生成器生成该 UUID。 + * + * @return 随机生成的 {@code UUID} + */ + public static UUID randomUUID() + { + return randomUUID(true); + } + + /** + * 获取类型 4(伪随机生成的)UUID 的静态工厂。 使用加密的强伪随机数生成器生成该 UUID。 + * + * @param isSecure 是否使用{@link SecureRandom}如果是可以获得更安全的随机码,否则可以得到更好的性能 + * @return 随机生成的 {@code UUID} + */ + public static UUID randomUUID(boolean isSecure) + { + final Random ng = isSecure ? Holder.numberGenerator : getRandom(); + + byte[] randomBytes = new byte[16]; + ng.nextBytes(randomBytes); + randomBytes[6] &= 0x0f; /* clear version */ + randomBytes[6] |= 0x40; /* set to version 4 */ + randomBytes[8] &= 0x3f; /* clear variant */ + randomBytes[8] |= 0x80; /* set to IETF variant */ + return new UUID(randomBytes); + } + + /** + * 根据指定的字节数组获取类型 3(基于名称的)UUID 的静态工厂。 + * + * @param name 用于构造 UUID 的字节数组。 + * + * @return 根据指定数组生成的 {@code UUID} + */ + public static UUID nameUUIDFromBytes(byte[] name) + { + MessageDigest md; + try + { + md = MessageDigest.getInstance("MD5"); + } + catch (NoSuchAlgorithmException nsae) + { + throw new InternalError("MD5 not supported"); + } + byte[] md5Bytes = md.digest(name); + md5Bytes[6] &= 0x0f; /* clear version */ + md5Bytes[6] |= 0x30; /* set to version 3 */ + md5Bytes[8] &= 0x3f; /* clear variant */ + md5Bytes[8] |= 0x80; /* set to IETF variant */ + return new UUID(md5Bytes); + } + + /** + * 根据 {@link #toString()} 方法中描述的字符串标准表示形式创建{@code UUID}。 + * + * @param name 指定 {@code UUID} 字符串 + * @return 具有指定值的 {@code UUID} + * @throws IllegalArgumentException 如果 name 与 {@link #toString} 中描述的字符串表示形式不符抛出此异常 + * + */ + public static UUID fromString(String name) + { + String[] components = name.split("-"); + if (components.length != 5) + { + throw new IllegalArgumentException("Invalid UUID string: " + name); + } + for (int i = 0; i < 5; i++) + { + components[i] = "0x" + components[i]; + } + + long mostSigBits = Long.decode(components[0]).longValue(); + mostSigBits <<= 16; + mostSigBits |= Long.decode(components[1]).longValue(); + mostSigBits <<= 16; + mostSigBits |= Long.decode(components[2]).longValue(); + + long leastSigBits = Long.decode(components[3]).longValue(); + leastSigBits <<= 48; + leastSigBits |= Long.decode(components[4]).longValue(); + + return new UUID(mostSigBits, leastSigBits); + } + + /** + * 返回此 UUID 的 128 位值中的最低有效 64 位。 + * + * @return 此 UUID 的 128 位值中的最低有效 64 位。 + */ + public long getLeastSignificantBits() + { + return leastSigBits; + } + + /** + * 返回此 UUID 的 128 位值中的最高有效 64 位。 + * + * @return 此 UUID 的 128 位值中最高有效 64 位。 + */ + public long getMostSignificantBits() + { + return mostSigBits; + } + + /** + * 与此 {@code UUID} 相关联的版本号. 版本号描述此 {@code UUID} 是如何生成的。 + * <p> + * 版本号具有以下含意: + * <ul> + * <li>1 基于时间的 UUID + * <li>2 DCE 安全 UUID + * <li>3 基于名称的 UUID + * <li>4 随机生成的 UUID + * </ul> + * + * @return 此 {@code UUID} 的版本号 + */ + public int version() + { + // Version is bits masked by 0x000000000000F000 in MS long + return (int) ((mostSigBits >> 12) & 0x0f); + } + + /** + * 与此 {@code UUID} 相关联的变体号。变体号描述 {@code UUID} 的布局。 + * <p> + * 变体号具有以下含意: + * <ul> + * <li>0 为 NCS 向后兼容保留 + * <li>2 <a href="http://www.ietf.org/rfc/rfc4122.txt">IETF RFC 4122</a>(Leach-Salz), 用于此类 + * <li>6 保留,微软向后兼容 + * <li>7 保留供以后定义使用 + * </ul> + * + * @return 此 {@code UUID} 相关联的变体号 + */ + public int variant() + { + // This field is composed of a varying number of bits. + // 0 - - Reserved for NCS backward compatibility + // 1 0 - The IETF aka Leach-Salz variant (used by this class) + // 1 1 0 Reserved, Microsoft backward compatibility + // 1 1 1 Reserved for future definition. + return (int) ((leastSigBits >>> (64 - (leastSigBits >>> 62))) & (leastSigBits >> 63)); + } + + /** + * 与此 UUID 相关联的时间戳值。 + * + * <p> + * 60 位的时间戳值根据此 {@code UUID} 的 time_low、time_mid 和 time_hi 字段构造。<br> + * 所得到的时间戳以 100 毫微秒为单位,从 UTC(通用协调时间) 1582 年 10 月 15 日零时开始。 + * + * <p> + * 时间戳值仅在在基于时间的 UUID(其 version 类型为 1)中才有意义。<br> + * 如果此 {@code UUID} 不是基于时间的 UUID,则此方法抛出 UnsupportedOperationException。 + * + * @throws UnsupportedOperationException 如果此 {@code UUID} 不是 version 为 1 的 UUID。 + */ + public long timestamp() throws UnsupportedOperationException + { + checkTimeBase(); + return (mostSigBits & 0x0FFFL) << 48// + | ((mostSigBits >> 16) & 0x0FFFFL) << 32// + | mostSigBits >>> 32; + } + + /** + * 与此 UUID 相关联的时钟序列值。 + * + * <p> + * 14 位的时钟序列值根据此 UUID 的 clock_seq 字段构造。clock_seq 字段用于保证在基于时间的 UUID 中的时间唯一性。 + * <p> + * {@code clockSequence} 值仅在基于时间的 UUID(其 version 类型为 1)中才有意义。 如果此 UUID 不是基于时间的 UUID,则此方法抛出 + * UnsupportedOperationException。 + * + * @return 此 {@code UUID} 的时钟序列 + * + * @throws UnsupportedOperationException 如果此 UUID 的 version 不为 1 + */ + public int clockSequence() throws UnsupportedOperationException + { + checkTimeBase(); + return (int) ((leastSigBits & 0x3FFF000000000000L) >>> 48); + } + + /** + * 与此 UUID 相关的节点值。 + * + * <p> + * 48 位的节点值根据此 UUID 的 node 字段构造。此字段旨在用于保存机器的 IEEE 802 地址,该地址用于生成此 UUID 以保证空间唯一性。 + * <p> + * 节点值仅在基于时间的 UUID(其 version 类型为 1)中才有意义。<br> + * 如果此 UUID 不是基于时间的 UUID,则此方法抛出 UnsupportedOperationException。 + * + * @return 此 {@code UUID} 的节点值 + * + * @throws UnsupportedOperationException 如果此 UUID 的 version 不为 1 + */ + public long node() throws UnsupportedOperationException + { + checkTimeBase(); + return leastSigBits & 0x0000FFFFFFFFFFFFL; + } + + /** + * 返回此{@code UUID} 的字符串表现形式。 + * + * <p> + * UUID 的字符串表示形式由此 BNF 描述: + * + * <pre> + * {@code + * UUID = <time_low>-<time_mid>-<time_high_and_version>-<variant_and_sequence>-<node> + * time_low = 4*<hexOctet> + * time_mid = 2*<hexOctet> + * time_high_and_version = 2*<hexOctet> + * variant_and_sequence = 2*<hexOctet> + * node = 6*<hexOctet> + * hexOctet = <hexDigit><hexDigit> + * hexDigit = [0-9a-fA-F] + * } + * </pre> + * + * </blockquote> + * + * @return 此{@code UUID} 的字符串表现形式 + * @see #toString(boolean) + */ + @Override + public String toString() + { + return toString(false); + } + + /** + * 返回此{@code UUID} 的字符串表现形式。 + * + * <p> + * UUID 的字符串表示形式由此 BNF 描述: + * + * <pre> + * {@code + * UUID = <time_low>-<time_mid>-<time_high_and_version>-<variant_and_sequence>-<node> + * time_low = 4*<hexOctet> + * time_mid = 2*<hexOctet> + * time_high_and_version = 2*<hexOctet> + * variant_and_sequence = 2*<hexOctet> + * node = 6*<hexOctet> + * hexOctet = <hexDigit><hexDigit> + * hexDigit = [0-9a-fA-F] + * } + * </pre> + * + * </blockquote> + * + * @param isSimple 是否简单模式,简单模式为不带'-'的UUID字符串 + * @return 此{@code UUID} 的字符串表现形式 + */ + public String toString(boolean isSimple) + { + final StringBuilder builder = new StringBuilder(isSimple ? 32 : 36); + // time_low + builder.append(digits(mostSigBits >> 32, 8)); + if (!isSimple) + { + builder.append('-'); + } + // time_mid + builder.append(digits(mostSigBits >> 16, 4)); + if (!isSimple) + { + builder.append('-'); + } + // time_high_and_version + builder.append(digits(mostSigBits, 4)); + if (!isSimple) + { + builder.append('-'); + } + // variant_and_sequence + builder.append(digits(leastSigBits >> 48, 4)); + if (!isSimple) + { + builder.append('-'); + } + // node + builder.append(digits(leastSigBits, 12)); + + return builder.toString(); + } + + /** + * 返回此 UUID 的哈希码。 + * + * @return UUID 的哈希码值。 + */ + @Override + public int hashCode() + { + long hilo = mostSigBits ^ leastSigBits; + return ((int) (hilo >> 32)) ^ (int) hilo; + } + + /** + * 将此对象与指定对象比较。 + * <p> + * 当且仅当参数不为 {@code null}、而是一个 UUID 对象、具有与此 UUID 相同的 varriant、包含相同的值(每一位均相同)时,结果才为 {@code true}。 + * + * @param obj 要与之比较的对象 + * + * @return 如果对象相同,则返回 {@code true};否则返回 {@code false} + */ + @Override + public boolean equals(Object obj) + { + if ((null == obj) || (obj.getClass() != UUID.class)) + { + return false; + } + UUID id = (UUID) obj; + return (mostSigBits == id.mostSigBits && leastSigBits == id.leastSigBits); + } + + // Comparison Operations + + /** + * 将此 UUID 与指定的 UUID 比较。 + * + * <p> + * 如果两个 UUID 不同,且第一个 UUID 的最高有效字段大于第二个 UUID 的对应字段,则第一个 UUID 大于第二个 UUID。 + * + * @param val 与此 UUID 比较的 UUID + * + * @return 在此 UUID 小于、等于或大于 val 时,分别返回 -1、0 或 1。 + * + */ + @Override + public int compareTo(UUID val) + { + // The ordering is intentionally set up so that the UUIDs + // can simply be numerically compared as two numbers + return (this.mostSigBits < val.mostSigBits ? -1 : // + (this.mostSigBits > val.mostSigBits ? 1 : // + (this.leastSigBits < val.leastSigBits ? -1 : // + (this.leastSigBits > val.leastSigBits ? 1 : // + 0)))); + } + + // ------------------------------------------------------------------------------------------------------------------- + // Private method start + /** + * 返回指定数字对应的hex值 + * + * @param val 值 + * @param digits 位 + * @return 值 + */ + private static String digits(long val, int digits) + { + long hi = 1L << (digits * 4); + return Long.toHexString(hi | (val & (hi - 1))).substring(1); + } + + /** + * 检查是否为time-based版本UUID + */ + private void checkTimeBase() + { + if (version() != 1) + { + throw new UnsupportedOperationException("Not a time-based UUID"); + } + } + + /** + * 获取{@link SecureRandom},类提供加密的强随机数生成器 (RNG) + * + * @return {@link SecureRandom} + */ + public static SecureRandom getSecureRandom() + { + try + { + return SecureRandom.getInstance("SHA1PRNG"); + } + catch (NoSuchAlgorithmException e) + { + throw new UtilException(e); + } + } + + /** + * 获取随机数生成器对象<br> + * ThreadLocalRandom是JDK 7之后提供并发产生随机数,能够解决多个线程发生的竞争争夺。 + * + * @return {@link ThreadLocalRandom} + */ + public static ThreadLocalRandom getRandom() + { + return ThreadLocalRandom.current(); + } +} diff --git a/dc-common/src/main/java/com/dc/common/xss/Xss.java b/dc-common/src/main/java/com/dc/common/xss/Xss.java new file mode 100644 index 0000000..c58ac49 --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/xss/Xss.java @@ -0,0 +1,27 @@ +package com.dc.common.xss; + +import javax.validation.Constraint; +import javax.validation.Payload; +import java.lang.annotation.ElementType; +import java.lang.annotation.Retention; +import java.lang.annotation.RetentionPolicy; +import java.lang.annotation.Target; + +/** + * 自定义xss校验注解 + * + * @author win + */ +@Retention(RetentionPolicy.RUNTIME) +@Target(value = { ElementType.METHOD, ElementType.FIELD, ElementType.CONSTRUCTOR, ElementType.PARAMETER }) +@Constraint(validatedBy = { XssValidator.class }) +public @interface Xss +{ + String message() + + default "不允许任何脚本运行"; + + Class<?>[] groups() default {}; + + Class<? extends Payload>[] payload() default {}; +} diff --git a/dc-common/src/main/java/com/dc/common/xss/XssValidator.java b/dc-common/src/main/java/com/dc/common/xss/XssValidator.java new file mode 100644 index 0000000..f084512 --- /dev/null +++ b/dc-common/src/main/java/com/dc/common/xss/XssValidator.java @@ -0,0 +1,35 @@ +package com.dc.common.xss; + +import com.dc.common.utils.StringUtils; + +import javax.validation.ConstraintValidator; +import javax.validation.ConstraintValidatorContext; +import java.util.regex.Matcher; +import java.util.regex.Pattern; + +/** + * 自定义xss校验注解实现 + * + * @author win + */ +public class XssValidator implements ConstraintValidator<Xss, String> +{ + private static final String HTML_PATTERN = "<(\\S*?)[^>]*>.*?|<.*? />"; + + @Override + public boolean isValid(String value, ConstraintValidatorContext constraintValidatorContext) + { + if (StringUtils.isBlank(value)) + { + return true; + } + return !containsHtml(value); + } + + public static boolean containsHtml(String value) + { + Pattern pattern = Pattern.compile(HTML_PATTERN); + Matcher matcher = pattern.matcher(value); + return matcher.matches(); + } +} \ No newline at end of file diff --git a/dc-framework/pom.xml b/dc-framework/pom.xml new file mode 100644 index 0000000..86c3df2 --- /dev/null +++ b/dc-framework/pom.xml @@ -0,0 +1,70 @@ +<?xml version="1.0" encoding="UTF-8"?> +<project xmlns="http://maven.apache.org/POM/4.0.0" + xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" + xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> + <parent> + <artifactId>dc</artifactId> + <groupId>com.dc</groupId> + <version>1.0.0</version> + </parent> + <modelVersion>4.0.0</modelVersion> + + <artifactId>dc-framework</artifactId> + + <description> + framework框架核心 + </description> + + <dependencies> + + <!-- SpringBoot Web容器 --> + <dependency> + <groupId>org.springframework.boot</groupId> + <artifactId>spring-boot-starter-web</artifactId> + </dependency> + + <!-- SpringBoot 拦截器 --> + <dependency> + <groupId>org.springframework.boot</groupId> + <artifactId>spring-boot-starter-aop</artifactId> + </dependency> + + <!-- SpringBoot Websocket --> + <dependency> + <groupId>org.springframework.boot</groupId> + <artifactId>spring-boot-starter-websocket</artifactId> + </dependency> + + <!-- 阿里数据库连接池 --> + <dependency> + <groupId>com.alibaba</groupId> + <artifactId>druid-spring-boot-starter</artifactId> + </dependency> + + <!-- 验证码 --> + <dependency> + <groupId>pro.fessional</groupId> + <artifactId>kaptcha</artifactId> + <exclusions> + <exclusion> + <artifactId>javax.servlet-api</artifactId> + <groupId>javax.servlet</groupId> + </exclusion> + </exclusions> + </dependency> + + <!-- 获取系统信息 --> + <dependency> + <groupId>com.github.oshi</groupId> + <artifactId>oshi-core</artifactId> + </dependency> + + <!-- 系统模块--> + <dependency> + <groupId>com.dc</groupId> + <artifactId>dc-system</artifactId> + </dependency> + + </dependencies> + +</project> \ No newline at end of file diff --git a/dc-framework/src/main/java/com/dc/framework/aspectj/DataScopeAspect.java b/dc-framework/src/main/java/com/dc/framework/aspectj/DataScopeAspect.java new file mode 100644 index 0000000..16d0caa --- /dev/null +++ b/dc-framework/src/main/java/com/dc/framework/aspectj/DataScopeAspect.java @@ -0,0 +1,168 @@ +package com.dc.framework.aspectj; + +import com.dc.framework.security.context.PermissionContextHolder; +import com.dc.common.annotation.DataScope; +import com.dc.common.core.domain.WinBaseEntity; +import com.dc.common.core.domain.entity.SysRole; +import com.dc.common.core.domain.entity.SysUser; +import com.dc.common.core.domain.model.LoginUser; +import com.dc.common.core.text.Convert; +import com.dc.common.utils.SecurityUtils; +import com.dc.common.utils.StringUtils; +import org.aspectj.lang.JoinPoint; +import org.aspectj.lang.annotation.Aspect; +import org.aspectj.lang.annotation.Before; +import org.springframework.stereotype.Component; + +import java.util.ArrayList; +import java.util.List; + +/** + * 数据过滤处理 + * + * @author win + */ +@Aspect +@Component +public class DataScopeAspect +{ + /** + * 全部数据权限 + */ + public static final String DATA_SCOPE_ALL = "1"; + + /** + * 自定数据权限 + */ + public static final String DATA_SCOPE_CUSTOM = "2"; + + /** + * 部门数据权限 + */ + public static final String DATA_SCOPE_DEPT = "3"; + + /** + * 部门及以下数据权限 + */ + public static final String DATA_SCOPE_DEPT_AND_CHILD = "4"; + + /** + * 仅本人数据权限 + */ + public static final String DATA_SCOPE_SELF = "5"; + + /** + * 数据权限过滤关键字 + */ + public static final String DATA_SCOPE = "dataScope"; + + @Before("@annotation(controllerDataScope)") + public void doBefore(JoinPoint point, DataScope controllerDataScope) throws Throwable + { + clearDataScope(point); + handleDataScope(point, controllerDataScope); + } + + protected void handleDataScope(final JoinPoint joinPoint, DataScope controllerDataScope) + { + // 获取当前的用户 + LoginUser loginUser = SecurityUtils.getLoginUser(); + if (StringUtils.isNotNull(loginUser)) + { + SysUser currentUser = loginUser.getUser(); + // 如果是超级管理员,则不过滤数据 + if (StringUtils.isNotNull(currentUser) && !currentUser.isAdmin()) + { + String permission = StringUtils.defaultIfEmpty(controllerDataScope.permission(), PermissionContextHolder.getContext()); + dataScopeFilter(joinPoint, currentUser, controllerDataScope.deptAlias(), + controllerDataScope.userAlias(), permission); + } + } + } + + /** + * 数据范围过滤 + * + * @param joinPoint 切点 + * @param user 用户 + * @param deptAlias 部门别名 + * @param userAlias 用户别名 + * @param permission 权限字符 + */ + public static void dataScopeFilter(JoinPoint joinPoint, SysUser user, String deptAlias, String userAlias, String permission) + { + StringBuilder sqlString = new StringBuilder(); + List<String> conditions = new ArrayList<String>(); + + for (SysRole role : user.getRoles()) + { + String dataScope = role.getDataScope(); + if (!DATA_SCOPE_CUSTOM.equals(dataScope) && conditions.contains(dataScope)) + { + continue; + } + if (StringUtils.isNotEmpty(permission) && StringUtils.isNotEmpty(role.getPermissions()) + && !StringUtils.containsAny(role.getPermissions(), Convert.toStrArray(permission))) + { + continue; + } + if (DATA_SCOPE_ALL.equals(dataScope)) + { + sqlString = new StringBuilder(); + break; + } + else if (DATA_SCOPE_CUSTOM.equals(dataScope)) + { + sqlString.append(StringUtils.format( + " OR {}.dept_id IN ( SELECT dept_id FROM sys_role_dept WHERE role_id = {} ) ", deptAlias, + role.getRoleId())); + } + else if (DATA_SCOPE_DEPT.equals(dataScope)) + { + sqlString.append(StringUtils.format(" OR {}.dept_id = {} ", deptAlias, user.getDeptId())); + } + else if (DATA_SCOPE_DEPT_AND_CHILD.equals(dataScope)) + { + sqlString.append(StringUtils.format( + " OR {}.dept_id IN ( SELECT dept_id FROM sys_dept WHERE dept_id = {} or find_in_set( {} , ancestors ) )", + deptAlias, user.getDeptId(), user.getDeptId())); + } + else if (DATA_SCOPE_SELF.equals(dataScope)) + { + if (StringUtils.isNotBlank(userAlias)) + { + sqlString.append(StringUtils.format(" OR {}.user_id = {} ", userAlias, user.getUserId())); + } + else + { + // 数据权限为仅本人且没有userAlias别名不查询任何数据 + sqlString.append(StringUtils.format(" OR {}.dept_id = 0 ", deptAlias)); + } + } + conditions.add(dataScope); + } + + if (StringUtils.isNotBlank(sqlString.toString())) + { + Object params = joinPoint.getArgs()[0]; + if (StringUtils.isNotNull(params) && params instanceof WinBaseEntity) + { + WinBaseEntity baseEntity = (WinBaseEntity) params; + baseEntity.getParams().put(DATA_SCOPE, " AND (" + sqlString.substring(4) + ")"); + } + } + } + + /** + * 拼接权限sql前先清空params.dataScope参数防止注入 + */ + private void clearDataScope(final JoinPoint joinPoint) + { + Object params = joinPoint.getArgs()[0]; + if (StringUtils.isNotNull(params) && params instanceof WinBaseEntity) + { + WinBaseEntity baseEntity = (WinBaseEntity) params; + baseEntity.getParams().put(DATA_SCOPE, ""); + } + } +} diff --git a/dc-framework/src/main/java/com/dc/framework/aspectj/DataScopeCommonAspect.java b/dc-framework/src/main/java/com/dc/framework/aspectj/DataScopeCommonAspect.java new file mode 100644 index 0000000..f5ffe28 --- /dev/null +++ b/dc-framework/src/main/java/com/dc/framework/aspectj/DataScopeCommonAspect.java @@ -0,0 +1,151 @@ +package com.dc.framework.aspectj; + +import com.dc.common.annotation.DataScopeCommon; +import com.dc.common.context.DataScopeHolder; +import com.dc.common.core.domain.entity.SysRole; +import com.dc.common.core.domain.entity.SysUser; +import com.dc.common.core.domain.model.LoginUser; +import com.dc.common.core.text.Convert; +import com.dc.common.utils.SecurityUtils; +import com.dc.common.utils.StringUtils; +import com.dc.common.utils.spring.SpringUtils; +import com.dc.framework.security.context.PermissionContextHolder; +import com.dc.system.service.SysMenuService; +import org.aspectj.lang.JoinPoint; +import org.aspectj.lang.ProceedingJoinPoint; +import org.aspectj.lang.annotation.Around; +import org.aspectj.lang.annotation.Aspect; +import org.springframework.stereotype.Component; + +import java.util.ArrayList; +import java.util.List; + +/** + * @Author longlongxiaogege + * @Description 权限范围控制Wrapper兼容 + * @Date 13:49 2023/6/21 + **/ +@Aspect +@Component +public class DataScopeCommonAspect { + + private SysMenuService sysMenuService = SpringUtils.getBean("sysMenuService");; + + /** + * 全部数据权限 + */ + public static final String DATA_SCOPE_ALL = "1"; + + /** + * 自定数据权限 + */ + public static final String DATA_SCOPE_CUSTOM = "2"; + + /** + * 部门数据权限 + */ + public static final String DATA_SCOPE_DEPT = "3"; + + /** + * 部门及以下数据权限 + */ + public static final String DATA_SCOPE_DEPT_AND_CHILD = "4"; + + /** + * 仅本人数据权限 + */ + public static final String DATA_SCOPE_SELF = "5"; + + /** + * 数据权限过滤关键字 + */ + public static final String DATA_SCOPE = "dataScope"; + + /** + * 定义切点,切点为添加了注解的方法 + */ + @Around("@annotation(controllerDataScope)") + public Object withAnnotationMethods(ProceedingJoinPoint joinPoint, DataScopeCommon controllerDataScope) throws Throwable { + handleDataScope(joinPoint, controllerDataScope); + Object obj = joinPoint.proceed(); + if(DataScopeHolder.getDataScopeSql() != null) { + DataScopeHolder.removeDataScopeSql(); + } + return obj; + } + + protected void handleDataScope(final JoinPoint joinPoint, DataScopeCommon controllerDataScope) { + // 获取当前的用户 + LoginUser loginUser = SecurityUtils.getLoginUser(); + if (StringUtils.isNotNull(loginUser)) { + SysUser currentUser = loginUser.getUser(); + // 如果是超级管理员,则不过滤数据 + if (StringUtils.isNotNull(currentUser) && !currentUser.isAdmin()) { + String permission = StringUtils.defaultIfEmpty(controllerDataScope.permission(), PermissionContextHolder.getContext()); + dataScopeFilter(joinPoint, currentUser, controllerDataScope.deptAlias(), controllerDataScope.userAlias(), permission); + } + } + } + + /** + * 数据范围过滤 + * + * @param joinPoint 切点 + * @param user 用户 + * @param deptAlias 部门别名 + * @param userAlias 用户别名 + * @param permission 权限字符 + */ + public void dataScopeFilter(JoinPoint joinPoint, SysUser user, String deptAlias, String userAlias, String permission) { + StringBuilder sqlString = new StringBuilder(); + List<String> conditions = new ArrayList<String>(); +// HttpServletRequest request = ServletUtils.getRequest(); +// String referer = request.getHeader("Referer1"); +// referer = referer.substring(referer.lastIndexOf("/") + 1); + for (SysRole role : user.getRoles()) { + //用户只有一个角色不参与 +// if(user.getRoles().size() > 1) { +// List<SysMenu> menList = sysMenuService.selectMenuList1ByRoleId(role.getRoleId()); +// boolean isExists = false; +// for (SysMenu sysMenu : menList) { +// if (sysMenu.getPath().equals(referer)) { +// isExists = true; +// } +// } +// //如果前端路由不在当前角色中直接continue +// if (!isExists) { +// continue; +// } +// } + String dataScope = role.getDataScope(); + if (!DATA_SCOPE_CUSTOM.equals(dataScope) && conditions.contains(dataScope)) { + continue; + } + if (StringUtils.isNotEmpty(permission) && StringUtils.isNotEmpty(role.getPermissions()) && !StringUtils.containsAny(role.getPermissions(), Convert.toStrArray(permission))) { + continue; + } + if (DATA_SCOPE_ALL.equals(dataScope)) { + sqlString = new StringBuilder(); + break; + } else if (DATA_SCOPE_CUSTOM.equals(dataScope)) { + sqlString.append(StringUtils.format(" OR {}.dept_id IN ( SELECT dept_id FROM sys_role_dept WHERE role_id = {} ) ", deptAlias, role.getRoleId())); + } else if (DATA_SCOPE_DEPT.equals(dataScope)) { + sqlString.append(StringUtils.format(" OR {}.dept_id = {} ", deptAlias, user.getDeptId())); + } else if (DATA_SCOPE_DEPT_AND_CHILD.equals(dataScope)) { + sqlString.append(StringUtils.format(" OR {}.dept_id IN ( SELECT dept_id FROM sys_dept WHERE dept_id = {} or find_in_set( {} , ancestors ) )", deptAlias, user.getDeptId(), user.getDeptId())); + } else if (DATA_SCOPE_SELF.equals(dataScope)) { + if (StringUtils.isNotBlank(userAlias)) { + sqlString.append(StringUtils.format(" OR {}.user_id = {} ", userAlias, user.getUserId())); + } else { + // 数据权限为仅本人且没有userAlias别名不查询任何数据 + sqlString.append(StringUtils.format(" OR {}.dept_id = 0 ", deptAlias)); + } + } + conditions.add(dataScope); + } + if (StringUtils.isNotBlank(sqlString.toString())) { + DataScopeHolder.addDataScopeSql(sqlString.substring(4)); + } + } + +} diff --git a/dc-framework/src/main/java/com/dc/framework/aspectj/LogAspect.java b/dc-framework/src/main/java/com/dc/framework/aspectj/LogAspect.java new file mode 100644 index 0000000..193b35a --- /dev/null +++ b/dc-framework/src/main/java/com/dc/framework/aspectj/LogAspect.java @@ -0,0 +1,228 @@ +package com.dc.framework.aspectj; + +import com.alibaba.fastjson2.JSON; +import com.dc.framework.manager.AsyncManager; +import com.dc.framework.manager.factory.AsyncFactory; +import com.dc.common.annotation.Log; +import com.dc.common.core.domain.model.LoginUser; +import com.dc.common.enums.BusinessStatus; +import com.dc.common.enums.HttpMethod; +import com.dc.common.filter.PropertyPreExcludeFilter; +import com.dc.common.utils.SecurityUtils; +import com.dc.common.utils.ServletUtils; +import com.dc.common.utils.StringUtils; +import com.dc.common.utils.ip.IpUtils; +import com.dc.system.domain.SysOperLog; +import org.aspectj.lang.JoinPoint; +import org.aspectj.lang.annotation.AfterReturning; +import org.aspectj.lang.annotation.AfterThrowing; +import org.aspectj.lang.annotation.Aspect; +import org.slf4j.Logger; +import org.slf4j.LoggerFactory; +import org.springframework.stereotype.Component; +import org.springframework.validation.BindingResult; +import org.springframework.web.multipart.MultipartFile; + +import javax.servlet.http.HttpServletRequest; +import javax.servlet.http.HttpServletResponse; +import java.util.Collection; +import java.util.Map; + +/** + * 操作日志记录处理 + * + * @author win + */ +@Aspect +@Component +public class LogAspect +{ + private static final Logger log = LoggerFactory.getLogger(LogAspect.class); + + /** 排除敏感属性字段 */ + public static final String[] EXCLUDE_PROPERTIES = { "password", "oldPassword", "newPassword", "confirmPassword" }; + + /** + * 处理完请求后执行 + * + * @param joinPoint 切点 + */ + @AfterReturning(pointcut = "@annotation(controllerLog)", returning = "jsonResult") + public void doAfterReturning(JoinPoint joinPoint, Log controllerLog, Object jsonResult) + { + handleLog(joinPoint, controllerLog, null, jsonResult); + } + + /** + * 拦截异常操作 + * + * @param joinPoint 切点 + * @param e 异常 + */ + @AfterThrowing(value = "@annotation(controllerLog)", throwing = "e") + public void doAfterThrowing(JoinPoint joinPoint, Log controllerLog, Exception e) + { + handleLog(joinPoint, controllerLog, e, null); + } + + protected void handleLog(final JoinPoint joinPoint, Log controllerLog, final Exception e, Object jsonResult) + { + try + { + // 获取当前的用户 + LoginUser loginUser = SecurityUtils.getLoginUser(); + + // *========数据库日志=========*// + SysOperLog operLog = new SysOperLog(); + operLog.setStatus(BusinessStatus.SUCCESS.ordinal()); + // 请求的地址 + String ip = IpUtils.getIpAddr(ServletUtils.getRequest()); + operLog.setOperIp(ip); + operLog.setOperUrl(StringUtils.substring(ServletUtils.getRequest().getRequestURI(), 0, 255)); + if (loginUser != null) + { + operLog.setOperName(loginUser.getUsername()); + } + + if (e != null) + { + operLog.setStatus(BusinessStatus.FAIL.ordinal()); + operLog.setErrorMsg(StringUtils.substring(e.getMessage(), 0, 2000)); + } + // 设置方法名称 + String className = joinPoint.getTarget().getClass().getName(); + String methodName = joinPoint.getSignature().getName(); + operLog.setMethod(className + "." + methodName + "()"); + // 设置请求方式 + operLog.setRequestMethod(ServletUtils.getRequest().getMethod()); + // 处理设置注解上的参数 + getControllerMethodDescription(joinPoint, controllerLog, operLog, jsonResult); + // 保存数据库 + AsyncManager.me().execute(AsyncFactory.recordOper(operLog)); + } + catch (Exception exp) + { + // 记录本地异常日志 + log.error("异常信息:{}", exp.getMessage()); + exp.printStackTrace(); + } + } + + /** + * 获取注解中对方法的描述信息 用于Controller层注解 + * + * @param log 日志 + * @param operLog 操作日志 + * @throws Exception + */ + public void getControllerMethodDescription(JoinPoint joinPoint, Log log, SysOperLog operLog, Object jsonResult) throws Exception + { + // 设置action动作 + operLog.setBusinessType(log.businessType().ordinal()); + // 设置标题 + operLog.setTitle(log.title()); + // 设置操作人类别 + operLog.setOperatorType(log.operatorType().ordinal()); + // 是否需要保存request,参数和值 + if (log.isSaveRequestData()) + { + // 获取参数的信息,传入到数据库中。 + setRequestValue(joinPoint, operLog); + } + // 是否需要保存response,参数和值 + if (log.isSaveResponseData() && StringUtils.isNotNull(jsonResult)) + { + operLog.setJsonResult(StringUtils.substring(JSON.toJSONString(jsonResult), 0, 2000)); + } + } + + /** + * 获取请求的参数,放到log中 + * + * @param operLog 操作日志 + * @throws Exception 异常 + */ + private void setRequestValue(JoinPoint joinPoint, SysOperLog operLog) throws Exception + { + String requestMethod = operLog.getRequestMethod(); + if (HttpMethod.PUT.name().equals(requestMethod) || HttpMethod.POST.name().equals(requestMethod)) + { + String params = argsArrayToString(joinPoint.getArgs()); + operLog.setOperParam(StringUtils.substring(params, 0, 2000)); + } + else + { + Map<?, ?> paramsMap = ServletUtils.getParamMap(ServletUtils.getRequest()); + operLog.setOperParam(StringUtils.substring(JSON.toJSONString(paramsMap, excludePropertyPreFilter()), 0, 2000)); + } + } + + /** + * 参数拼装 + */ + private String argsArrayToString(Object[] paramsArray) + { + String params = ""; + if (paramsArray != null && paramsArray.length > 0) + { + for (Object o : paramsArray) + { + if (StringUtils.isNotNull(o) && !isFilterObject(o)) + { + try + { + String jsonObj = JSON.toJSONString(o, excludePropertyPreFilter()); + params += jsonObj.toString() + " "; + } + catch (Exception e) + { + } + } + } + } + return params.trim(); + } + + /** + * 忽略敏感属性 + */ + public PropertyPreExcludeFilter excludePropertyPreFilter() + { + return new PropertyPreExcludeFilter().addExcludes(EXCLUDE_PROPERTIES); + } + + /** + * 判断是否需要过滤的对象。 + * + * @param o 对象信息。 + * @return 如果是需要过滤的对象,则返回true;否则返回false。 + */ + @SuppressWarnings("rawtypes") + public boolean isFilterObject(final Object o) + { + Class<?> clazz = o.getClass(); + if (clazz.isArray()) + { + return clazz.getComponentType().isAssignableFrom(MultipartFile.class); + } + else if (Collection.class.isAssignableFrom(clazz)) + { + Collection collection = (Collection) o; + for (Object value : collection) + { + return value instanceof MultipartFile; + } + } + else if (Map.class.isAssignableFrom(clazz)) + { + Map map = (Map) o; + for (Object value : map.entrySet()) + { + Map.Entry entry = (Map.Entry) value; + return entry.getValue() instanceof MultipartFile; + } + } + return o instanceof MultipartFile || o instanceof HttpServletRequest || o instanceof HttpServletResponse + || o instanceof BindingResult; + } +} diff --git a/dc-framework/src/main/java/com/dc/framework/aspectj/RateLimiterAspect.java b/dc-framework/src/main/java/com/dc/framework/aspectj/RateLimiterAspect.java new file mode 100644 index 0000000..48ea837 --- /dev/null +++ b/dc-framework/src/main/java/com/dc/framework/aspectj/RateLimiterAspect.java @@ -0,0 +1,91 @@ +package com.dc.framework.aspectj; + +import com.dc.common.annotation.RateLimiter; +import com.dc.common.enums.LimitType; +import com.dc.common.exception.ServiceException; +import com.dc.common.utils.ServletUtils; +import com.dc.common.utils.StringUtils; +import com.dc.common.utils.ip.IpUtils; +import org.aspectj.lang.JoinPoint; +import org.aspectj.lang.annotation.Aspect; +import org.aspectj.lang.annotation.Before; +import org.aspectj.lang.reflect.MethodSignature; +import org.slf4j.Logger; +import org.slf4j.LoggerFactory; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.data.redis.core.RedisTemplate; +import org.springframework.data.redis.core.script.RedisScript; +import org.springframework.stereotype.Component; + +import java.lang.reflect.Method; +import java.util.Collections; +import java.util.List; + +/** + * 限流处理 + * + * @author win + */ +@Aspect +@Component +public class RateLimiterAspect +{ + private static final Logger log = LoggerFactory.getLogger(RateLimiterAspect.class); + + private RedisTemplate<Object, Object> redisTemplate; + + private RedisScript<Long> limitScript; + + @Autowired + public void setRedisTemplate1(RedisTemplate<Object, Object> redisTemplate) + { + this.redisTemplate = redisTemplate; + } + + @Autowired + public void setLimitScript(RedisScript<Long> limitScript) + { + this.limitScript = limitScript; + } + + @Before("@annotation(rateLimiter)") + public void doBefore(JoinPoint point, RateLimiter rateLimiter) throws Throwable + { + int time = rateLimiter.time(); + int count = rateLimiter.count(); + + String combineKey = getCombineKey(rateLimiter, point); + List<Object> keys = Collections.singletonList(combineKey); + try + { + Long number = redisTemplate.execute(limitScript, keys, count, time); + if (StringUtils.isNull(number) || number.intValue() > count) + { + throw new ServiceException("访问过于频繁,请稍候再试"); + } + log.info("限制请求'{}',当前请求'{}',缓存key'{}'", count, number.intValue(), combineKey); + } + catch (ServiceException e) + { + throw e; + } + catch (Exception e) + { + throw new RuntimeException("服务器限流异常,请稍候再试"); + } + } + + public String getCombineKey(RateLimiter rateLimiter, JoinPoint point) + { + StringBuffer stringBuffer = new StringBuffer(rateLimiter.key()); + if (rateLimiter.limitType() == LimitType.IP) + { + stringBuffer.append(IpUtils.getIpAddr(ServletUtils.getRequest())).append("-"); + } + MethodSignature signature = (MethodSignature) point.getSignature(); + Method method = signature.getMethod(); + Class<?> targetClass = method.getDeclaringClass(); + stringBuffer.append(targetClass.getName()).append("-").append(method.getName()); + return stringBuffer.toString(); + } +} diff --git a/dc-framework/src/main/java/com/dc/framework/config/ApplicationConfig.java b/dc-framework/src/main/java/com/dc/framework/config/ApplicationConfig.java new file mode 100644 index 0000000..b247d00 --- /dev/null +++ b/dc-framework/src/main/java/com/dc/framework/config/ApplicationConfig.java @@ -0,0 +1,31 @@ +package com.dc.framework.config; + +import org.mybatis.spring.annotation.MapperScan; +import org.springframework.boot.autoconfigure.jackson.Jackson2ObjectMapperBuilderCustomizer; +import org.springframework.context.annotation.Bean; +import org.springframework.context.annotation.Configuration; +import org.springframework.context.annotation.EnableAspectJAutoProxy; + +import java.util.TimeZone; + +/** + * 程序注解配置 + * + * @author win + */ +@Configuration +// 表示通过aop框架暴露该代理对象,AopContext能够访问 +@EnableAspectJAutoProxy(exposeProxy = true) +// 指定要扫描的Mapper类的包的路径 +@MapperScan("com.dc.**.mapper") +public class ApplicationConfig +{ + /** + * 时区配置 + */ + @Bean + public Jackson2ObjectMapperBuilderCustomizer jacksonObjectMapperCustomization() + { + return jacksonObjectMapperBuilder -> jacksonObjectMapperBuilder.timeZone(TimeZone.getDefault()); + } +} diff --git a/dc-framework/src/main/java/com/dc/framework/config/CaptchaConfig.java b/dc-framework/src/main/java/com/dc/framework/config/CaptchaConfig.java new file mode 100644 index 0000000..bcc605a --- /dev/null +++ b/dc-framework/src/main/java/com/dc/framework/config/CaptchaConfig.java @@ -0,0 +1,85 @@ +package com.dc.framework.config; + +import com.google.code.kaptcha.impl.DefaultKaptcha; +import com.google.code.kaptcha.util.Config; +import org.springframework.context.annotation.Bean; +import org.springframework.context.annotation.Configuration; + +import java.util.Properties; + +import static com.google.code.kaptcha.Constants.*; + +/** + * 验证码配置 + * + * @author win + */ +@Configuration +public class CaptchaConfig +{ + @Bean(name = "captchaProducer") + public DefaultKaptcha getKaptchaBean() + { + DefaultKaptcha defaultKaptcha = new DefaultKaptcha(); + Properties properties = new Properties(); + // 是否有边框 默认为true 我们可以自己设置yes,no + properties.setProperty(KAPTCHA_BORDER, "yes"); + // 验证码文本字符颜色 默认为Color.BLACK + properties.setProperty(KAPTCHA_TEXTPRODUCER_FONT_COLOR, "black"); + // 验证码图片宽度 默认为200 + properties.setProperty(KAPTCHA_IMAGE_WIDTH, "160"); + // 验证码图片高度 默认为50 + properties.setProperty(KAPTCHA_IMAGE_HEIGHT, "60"); + // 验证码文本字符大小 默认为40 + properties.setProperty(KAPTCHA_TEXTPRODUCER_FONT_SIZE, "38"); + // KAPTCHA_SESSION_KEY + properties.setProperty(KAPTCHA_SESSION_CONFIG_KEY, "kaptchaCode"); + // 验证码文本字符长度 默认为5 + properties.setProperty(KAPTCHA_TEXTPRODUCER_CHAR_LENGTH, "4"); + // 验证码文本字体样式 默认为new Font("Arial", 1, fontSize), new Font("Courier", 1, fontSize) + properties.setProperty(KAPTCHA_TEXTPRODUCER_FONT_NAMES, "Arial,Courier"); + // 图片样式 水纹com.google.code.kaptcha.impl.WaterRipple 鱼眼com.google.code.kaptcha.impl.FishEyeGimpy 阴影com.google.code.kaptcha.impl.ShadowGimpy + properties.setProperty(KAPTCHA_OBSCURIFICATOR_IMPL, "com.google.code.kaptcha.impl.ShadowGimpy"); + Config config = new Config(properties); + defaultKaptcha.setConfig(config); + return defaultKaptcha; + } + + @Bean(name = "captchaProducerMath") + public DefaultKaptcha getKaptchaBeanMath() + { + DefaultKaptcha defaultKaptcha = new DefaultKaptcha(); + Properties properties = new Properties(); + // 是否有边框 默认为true 我们可以自己设置yes,no + properties.setProperty(KAPTCHA_BORDER, "yes"); + // 边框颜色 默认为Color.BLACK + properties.setProperty(KAPTCHA_BORDER_COLOR, "105,179,90"); + // 验证码文本字符颜色 默认为Color.BLACK + properties.setProperty(KAPTCHA_TEXTPRODUCER_FONT_COLOR, "blue"); + // 验证码图片宽度 默认为200 + properties.setProperty(KAPTCHA_IMAGE_WIDTH, "160"); + // 验证码图片高度 默认为50 + properties.setProperty(KAPTCHA_IMAGE_HEIGHT, "60"); + // 验证码文本字符大小 默认为40 + properties.setProperty(KAPTCHA_TEXTPRODUCER_FONT_SIZE, "35"); + // KAPTCHA_SESSION_KEY + properties.setProperty(KAPTCHA_SESSION_CONFIG_KEY, "kaptchaCodeMath"); + // 验证码文本生成器 + properties.setProperty(KAPTCHA_TEXTPRODUCER_IMPL, "com.dc.framework.config.KaptchaTextCreator"); + // 验证码文本字符间距 默认为2 + properties.setProperty(KAPTCHA_TEXTPRODUCER_CHAR_SPACE, "3"); + // 验证码文本字符长度 默认为5 + properties.setProperty(KAPTCHA_TEXTPRODUCER_CHAR_LENGTH, "6"); + // 验证码文本字体样式 默认为new Font("Arial", 1, fontSize), new Font("Courier", 1, fontSize) + properties.setProperty(KAPTCHA_TEXTPRODUCER_FONT_NAMES, "Arial,Courier"); + // 验证码噪点颜色 默认为Color.BLACK + properties.setProperty(KAPTCHA_NOISE_COLOR, "white"); + // 干扰实现类 + properties.setProperty(KAPTCHA_NOISE_IMPL, "com.google.code.kaptcha.impl.NoNoise"); + // 图片样式 水纹com.google.code.kaptcha.impl.WaterRipple 鱼眼com.google.code.kaptcha.impl.FishEyeGimpy 阴影com.google.code.kaptcha.impl.ShadowGimpy + properties.setProperty(KAPTCHA_OBSCURIFICATOR_IMPL, "com.google.code.kaptcha.impl.ShadowGimpy"); + Config config = new Config(properties); + defaultKaptcha.setConfig(config); + return defaultKaptcha; + } +} diff --git a/dc-framework/src/main/java/com/dc/framework/config/DataSourceConfiguration.java b/dc-framework/src/main/java/com/dc/framework/config/DataSourceConfiguration.java new file mode 100644 index 0000000..909af4a --- /dev/null +++ b/dc-framework/src/main/java/com/dc/framework/config/DataSourceConfiguration.java @@ -0,0 +1,112 @@ +package com.dc.framework.config; + +import com.baomidou.dynamic.datasource.DynamicRoutingDataSource; +import com.baomidou.dynamic.datasource.provider.AbstractDataSourceProvider; +import com.baomidou.dynamic.datasource.provider.DynamicDataSourceProvider; +import com.baomidou.dynamic.datasource.spring.boot.autoconfigure.DataSourceProperty; +import com.baomidou.dynamic.datasource.spring.boot.autoconfigure.DynamicDataSourceAutoConfiguration; +import com.baomidou.dynamic.datasource.spring.boot.autoconfigure.DynamicDataSourceProperties; +import com.baomidou.mybatisplus.extension.plugins.MybatisPlusInterceptor; +import com.baomidou.mybatisplus.extension.spring.MybatisSqlSessionFactoryBean; +import com.dc.common.constant.DBConstants; +import org.apache.ibatis.plugin.Interceptor; +import org.apache.ibatis.session.SqlSessionFactory; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.beans.factory.annotation.Qualifier; +import org.springframework.beans.factory.annotation.Value; +import org.springframework.boot.SpringBootConfiguration; +import org.springframework.boot.autoconfigure.AutoConfigureBefore; +import org.springframework.context.annotation.Bean; +import org.springframework.context.annotation.Configuration; +import org.springframework.context.annotation.Lazy; +import org.springframework.context.annotation.Primary; +import org.springframework.core.io.Resource; +import org.springframework.core.io.support.PathMatchingResourcePatternResolver; + +import javax.sql.DataSource; +import java.util.Map; + +/** + * 动态数据源配置: + * + * 使用{@link com.baomidou.dynamic.datasource.annotation.DS}注解,切换数据源 + * + * <code>@DS(DataSourceConfiguration.SHARDING_DATA_SOURCE_NAME)</code> + * + * @author songyinyin + * @date 2020/7/27 15:19 + */ +@Configuration +@AutoConfigureBefore({DynamicDataSourceAutoConfiguration.class, SpringBootConfiguration.class}) +public class DataSourceConfiguration { + + @Value("${mybatis-plus.mapper-locations}") + private String mapperLocation; + @Value("${mybatis-plus.type-aliases-package}") + private String typeAliasesPackage; + + /** + * 动态数据源配置项 + * 这里会根据yml文件的配置自动加载配置,将多个数据源信息放到datasourceMap中 + */ + @Autowired + private DynamicDataSourceProperties properties; + + /** + * 使用shardingSphereDataSource 自动装载的 DataSource + * 5.1.1版本自动装载的shardingSphereDataSource beanName="shardingSphereDataSource" + * 要加@Lazy + */ + @Lazy + @Autowired + private DataSource shardingSphereDataSource; + @Autowired + private MybatisPlusInterceptor mybatisPlusInterceptor; + + @Bean + public DynamicDataSourceProvider dynamicDataSourceProvider() { + Map<String, DataSourceProperty> datasourceMap = properties.getDatasource(); + return new AbstractDataSourceProvider() { + @Override + public Map<String, DataSource> loadDataSources() { + Map<String, DataSource> dataSourceMap = createDataSourceMap(datasourceMap); + // 将 shardingjdbc 管理的数据源也交给动态数据源管理 + dataSourceMap.put(DBConstants.SHARDING, shardingSphereDataSource); + return dataSourceMap; + } + }; + } + + /** + * 将动态数据源设置为首选的 + * 当spring存在多个数据源时, 自动注入的是首选的对象 + * 设置为主要的数据源之后,就可以支持shardingjdbc原生的配置方式了 + * + * @return + */ + @Primary + @Bean + public DataSource dataSource(DynamicDataSourceProvider dynamicDataSourceProvider) { + DynamicRoutingDataSource dataSource = new DynamicRoutingDataSource(); + dataSource.setPrimary(properties.getPrimary()); + dataSource.setStrict(properties.getStrict()); + dataSource.setStrategy(properties.getStrategy()); + dataSource.setProvider(dynamicDataSourceProvider); + dataSource.setP6spy(properties.getP6spy()); + dataSource.setSeata(properties.getSeata()); + return dataSource; + } + + @Bean + public SqlSessionFactory sqlSessionFactory(@Qualifier("dataSource") DataSource adsDataSource) throws Exception { + final MybatisSqlSessionFactoryBean sqlSessionFactoryBean = new MybatisSqlSessionFactoryBean(); + sqlSessionFactoryBean.setDataSource(adsDataSource); + PathMatchingResourcePatternResolver resolver = new PathMatchingResourcePatternResolver(); + Resource[] resources1 = resolver.getResources(mapperLocation); + sqlSessionFactoryBean.setMapperLocations(resources1); + sqlSessionFactoryBean.setPlugins(new Interceptor[] { mybatisPlusInterceptor }); + sqlSessionFactoryBean.setTypeAliasesPackage(typeAliasesPackage); + return sqlSessionFactoryBean.getObject(); + } + +} diff --git a/dc-framework/src/main/java/com/dc/framework/config/FastJson2JsonRedisSerializer.java b/dc-framework/src/main/java/com/dc/framework/config/FastJson2JsonRedisSerializer.java new file mode 100644 index 0000000..3fd5f53 --- /dev/null +++ b/dc-framework/src/main/java/com/dc/framework/config/FastJson2JsonRedisSerializer.java @@ -0,0 +1,49 @@ +package com.dc.framework.config; + +import com.alibaba.fastjson2.JSON; +import com.alibaba.fastjson2.JSONReader; +import com.alibaba.fastjson2.JSONWriter; +import org.springframework.data.redis.serializer.RedisSerializer; +import org.springframework.data.redis.serializer.SerializationException; + +import java.nio.charset.Charset; + +/** + * Redis使用FastJson序列化 + * + * @author win + */ +public class FastJson2JsonRedisSerializer<T> implements RedisSerializer<T> +{ + public static final Charset DEFAULT_CHARSET = Charset.forName("UTF-8"); + + private Class<T> clazz; + + public FastJson2JsonRedisSerializer(Class<T> clazz) + { + super(); + this.clazz = clazz; + } + + @Override + public byte[] serialize(T t) throws SerializationException + { + if (t == null) + { + return new byte[0]; + } + return JSON.toJSONString(t, JSONWriter.Feature.WriteClassName).getBytes(DEFAULT_CHARSET); + } + + @Override + public T deserialize(byte[] bytes) throws SerializationException + { + if (bytes == null || bytes.length <= 0) + { + return null; + } + String str = new String(bytes, DEFAULT_CHARSET); + + return JSON.parseObject(str, clazz, JSONReader.Feature.SupportAutoType); + } +} diff --git a/dc-framework/src/main/java/com/dc/framework/config/FilterConfig.java b/dc-framework/src/main/java/com/dc/framework/config/FilterConfig.java new file mode 100644 index 0000000..f877cb8 --- /dev/null +++ b/dc-framework/src/main/java/com/dc/framework/config/FilterConfig.java @@ -0,0 +1,59 @@ +package com.dc.framework.config; + +import com.dc.common.filter.RepeatableFilter; +import com.dc.common.filter.XssFilter; +import com.dc.common.utils.StringUtils; +import org.springframework.beans.factory.annotation.Value; +import org.springframework.boot.autoconfigure.condition.ConditionalOnProperty; +import org.springframework.boot.web.servlet.FilterRegistrationBean; +import org.springframework.context.annotation.Bean; +import org.springframework.context.annotation.Configuration; + +import javax.servlet.DispatcherType; +import java.util.HashMap; +import java.util.Map; + +/** + * Filter配置 + * + * @author win + */ +@Configuration +public class FilterConfig +{ + @Value("${xss.excludes}") + private String excludes; + + @Value("${xss.urlPatterns}") + private String urlPatterns; + + @SuppressWarnings({ "rawtypes", "unchecked" }) + @Bean + @ConditionalOnProperty(value = "xss.enabled", havingValue = "true") + public FilterRegistrationBean xssFilterRegistration() + { + FilterRegistrationBean registration = new FilterRegistrationBean(); + registration.setDispatcherTypes(DispatcherType.REQUEST); + registration.setFilter(new XssFilter()); + registration.addUrlPatterns(StringUtils.split(urlPatterns, ",")); + registration.setName("xssFilter"); + registration.setOrder(FilterRegistrationBean.HIGHEST_PRECEDENCE); + Map<String, String> initParameters = new HashMap<String, String>(); + initParameters.put("excludes", excludes); + registration.setInitParameters(initParameters); + return registration; + } + + @SuppressWarnings({ "rawtypes", "unchecked" }) + @Bean + public FilterRegistrationBean someFilterRegistration() + { + FilterRegistrationBean registration = new FilterRegistrationBean(); + registration.setFilter(new RepeatableFilter()); + registration.addUrlPatterns("/*"); + registration.setName("repeatableFilter"); + registration.setOrder(FilterRegistrationBean.LOWEST_PRECEDENCE); + return registration; + } + +} diff --git a/dc-framework/src/main/java/com/dc/framework/config/KaptchaTextCreator.java b/dc-framework/src/main/java/com/dc/framework/config/KaptchaTextCreator.java new file mode 100644 index 0000000..d5c2f16 --- /dev/null +++ b/dc-framework/src/main/java/com/dc/framework/config/KaptchaTextCreator.java @@ -0,0 +1,69 @@ +package com.dc.framework.config; + +import com.google.code.kaptcha.text.impl.DefaultTextCreator; + +import java.util.Random; + +/** + * 验证码文本生成器 + * + * @author win + */ +public class KaptchaTextCreator extends DefaultTextCreator +{ + private static final String[] CNUMBERS = "0,1,2,3,4,5,6,7,8,9,10".split(","); + + @Override + public String getText() + { + Integer result = 0; + Random random = new Random(); + int x = random.nextInt(10); + int y = random.nextInt(10); + StringBuilder suChinese = new StringBuilder(); + int randomoperands = random.nextInt(3); + if (randomoperands == 0) + { + result = x * y; + suChinese.append(CNUMBERS[x]); + suChinese.append("*"); + suChinese.append(CNUMBERS[y]); + } + else if (randomoperands == 1) + { + if ((x != 0) && y % x == 0) + { + result = y / x; + suChinese.append(CNUMBERS[y]); + suChinese.append("/"); + suChinese.append(CNUMBERS[x]); + } + else + { + result = x + y; + suChinese.append(CNUMBERS[x]); + suChinese.append("+"); + suChinese.append(CNUMBERS[y]); + } + } + else + { + if (x >= y) + { + result = x - y; + suChinese.append(CNUMBERS[x]); + suChinese.append("-"); + suChinese.append(CNUMBERS[y]); + } + else + { + result = y - x; + suChinese.append(CNUMBERS[y]); + suChinese.append("-"); + suChinese.append(CNUMBERS[x]); + } + } + suChinese.append("=?@" + result); + return suChinese.toString(); + } +} \ No newline at end of file diff --git a/dc-framework/src/main/java/com/dc/framework/config/MybatisPlusConfig.java b/dc-framework/src/main/java/com/dc/framework/config/MybatisPlusConfig.java new file mode 100644 index 0000000..e5ce4e0 --- /dev/null +++ b/dc-framework/src/main/java/com/dc/framework/config/MybatisPlusConfig.java @@ -0,0 +1,72 @@ +package com.dc.framework.config; + +import com.baomidou.mybatisplus.annotation.DbType; +import com.baomidou.mybatisplus.extension.plugins.MybatisPlusInterceptor; +import com.baomidou.mybatisplus.extension.plugins.inner.BlockAttackInnerInterceptor; +import com.baomidou.mybatisplus.extension.plugins.inner.OptimisticLockerInnerInterceptor; +import com.baomidou.mybatisplus.extension.plugins.inner.PaginationInnerInterceptor; +import com.dc.common.extension.MpSqlInjector; +import com.dc.framework.interceptor.impl.DataScopeInterceptor; +import org.springframework.context.annotation.Bean; +import org.springframework.context.annotation.Configuration; +import org.springframework.transaction.annotation.EnableTransactionManagement; + +/** + * Mybatis Plus 配置 + * + * @author win + */ +@EnableTransactionManagement(proxyTargetClass = true) +@Configuration +public class MybatisPlusConfig { + + @Bean + public MybatisPlusInterceptor mybatisPlusInterceptor() { + MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor(); + // 权限控制 + interceptor.addInnerInterceptor(dataScopeInterceptor()); + // 乐观锁插件 + interceptor.addInnerInterceptor(optimisticLockerInnerInterceptor()); + // 分页插件 + interceptor.addInnerInterceptor(paginationInnerInterceptor()); + // 阻断插件 + interceptor.addInnerInterceptor(blockAttackInnerInterceptor()); + return interceptor; + } + + /** + * 分页插件,自动识别数据库类型 https://baomidou.com/guide/interceptor-pagination.html + */ + public PaginationInnerInterceptor paginationInnerInterceptor() { + PaginationInnerInterceptor paginationInnerInterceptor = new PaginationInnerInterceptor(); + // 设置数据库类型为mysql + paginationInnerInterceptor.setDbType(DbType.MYSQL); + // 设置最大单页限制数量,默认 500 条,-1 不受限制 + paginationInnerInterceptor.setMaxLimit(-1L); + return paginationInnerInterceptor; + } + + /** + * 乐观锁插件 https://baomidou.com/guide/interceptor-optimistic-locker.html + */ + public OptimisticLockerInnerInterceptor optimisticLockerInnerInterceptor() { + return new OptimisticLockerInnerInterceptor(); + } + + /** + * 如果是对全表的删除或更新操作,就会终止该操作 https://baomidou.com/guide/interceptor-block-attack.html + */ + public BlockAttackInnerInterceptor blockAttackInnerInterceptor() { + return new BlockAttackInnerInterceptor(); + } + + public DataScopeInterceptor dataScopeInterceptor() { + return new DataScopeInterceptor(); + } + + @Bean + public MpSqlInjector mpSqlInjector () { + return new MpSqlInjector(); + } + +} \ No newline at end of file diff --git a/dc-framework/src/main/java/com/dc/framework/config/RedisConfig.java b/dc-framework/src/main/java/com/dc/framework/config/RedisConfig.java new file mode 100644 index 0000000..50f4c17 --- /dev/null +++ b/dc-framework/src/main/java/com/dc/framework/config/RedisConfig.java @@ -0,0 +1,69 @@ +package com.dc.framework.config; + +import org.springframework.cache.annotation.CachingConfigurerSupport; +import org.springframework.cache.annotation.EnableCaching; +import org.springframework.context.annotation.Bean; +import org.springframework.context.annotation.Configuration; +import org.springframework.data.redis.connection.RedisConnectionFactory; +import org.springframework.data.redis.core.RedisTemplate; +import org.springframework.data.redis.core.script.DefaultRedisScript; +import org.springframework.data.redis.serializer.StringRedisSerializer; + +/** + * redis配置 + * + * @author win + */ +@Configuration +@EnableCaching +public class RedisConfig extends CachingConfigurerSupport +{ + @Bean + @SuppressWarnings(value = { "unchecked", "rawtypes" }) + public RedisTemplate<Object, Object> redisTemplate(RedisConnectionFactory connectionFactory) + { + RedisTemplate<Object, Object> template = new RedisTemplate<>(); + template.setConnectionFactory(connectionFactory); + + FastJson2JsonRedisSerializer serializer = new FastJson2JsonRedisSerializer(Object.class); + + // 使用StringRedisSerializer来序列化和反序列化redis的key值 + template.setKeySerializer(new StringRedisSerializer()); + template.setValueSerializer(serializer); + + // Hash的key也采用StringRedisSerializer的序列化方式 + template.setHashKeySerializer(new StringRedisSerializer()); + template.setHashValueSerializer(serializer); + + template.afterPropertiesSet(); + return template; + } + + @Bean + public DefaultRedisScript<Long> limitScript() + { + DefaultRedisScript<Long> redisScript = new DefaultRedisScript<>(); + redisScript.setScriptText(limitScriptText()); + redisScript.setResultType(Long.class); + return redisScript; + } + + /** + * 限流脚本 + */ + private String limitScriptText() + { + return "local key = KEYS[1]\n" + + "local count = tonumber(ARGV[1])\n" + + "local time = tonumber(ARGV[2])\n" + + "local current = redis.call('get', key);\n" + + "if current and tonumber(current) > count then\n" + + " return tonumber(current);\n" + + "end\n" + + "current = redis.call('incr', key)\n" + + "if tonumber(current) == 1 then\n" + + " redis.call('expire', key, time)\n" + + "end\n" + + "return tonumber(current);"; + } +} diff --git a/dc-framework/src/main/java/com/dc/framework/config/ResourcesConfig.java b/dc-framework/src/main/java/com/dc/framework/config/ResourcesConfig.java new file mode 100644 index 0000000..427e567 --- /dev/null +++ b/dc-framework/src/main/java/com/dc/framework/config/ResourcesConfig.java @@ -0,0 +1,74 @@ +package com.dc.framework.config; + +import com.dc.common.config.WinConfig; +import com.dc.common.constant.Constants; +import com.dc.framework.interceptor.RepeatSubmitInterceptor; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.context.annotation.Bean; +import org.springframework.context.annotation.Configuration; +import org.springframework.http.CacheControl; +import org.springframework.web.cors.CorsConfiguration; +import org.springframework.web.cors.UrlBasedCorsConfigurationSource; +import org.springframework.web.filter.CorsFilter; +import org.springframework.web.servlet.config.annotation.InterceptorRegistry; +import org.springframework.web.servlet.config.annotation.ResourceHandlerRegistry; +import org.springframework.web.servlet.config.annotation.WebMvcConfigurer; + +import java.util.concurrent.TimeUnit; + +/** + * 通用配置 + * + * @author win + */ +@Configuration +public class ResourcesConfig implements WebMvcConfigurer +{ + @Autowired + private RepeatSubmitInterceptor repeatSubmitInterceptor; + + @Override + public void addResourceHandlers(ResourceHandlerRegistry registry) + { + /** 本地文件上传路径 */ + registry.addResourceHandler(Constants.RESOURCE_PREFIX + "/**") + .addResourceLocations("file:" + WinConfig.getProfile() + "/"); + + /** swagger配置 */ + registry.addResourceHandler("/swagger-ui/**") + .addResourceLocations("classpath:/META-INF/resources/webjars/springfox-swagger-ui/") + .setCacheControl(CacheControl.maxAge(5, TimeUnit.HOURS).cachePublic());; + } + + /** + * 自定义拦截规则 + */ + @Override + public void addInterceptors(InterceptorRegistry registry) + { + registry.addInterceptor(repeatSubmitInterceptor).addPathPatterns("/**"); + } + + /** + * 跨域配置 + */ + @Bean + public CorsFilter corsFilter() + { + CorsConfiguration config = new CorsConfiguration(); + config.setAllowCredentials(true); + // 设置访问源地址 + config.addAllowedOriginPattern("*"); + // 设置访问源请求头 + config.addAllowedHeader("*"); + // 设置访问源请求方法 + config.addAllowedMethod("*"); + // 有效期 1800秒 + config.setMaxAge(1800L); + // 添加映射路径,拦截一切请求 + UrlBasedCorsConfigurationSource source = new UrlBasedCorsConfigurationSource(); + source.registerCorsConfiguration("/**", config); + // 返回新的CorsFilter + return new CorsFilter(source); + } +} \ No newline at end of file diff --git a/dc-framework/src/main/java/com/dc/framework/config/SecurityConfig.java b/dc-framework/src/main/java/com/dc/framework/config/SecurityConfig.java new file mode 100644 index 0000000..d8f577d --- /dev/null +++ b/dc-framework/src/main/java/com/dc/framework/config/SecurityConfig.java @@ -0,0 +1,149 @@ +package com.dc.framework.config; + +import com.dc.framework.security.filter.JwtAuthenticationTokenFilter; +import com.dc.framework.security.handle.AuthenticationEntryPointImpl; +import com.dc.framework.security.handle.LogoutSuccessHandlerImpl; +import com.dc.framework.config.properties.PermitAllUrlProperties; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.context.annotation.Bean; +import org.springframework.http.HttpMethod; +import org.springframework.security.authentication.AuthenticationManager; +import org.springframework.security.config.annotation.authentication.builders.AuthenticationManagerBuilder; +import org.springframework.security.config.annotation.method.configuration.EnableGlobalMethodSecurity; +import org.springframework.security.config.annotation.web.builders.HttpSecurity; +import org.springframework.security.config.annotation.web.configuration.WebSecurityConfigurerAdapter; +import org.springframework.security.config.annotation.web.configurers.ExpressionUrlAuthorizationConfigurer; +import org.springframework.security.config.http.SessionCreationPolicy; +import org.springframework.security.core.userdetails.UserDetailsService; +import org.springframework.security.crypto.bcrypt.BCryptPasswordEncoder; +import org.springframework.security.web.authentication.UsernamePasswordAuthenticationFilter; +import org.springframework.security.web.authentication.logout.LogoutFilter; +import org.springframework.web.filter.CorsFilter; + +/** + * spring security配置 + * + * @author win + */ +@EnableGlobalMethodSecurity(prePostEnabled = true, securedEnabled = true) +public class SecurityConfig extends WebSecurityConfigurerAdapter +{ + /** + * 自定义用户认证逻辑 + */ + @Autowired + private UserDetailsService userDetailsService; + + /** + * 认证失败处理类 + */ + @Autowired + private AuthenticationEntryPointImpl unauthorizedHandler; + + /** + * 退出处理类 + */ + @Autowired + private LogoutSuccessHandlerImpl logoutSuccessHandler; + + /** + * token认证过滤器 + */ + @Autowired + private JwtAuthenticationTokenFilter authenticationTokenFilter; + + /** + * 跨域过滤器 + */ + @Autowired + private CorsFilter corsFilter; + + /** + * 允许匿名访问的地址 + */ + @Autowired + private PermitAllUrlProperties permitAllUrl; + + /** + * 解决 无法直接注入 AuthenticationManager + * + * @return + * @throws Exception + */ + @Bean + @Override + public AuthenticationManager authenticationManagerBean() throws Exception + { + return super.authenticationManagerBean(); + } + + /** + * anyRequest | 匹配所有请求路径 + * access | SpringEl表达式结果为true时可以访问 + * anonymous | 匿名可以访问 + * denyAll | 用户不能访问 + * fullyAuthenticated | 用户完全认证可以访问(非remember-me下自动登录) + * hasAnyAuthority | 如果有参数,参数表示权限,则其中任何一个权限可以访问 + * hasAnyRole | 如果有参数,参数表示角色,则其中任何一个角色可以访问 + * hasAuthority | 如果有参数,参数表示权限,则其权限可以访问 + * hasIpAddress | 如果有参数,参数表示IP地址,如果用户IP和参数匹配,则可以访问 + * hasRole | 如果有参数,参数表示角色,则其角色可以访问 + * permitAll | 用户可以任意访问 + * rememberMe | 允许通过remember-me登录的用户访问 + * authenticated | 用户登录后可访问 + */ + @Override + protected void configure(HttpSecurity httpSecurity) throws Exception + { + // 注解标记允许匿名访问的url + ExpressionUrlAuthorizationConfigurer<HttpSecurity>.ExpressionInterceptUrlRegistry registry = httpSecurity.authorizeRequests(); + permitAllUrl.getUrls().forEach(url -> registry.antMatchers(url).permitAll()); + + httpSecurity + // CSRF禁用,因为不使用session + .csrf().disable() + // 禁用HTTP响应标头 + .headers().cacheControl().disable().and() + // 认证失败处理类 + .exceptionHandling().authenticationEntryPoint(unauthorizedHandler).and() + // 基于token,所以不需要session + .sessionManagement().sessionCreationPolicy(SessionCreationPolicy.STATELESS).and() + // 过滤请求 + .authorizeRequests() + // 对于登录login 注册register 验证码captchaImage 允许匿名访问 + .antMatchers("/login", "/register", "/captchaImage").permitAll() + // 静态资源,可匿名访问 + .antMatchers(HttpMethod.GET, "/", "/*.html", "/**/*.html", "/**/*.css", "/**/*.js", "/profile/**").permitAll() + .antMatchers("/swagger-ui.html", "/swagger-resources/**", "/webjars/**", "/*/api-docs", "/druid/**").permitAll() + .antMatchers("/websocket/**").permitAll() + // 除上面外的所有请求全部需要鉴权认证 + .anyRequest().authenticated() + .and() + .headers().frameOptions().disable(); + // 添加Logout filter + httpSecurity.logout().logoutUrl("/logout").logoutSuccessHandler(logoutSuccessHandler); + // 添加JWT filter + httpSecurity.addFilterBefore(authenticationTokenFilter, UsernamePasswordAuthenticationFilter.class); + // 添加CORS filter + httpSecurity.addFilterBefore(corsFilter, JwtAuthenticationTokenFilter.class); + httpSecurity.addFilterBefore(corsFilter, LogoutFilter.class); + } + + /** + * 强散列哈希加密实现 + */ + @Bean + public BCryptPasswordEncoder bCryptPasswordEncoder() + { + return new BCryptPasswordEncoder(); + } + + /** + * 身份认证接口 + */ + @Override + protected void configure(AuthenticationManagerBuilder auth) throws Exception + { + auth.userDetailsService(userDetailsService).passwordEncoder(bCryptPasswordEncoder()); + } +} diff --git a/dc-framework/src/main/java/com/dc/framework/config/ServerConfig.java b/dc-framework/src/main/java/com/dc/framework/config/ServerConfig.java new file mode 100644 index 0000000..af0e374 --- /dev/null +++ b/dc-framework/src/main/java/com/dc/framework/config/ServerConfig.java @@ -0,0 +1,38 @@ +package com.dc.framework.config; + +import com.dc.common.utils.ServletUtils; +import com.dc.common.utils.spring.SpringUtils; +import org.springframework.stereotype.Component; + +import javax.servlet.http.HttpServletRequest; + +/** + * 服务相关配置 + * + * @author win + */ +@Component +public class ServerConfig +{ + /** + * 获取完整的请求路径,包括:域名,端口,上下文访问路径 + * + * @return 服务地址 + */ + public String getUrl() + { + HttpServletRequest request = ServletUtils.getRequest(); + return getDomain(request); + } + + public static String getDomain(HttpServletRequest request) + { + StringBuffer url = request.getRequestURL(); + String contextPath = request.getServletContext().getContextPath(); + String returnUrl = url.delete(url.length() - request.getRequestURI().length(), url.length()).append(contextPath).toString(); + if(SpringUtils.getActiveProfile().equals("prod")) { + returnUrl = returnUrl.replaceAll("http://", "https://"); + } + return returnUrl; + } +} diff --git a/dc-framework/src/main/java/com/dc/framework/config/ThreadPoolConfig.java b/dc-framework/src/main/java/com/dc/framework/config/ThreadPoolConfig.java new file mode 100644 index 0000000..d237dd4 --- /dev/null +++ b/dc-framework/src/main/java/com/dc/framework/config/ThreadPoolConfig.java @@ -0,0 +1,63 @@ +package com.dc.framework.config; + +import com.dc.common.utils.Threads; +import org.apache.commons.lang3.concurrent.BasicThreadFactory; +import org.springframework.context.annotation.Bean; +import org.springframework.context.annotation.Configuration; +import org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor; +import java.util.concurrent.ScheduledExecutorService; +import java.util.concurrent.ScheduledThreadPoolExecutor; +import java.util.concurrent.ThreadPoolExecutor; + +/** + * 线程池配置 + * + * @author win + **/ +@Configuration +public class ThreadPoolConfig +{ + // 核心线程池大小 + private int corePoolSize = 50; + + // 最大可创建的线程数 + private int maxPoolSize = 200; + + // 队列最大长度 + private int queueCapacity = 1000; + + // 线程池维护线程所允许的空闲时间 + private int keepAliveSeconds = 300; + + @Bean(name = "threadPoolTaskExecutor") + public ThreadPoolTaskExecutor threadPoolTaskExecutor() + { + ThreadPoolTaskExecutor executor = new ThreadPoolTaskExecutor(); + executor.setMaxPoolSize(maxPoolSize); + executor.setCorePoolSize(corePoolSize); + executor.setQueueCapacity(queueCapacity); + executor.setKeepAliveSeconds(keepAliveSeconds); + // 线程池对拒绝任务(无线程可用)的处理策略 + executor.setRejectedExecutionHandler(new ThreadPoolExecutor.CallerRunsPolicy()); + return executor; + } + + /** + * 执行周期性或定时任务 + */ + @Bean(name = "scheduledExecutorService") + protected ScheduledExecutorService scheduledExecutorService() + { + return new ScheduledThreadPoolExecutor(corePoolSize, + new BasicThreadFactory.Builder().namingPattern("schedule-pool-%d").daemon(true).build(), + new ThreadPoolExecutor.CallerRunsPolicy()) + { + @Override + protected void afterExecute(Runnable r, Throwable t) + { + super.afterExecute(r, t); + Threads.printException(r, t); + } + }; + } +} diff --git a/dc-framework/src/main/java/com/dc/framework/config/properties/PermitAllUrlProperties.java b/dc-framework/src/main/java/com/dc/framework/config/properties/PermitAllUrlProperties.java new file mode 100644 index 0000000..360c6d8 --- /dev/null +++ b/dc-framework/src/main/java/com/dc/framework/config/properties/PermitAllUrlProperties.java @@ -0,0 +1,73 @@ +package com.dc.framework.config.properties; + +import com.dc.common.annotation.Anonymous; +import org.apache.commons.lang3.RegExUtils; +import org.springframework.beans.BeansException; +import org.springframework.beans.factory.InitializingBean; +import org.springframework.context.ApplicationContext; +import org.springframework.context.ApplicationContextAware; +import org.springframework.context.annotation.Configuration; +import org.springframework.core.annotation.AnnotationUtils; +import org.springframework.web.method.HandlerMethod; +import org.springframework.web.servlet.mvc.method.RequestMappingInfo; +import org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerMapping; + +import java.util.ArrayList; +import java.util.List; +import java.util.Map; +import java.util.Optional; +import java.util.regex.Pattern; + +/** + * 设置Anonymous注解允许匿名访问的url + * + * @author win + */ +@Configuration +public class PermitAllUrlProperties implements InitializingBean, ApplicationContextAware +{ + private static final Pattern PATTERN = Pattern.compile("\\{(.*?)\\}"); + + private ApplicationContext applicationContext; + + private List<String> urls = new ArrayList<>(); + + public String ASTERISK = "*"; + + @Override + public void afterPropertiesSet() + { + RequestMappingHandlerMapping mapping = applicationContext.getBean(RequestMappingHandlerMapping.class); + Map<RequestMappingInfo, HandlerMethod> map = mapping.getHandlerMethods(); + + map.keySet().forEach(info -> { + HandlerMethod handlerMethod = map.get(info); + + // 获取方法上边的注解 替代path variable 为 * + Anonymous method = AnnotationUtils.findAnnotation(handlerMethod.getMethod(), Anonymous.class); + Optional.ofNullable(method).ifPresent(anonymous -> info.getPatternsCondition().getPatterns() + .forEach(url -> urls.add(RegExUtils.replaceAll(url, PATTERN, ASTERISK)))); + + // 获取类上边的注解, 替代path variable 为 * + Anonymous controller = AnnotationUtils.findAnnotation(handlerMethod.getBeanType(), Anonymous.class); + Optional.ofNullable(controller).ifPresent(anonymous -> info.getPatternsCondition().getPatterns() + .forEach(url -> urls.add(RegExUtils.replaceAll(url, PATTERN, ASTERISK)))); + }); + } + + @Override + public void setApplicationContext(ApplicationContext context) throws BeansException + { + this.applicationContext = context; + } + + public List<String> getUrls() + { + return urls; + } + + public void setUrls(List<String> urls) + { + this.urls = urls; + } +} diff --git a/dc-framework/src/main/java/com/dc/framework/interceptor/RepeatSubmitInterceptor.java b/dc-framework/src/main/java/com/dc/framework/interceptor/RepeatSubmitInterceptor.java new file mode 100644 index 0000000..5ef70b2 --- /dev/null +++ b/dc-framework/src/main/java/com/dc/framework/interceptor/RepeatSubmitInterceptor.java @@ -0,0 +1,56 @@ +package com.dc.framework.interceptor; + +import com.alibaba.fastjson2.JSON; +import com.dc.common.annotation.RepeatSubmit; +import com.dc.common.core.domain.AjaxResult; +import com.dc.common.utils.ServletUtils; +import org.springframework.stereotype.Component; +import org.springframework.web.method.HandlerMethod; +import org.springframework.web.servlet.HandlerInterceptor; + +import javax.servlet.http.HttpServletRequest; +import javax.servlet.http.HttpServletResponse; +import java.lang.reflect.Method; + +/** + * 防止重复提交拦截器 + * + * @author win + */ +@Component +public abstract class RepeatSubmitInterceptor implements HandlerInterceptor +{ + @Override + public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception + { + if (handler instanceof HandlerMethod) + { + HandlerMethod handlerMethod = (HandlerMethod) handler; + Method method = handlerMethod.getMethod(); + RepeatSubmit annotation = method.getAnnotation(RepeatSubmit.class); + if (annotation != null) + { + if (this.isRepeatSubmit(request, annotation)) + { + AjaxResult ajaxResult = AjaxResult.error(annotation.message()); + ServletUtils.renderString(response, JSON.toJSONString(ajaxResult)); + return false; + } + } + return true; + } + else + { + return true; + } + } + + /** + * 验证是否重复提交由子类实现具体的防重复提交的规则 + * + * @param request + * @return + * @throws Exception + */ + public abstract boolean isRepeatSubmit(HttpServletRequest request, RepeatSubmit annotation); +} diff --git a/dc-framework/src/main/java/com/dc/framework/interceptor/UnionIdInterceptor.java b/dc-framework/src/main/java/com/dc/framework/interceptor/UnionIdInterceptor.java new file mode 100644 index 0000000..d604fb4 --- /dev/null +++ b/dc-framework/src/main/java/com/dc/framework/interceptor/UnionIdInterceptor.java @@ -0,0 +1,50 @@ +package com.dc.framework.interceptor; + +import com.alibaba.fastjson2.JSONObject; +import com.dc.common.core.domain.AjaxResult; +import com.dc.common.utils.SecurityUtils; +import com.dc.common.utils.StringUtils; +import org.springframework.web.servlet.HandlerInterceptor; + +import javax.servlet.http.HttpServletRequest; +import javax.servlet.http.HttpServletResponse; +import java.util.Arrays; +import java.util.List; + +public class UnionIdInterceptor implements HandlerInterceptor { + + public static final String OPEN_ID = "openId"; + + /** + * 白名单,允许使用通配符 + */ + private final List<String> whiteList = Arrays.asList( + "/base/driver/getOpenId", "/swagger" + ); + + @Override + public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception { + String uri = request.getRequestURI(); + for (String path : whiteList) { + if (StringUtils.startsWith(uri, path)) { + return true; + } + } + String openId = request.getHeader(OPEN_ID); + if(StringUtils.isNotEmpty(openId)){ + SecurityUtils.setOpenId(openId); + } else { + response.setContentType("application/json; charset=utf-8"); + response.getWriter().print(JSONObject.toJSONString(AjaxResult.error("openId为空!"))); + return false; + } + return true;//注意 这里必须是true否则请求将就此终止。 + } + + @Override + public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception { + //移除 + SecurityUtils.removeOpenId(); + } + +} diff --git a/dc-framework/src/main/java/com/dc/framework/interceptor/impl/DataScopeInterceptor.java b/dc-framework/src/main/java/com/dc/framework/interceptor/impl/DataScopeInterceptor.java new file mode 100644 index 0000000..30e9181 --- /dev/null +++ b/dc-framework/src/main/java/com/dc/framework/interceptor/impl/DataScopeInterceptor.java @@ -0,0 +1,56 @@ +package com.dc.framework.interceptor.impl; + +import com.baomidou.mybatisplus.core.toolkit.PluginUtils; +import com.baomidou.mybatisplus.extension.plugins.inner.InnerInterceptor; +import com.dc.common.context.DataScopeHolder; +import lombok.extern.slf4j.Slf4j; +import org.apache.ibatis.executor.Executor; +import org.apache.ibatis.mapping.BoundSql; +import org.apache.ibatis.mapping.MappedStatement; +import org.apache.ibatis.session.ResultHandler; +import org.apache.ibatis.session.RowBounds; + +import java.sql.SQLException; +import java.util.regex.Matcher; +import java.util.regex.Pattern; + +/** + * @ClassName DataScopeInterceptor + * @Description TODO + * @Author longlongxiaogege + * @Date 2023/6/27 13:21 + * @Version 1.0 + */ +@Slf4j +public class DataScopeInterceptor implements InnerInterceptor { + + @Override + public void beforeQuery(Executor executor, MappedStatement ms, Object parameter, RowBounds rowBounds, ResultHandler resultHandler, BoundSql boundSql) throws SQLException { + String buildSql = boundSql.getSql(); + Object dataScopeSql = DataScopeHolder.getDataScopeSql(); + if(dataScopeSql != null) { + Pattern patternOrder = Pattern.compile("ORDER(\\s+)BY",Pattern.CASE_INSENSITIVE|Pattern.MULTILINE);//匹配ORDER BY正则 + Pattern patternGroup = Pattern.compile("GROUP(\\s+)BY",Pattern.CASE_INSENSITIVE|Pattern.MULTILINE);//匹配GROUP BY正则 + Matcher matcherOrder = patternOrder.matcher(buildSql); + Matcher matcherGroup = patternGroup.matcher(buildSql); + Pattern patternCount = Pattern.compile("COUNT",Pattern.CASE_INSENSITIVE|Pattern.MULTILINE);//匹配ORDER BY正则 + Matcher matcherCount = patternCount.matcher(buildSql); + //不带COUNT时清除数据权限sql + if (!matcherCount.find()) { + DataScopeHolder.removeDataScopeSql(); + } + if (buildSql.contains("WHERE")) {//带where + buildSql = buildSql.replaceFirst("WHERE", " WHERE (" + dataScopeSql.toString() + ") AND "); + } else if (matcherOrder.find()) {//带order by + buildSql = matcherOrder.replaceFirst(" WHERE (" + dataScopeSql.toString() + ") ORDER BY"); + } else if (matcherGroup.find()) {//带group by + buildSql = matcherGroup.replaceFirst(" WHERE (" + dataScopeSql.toString() + ") GROUP BY"); + } else {//什么都不带 + buildSql += " WHERE (" + dataScopeSql.toString() + ")"; + } + PluginUtils.MPBoundSql mpBoundSql = PluginUtils.mpBoundSql(boundSql); + mpBoundSql.sql(buildSql); + } + } + +} diff --git a/dc-framework/src/main/java/com/dc/framework/interceptor/impl/SameUrlDataInterceptor.java b/dc-framework/src/main/java/com/dc/framework/interceptor/impl/SameUrlDataInterceptor.java new file mode 100644 index 0000000..fb0f00c --- /dev/null +++ b/dc-framework/src/main/java/com/dc/framework/interceptor/impl/SameUrlDataInterceptor.java @@ -0,0 +1,111 @@ +package com.dc.framework.interceptor.impl; + +import com.alibaba.fastjson2.JSON; +import com.dc.common.annotation.RepeatSubmit; +import com.dc.common.constant.CacheConstants; +import com.dc.common.core.redis.RedisCache; +import com.dc.common.filter.RepeatedlyRequestWrapper; +import com.dc.common.utils.StringUtils; +import com.dc.common.utils.http.HttpHelper; +import com.dc.framework.interceptor.RepeatSubmitInterceptor; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.beans.factory.annotation.Value; +import org.springframework.stereotype.Component; + +import javax.servlet.http.HttpServletRequest; +import java.util.HashMap; +import java.util.Map; +import java.util.concurrent.TimeUnit; + +/** + * 判断请求url和数据是否和上一次相同, + * 如果和上次相同,则是重复提交表单。 有效时间为10秒内。 + * + * @author win + */ +@Component +public class SameUrlDataInterceptor extends RepeatSubmitInterceptor +{ + public final String REPEAT_PARAMS = "repeatParams"; + + public final String REPEAT_TIME = "repeatTime"; + + // 令牌自定义标识 + @Value("${token.header}") + private String header; + + @Autowired + private RedisCache redisCache; + + @SuppressWarnings("unchecked") + @Override + public boolean isRepeatSubmit(HttpServletRequest request, RepeatSubmit annotation) + { + String nowParams = ""; + if (request instanceof RepeatedlyRequestWrapper) + { + RepeatedlyRequestWrapper repeatedlyRequest = (RepeatedlyRequestWrapper) request; + nowParams = HttpHelper.getBodyString(repeatedlyRequest); + } + + // body参数为空,获取Parameter的数据 + if (StringUtils.isEmpty(nowParams)) + { + nowParams = JSON.toJSONString(request.getParameterMap()); + } + Map<String, Object> nowDataMap = new HashMap<String, Object>(); + nowDataMap.put(REPEAT_PARAMS, nowParams); + nowDataMap.put(REPEAT_TIME, System.currentTimeMillis()); + + // 请求地址(作为存放cache的key值) + String url = request.getRequestURI(); + + // 唯一值(没有消息头则使用请求地址) + String submitKey = StringUtils.trimToEmpty(request.getHeader(header)); + + // 唯一标识(指定key + url + 消息头) + String cacheRepeatKey = CacheConstants.REPEAT_SUBMIT_KEY + url + submitKey; + + Object sessionObj = redisCache.getCacheObject(cacheRepeatKey); + if (sessionObj != null) + { + Map<String, Object> sessionMap = (Map<String, Object>) sessionObj; + if (sessionMap.containsKey(url)) + { + Map<String, Object> preDataMap = (Map<String, Object>) sessionMap.get(url); + if (compareParams(nowDataMap, preDataMap) && compareTime(nowDataMap, preDataMap, annotation.interval())) + { + return true; + } + } + } + Map<String, Object> cacheMap = new HashMap<String, Object>(); + cacheMap.put(url, nowDataMap); + redisCache.setCacheObject(cacheRepeatKey, cacheMap, annotation.interval(), TimeUnit.MILLISECONDS); + return false; + } + + /** + * 判断参数是否相同 + */ + private boolean compareParams(Map<String, Object> nowMap, Map<String, Object> preMap) + { + String nowParams = (String) nowMap.get(REPEAT_PARAMS); + String preParams = (String) preMap.get(REPEAT_PARAMS); + return nowParams.equals(preParams); + } + + /** + * 判断两次间隔时间 + */ + private boolean compareTime(Map<String, Object> nowMap, Map<String, Object> preMap, int interval) + { + long time1 = (Long) nowMap.get(REPEAT_TIME); + long time2 = (Long) preMap.get(REPEAT_TIME); + if ((time1 - time2) < interval) + { + return true; + } + return false; + } +} diff --git a/dc-framework/src/main/java/com/dc/framework/manager/AsyncManager.java b/dc-framework/src/main/java/com/dc/framework/manager/AsyncManager.java new file mode 100644 index 0000000..e56c4b2 --- /dev/null +++ b/dc-framework/src/main/java/com/dc/framework/manager/AsyncManager.java @@ -0,0 +1,56 @@ +package com.dc.framework.manager; + +import com.dc.common.utils.Threads; +import com.dc.common.utils.spring.SpringUtils; + +import java.util.TimerTask; +import java.util.concurrent.ScheduledExecutorService; +import java.util.concurrent.TimeUnit; + +/** + * 异步任务管理器 + * + * @author win + */ +public class AsyncManager +{ + /** + * 操作延迟10毫秒 + */ + private final int OPERATE_DELAY_TIME = 10; + + /** + * 异步操作任务调度线程池 + */ + private ScheduledExecutorService executor = SpringUtils.getBean("scheduledExecutorService"); + + /** + * 单例模式 + */ + private AsyncManager(){} + + private static AsyncManager me = new AsyncManager(); + + public static AsyncManager me() + { + return me; + } + + /** + * 执行任务 + * + * @param task 任务 + */ + public void execute(TimerTask task) + { + executor.schedule(task, OPERATE_DELAY_TIME, TimeUnit.MILLISECONDS); + } + + /** + * 停止任务线程池 + */ + public void shutdown() + { + Threads.shutdownAndAwaitTermination(executor); + } +} diff --git a/dc-framework/src/main/java/com/dc/framework/manager/ShutdownManager.java b/dc-framework/src/main/java/com/dc/framework/manager/ShutdownManager.java new file mode 100644 index 0000000..74d31b0 --- /dev/null +++ b/dc-framework/src/main/java/com/dc/framework/manager/ShutdownManager.java @@ -0,0 +1,39 @@ +package com.dc.framework.manager; + +import org.slf4j.Logger; +import org.slf4j.LoggerFactory; +import org.springframework.stereotype.Component; +import javax.annotation.PreDestroy; + +/** + * 确保应用退出时能关闭后台线程 + * + * @author win + */ +@Component +public class ShutdownManager +{ + private static final Logger logger = LoggerFactory.getLogger("sys-user"); + + @PreDestroy + public void destroy() + { + shutdownAsyncManager(); + } + + /** + * 停止异步执行任务 + */ + private void shutdownAsyncManager() + { + try + { + logger.info("====关闭后台任务任务线程池===="); + AsyncManager.me().shutdown(); + } + catch (Exception e) + { + logger.error(e.getMessage(), e); + } + } +} diff --git a/dc-framework/src/main/java/com/dc/framework/manager/factory/AsyncFactory.java b/dc-framework/src/main/java/com/dc/framework/manager/factory/AsyncFactory.java new file mode 100644 index 0000000..4fd4d78 --- /dev/null +++ b/dc-framework/src/main/java/com/dc/framework/manager/factory/AsyncFactory.java @@ -0,0 +1,103 @@ +package com.dc.framework.manager.factory; + +import com.dc.common.constant.Constants; +import com.dc.common.utils.LogUtils; +import com.dc.common.utils.ServletUtils; +import com.dc.common.utils.StringUtils; +import com.dc.common.utils.ip.AddressUtils; +import com.dc.common.utils.ip.IpUtils; +import com.dc.common.utils.spring.SpringUtils; +import com.dc.system.domain.SysLogininfor; +import com.dc.system.domain.SysOperLog; +import com.dc.system.service.SysLogininforService; +import com.dc.system.service.SysOperLogService; +import eu.bitwalker.useragentutils.UserAgent; +import org.slf4j.Logger; +import org.slf4j.LoggerFactory; + +import java.util.TimerTask; + +/** + * 异步工厂(产生任务用) + * + * @author win + */ +public class AsyncFactory +{ + private static final Logger sys_user_logger = LoggerFactory.getLogger("sys-user"); + + /** + * 记录登录信息 + * + * @param username 用户名 + * @param status 状态 + * @param message 消息 + * @param args 列表 + * @return 任务task + */ + public static TimerTask recordLogininfor(final String username, final String status, final String message, + final Object... args) + { + final UserAgent userAgent = UserAgent.parseUserAgentString(ServletUtils.getRequest().getHeader("User-Agent")); + final String ip = IpUtils.getIpAddr(ServletUtils.getRequest()); + return new TimerTask() + { + @Override + public void run() + { + String address = AddressUtils.getRealAddressByIP(ip); + StringBuilder s = new StringBuilder(); + s.append(LogUtils.getBlock(ip)); + s.append(address); + s.append(LogUtils.getBlock(username)); + s.append(LogUtils.getBlock(status)); + s.append(LogUtils.getBlock(message)); + // 打印信息到日志 + sys_user_logger.info(s.toString(), args); + // 获取客户端操作系统 + String os = userAgent.getOperatingSystem().getName(); + // 获取客户端浏览器 + String browser = userAgent.getBrowser().getName(); + // 封装对象 + SysLogininfor logininfor = new SysLogininfor(); + logininfor.setUserName(username); + logininfor.setIpaddr(ip); + logininfor.setLoginLocation(address); + logininfor.setBrowser(browser); + logininfor.setOs(os); + logininfor.setMsg(message); + // 日志状态 + if (StringUtils.equalsAny(status, Constants.LOGIN_SUCCESS, Constants.LOGOUT, Constants.REGISTER)) + { + logininfor.setStatus(Constants.SUCCESS); + } + else if (Constants.LOGIN_FAIL.equals(status)) + { + logininfor.setStatus(Constants.FAIL); + } + // 插入数据 + SpringUtils.getBean(SysLogininforService.class).insertLogininfor(logininfor); + } + }; + } + + /** + * 操作日志记录 + * + * @param operLog 操作日志信息 + * @return 任务task + */ + public static TimerTask recordOper(final SysOperLog operLog) + { + return new TimerTask() + { + @Override + public void run() + { + // 远程查询操作地点 + operLog.setOperLocation(AddressUtils.getRealAddressByIP(operLog.getOperIp())); + SpringUtils.getBean(SysOperLogService.class).insertOperlog(operLog); + } + }; + } +} diff --git a/dc-framework/src/main/java/com/dc/framework/security/context/AuthenticationContextHolder.java b/dc-framework/src/main/java/com/dc/framework/security/context/AuthenticationContextHolder.java new file mode 100644 index 0000000..a6afb31 --- /dev/null +++ b/dc-framework/src/main/java/com/dc/framework/security/context/AuthenticationContextHolder.java @@ -0,0 +1,28 @@ +package com.dc.framework.security.context; + +import org.springframework.security.core.Authentication; + +/** + * 身份验证信息 + * + * @author win + */ +public class AuthenticationContextHolder +{ + private static final ThreadLocal<Authentication> contextHolder = new ThreadLocal<>(); + + public static Authentication getContext() + { + return contextHolder.get(); + } + + public static void setContext(Authentication context) + { + contextHolder.set(context); + } + + public static void clearContext() + { + contextHolder.remove(); + } +} diff --git a/dc-framework/src/main/java/com/dc/framework/security/context/PermissionContextHolder.java b/dc-framework/src/main/java/com/dc/framework/security/context/PermissionContextHolder.java new file mode 100644 index 0000000..eff5567 --- /dev/null +++ b/dc-framework/src/main/java/com/dc/framework/security/context/PermissionContextHolder.java @@ -0,0 +1,27 @@ +package com.dc.framework.security.context; + +import com.dc.common.core.text.Convert; +import org.springframework.web.context.request.RequestAttributes; +import org.springframework.web.context.request.RequestContextHolder; + +/** + * 权限信息 + * + * @author win + */ +public class PermissionContextHolder +{ + private static final String PERMISSION_CONTEXT_ATTRIBUTES = "PERMISSION_CONTEXT"; + + public static void setContext(String permission) + { + RequestContextHolder.currentRequestAttributes().setAttribute(PERMISSION_CONTEXT_ATTRIBUTES, permission, + RequestAttributes.SCOPE_REQUEST); + } + + public static String getContext() + { + return Convert.toStr(RequestContextHolder.currentRequestAttributes().getAttribute(PERMISSION_CONTEXT_ATTRIBUTES, + RequestAttributes.SCOPE_REQUEST)); + } +} diff --git a/dc-framework/src/main/java/com/dc/framework/security/filter/JwtAuthenticationTokenFilter.java b/dc-framework/src/main/java/com/dc/framework/security/filter/JwtAuthenticationTokenFilter.java new file mode 100644 index 0000000..1d84c84 --- /dev/null +++ b/dc-framework/src/main/java/com/dc/framework/security/filter/JwtAuthenticationTokenFilter.java @@ -0,0 +1,45 @@ +package com.dc.framework.security.filter; + +import com.dc.framework.web.service.TokenService; +import com.dc.common.core.domain.model.LoginUser; +import com.dc.common.utils.SecurityUtils; +import com.dc.common.utils.StringUtils; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.security.authentication.UsernamePasswordAuthenticationToken; +import org.springframework.security.core.context.SecurityContextHolder; +import org.springframework.security.web.authentication.WebAuthenticationDetailsSource; +import org.springframework.stereotype.Component; +import org.springframework.web.filter.OncePerRequestFilter; + +import javax.servlet.FilterChain; +import javax.servlet.ServletException; +import javax.servlet.http.HttpServletRequest; +import javax.servlet.http.HttpServletResponse; +import java.io.IOException; + +/** + * token过滤器 验证token有效性 + * + * @author win + */ +@Component +public class JwtAuthenticationTokenFilter extends OncePerRequestFilter +{ + @Autowired + private TokenService tokenService; + + @Override + protected void doFilterInternal(HttpServletRequest request, HttpServletResponse response, FilterChain chain) + throws ServletException, IOException + { + LoginUser loginUser = tokenService.getLoginUser(request); + if (StringUtils.isNotNull(loginUser) && StringUtils.isNull(SecurityUtils.getAuthentication())) + { + tokenService.verifyToken(loginUser); + UsernamePasswordAuthenticationToken authenticationToken = new UsernamePasswordAuthenticationToken(loginUser, null, loginUser.getAuthorities()); + authenticationToken.setDetails(new WebAuthenticationDetailsSource().buildDetails(request)); + SecurityContextHolder.getContext().setAuthentication(authenticationToken); + } + chain.doFilter(request, response); + } +} diff --git a/dc-framework/src/main/java/com/dc/framework/security/handle/AuthenticationEntryPointImpl.java b/dc-framework/src/main/java/com/dc/framework/security/handle/AuthenticationEntryPointImpl.java new file mode 100644 index 0000000..de16281 --- /dev/null +++ b/dc-framework/src/main/java/com/dc/framework/security/handle/AuthenticationEntryPointImpl.java @@ -0,0 +1,35 @@ +package com.dc.framework.security.handle; + +import com.alibaba.fastjson2.JSON; +import com.dc.common.constant.HttpStatus; +import com.dc.common.core.domain.AjaxResult; +import com.dc.common.utils.ServletUtils; +import com.dc.common.utils.StringUtils; +import org.springframework.security.core.AuthenticationException; +import org.springframework.security.web.AuthenticationEntryPoint; +import org.springframework.stereotype.Component; + +import javax.servlet.http.HttpServletRequest; +import javax.servlet.http.HttpServletResponse; +import java.io.IOException; +import java.io.Serializable; + +/** + * 认证失败处理类 返回未授权 + * + * @author win + */ +@Component +public class AuthenticationEntryPointImpl implements AuthenticationEntryPoint, Serializable +{ + private static final long serialVersionUID = -8970718410437077606L; + + @Override + public void commence(HttpServletRequest request, HttpServletResponse response, AuthenticationException e) + throws IOException + { + int code = HttpStatus.UNAUTHORIZED; + String msg = StringUtils.format("请求访问:{},认证失败,无法访问系统资源", request.getRequestURI()); + ServletUtils.renderString(response, JSON.toJSONString(AjaxResult.error(code, msg))); + } +} diff --git a/dc-framework/src/main/java/com/dc/framework/security/handle/LogoutSuccessHandlerImpl.java b/dc-framework/src/main/java/com/dc/framework/security/handle/LogoutSuccessHandlerImpl.java new file mode 100644 index 0000000..56942c5 --- /dev/null +++ b/dc-framework/src/main/java/com/dc/framework/security/handle/LogoutSuccessHandlerImpl.java @@ -0,0 +1,54 @@ +package com.dc.framework.security.handle; + +import com.alibaba.fastjson2.JSON; +import com.dc.framework.web.service.TokenService; +import com.dc.common.constant.Constants; +import com.dc.common.core.domain.AjaxResult; +import com.dc.common.core.domain.model.LoginUser; +import com.dc.common.utils.ServletUtils; +import com.dc.common.utils.StringUtils; +import com.dc.framework.manager.AsyncManager; +import com.dc.framework.manager.factory.AsyncFactory; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.context.annotation.Configuration; +import org.springframework.security.core.Authentication; +import org.springframework.security.web.authentication.logout.LogoutSuccessHandler; + +import javax.servlet.ServletException; +import javax.servlet.http.HttpServletRequest; +import javax.servlet.http.HttpServletResponse; +import java.io.IOException; + +/** + * 自定义退出处理类 返回成功 + * + * @author win + */ +@Configuration +public class LogoutSuccessHandlerImpl implements LogoutSuccessHandler +{ + @Autowired + private TokenService tokenService; + + /** + * 退出处理 + * + * @return + */ + @Override + public void onLogoutSuccess(HttpServletRequest request, HttpServletResponse response, Authentication authentication) + throws IOException, ServletException + { + LoginUser loginUser = tokenService.getLoginUser(request); + if (StringUtils.isNotNull(loginUser)) + { + String userName = loginUser.getUsername(); + // 删除用户缓存记录 + tokenService.delLoginUser(loginUser.getToken(), loginUser.getUser().getUserId()); + // 记录用户退出日志 + AsyncManager.me().execute(AsyncFactory.recordLogininfor(userName, Constants.LOGOUT, "退出成功")); + } + ServletUtils.renderString(response, JSON.toJSONString(AjaxResult.success("退出成功"))); + } + +} diff --git a/dc-framework/src/main/java/com/dc/framework/web/domain/Server.java b/dc-framework/src/main/java/com/dc/framework/web/domain/Server.java new file mode 100644 index 0000000..88b3f0a --- /dev/null +++ b/dc-framework/src/main/java/com/dc/framework/web/domain/Server.java @@ -0,0 +1,237 @@ +package com.dc.framework.web.domain; + +import com.dc.common.utils.Arith; +import com.dc.common.utils.ip.IpUtils; +import com.dc.framework.web.domain.server.*; +import oshi.SystemInfo; +import oshi.hardware.CentralProcessor; +import oshi.hardware.CentralProcessor.TickType; +import oshi.hardware.GlobalMemory; +import oshi.hardware.HardwareAbstractionLayer; +import oshi.software.os.FileSystem; +import oshi.software.os.OSFileStore; +import oshi.software.os.OperatingSystem; +import oshi.util.Util; + +import java.net.UnknownHostException; +import java.util.LinkedList; +import java.util.List; +import java.util.Properties; + +/** + * 服务器相关信息 + * + * @author win + */ +public class Server +{ + private static final int OSHI_WAIT_SECOND = 1000; + + /** + * CPU相关信息 + */ + private Cpu cpu = new Cpu(); + + /** + * 內存相关信息 + */ + private Mem mem = new Mem(); + + /** + * JVM相关信息 + */ + private Jvm jvm = new Jvm(); + + /** + * 服务器相关信息 + */ + private Sys sys = new Sys(); + + /** + * 磁盘相关信息 + */ + private List<SysFile> sysFiles = new LinkedList<SysFile>(); + + public Cpu getCpu() + { + return cpu; + } + + public void setCpu(Cpu cpu) + { + this.cpu = cpu; + } + + public Mem getMem() + { + return mem; + } + + public void setMem(Mem mem) + { + this.mem = mem; + } + + public Jvm getJvm() + { + return jvm; + } + + public void setJvm(Jvm jvm) + { + this.jvm = jvm; + } + + public Sys getSys() + { + return sys; + } + + public void setSys(Sys sys) + { + this.sys = sys; + } + + public List<SysFile> getSysFiles() + { + return sysFiles; + } + + public void setSysFiles(List<SysFile> sysFiles) + { + this.sysFiles = sysFiles; + } + + public void copyTo() throws Exception + { + SystemInfo si = new SystemInfo(); + HardwareAbstractionLayer hal = si.getHardware(); + + setCpuInfo(hal.getProcessor()); + + setMemInfo(hal.getMemory()); + + setSysInfo(); + + setJvmInfo(); + + setSysFiles(si.getOperatingSystem()); + } + + /** + * 设置CPU信息 + */ + private void setCpuInfo(CentralProcessor processor) + { + // CPU信息 + long[] prevTicks = processor.getSystemCpuLoadTicks(); + Util.sleep(OSHI_WAIT_SECOND); + long[] ticks = processor.getSystemCpuLoadTicks(); + long nice = ticks[TickType.NICE.getIndex()] - prevTicks[TickType.NICE.getIndex()]; + long irq = ticks[TickType.IRQ.getIndex()] - prevTicks[TickType.IRQ.getIndex()]; + long softirq = ticks[TickType.SOFTIRQ.getIndex()] - prevTicks[TickType.SOFTIRQ.getIndex()]; + long steal = ticks[TickType.STEAL.getIndex()] - prevTicks[TickType.STEAL.getIndex()]; + long cSys = ticks[TickType.SYSTEM.getIndex()] - prevTicks[TickType.SYSTEM.getIndex()]; + long user = ticks[TickType.USER.getIndex()] - prevTicks[TickType.USER.getIndex()]; + long iowait = ticks[TickType.IOWAIT.getIndex()] - prevTicks[TickType.IOWAIT.getIndex()]; + long idle = ticks[TickType.IDLE.getIndex()] - prevTicks[TickType.IDLE.getIndex()]; + long totalCpu = user + nice + cSys + idle + iowait + irq + softirq + steal; + cpu.setCpuNum(processor.getLogicalProcessorCount()); + cpu.setTotal(totalCpu); + cpu.setSys(cSys); + cpu.setUsed(user); + cpu.setWait(iowait); + cpu.setFree(idle); + } + + /** + * 设置内存信息 + */ + private void setMemInfo(GlobalMemory memory) + { + mem.setTotal(memory.getTotal()); + mem.setUsed(memory.getTotal() - memory.getAvailable()); + mem.setFree(memory.getAvailable()); + } + + /** + * 设置服务器信息 + */ + private void setSysInfo() + { + Properties props = System.getProperties(); + sys.setComputerName(IpUtils.getHostName()); + sys.setComputerIp(IpUtils.getHostIp()); + sys.setOsName(props.getProperty("os.name")); + sys.setOsArch(props.getProperty("os.arch")); + sys.setUserDir(props.getProperty("user.dir")); + } + + /** + * 设置Java虚拟机 + */ + private void setJvmInfo() throws UnknownHostException + { + Properties props = System.getProperties(); + jvm.setTotal(Runtime.getRuntime().totalMemory()); + jvm.setMax(Runtime.getRuntime().maxMemory()); + jvm.setFree(Runtime.getRuntime().freeMemory()); + jvm.setVersion(props.getProperty("java.version")); + jvm.setHome(props.getProperty("java.home")); + } + + /** + * 设置磁盘信息 + */ + private void setSysFiles(OperatingSystem os) + { + FileSystem fileSystem = os.getFileSystem(); + List<OSFileStore> fsArray = fileSystem.getFileStores(); + for (OSFileStore fs : fsArray) + { + long free = fs.getUsableSpace(); + long total = fs.getTotalSpace(); + long used = total - free; + SysFile sysFile = new SysFile(); + sysFile.setDirName(fs.getMount()); + sysFile.setSysTypeName(fs.getType()); + sysFile.setTypeName(fs.getName()); + sysFile.setTotal(convertFileSize(total)); + sysFile.setFree(convertFileSize(free)); + sysFile.setUsed(convertFileSize(used)); + sysFile.setUsage(Arith.mul(Arith.div(used, total, 4), 100)); + sysFiles.add(sysFile); + } + } + + /** + * 字节转换 + * + * @param size 字节大小 + * @return 转换后值 + */ + public String convertFileSize(long size) + { + long kb = 1024; + long mb = kb * 1024; + long gb = mb * 1024; + if (size >= gb) + { + return String.format("%.1f GB", (float) size / gb); + } + else if (size >= mb) + { + float f = (float) size / mb; + return String.format(f > 100 ? "%.0f MB" : "%.1f MB", f); + } + else if (size >= kb) + { + float f = (float) size / kb; + return String.format(f > 100 ? "%.0f KB" : "%.1f KB", f); + } + else + { + return String.format("%d B", size); + } + } +} diff --git a/dc-framework/src/main/java/com/dc/framework/web/domain/server/Cpu.java b/dc-framework/src/main/java/com/dc/framework/web/domain/server/Cpu.java new file mode 100644 index 0000000..56856cf --- /dev/null +++ b/dc-framework/src/main/java/com/dc/framework/web/domain/server/Cpu.java @@ -0,0 +1,101 @@ +package com.dc.framework.web.domain.server; + +import com.dc.common.utils.Arith; + +/** + * CPU相关信息 + * + * @author win + */ +public class Cpu +{ + /** + * 核心数 + */ + private int cpuNum; + + /** + * CPU总的使用率 + */ + private double total; + + /** + * CPU系统使用率 + */ + private double sys; + + /** + * CPU用户使用率 + */ + private double used; + + /** + * CPU当前等待率 + */ + private double wait; + + /** + * CPU当前空闲率 + */ + private double free; + + public int getCpuNum() + { + return cpuNum; + } + + public void setCpuNum(int cpuNum) + { + this.cpuNum = cpuNum; + } + + public double getTotal() + { + return Arith.round(Arith.mul(total, 100), 2); + } + + public void setTotal(double total) + { + this.total = total; + } + + public double getSys() + { + return Arith.round(Arith.mul(sys / total, 100), 2); + } + + public void setSys(double sys) + { + this.sys = sys; + } + + public double getUsed() + { + return Arith.round(Arith.mul(used / total, 100), 2); + } + + public void setUsed(double used) + { + this.used = used; + } + + public double getWait() + { + return Arith.round(Arith.mul(wait / total, 100), 2); + } + + public void setWait(double wait) + { + this.wait = wait; + } + + public double getFree() + { + return Arith.round(Arith.mul(free / total, 100), 2); + } + + public void setFree(double free) + { + this.free = free; + } +} diff --git a/dc-framework/src/main/java/com/dc/framework/web/domain/server/Jvm.java b/dc-framework/src/main/java/com/dc/framework/web/domain/server/Jvm.java new file mode 100644 index 0000000..da892c9 --- /dev/null +++ b/dc-framework/src/main/java/com/dc/framework/web/domain/server/Jvm.java @@ -0,0 +1,131 @@ +package com.dc.framework.web.domain.server; + +import com.dc.common.utils.Arith; +import com.dc.common.utils.DateUtils; + +import java.lang.management.ManagementFactory; + +/** + * JVM相关信息 + * + * @author win + */ +public class Jvm +{ + /** + * 当前JVM占用的内存总数(M) + */ + private double total; + + /** + * JVM最大可用内存总数(M) + */ + private double max; + + /** + * JVM空闲内存(M) + */ + private double free; + + /** + * JDK版本 + */ + private String version; + + /** + * JDK路径 + */ + private String home; + + public double getTotal() + { + return Arith.div(total, (1024 * 1024), 2); + } + + public void setTotal(double total) + { + this.total = total; + } + + public double getMax() + { + return Arith.div(max, (1024 * 1024), 2); + } + + public void setMax(double max) + { + this.max = max; + } + + public double getFree() + { + return Arith.div(free, (1024 * 1024), 2); + } + + public void setFree(double free) + { + this.free = free; + } + + public double getUsed() + { + return Arith.div(total - free, (1024 * 1024), 2); + } + + public double getUsage() + { + return Arith.mul(Arith.div(total - free, total, 4), 100); + } + + /** + * 获取JDK名称 + */ + public String getName() + { + return ManagementFactory.getRuntimeMXBean().getVmName(); + } + + public String getVersion() + { + return version; + } + + public void setVersion(String version) + { + this.version = version; + } + + public String getHome() + { + return home; + } + + public void setHome(String home) + { + this.home = home; + } + + /** + * JDK启动时间 + */ + public String getStartTime() + { + return DateUtils.parseDateToStr(DateUtils.YYYY_MM_DD_HH_MM_SS, DateUtils.getServerStartDate()); + } + + /** + * JDK运行时间 + */ + public String getRunTime() + { + return DateUtils.getDatePoor(DateUtils.getNowDate(), DateUtils.getServerStartDate()); + } + + /** + * 运行参数 + */ + public String getInputArgs() + { + return ManagementFactory.getRuntimeMXBean().getInputArguments().toString(); + } +} diff --git a/dc-framework/src/main/java/com/dc/framework/web/domain/server/Mem.java b/dc-framework/src/main/java/com/dc/framework/web/domain/server/Mem.java new file mode 100644 index 0000000..dba47ff --- /dev/null +++ b/dc-framework/src/main/java/com/dc/framework/web/domain/server/Mem.java @@ -0,0 +1,61 @@ +package com.dc.framework.web.domain.server; + +import com.dc.common.utils.Arith; + +/** + * 內存相关信息 + * + * @author win + */ +public class Mem +{ + /** + * 内存总量 + */ + private double total; + + /** + * 已用内存 + */ + private double used; + + /** + * 剩余内存 + */ + private double free; + + public double getTotal() + { + return Arith.div(total, (1024 * 1024 * 1024), 2); + } + + public void setTotal(long total) + { + this.total = total; + } + + public double getUsed() + { + return Arith.div(used, (1024 * 1024 * 1024), 2); + } + + public void setUsed(long used) + { + this.used = used; + } + + public double getFree() + { + return Arith.div(free, (1024 * 1024 * 1024), 2); + } + + public void setFree(long free) + { + this.free = free; + } + + public double getUsage() + { + return Arith.mul(Arith.div(used, total, 4), 100); + } +} diff --git a/dc-framework/src/main/java/com/dc/framework/web/domain/server/Sys.java b/dc-framework/src/main/java/com/dc/framework/web/domain/server/Sys.java new file mode 100644 index 0000000..34a7fd1 --- /dev/null +++ b/dc-framework/src/main/java/com/dc/framework/web/domain/server/Sys.java @@ -0,0 +1,84 @@ +package com.dc.framework.web.domain.server; + +/** + * 系统相关信息 + * + * @author win + */ +public class Sys +{ + /** + * 服务器名称 + */ + private String computerName; + + /** + * 服务器Ip + */ + private String computerIp; + + /** + * 项目路径 + */ + private String userDir; + + /** + * 操作系统 + */ + private String osName; + + /** + * 系统架构 + */ + private String osArch; + + public String getComputerName() + { + return computerName; + } + + public void setComputerName(String computerName) + { + this.computerName = computerName; + } + + public String getComputerIp() + { + return computerIp; + } + + public void setComputerIp(String computerIp) + { + this.computerIp = computerIp; + } + + public String getUserDir() + { + return userDir; + } + + public void setUserDir(String userDir) + { + this.userDir = userDir; + } + + public String getOsName() + { + return osName; + } + + public void setOsName(String osName) + { + this.osName = osName; + } + + public String getOsArch() + { + return osArch; + } + + public void setOsArch(String osArch) + { + this.osArch = osArch; + } +} diff --git a/dc-framework/src/main/java/com/dc/framework/web/domain/server/SysFile.java b/dc-framework/src/main/java/com/dc/framework/web/domain/server/SysFile.java new file mode 100644 index 0000000..09dc549 --- /dev/null +++ b/dc-framework/src/main/java/com/dc/framework/web/domain/server/SysFile.java @@ -0,0 +1,114 @@ +package com.dc.framework.web.domain.server; + +/** + * 系统文件相关信息 + * + * @author win + */ +public class SysFile +{ + /** + * 盘符路径 + */ + private String dirName; + + /** + * 盘符类型 + */ + private String sysTypeName; + + /** + * 文件类型 + */ + private String typeName; + + /** + * 总大小 + */ + private String total; + + /** + * 剩余大小 + */ + private String free; + + /** + * 已经使用量 + */ + private String used; + + /** + * 资源的使用率 + */ + private double usage; + + public String getDirName() + { + return dirName; + } + + public void setDirName(String dirName) + { + this.dirName = dirName; + } + + public String getSysTypeName() + { + return sysTypeName; + } + + public void setSysTypeName(String sysTypeName) + { + this.sysTypeName = sysTypeName; + } + + public String getTypeName() + { + return typeName; + } + + public void setTypeName(String typeName) + { + this.typeName = typeName; + } + + public String getTotal() + { + return total; + } + + public void setTotal(String total) + { + this.total = total; + } + + public String getFree() + { + return free; + } + + public void setFree(String free) + { + this.free = free; + } + + public String getUsed() + { + return used; + } + + public void setUsed(String used) + { + this.used = used; + } + + public double getUsage() + { + return usage; + } + + public void setUsage(double usage) + { + this.usage = usage; + } +} diff --git a/dc-framework/src/main/java/com/dc/framework/web/exception/GlobalExceptionHandler.java b/dc-framework/src/main/java/com/dc/framework/web/exception/GlobalExceptionHandler.java new file mode 100644 index 0000000..eb3459b --- /dev/null +++ b/dc-framework/src/main/java/com/dc/framework/web/exception/GlobalExceptionHandler.java @@ -0,0 +1,127 @@ +package com.dc.framework.web.exception; + +import com.dc.common.constant.HttpStatus; +import com.dc.common.core.domain.AjaxResult; +import com.dc.common.exception.DatabaseException; +import com.dc.common.exception.DemoModeException; +import com.dc.common.exception.ServiceException; +import com.dc.common.utils.StringUtils; +import org.slf4j.Logger; +import org.slf4j.LoggerFactory; +import org.springframework.security.access.AccessDeniedException; +import org.springframework.validation.BindException; +import org.springframework.web.HttpRequestMethodNotSupportedException; +import org.springframework.web.bind.MethodArgumentNotValidException; +import org.springframework.web.bind.annotation.ExceptionHandler; +import org.springframework.web.bind.annotation.RestControllerAdvice; + +import javax.servlet.http.HttpServletRequest; + +/** + * 全局异常处理器 + * + * @author win + */ +@RestControllerAdvice +public class GlobalExceptionHandler +{ + private static final Logger log = LoggerFactory.getLogger(GlobalExceptionHandler.class); + + /** + * 权限校验异常 + */ + @ExceptionHandler(AccessDeniedException.class) + public AjaxResult handleAccessDeniedException(AccessDeniedException e, HttpServletRequest request) + { + String requestURI = request.getRequestURI(); + log.error("请求地址'{}',权限校验失败'{}'", requestURI, e.getMessage()); + return AjaxResult.error(HttpStatus.FORBIDDEN, "没有权限,请联系管理员授权"); + } + + /** + * 请求方式不支持 + */ + @ExceptionHandler(HttpRequestMethodNotSupportedException.class) + public AjaxResult handleHttpRequestMethodNotSupported(HttpRequestMethodNotSupportedException e, + HttpServletRequest request) + { + String requestURI = request.getRequestURI(); + log.error("请求地址'{}',不支持'{}'请求", requestURI, e.getMethod()); + return AjaxResult.error(e.getMessage()); + } + + /** + * 业务异常 + */ + @ExceptionHandler(ServiceException.class) + public AjaxResult handleServiceException(ServiceException e, HttpServletRequest request) + { + log.error(e.getMessage(), e); + Integer code = e.getCode(); + return StringUtils.isNotNull(code) ? AjaxResult.error(code, e.getMessage()) : AjaxResult.error(e.getMessage()); + } + + /** + * 业务异常 + */ + @ExceptionHandler(DatabaseException.class) + public AjaxResult handleDatabaseException(DatabaseException e, HttpServletRequest request) + { + log.error(e.getMessage(), e); + Integer code = e.getCode(); + return StringUtils.isNotNull(code) ? AjaxResult.error(code, e.getMessage()) : AjaxResult.error(e.getMessage()); + } + + /** + * 拦截未知的运行时异常 + */ + @ExceptionHandler(RuntimeException.class) + public AjaxResult handleRuntimeException(RuntimeException e, HttpServletRequest request) + { + String requestURI = request.getRequestURI(); + log.error("请求地址'{}',发生未知异常.", requestURI, e); + return AjaxResult.error(e.getMessage()); + } + + /** + * 系统异常 + */ + @ExceptionHandler(Exception.class) + public AjaxResult handleException(Exception e, HttpServletRequest request) + { + String requestURI = request.getRequestURI(); + log.error("请求地址'{}',发生系统异常.", requestURI, e); + return AjaxResult.error(e.getMessage()); + } + + /** + * 自定义验证异常 + */ + @ExceptionHandler(BindException.class) + public AjaxResult handleBindException(BindException e) + { + log.error(e.getMessage(), e); + String message = e.getAllErrors().get(0).getDefaultMessage(); + return AjaxResult.error(message); + } + + /** + * 自定义验证异常 + */ + @ExceptionHandler(MethodArgumentNotValidException.class) + public Object handleMethodArgumentNotValidException(MethodArgumentNotValidException e) + { + log.error(e.getMessage(), e); + String message = e.getBindingResult().getFieldError().getDefaultMessage(); + return AjaxResult.error(message); + } + + /** + * 演示模式异常 + */ + @ExceptionHandler(DemoModeException.class) + public AjaxResult handleDemoModeException(DemoModeException e) + { + return AjaxResult.error("演示模式,不允许操作"); + } +} diff --git a/dc-framework/src/main/java/com/dc/framework/web/service/PermissionService.java b/dc-framework/src/main/java/com/dc/framework/web/service/PermissionService.java new file mode 100644 index 0000000..d71dc43 --- /dev/null +++ b/dc-framework/src/main/java/com/dc/framework/web/service/PermissionService.java @@ -0,0 +1,169 @@ +package com.dc.framework.web.service; + +import com.dc.common.core.domain.entity.SysRole; +import com.dc.common.core.domain.model.LoginUser; +import com.dc.common.utils.SecurityUtils; +import com.dc.common.utils.StringUtils; +import com.dc.framework.security.context.PermissionContextHolder; +import org.springframework.stereotype.Service; +import org.springframework.util.CollectionUtils; + +import java.util.Set; + +/** + * Win首创 自定义权限实现,ss取自SpringSecurity首字母 + * + * @author win + */ +@Service("ss") +public class PermissionService +{ + /** 所有权限标识 */ + private static final String ALL_PERMISSION = "*:*:*"; + + /** 管理员角色权限标识 */ + private static final String SUPER_ADMIN = "admin"; + + private static final String ROLE_DELIMETER = ","; + + private static final String PERMISSION_DELIMETER = ","; + + /** + * 验证用户是否具备某权限 + * + * @param permission 权限字符串 + * @return 用户是否具备某权限 + */ + public boolean hasPermi(String permission) + { + if (StringUtils.isEmpty(permission)) + { + return false; + } + LoginUser loginUser = SecurityUtils.getLoginUser(); + if (StringUtils.isNull(loginUser) || CollectionUtils.isEmpty(loginUser.getPermissions())) + { + return false; + } + PermissionContextHolder.setContext(permission); + return hasPermissions(loginUser.getPermissions(), permission); + } + + /** + * 验证用户是否不具备某权限,与 hasPermi逻辑相反 + * + * @param permission 权限字符串 + * @return 用户是否不具备某权限 + */ + public boolean lacksPermi(String permission) + { + return hasPermi(permission) != true; + } + + /** + * 验证用户是否具有以下任意一个权限 + * + * @param permissions 以 PERMISSION_NAMES_DELIMETER 为分隔符的权限列表 + * @return 用户是否具有以下任意一个权限 + */ + public boolean hasAnyPermi(String permissions) + { + if (StringUtils.isEmpty(permissions)) + { + return false; + } + LoginUser loginUser = SecurityUtils.getLoginUser(); + if (StringUtils.isNull(loginUser) || CollectionUtils.isEmpty(loginUser.getPermissions())) + { + return false; + } + PermissionContextHolder.setContext(permissions); + Set<String> authorities = loginUser.getPermissions(); + for (String permission : permissions.split(PERMISSION_DELIMETER)) + { + if (permission != null && hasPermissions(authorities, permission)) + { + return true; + } + } + return false; + } + + /** + * 判断用户是否拥有某个角色 + * + * @param role 角色字符串 + * @return 用户是否具备某角色 + */ + public boolean hasRole(String role) + { + if (StringUtils.isEmpty(role)) + { + return false; + } + LoginUser loginUser = SecurityUtils.getLoginUser(); + if (StringUtils.isNull(loginUser) || CollectionUtils.isEmpty(loginUser.getUser().getRoles())) + { + return false; + } + for (SysRole sysRole : loginUser.getUser().getRoles()) + { + String roleKey = sysRole.getRoleKey(); + if (SUPER_ADMIN.equals(roleKey) || roleKey.equals(StringUtils.trim(role))) + { + return true; + } + } + return false; + } + + /** + * 验证用户是否不具备某角色,与 isRole逻辑相反。 + * + * @param role 角色名称 + * @return 用户是否不具备某角色 + */ + public boolean lacksRole(String role) + { + return hasRole(role) != true; + } + + /** + * 验证用户是否具有以下任意一个角色 + * + * @param roles 以 ROLE_NAMES_DELIMETER 为分隔符的角色列表 + * @return 用户是否具有以下任意一个角色 + */ + public boolean hasAnyRoles(String roles) + { + if (StringUtils.isEmpty(roles)) + { + return false; + } + LoginUser loginUser = SecurityUtils.getLoginUser(); + if (StringUtils.isNull(loginUser) || CollectionUtils.isEmpty(loginUser.getUser().getRoles())) + { + return false; + } + for (String role : roles.split(ROLE_DELIMETER)) + { + if (hasRole(role)) + { + return true; + } + } + return false; + } + + /** + * 判断是否包含权限 + * + * @param permissions 权限列表 + * @param permission 权限字符串 + * @return 用户是否具备某权限 + */ + private boolean hasPermissions(Set<String> permissions, String permission) + { + return permissions.contains(ALL_PERMISSION) || permissions.contains(StringUtils.trim(permission)); + } +} diff --git a/dc-framework/src/main/java/com/dc/framework/web/service/SysLoginService.java b/dc-framework/src/main/java/com/dc/framework/web/service/SysLoginService.java new file mode 100644 index 0000000..c914a92 --- /dev/null +++ b/dc-framework/src/main/java/com/dc/framework/web/service/SysLoginService.java @@ -0,0 +1,160 @@ +package com.dc.framework.web.service; + +import com.dc.common.constant.CacheConstants; +import com.dc.common.constant.Constants; +import com.dc.common.core.domain.entity.SysUser; +import com.dc.common.core.domain.model.LoginUser; +import com.dc.common.core.redis.RedisCache; +import com.dc.common.exception.ServiceException; +import com.dc.common.exception.user.CaptchaException; +import com.dc.common.exception.user.CaptchaExpireException; +import com.dc.common.exception.user.UserPasswordNotMatchException; +import com.dc.common.utils.DateUtils; +import com.dc.common.utils.MessageUtils; +import com.dc.common.utils.ServletUtils; +import com.dc.common.utils.StringUtils; +import com.dc.common.utils.ip.IpUtils; +import com.dc.framework.manager.AsyncManager; +import com.dc.framework.manager.factory.AsyncFactory; +import com.dc.framework.security.context.AuthenticationContextHolder; +import com.dc.system.service.SysConfigService; +import com.dc.system.service.SysUserService; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.beans.factory.annotation.Value; +import org.springframework.security.authentication.AuthenticationManager; +import org.springframework.security.authentication.BadCredentialsException; +import org.springframework.security.authentication.UsernamePasswordAuthenticationToken; +import org.springframework.security.core.Authentication; +import org.springframework.stereotype.Component; + +import javax.annotation.Resource; + +/** + * 登录校验方法 + * + * @author ruoyi + */ +@Component +public class SysLoginService +{ + @Autowired + private TokenService tokenService; + + @Resource + private AuthenticationManager authenticationManager; + + @Autowired + private RedisCache redisCache; + + @Autowired + private SysUserService userService; + + @Autowired + private SysConfigService configService; + + // 是否允许账户多终端同时登录(true允许 false不允许) + @Value("${token.soloLogin}") + private boolean soloLogin; + + /** + * 登录验证 + * + * @param username 用户名 + * @param password 密码 + * @param code 验证码 + * @param uuid 唯一标识 + * @return 结果 + */ + public String login(String username, String password, String code, String uuid) + { + boolean captchaEnabled = configService.selectCaptchaEnabled(); + // 验证码开关 + if (captchaEnabled) + { + validateCaptcha(username, code, uuid); + } + // 用户验证 + Authentication authentication = null; + try + { + UsernamePasswordAuthenticationToken authenticationToken = new UsernamePasswordAuthenticationToken(username, password); + AuthenticationContextHolder.setContext(authenticationToken); + // 该方法会去调用UserDetailsServiceImpl.loadUserByUsername + authentication = authenticationManager.authenticate(authenticationToken); + } + catch (Exception e) + { + if (e instanceof BadCredentialsException) + { + AsyncManager.me().execute(AsyncFactory.recordLogininfor(username, Constants.LOGIN_FAIL, MessageUtils.message("user.password.not.match"))); + throw new UserPasswordNotMatchException(); + } + else + { + AsyncManager.me().execute(AsyncFactory.recordLogininfor(username, Constants.LOGIN_FAIL, e.getMessage())); + throw new ServiceException(e.getMessage()); + } + } + finally + { + AuthenticationContextHolder.clearContext(); + } + AsyncManager.me().execute(AsyncFactory.recordLogininfor(username, Constants.LOGIN_SUCCESS, MessageUtils.message("user.login.success"))); + LoginUser loginUser = (LoginUser) authentication.getPrincipal(); + recordLoginInfo(loginUser.getUserId()); + // 添加到这里 + // 判断是否允许账户多终端同时登录 + if (!soloLogin) + { + // 如果用户不允许多终端同时登录,清除缓存信息 + String userIdKey = Constants.LOGIN_USERID_KEY + loginUser.getUser().getUserId(); + String userKey = redisCache.getCacheObject(userIdKey); + if (StringUtils.isNotEmpty(userKey)) + { + redisCache.deleteObject(userIdKey); + redisCache.deleteObject(userKey); + } + } + // 生成token + return tokenService.createToken(loginUser); + } + + /** + * 校验验证码 + * + * @param username 用户名 + * @param code 验证码 + * @param uuid 唯一标识 + * @return 结果 + */ + public void validateCaptcha(String username, String code, String uuid) + { + String verifyKey = CacheConstants.CAPTCHA_CODE_KEY + StringUtils.nvl(uuid, ""); + String captcha = redisCache.getCacheObject(verifyKey); + redisCache.deleteObject(verifyKey); + if (captcha == null) + { + AsyncManager.me().execute(AsyncFactory.recordLogininfor(username, Constants.LOGIN_FAIL, MessageUtils.message("user.jcaptcha.expire"))); + throw new CaptchaExpireException(); + } + if (!code.equalsIgnoreCase(captcha)) + { + AsyncManager.me().execute(AsyncFactory.recordLogininfor(username, Constants.LOGIN_FAIL, MessageUtils.message("user.jcaptcha.error"))); + throw new CaptchaException(); + } + } + + /** + * 记录登录信息 + * + * @param userId 用户ID + */ + public void recordLoginInfo(Long userId) + { + SysUser sysUser = new SysUser(); + sysUser.setUserId(userId); + sysUser.setLoginIp(IpUtils.getIpAddr(ServletUtils.getRequest())); + sysUser.setLoginDate(DateUtils.getNowDate()); + userService.updateUserProfile(sysUser); + } +} diff --git a/dc-framework/src/main/java/com/dc/framework/web/service/SysPasswordService.java b/dc-framework/src/main/java/com/dc/framework/web/service/SysPasswordService.java new file mode 100644 index 0000000..1b25853 --- /dev/null +++ b/dc-framework/src/main/java/com/dc/framework/web/service/SysPasswordService.java @@ -0,0 +1,95 @@ +package com.dc.framework.web.service; + +import com.dc.common.constant.CacheConstants; +import com.dc.common.constant.Constants; +import com.dc.common.core.domain.entity.SysUser; +import com.dc.common.core.redis.RedisCache; +import com.dc.common.exception.user.UserPasswordNotMatchException; +import com.dc.common.exception.user.UserPasswordRetryLimitExceedException; +import com.dc.common.utils.MessageUtils; +import com.dc.common.utils.SecurityUtils; +import com.dc.framework.manager.AsyncManager; +import com.dc.framework.manager.factory.AsyncFactory; +import com.dc.framework.security.context.AuthenticationContextHolder; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.beans.factory.annotation.Value; +import org.springframework.security.core.Authentication; +import org.springframework.stereotype.Component; + +import java.util.concurrent.TimeUnit; + +/** + * 登录密码方法 + * + * @author win + */ +@Component +public class SysPasswordService +{ + @Autowired + private RedisCache redisCache; + + @Value(value = "${user.password.maxRetryCount}") + private int maxRetryCount; + + @Value(value = "${user.password.lockTime}") + private int lockTime; + + /** + * 登录账户密码错误次数缓存键名 + * + * @param username 用户名 + * @return 缓存键key + */ + private String getCacheKey(String username) + { + return CacheConstants.PWD_ERR_CNT_KEY + username; + } + + public void validate(SysUser user) + { + Authentication usernamePasswordAuthenticationToken = AuthenticationContextHolder.getContext(); + String username = usernamePasswordAuthenticationToken.getName(); + String password = usernamePasswordAuthenticationToken.getCredentials().toString(); + + Integer retryCount = redisCache.getCacheObject(getCacheKey(username)); + + if (retryCount == null) + { + retryCount = 0; + } + + if (retryCount >= Integer.valueOf(maxRetryCount).intValue()) + { + AsyncManager.me().execute(AsyncFactory.recordLogininfor(username, Constants.LOGIN_FAIL, + MessageUtils.message("user.password.retry.limit.exceed", maxRetryCount, lockTime))); + throw new UserPasswordRetryLimitExceedException(maxRetryCount, lockTime); + } + + if (!matches(user, password)) + { + retryCount = retryCount + 1; + AsyncManager.me().execute(AsyncFactory.recordLogininfor(username, Constants.LOGIN_FAIL, + MessageUtils.message("user.password.retry.limit.count", retryCount))); + redisCache.setCacheObject(getCacheKey(username), retryCount, lockTime, TimeUnit.MINUTES); + throw new UserPasswordNotMatchException(); + } + else + { + clearLoginRecordCache(username); + } + } + + public boolean matches(SysUser user, String rawPassword) + { + return SecurityUtils.matchesPassword(rawPassword, user.getPassword()); + } + + public void clearLoginRecordCache(String loginName) + { + if (redisCache.hasKey(getCacheKey(loginName))) + { + redisCache.deleteObject(getCacheKey(loginName)); + } + } +} diff --git a/dc-framework/src/main/java/com/dc/framework/web/service/SysPermissionService.java b/dc-framework/src/main/java/com/dc/framework/web/service/SysPermissionService.java new file mode 100644 index 0000000..757b707 --- /dev/null +++ b/dc-framework/src/main/java/com/dc/framework/web/service/SysPermissionService.java @@ -0,0 +1,83 @@ +package com.dc.framework.web.service; + +import com.dc.common.core.domain.entity.SysRole; +import com.dc.common.core.domain.entity.SysUser; +import com.dc.system.service.SysMenuService; +import com.dc.system.service.SysRoleService; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.stereotype.Component; + +import java.util.HashSet; +import java.util.List; +import java.util.Set; + +/** + * 用户权限处理 + * + * @author win + */ +@Component +public class SysPermissionService +{ + @Autowired + private SysRoleService roleService; + + @Autowired + private SysMenuService menuService; + + /** + * 获取角色数据权限 + * + * @param user 用户信息 + * @return 角色权限信息 + */ + public Set<String> getRolePermission(SysUser user) + { + Set<String> roles = new HashSet<String>(); + // 管理员拥有所有权限 + if (user.isAdmin()) + { + roles.add("admin"); + } + else + { + roles.addAll(roleService.selectRolePermissionByUserId(user.getUserId())); + } + return roles; + } + + /** + * 获取菜单数据权限 + * + * @param user 用户信息 + * @return 菜单权限信息 + */ + public Set<String> getMenuPermission(SysUser user) + { + Set<String> perms = new HashSet<String>(); + // 管理员拥有所有权限 + if (user.isAdmin()) + { + perms.add("*:*:*"); + } + else + { + List<SysRole> roles = user.getRoles(); + if (!roles.isEmpty() && roles.size() > 1) + { + // 多角色设置permissions属性,以便数据权限匹配权限 + for (SysRole role : roles) + { + Set<String> rolePerms = menuService.selectMenuPermsByRoleId(role.getRoleId()); + role.setPermissions(rolePerms); + perms.addAll(rolePerms); + } + } + else + { + perms.addAll(menuService.selectMenuPermsByUserId(user.getUserId())); + } + } + return perms; + } +} diff --git a/dc-framework/src/main/java/com/dc/framework/web/service/SysRegisterService.java b/dc-framework/src/main/java/com/dc/framework/web/service/SysRegisterService.java new file mode 100644 index 0000000..7c1738a --- /dev/null +++ b/dc-framework/src/main/java/com/dc/framework/web/service/SysRegisterService.java @@ -0,0 +1,115 @@ +package com.dc.framework.web.service; + +import com.dc.framework.manager.AsyncManager; +import com.dc.framework.manager.factory.AsyncFactory; +import com.dc.system.service.SysConfigService; +import com.dc.system.service.SysUserService; +import com.dc.common.constant.CacheConstants; +import com.dc.common.constant.Constants; +import com.dc.common.core.domain.model.RegisterBody; +import com.dc.common.core.redis.RedisCache; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.stereotype.Component; +import com.dc.common.constant.UserConstants; +import com.dc.common.core.domain.entity.SysUser; +import com.dc.common.exception.user.CaptchaException; +import com.dc.common.exception.user.CaptchaExpireException; +import com.dc.common.utils.MessageUtils; +import com.dc.common.utils.SecurityUtils; +import com.dc.common.utils.StringUtils; + +/** + * 注册校验方法 + * + * @author win + */ +@Component +public class SysRegisterService +{ + @Autowired + private SysUserService userService; + + @Autowired + private SysConfigService configService; + + @Autowired + private RedisCache redisCache; + + /** + * 注册 + */ + public String register(RegisterBody registerBody) + { + String msg = "", username = registerBody.getUsername(), password = registerBody.getPassword(); + SysUser sysUser = new SysUser(); + sysUser.setUserName(username); + + // 验证码开关 + boolean captchaEnabled = configService.selectCaptchaEnabled(); + if (captchaEnabled) + { + validateCaptcha(username, registerBody.getCode(), registerBody.getUuid()); + } + + if (StringUtils.isEmpty(username)) + { + msg = "用户名不能为空"; + } + else if (StringUtils.isEmpty(password)) + { + msg = "用户密码不能为空"; + } + else if (username.length() < UserConstants.USERNAME_MIN_LENGTH + || username.length() > UserConstants.USERNAME_MAX_LENGTH) + { + msg = "账户长度必须在2到20个字符之间"; + } + else if (password.length() < UserConstants.PASSWORD_MIN_LENGTH + || password.length() > UserConstants.PASSWORD_MAX_LENGTH) + { + msg = "密码长度必须在5到20个字符之间"; + } + else if (UserConstants.NOT_UNIQUE.equals(userService.checkUserNameUnique(sysUser))) + { + msg = "保存用户'" + username + "'失败,注册账号已存在"; + } + else + { + sysUser.setNickName(username); + sysUser.setPassword(SecurityUtils.encryptPassword(password)); + boolean regFlag = userService.registerUser(sysUser); + if (!regFlag) + { + msg = "注册失败,请联系系统管理人员"; + } + else + { + AsyncManager.me().execute(AsyncFactory.recordLogininfor(username, Constants.REGISTER, MessageUtils.message("user.register.success"))); + } + } + return msg; + } + + /** + * 校验验证码 + * + * @param username 用户名 + * @param code 验证码 + * @param uuid 唯一标识 + * @return 结果 + */ + public void validateCaptcha(String username, String code, String uuid) + { + String verifyKey = CacheConstants.CAPTCHA_CODE_KEY + StringUtils.nvl(uuid, ""); + String captcha = redisCache.getCacheObject(verifyKey); + redisCache.deleteObject(verifyKey); + if (captcha == null) + { + throw new CaptchaExpireException(); + } + if (!code.equalsIgnoreCase(captcha)) + { + throw new CaptchaException(); + } + } +} diff --git a/dc-framework/src/main/java/com/dc/framework/web/service/TokenService.java b/dc-framework/src/main/java/com/dc/framework/web/service/TokenService.java new file mode 100644 index 0000000..c1c0344 --- /dev/null +++ b/dc-framework/src/main/java/com/dc/framework/web/service/TokenService.java @@ -0,0 +1,263 @@ +package com.dc.framework.web.service; + +import com.dc.common.constant.CacheConstants; +import com.dc.common.constant.Constants; +import com.dc.common.core.domain.model.LoginUser; +import com.dc.common.core.redis.RedisCache; +import com.dc.common.utils.ServletUtils; +import com.dc.common.utils.StringUtils; +import com.dc.common.utils.ip.AddressUtils; +import com.dc.common.utils.ip.IpUtils; +import com.dc.common.utils.uuid.IdUtils; +import eu.bitwalker.useragentutils.UserAgent; +import io.jsonwebtoken.Claims; +import io.jsonwebtoken.Jwts; +import io.jsonwebtoken.SignatureAlgorithm; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.beans.factory.annotation.Value; +import org.springframework.stereotype.Component; + +import javax.servlet.http.HttpServletRequest; +import java.util.HashMap; +import java.util.Map; +import java.util.concurrent.TimeUnit; + +/** + * token验证处理 + * + * @author win + */ +@Component +public class TokenService +{ + // 令牌自定义标识 + @Value("${token.header}") + private String header; + + // 令牌秘钥 + @Value("${token.secret}") + private String secret; + + // 令牌有效期(默认30分钟) + @Value("${token.expireTime}") + private int expireTime; + + // 是否允许账户多终端同时登录(true允许 false不允许) + @Value("${token.soloLogin}") + private boolean soloLogin; + + protected static final long MILLIS_SECOND = 1000; + + protected static final long MILLIS_MINUTE = 60 * MILLIS_SECOND; + + private static final Long MILLIS_MINUTE_TEN = 20 * 60 * 1000L; + + @Autowired + private RedisCache redisCache; + + /** + * 获取用户身份信息 + * + * @return 用户信息 + */ + public LoginUser getLoginUser(HttpServletRequest request) + { + // 获取请求携带的令牌 + String token = getToken(request); + if (StringUtils.isNotEmpty(token)) + { + try + { + Claims claims = parseToken(token); + // 解析对应的权限以及用户信息 + String uuid = (String) claims.get(Constants.LOGIN_USER_KEY); + String userKey = getTokenKey(uuid); + LoginUser user = redisCache.getCacheObject(userKey); + return user; + } + catch (Exception e) + { + } + } + return null; + } + + /** + * 设置用户身份信息 + */ + public void setLoginUser(LoginUser loginUser) + { + if (StringUtils.isNotNull(loginUser) && StringUtils.isNotEmpty(loginUser.getToken())) + { + refreshToken(loginUser); + } + } + + /** + * 删除用户身份信息 + */ + public void delLoginUser(String token) + { + if (StringUtils.isNotEmpty(token)) + { + String userKey = getTokenKey(token); + redisCache.deleteObject(userKey); + } + } + + /** + * 创建令牌 + * + * @param loginUser 用户信息 + * @return 令牌 + */ + public String createToken(LoginUser loginUser) + { + String token = IdUtils.fastUUID(); + loginUser.setToken(token); + setUserAgent(loginUser); + refreshToken(loginUser); + + Map<String, Object> claims = new HashMap<>(); + claims.put(Constants.LOGIN_USER_KEY, token); + return createToken(claims); + } + + /** + * 验证令牌有效期,相差不足20分钟,自动刷新缓存 + * + * @param loginUser + * @return 令牌 + */ + public void verifyToken(LoginUser loginUser) + { + long expireTime = loginUser.getExpireTime(); + long currentTime = System.currentTimeMillis(); + if (expireTime - currentTime <= MILLIS_MINUTE_TEN) + { + refreshToken(loginUser); + } + } + + /** + * 设置用户代理信息 + * + * @param loginUser 登录信息 + */ + public void setUserAgent(LoginUser loginUser) + { + UserAgent userAgent = UserAgent.parseUserAgentString(ServletUtils.getRequest().getHeader("User-Agent")); + String ip = IpUtils.getIpAddr(ServletUtils.getRequest()); + loginUser.setIpaddr(ip); + loginUser.setLoginLocation(AddressUtils.getRealAddressByIP(ip)); + loginUser.setBrowser(userAgent.getBrowser().getName()); + loginUser.setOs(userAgent.getOperatingSystem().getName()); + } + + /** + * 从数据声明生成令牌 + * + * @param claims 数据声明 + * @return 令牌 + */ + private String createToken(Map<String, Object> claims) + { + String token = Jwts.builder() + .setClaims(claims) + .signWith(SignatureAlgorithm.HS512, secret).compact(); + return token; + } + + /** + * 从令牌中获取数据声明 + * + * @param token 令牌 + * @return 数据声明 + */ + private Claims parseToken(String token) + { + return Jwts.parser() + .setSigningKey(secret) + .parseClaimsJws(token) + .getBody(); + } + + /** + * 从令牌中获取用户名 + * + * @param token 令牌 + * @return 用户名 + */ + public String getUsernameFromToken(String token) + { + Claims claims = parseToken(token); + return claims.getSubject(); + } + + /** + * 获取请求token + * + * @param request + * @return token + */ + private String getToken(HttpServletRequest request) + { + String token = request.getHeader(header); + if (StringUtils.isNotEmpty(token) && token.startsWith(Constants.TOKEN_PREFIX)) + { + token = token.replace(Constants.TOKEN_PREFIX, ""); + } + return token; + } + + private String getTokenKey(String uuid) + { + return CacheConstants.LOGIN_TOKEN_KEY + uuid; + } + + /** + * 删除用户身份信息 + */ + public void delLoginUser(String token, Long userId) + { + if (StringUtils.isNotEmpty(token)) + { + String userKey = getTokenKey(token); + redisCache.deleteObject(userKey); + } + //在原有代码上添加下面的代码 + if (!soloLogin && StringUtils.isNotNull(userId)) + { + String userIdKey = getUserIdKey(userId); + redisCache.deleteObject(userIdKey); + } + } + + /** + * 刷新令牌有效期 + * + * @param loginUser 登录信息 + */ + public void refreshToken(LoginUser loginUser) + { + loginUser.setLoginTime(System.currentTimeMillis()); + loginUser.setExpireTime(loginUser.getLoginTime() + expireTime * MILLIS_MINUTE); + // 根据uuid将loginUser缓存 + String userKey = getTokenKey(loginUser.getToken()); + redisCache.setCacheObject(userKey, loginUser, expireTime, TimeUnit.MINUTES); + //在原有代码上添加下面的代码 + if (!soloLogin) + { + // 缓存用户唯一标识,防止同一帐号,同时登录 + String userIdKey = getUserIdKey(loginUser.getUser().getUserId()); + redisCache.setCacheObject(userIdKey, userKey, expireTime, TimeUnit.MINUTES); + } + } + + //添加下面的代码 + private String getUserIdKey(Long userId) + { + return Constants.LOGIN_USERID_KEY + userId; + } + +} diff --git a/dc-framework/src/main/java/com/dc/framework/web/service/UserDetailsServiceImpl.java b/dc-framework/src/main/java/com/dc/framework/web/service/UserDetailsServiceImpl.java new file mode 100644 index 0000000..8a60886 --- /dev/null +++ b/dc-framework/src/main/java/com/dc/framework/web/service/UserDetailsServiceImpl.java @@ -0,0 +1,65 @@ +package com.dc.framework.web.service; + +import com.dc.system.service.SysUserService; +import com.dc.common.core.domain.model.LoginUser; +import com.dc.common.exception.ServiceException; +import org.slf4j.Logger; +import org.slf4j.LoggerFactory; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.security.core.userdetails.UserDetails; +import org.springframework.security.core.userdetails.UserDetailsService; +import org.springframework.security.core.userdetails.UsernameNotFoundException; +import org.springframework.stereotype.Service; +import com.dc.common.core.domain.entity.SysUser; +import com.dc.common.enums.UserStatus; +import com.dc.common.utils.StringUtils; + +/** + * 用户验证处理 + * + * @author ruoyi + */ +@Service +public class UserDetailsServiceImpl implements UserDetailsService +{ + private static final Logger log = LoggerFactory.getLogger(UserDetailsServiceImpl.class); + + @Autowired + private SysUserService userService; + + @Autowired + private SysPasswordService passwordService; + + @Autowired + private SysPermissionService permissionService; + + @Override + public UserDetails loadUserByUsername(String username) throws UsernameNotFoundException + { + SysUser user = userService.selectUserByUserName(username); + if (StringUtils.isNull(user)) + { + log.info("登录用户:{} 不存在.", username); + throw new ServiceException("登录用户:" + username + " 不存在"); + } + else if (UserStatus.DELETED.getCode().equals(user.getDelFlag())) + { + log.info("登录用户:{} 已被删除.", username); + throw new ServiceException("对不起,您的账号:" + username + " 已被删除"); + } + else if (UserStatus.DISABLE.getCode().equals(user.getStatus())) + { + log.info("登录用户:{} 已被停用.", username); + throw new ServiceException("对不起,您的账号:" + username + " 已停用"); + } + + passwordService.validate(user); + + return createLoginUser(user); + } + + public UserDetails createLoginUser(SysUser user) + { + return new LoginUser(user.getUserId(), user.getDeptId(), user, permissionService.getMenuPermission(user)); + } +} diff --git a/dc-generator/pom.xml b/dc-generator/pom.xml new file mode 100644 index 0000000..ebdddab --- /dev/null +++ b/dc-generator/pom.xml @@ -0,0 +1,40 @@ +<?xml version="1.0" encoding="UTF-8"?> +<project xmlns="http://maven.apache.org/POM/4.0.0" + xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" + xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> + <parent> + <artifactId>dc</artifactId> + <groupId>com.dc</groupId> + <version>1.0.0</version> + </parent> + <modelVersion>4.0.0</modelVersion> + + <artifactId>dc-generator</artifactId> + + <description> + generator代码生成 + </description> + + <dependencies> + + <!--velocity代码生成使用模板 --> + <dependency> + <groupId>org.apache.velocity</groupId> + <artifactId>velocity-engine-core</artifactId> + </dependency> + + <!-- collections工具类 --> + <dependency> + <groupId>commons-collections</groupId> + <artifactId>commons-collections</artifactId> + </dependency> + + <!-- 通用工具--> + <dependency> + <groupId>com.dc</groupId> + <artifactId>dc-common</artifactId> + </dependency> + + </dependencies> + +</project> \ No newline at end of file diff --git a/dc-generator/src/main/java/com/dc/generator/config/GenConfig.java b/dc-generator/src/main/java/com/dc/generator/config/GenConfig.java new file mode 100644 index 0000000..36fe099 --- /dev/null +++ b/dc-generator/src/main/java/com/dc/generator/config/GenConfig.java @@ -0,0 +1,73 @@ +package com.dc.generator.config; + +import org.springframework.beans.factory.annotation.Value; +import org.springframework.boot.context.properties.ConfigurationProperties; +import org.springframework.context.annotation.PropertySource; +import org.springframework.stereotype.Component; + +/** + * 读取代码生成相关配置 + * + * @author win + */ +@Component +@ConfigurationProperties(prefix = "gen") +@PropertySource(value = { "classpath:generator.yml" }) +public class GenConfig +{ + /** 作者 */ + public static String author; + + /** 生成包路径 */ + public static String packageName; + + /** 自动去除表前缀,默认是false */ + public static boolean autoRemovePre; + + /** 表前缀(类名不会包含表前缀) */ + public static String tablePrefix; + + public static String getAuthor() + { + return author; + } + + @Value("${author}") + public void setAuthor(String author) + { + GenConfig.author = author; + } + + public static String getPackageName() + { + return packageName; + } + + @Value("${packageName}") + public void setPackageName(String packageName) + { + GenConfig.packageName = packageName; + } + + public static boolean getAutoRemovePre() + { + return autoRemovePre; + } + + @Value("${autoRemovePre}") + public void setAutoRemovePre(boolean autoRemovePre) + { + GenConfig.autoRemovePre = autoRemovePre; + } + + public static String getTablePrefix() + { + return tablePrefix; + } + + @Value("${tablePrefix}") + public void setTablePrefix(String tablePrefix) + { + GenConfig.tablePrefix = tablePrefix; + } +} diff --git a/dc-generator/src/main/java/com/dc/generator/controller/GenController.java b/dc-generator/src/main/java/com/dc/generator/controller/GenController.java new file mode 100644 index 0000000..837f6d1 --- /dev/null +++ b/dc-generator/src/main/java/com/dc/generator/controller/GenController.java @@ -0,0 +1,208 @@ +package com.dc.generator.controller; + +import com.dc.common.core.controller.BaseController; +import com.dc.common.core.domain.AjaxResult; +import com.dc.common.core.page.TableDataInfo; +import com.dc.common.core.text.Convert; +import com.dc.common.enums.BusinessType; +import com.dc.generator.domain.GenTable; +import com.dc.generator.domain.GenTableColumn; +import com.dc.common.annotation.Log; +import com.dc.generator.service.GenTableColumnService; +import com.dc.generator.service.GenTableService; +import org.apache.commons.io.IOUtils; +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; +import java.io.IOException; +import java.util.HashMap; +import java.util.List; +import java.util.Map; + +/** + * 代码生成 操作处理 + * + * @author win + */ +@RestController +@RequestMapping("/tool/gen") +public class GenController extends BaseController +{ + @Autowired + private GenTableService genTableService; + + @Autowired + private GenTableColumnService genTableColumnService; + + /** + * 查询代码生成列表 + */ + @PreAuthorize("@ss.hasPermi('tool:gen:list')") + @GetMapping("/list") + public TableDataInfo genList(GenTable genTable) + { + startPage(); + List<GenTable> list = genTableService.selectGenTableList(genTable); + return getDataTable(list); + } + + /** + * 修改代码生成业务 + */ + @PreAuthorize("@ss.hasPermi('tool:gen:query')") + @GetMapping(value = "/{tableId}") + public AjaxResult getInfo(@PathVariable Long tableId) + { + GenTable table = genTableService.selectGenTableById(tableId); + List<GenTable> tables = genTableService.selectGenTableAll(); + List<GenTableColumn> list = genTableColumnService.selectGenTableColumnListByTableId(tableId); + Map<String, Object> map = new HashMap<String, Object>(); + map.put("info", table); + map.put("rows", list); + map.put("tables", tables); + return success(map); + } + + /** + * 查询数据库列表 + */ + @PreAuthorize("@ss.hasPermi('tool:gen:list')") + @GetMapping("/db/list") + public TableDataInfo dataList(GenTable genTable) + { + startPage(); + List<GenTable> list = genTableService.selectDbTableList(genTable); + return getDataTable(list); + } + + /** + * 查询数据表字段列表 + */ + @PreAuthorize("@ss.hasPermi('tool:gen:list')") + @GetMapping(value = "/column/{tableId}") + public TableDataInfo columnList(Long tableId) + { + TableDataInfo dataInfo = new TableDataInfo(); + List<GenTableColumn> list = genTableColumnService.selectGenTableColumnListByTableId(tableId); + dataInfo.setRows(list); + dataInfo.setTotal(list.size()); + return dataInfo; + } + + /** + * 导入表结构(保存) + */ + @PreAuthorize("@ss.hasPermi('tool:gen:import')") + @Log(title = "代码生成", businessType = BusinessType.IMPORT) + @PostMapping("/importTable") + public AjaxResult importTableSave(String tables) + { + String[] tableNames = Convert.toStrArray(tables); + // 查询表信息 + List<GenTable> tableList = genTableService.selectDbTableListByNames(tableNames); + genTableService.importGenTable(tableList); + return success(); + } + + /** + * 修改保存代码生成业务 + */ + @PreAuthorize("@ss.hasPermi('tool:gen:edit')") + @Log(title = "代码生成", businessType = BusinessType.UPDATE) + @PutMapping + public AjaxResult editSave(@Validated @RequestBody GenTable genTable) + { + genTableService.validateEdit(genTable); + genTableService.updateGenTable(genTable); + return success(); + } + + /** + * 删除代码生成 + */ + @PreAuthorize("@ss.hasPermi('tool:gen:remove')") + @Log(title = "代码生成", businessType = BusinessType.DELETE) + @DeleteMapping("/{tableIds}") + public AjaxResult remove(@PathVariable Long[] tableIds) + { + genTableService.deleteGenTableByIds(tableIds); + return success(); + } + + /** + * 预览代码 + */ + @PreAuthorize("@ss.hasPermi('tool:gen:preview')") + @GetMapping("/preview/{tableId}") + public AjaxResult preview(@PathVariable("tableId") Long tableId) throws IOException + { + Map<String, String> dataMap = genTableService.previewCode(tableId); + return success(dataMap); + } + + /** + * 生成代码(下载方式) + */ + @PreAuthorize("@ss.hasPermi('tool:gen:code')") + @Log(title = "代码生成", businessType = BusinessType.GENCODE) + @GetMapping("/download/{tableName}") + public void download(HttpServletResponse response, @PathVariable("tableName") String tableName) throws IOException + { + byte[] data = genTableService.downloadCode(tableName); + genCode(response, data); + } + + /** + * 生成代码(自定义路径) + */ + @PreAuthorize("@ss.hasPermi('tool:gen:code')") + @Log(title = "代码生成", businessType = BusinessType.GENCODE) + @GetMapping("/genCode/{tableName}") + public AjaxResult genCode(@PathVariable("tableName") String tableName) + { + genTableService.generatorCode(tableName); + return success(); + } + + /** + * 同步数据库 + */ + @PreAuthorize("@ss.hasPermi('tool:gen:edit')") + @Log(title = "代码生成", businessType = BusinessType.UPDATE) + @GetMapping("/synchDb/{tableName}") + public AjaxResult synchDb(@PathVariable("tableName") String tableName) + { + genTableService.synchDb(tableName); + return success(); + } + + /** + * 批量生成代码 + */ + @PreAuthorize("@ss.hasPermi('tool:gen:code')") + @Log(title = "代码生成", businessType = BusinessType.GENCODE) + @GetMapping("/batchGenCode") + public void batchGenCode(HttpServletResponse response, String tables) throws IOException + { + String[] tableNames = Convert.toStrArray(tables); + byte[] data = genTableService.downloadCode(tableNames); + genCode(response, data); + } + + /** + * 生成zip文件 + */ + private void genCode(HttpServletResponse response, byte[] data) throws IOException + { + response.reset(); + response.addHeader("Access-Control-Allow-Origin", "*"); + response.addHeader("Access-Control-Expose-Headers", "Content-Disposition"); + response.setHeader("Content-Disposition", "attachment; filename=\"win.zip\""); + response.addHeader("Content-Length", "" + data.length); + response.setContentType("application/octet-stream; charset=UTF-8"); + IOUtils.write(data, response.getOutputStream()); + } +} \ No newline at end of file diff --git a/dc-generator/src/main/java/com/dc/generator/domain/GenTable.java b/dc-generator/src/main/java/com/dc/generator/domain/GenTable.java new file mode 100644 index 0000000..f9de7fe --- /dev/null +++ b/dc-generator/src/main/java/com/dc/generator/domain/GenTable.java @@ -0,0 +1,151 @@ +package com.dc.generator.domain; + +import com.dc.common.core.domain.WinBaseEntity; +import com.dc.common.utils.StringUtils; +import com.dc.common.constant.GenConstants; +import lombok.AllArgsConstructor; +import lombok.Data; +import lombok.NoArgsConstructor; +import lombok.experimental.Accessors; +import org.apache.commons.lang3.ArrayUtils; + +import javax.validation.Valid; +import javax.validation.constraints.NotBlank; +import java.util.List; + +/** + * 业务表 gen_table + * + * @author win + */ +@Data +@NoArgsConstructor +@AllArgsConstructor +@Accessors(chain = true) +public class GenTable extends WinBaseEntity +{ + private static final long serialVersionUID = 1L; + + /** 编号 */ + private Long tableId; + + /** 表名称 */ + @NotBlank(message = "表名称不能为空") + private String tableName; + + /** 表描述 */ + @NotBlank(message = "表描述不能为空") + private String tableComment; + + /** 关联父表的表名 */ + private String subTableName; + + /** 本表关联父表的外键名 */ + private String subTableFkName; + + /** 实体类名称(首字母大写) */ + @NotBlank(message = "实体类名称不能为空") + private String className; + + /** 使用的模板(crud单表操作 tree树表操作 sub主子表操作) */ + private String tplCategory; + + /** 生成包路径 */ + @NotBlank(message = "生成包路径不能为空") + private String packageName; + + /** 生成模块名 */ + @NotBlank(message = "生成模块名不能为空") + private String moduleName; + + /** 生成业务名 */ + @NotBlank(message = "生成业务名不能为空") + private String businessName; + + /** 生成功能名 */ + @NotBlank(message = "生成功能名不能为空") + private String functionName; + + /** 生成作者 */ + @NotBlank(message = "作者不能为空") + private String functionAuthor; + + /** 生成代码方式(0zip压缩包 1自定义路径) */ + private String genType; + + /** 生成路径(不填默认项目路径) */ + private String genPath; + + /** 主键信息 */ + private GenTableColumn pkColumn; + + /** 子表信息 */ + private GenTable subTable; + + /** 表列信息 */ + @Valid + private List<GenTableColumn> columns; + + /** 其它生成选项 */ + private String options; + + /** 树编码字段 */ + private String treeCode; + + /** 树父编码字段 */ + private String treeParentCode; + + /** 树名称字段 */ + private String treeName; + + /** 上级菜单ID字段 */ + private String parentMenuId; + + /** 上级菜单名称字段 */ + private String parentMenuName; + + public boolean isSub() + { + return isSub(this.tplCategory); + } + + public static boolean isSub(String tplCategory) + { + return tplCategory != null && StringUtils.equals(GenConstants.TPL_SUB, tplCategory); + } + + public boolean isTree() + { + return isTree(this.tplCategory); + } + + public static boolean isTree(String tplCategory) + { + return tplCategory != null && StringUtils.equals(GenConstants.TPL_TREE, tplCategory); + } + + public boolean isCrud() + { + return isCrud(this.tplCategory); + } + + public static boolean isCrud(String tplCategory) + { + return tplCategory != null && StringUtils.equals(GenConstants.TPL_CRUD, tplCategory); + } + + public boolean isSuperColumn(String javaField) + { + return isSuperColumn(this.tplCategory, javaField); + } + + public static boolean isSuperColumn(String tplCategory, String javaField) + { + if (isTree(tplCategory)) + { + return StringUtils.equalsAnyIgnoreCase(javaField, + ArrayUtils.addAll(GenConstants.TREE_ENTITY, GenConstants.BASE_ENTITY)); + } + return StringUtils.equalsAnyIgnoreCase(javaField, GenConstants.BASE_ENTITY); + } +} \ No newline at end of file diff --git a/dc-generator/src/main/java/com/dc/generator/domain/GenTableColumn.java b/dc-generator/src/main/java/com/dc/generator/domain/GenTableColumn.java new file mode 100644 index 0000000..0fb16da --- /dev/null +++ b/dc-generator/src/main/java/com/dc/generator/domain/GenTableColumn.java @@ -0,0 +1,197 @@ +package com.dc.generator.domain; + +import com.dc.common.core.domain.WinBaseEntity; +import com.dc.common.utils.StringUtils; +import lombok.AllArgsConstructor; +import lombok.Data; +import lombok.NoArgsConstructor; +import lombok.experimental.Accessors; + +import javax.validation.constraints.NotBlank; + +/** + * 代码生成业务字段表 gen_table_column + * + * @author win + */ +@Data +@NoArgsConstructor +@AllArgsConstructor +@Accessors(chain = true) +public class GenTableColumn extends WinBaseEntity +{ + private static final long serialVersionUID = 1L; + + /** 编号 */ + private Long columnId; + + /** 归属表编号 */ + private Long tableId; + + /** 列名称 */ + private String columnName; + + /** 列描述 */ + private String columnComment; + + /** 列类型 */ + private String columnType; + + /** JAVA类型 */ + private String javaType; + + /** JAVA字段名 */ + @NotBlank(message = "Java属性不能为空") + private String javaField; + + /** 是否主键(1是) */ + private String isPk; + + /** 是否自增(1是) */ + private String isIncrement; + + /** 是否必填(1是) */ + private String isRequired; + + /** 是否为插入字段(1是) */ + private String isInsert; + + /** 是否编辑字段(1是) */ + private String isEdit; + + /** 是否列表字段(1是) */ + private String isList; + + /** 是否查询字段(1是) */ + private String isQuery; + + /** 查询方式(EQ等于、NE不等于、GT大于、LT小于、LIKE模糊、BETWEEN范围) */ + private String queryType; + + /** 显示类型(input文本框、textarea文本域、select下拉框、checkbox复选框、radio单选框、datetime日期控件、image图片上传控件、upload文件上传控件、editor富文本控件) */ + private String htmlType; + + /** 字典类型 */ + private String dictType; + + /** 排序 */ + private Integer sort; + + public boolean isIncrement() + { + return isIncrement(this.isIncrement); + } + + public boolean isIncrement(String isIncrement) + { + return isIncrement != null && StringUtils.equals("1", isIncrement); + } + + public boolean isRequired() + { + return isRequired(this.isRequired); + } + + public boolean isRequired(String isRequired) + { + return isRequired != null && StringUtils.equals("1", isRequired); + } + + public boolean isInsert() + { + return isInsert(this.isInsert); + } + + public boolean isInsert(String isInsert) + { + return isInsert != null && StringUtils.equals("1", isInsert); + } + + public boolean isEdit() + { + return isInsert(this.isEdit); + } + + public boolean isEdit(String isEdit) + { + return isEdit != null && StringUtils.equals("1", isEdit); + } + + public boolean isList() + { + return isList(this.isList); + } + + public boolean isList(String isList) + { + return isList != null && StringUtils.equals("1", isList); + } + + public boolean isSuperColumn() + { + return isSuperColumn(this.javaField); + } + + public static boolean isSuperColumn(String javaField) + { + return StringUtils.equalsAnyIgnoreCase(javaField, + // BaseEntity + //"createBy", "createTime", "updateBy", "updateTime", "remark", + // TreeEntity + "parentName", "parentId", "orderNum", "ancestors","tenantId"); + } + + public boolean isQuery() + { + return isQuery(this.isQuery); + } + + public boolean isQuery(String isQuery) + { + return isQuery != null && StringUtils.equals("1", isQuery); + } + + public boolean isPk() + { + return isPk(this.isPk); + } + + public boolean isPk(String isPk) + { + return isPk != null && StringUtils.equals("1", isPk); + } + + public boolean isUsableColumn() + { + return isUsableColumn(javaField); + } + + public static boolean isUsableColumn(String javaField) + { + // isSuperColumn()中的名单用于避免生成多余Domain属性,若某些属性在生成页面时需要用到不能忽略,则放在此处白名单 + return StringUtils.equalsAnyIgnoreCase(javaField, "parentId", "orderNum", "remark"); + } + + public String readConverterExp() + { + String remarks = StringUtils.substringBetween(this.columnComment, "(", ")"); + StringBuffer sb = new StringBuffer(); + if (StringUtils.isNotEmpty(remarks)) + { + for (String value : remarks.split(" ")) + { + if (StringUtils.isNotEmpty(value)) + { + Object startStr = value.subSequence(0, 1); + String endStr = value.substring(1); + sb.append("").append(startStr).append("=").append(endStr).append(","); + } + } + return sb.deleteCharAt(sb.length() - 1).toString(); + } + else + { + return this.columnComment; + } + } +} diff --git a/dc-generator/src/main/java/com/dc/generator/mapper/GenTableColumnMapper.java b/dc-generator/src/main/java/com/dc/generator/mapper/GenTableColumnMapper.java new file mode 100644 index 0000000..16ff82e --- /dev/null +++ b/dc-generator/src/main/java/com/dc/generator/mapper/GenTableColumnMapper.java @@ -0,0 +1,64 @@ +package com.dc.generator.mapper; + +import java.util.List; + +import com.baomidou.mybatisplus.annotation.InterceptorIgnore; +import com.baomidou.mybatisplus.core.mapper.BaseMapper; +import com.dc.generator.domain.GenTableColumn; + +/** + * 业务字段 数据层 + * + * @author ruoyi + */ +@InterceptorIgnore(tenantLine = "true") +public interface GenTableColumnMapper extends BaseMapper<GenTableColumn> +{ + /** + * 根据表名称查询列信息 + * + * @param tableName 表名称 + * @return 列信息 + */ + public List<GenTableColumn> selectDbTableColumnsByName(String tableName); + + /** + * 查询业务字段列表 + * + * @param tableId 业务字段编号 + * @return 业务字段集合 + */ + public List<GenTableColumn> selectGenTableColumnListByTableId(Long tableId); + + /** + * 新增业务字段 + * + * @param genTableColumn 业务字段信息 + * @return 结果 + */ + public int insertGenTableColumn(GenTableColumn genTableColumn); + + /** + * 修改业务字段 + * + * @param genTableColumn 业务字段信息 + * @return 结果 + */ + public int updateGenTableColumn(GenTableColumn genTableColumn); + + /** + * 删除业务字段 + * + * @param genTableColumns 列数据 + * @return 结果 + */ + public int deleteGenTableColumns(List<GenTableColumn> genTableColumns); + + /** + * 批量删除业务字段 + * + * @param ids 需要删除的数据ID + * @return 结果 + */ + public int deleteGenTableColumnByIds(Long[] ids); +} diff --git a/dc-generator/src/main/java/com/dc/generator/mapper/GenTableMapper.java b/dc-generator/src/main/java/com/dc/generator/mapper/GenTableMapper.java new file mode 100644 index 0000000..8fc632d --- /dev/null +++ b/dc-generator/src/main/java/com/dc/generator/mapper/GenTableMapper.java @@ -0,0 +1,87 @@ +package com.dc.generator.mapper; + +import com.baomidou.mybatisplus.annotation.InterceptorIgnore; +import com.baomidou.mybatisplus.core.mapper.BaseMapper; +import com.dc.generator.domain.GenTable; + +import java.util.List; + +/** + * 业务 数据层 + * + * @author win + */ +@InterceptorIgnore(tenantLine = "true") +public interface GenTableMapper extends BaseMapper<GenTable> +{ + /** + * 查询业务列表 + * + * @param genTable 业务信息 + * @return 业务集合 + */ + public List<GenTable> selectGenTableList(GenTable genTable); + + /** + * 查询据库列表 + * + * @param genTable 业务信息 + * @return 数据库表集合 + */ + public List<GenTable> selectDbTableList(GenTable genTable); + + /** + * 查询据库列表 + * + * @param tableNames 表名称组 + * @return 数据库表集合 + */ + public List<GenTable> selectDbTableListByNames(String[] tableNames); + + /** + * 查询所有表信息 + * + * @return 表信息集合 + */ + public List<GenTable> selectGenTableAll(); + + /** + * 查询表ID业务信息 + * + * @param id 业务ID + * @return 业务信息 + */ + public GenTable selectGenTableById(Long id); + + /** + * 查询表名称业务信息 + * + * @param tableName 表名称 + * @return 业务信息 + */ + public GenTable selectGenTableByName(String tableName); + + /** + * 新增业务 + * + * @param genTable 业务信息 + * @return 结果 + */ + public int insertGenTable(GenTable genTable); + + /** + * 修改业务 + * + * @param genTable 业务信息 + * @return 结果 + */ + public int updateGenTable(GenTable genTable); + + /** + * 批量删除业务 + * + * @param ids 需要删除的数据ID + * @return 结果 + */ + public int deleteGenTableByIds(Long[] ids); +} diff --git a/dc-generator/src/main/java/com/dc/generator/service/GenTableColumnService.java b/dc-generator/src/main/java/com/dc/generator/service/GenTableColumnService.java new file mode 100644 index 0000000..042b5f4 --- /dev/null +++ b/dc-generator/src/main/java/com/dc/generator/service/GenTableColumnService.java @@ -0,0 +1,65 @@ +package com.dc.generator.service; + +import com.baomidou.mybatisplus.extension.service.IService; +import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; +import com.dc.common.core.text.Convert; +import com.dc.generator.domain.GenTableColumn; +import com.dc.generator.mapper.GenTableColumnMapper; +import lombok.extern.slf4j.Slf4j; +import org.springframework.stereotype.Service; + +import java.util.List; + +/** + * 业务字段 服务层实现 + * + * @author win + */ +@Slf4j +@Service +public class GenTableColumnService extends ServiceImpl<GenTableColumnMapper, GenTableColumn> implements IService<GenTableColumn> +{ + /** + * 查询业务字段列表 + * + * @param tableId 业务字段编号 + * @return 业务字段集合 + */ + public List<GenTableColumn> selectGenTableColumnListByTableId(Long tableId) + { + return baseMapper.selectGenTableColumnListByTableId(tableId); + } + + /** + * 新增业务字段 + * + * @param genTableColumn 业务字段信息 + * @return 结果 + */ + public int insertGenTableColumn(GenTableColumn genTableColumn) + { + return baseMapper.insertGenTableColumn(genTableColumn); + } + + /** + * 修改业务字段 + * + * @param genTableColumn 业务字段信息 + * @return 结果 + */ + public int updateGenTableColumn(GenTableColumn genTableColumn) + { + return baseMapper.updateGenTableColumn(genTableColumn); + } + + /** + * 删除业务字段对象 + * + * @param ids 需要删除的数据ID + * @return 结果 + */ + public int deleteGenTableColumnByIds(String ids) + { + return baseMapper.deleteGenTableColumnByIds(Convert.toLongArray(ids)); + } +} diff --git a/dc-generator/src/main/java/com/dc/generator/service/GenTableService.java b/dc-generator/src/main/java/com/dc/generator/service/GenTableService.java new file mode 100644 index 0000000..c0871f6 --- /dev/null +++ b/dc-generator/src/main/java/com/dc/generator/service/GenTableService.java @@ -0,0 +1,505 @@ +package com.dc.generator.service; + +import com.alibaba.fastjson2.JSON; +import com.alibaba.fastjson2.JSONObject; +import com.baomidou.mybatisplus.extension.service.IService; +import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; +import com.dc.common.core.text.CharsetKit; +import com.dc.common.utils.SecurityUtils; +import com.dc.common.utils.StringUtils; +import com.dc.generator.domain.GenTable; +import com.dc.generator.domain.GenTableColumn; +import com.dc.generator.mapper.GenTableColumnMapper; +import com.dc.generator.mapper.GenTableMapper; +import com.dc.common.constant.Constants; +import com.dc.common.constant.GenConstants; +import com.dc.common.exception.ServiceException; +import com.dc.generator.util.GenUtils; +import com.dc.generator.util.VelocityInitializer; +import com.dc.generator.util.VelocityUtils; +import lombok.extern.slf4j.Slf4j; +import org.apache.commons.io.FileUtils; +import org.apache.commons.io.IOUtils; +import org.apache.velocity.Template; +import org.apache.velocity.VelocityContext; +import org.apache.velocity.app.Velocity; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.stereotype.Service; +import org.springframework.transaction.annotation.Transactional; + +import java.io.ByteArrayOutputStream; +import java.io.File; +import java.io.IOException; +import java.io.StringWriter; +import java.util.LinkedHashMap; +import java.util.List; +import java.util.Map; +import java.util.function.Function; +import java.util.stream.Collectors; +import java.util.zip.ZipEntry; +import java.util.zip.ZipOutputStream; + +/** + * 业务 服务层实现 + * + * @author win + */ +@Slf4j +@Service +public class GenTableService extends ServiceImpl<GenTableMapper, GenTable> implements IService<GenTable> +{ + @Autowired + private GenTableColumnMapper genTableColumnMapper; + + /** + * 查询业务信息 + * + * @param id 业务ID + * @return 业务信息 + */ + public GenTable selectGenTableById(Long id) + { + GenTable genTable = baseMapper.selectGenTableById(id); + setTableFromOptions(genTable); + return genTable; + } + + /** + * 查询业务列表 + * + * @param genTable 业务信息 + * @return 业务集合 + */ + public List<GenTable> selectGenTableList(GenTable genTable) + { + return baseMapper.selectGenTableList(genTable); + } + + /** + * 查询据库列表 + * + * @param genTable 业务信息 + * @return 数据库表集合 + */ + public List<GenTable> selectDbTableList(GenTable genTable) + { + return baseMapper.selectDbTableList(genTable); + } + + /** + * 查询据库列表 + * + * @param tableNames 表名称组 + * @return 数据库表集合 + */ + public List<GenTable> selectDbTableListByNames(String[] tableNames) + { + return baseMapper.selectDbTableListByNames(tableNames); + } + + /** + * 查询所有表信息 + * + * @return 表信息集合 + */ + public List<GenTable> selectGenTableAll() + { + return baseMapper.selectGenTableAll(); + } + + /** + * 修改业务 + * + * @param genTable 业务信息 + * @return 结果 + */ + @Transactional + public void updateGenTable(GenTable genTable) + { + String options = JSON.toJSONString(genTable.getParams()); + genTable.setOptions(options); + int row = baseMapper.updateGenTable(genTable); + if (row > 0) + { + for (GenTableColumn cenTableColumn : genTable.getColumns()) + { + genTableColumnMapper.updateGenTableColumn(cenTableColumn); + } + } + } + + /** + * 删除业务对象 + * + * @param tableIds 需要删除的数据ID + * @return 结果 + */ + @Transactional + public void deleteGenTableByIds(Long[] tableIds) + { + baseMapper.deleteGenTableByIds(tableIds); + genTableColumnMapper.deleteGenTableColumnByIds(tableIds); + } + + /** + * 导入表结构 + * + * @param tableList 导入表列表 + */ + @Transactional + public void importGenTable(List<GenTable> tableList) + { + String operName = SecurityUtils.getUsername(); + try + { + for (GenTable table : tableList) + { + String tableName = table.getTableName(); + GenUtils.initTable(table, operName); + int row = baseMapper.insertGenTable(table); + if (row > 0) + { + // 保存列信息 + List<GenTableColumn> genTableColumns = genTableColumnMapper.selectDbTableColumnsByName(tableName); + for (GenTableColumn column : genTableColumns) + { + GenUtils.initColumnField(column, table); + genTableColumnMapper.insertGenTableColumn(column); + } + } + } + } + catch (Exception e) + { + throw new ServiceException("导入失败:" + e.getMessage()); + } + } + + /** + * 预览代码 + * + * @param tableId 表编号 + * @return 预览数据列表 + */ + public Map<String, String> previewCode(Long tableId) + { + Map<String, String> dataMap = new LinkedHashMap<>(); + // 查询表信息 + GenTable table = baseMapper.selectGenTableById(tableId); + // 设置主子表信息 + setSubTable(table); + // 设置主键列信息 + setPkColumn(table); + VelocityInitializer.initVelocity(); + + VelocityContext context = VelocityUtils.prepareContext(table); + + // 获取模板列表 + List<String> templates = VelocityUtils.getTemplateList(table.getTplCategory()); + for (String template : templates) + { + // 渲染模板 + StringWriter sw = new StringWriter(); + Template tpl = Velocity.getTemplate(template, Constants.UTF8); + tpl.merge(context, sw); + dataMap.put(template, sw.toString()); + } + return dataMap; + } + + /** + * 生成代码(下载方式) + * + * @param tableName 表名称 + * @return 数据 + */ + public byte[] downloadCode(String tableName) + { + ByteArrayOutputStream outputStream = new ByteArrayOutputStream(); + ZipOutputStream zip = new ZipOutputStream(outputStream); + generatorCode(tableName, zip); + IOUtils.closeQuietly(zip); + return outputStream.toByteArray(); + } + + /** + * 生成代码(自定义路径) + * + * @param tableName 表名称 + */ + public void generatorCode(String tableName) + { + // 查询表信息 + GenTable table = baseMapper.selectGenTableByName(tableName); + // 设置主子表信息 + setSubTable(table); + // 设置主键列信息 + setPkColumn(table); + + VelocityInitializer.initVelocity(); + + VelocityContext context = VelocityUtils.prepareContext(table); + + // 获取模板列表 + List<String> templates = VelocityUtils.getTemplateList(table.getTplCategory()); + for (String template : templates) + { + if (!StringUtils.containsAny(template, "sql.vm", "api.js.vm", "index.vue.vm", "index-tree.vue.vm")) + { + // 渲染模板 + StringWriter sw = new StringWriter(); + Template tpl = Velocity.getTemplate(template, Constants.UTF8); + tpl.merge(context, sw); + try + { + String path = getGenPath(table, template); + FileUtils.writeStringToFile(new File(path), sw.toString(), CharsetKit.UTF_8); + } + catch (IOException e) + { + throw new ServiceException("渲染模板失败,表名:" + table.getTableName()); + } + } + } + } + + /** + * 同步数据库 + * + * @param tableName 表名称 + */ + @Transactional + public void synchDb(String tableName) + { + GenTable table = baseMapper.selectGenTableByName(tableName); + List<GenTableColumn> tableColumns = table.getColumns(); + Map<String, GenTableColumn> tableColumnMap = tableColumns.stream().collect(Collectors.toMap(GenTableColumn::getColumnName, Function.identity())); + + List<GenTableColumn> dbTableColumns = genTableColumnMapper.selectDbTableColumnsByName(tableName); + if (StringUtils.isEmpty(dbTableColumns)) + { + throw new ServiceException("同步数据失败,原表结构不存在"); + } + List<String> dbTableColumnNames = dbTableColumns.stream().map(GenTableColumn::getColumnName).collect(Collectors.toList()); + + dbTableColumns.forEach(column -> { + GenUtils.initColumnField(column, table); + if (tableColumnMap.containsKey(column.getColumnName())) + { + GenTableColumn prevColumn = tableColumnMap.get(column.getColumnName()); + column.setColumnId(prevColumn.getColumnId()); + if (column.isList()) + { + // 如果是列表,继续保留查询方式/字典类型选项 + column.setDictType(prevColumn.getDictType()); + column.setQueryType(prevColumn.getQueryType()); + } + if (StringUtils.isNotEmpty(prevColumn.getIsRequired()) && !column.isPk() + && (column.isInsert() || column.isEdit()) + && ((column.isUsableColumn()) || (!column.isSuperColumn()))) + { + // 如果是(新增/修改&非主键/非忽略及父属性),继续保留必填/显示类型选项 + column.setIsRequired(prevColumn.getIsRequired()); + column.setHtmlType(prevColumn.getHtmlType()); + } + genTableColumnMapper.updateGenTableColumn(column); + } + else + { + genTableColumnMapper.insertGenTableColumn(column); + } + }); + + List<GenTableColumn> delColumns = tableColumns.stream().filter(column -> !dbTableColumnNames.contains(column.getColumnName())).collect(Collectors.toList()); + if (StringUtils.isNotEmpty(delColumns)) + { + genTableColumnMapper.deleteGenTableColumns(delColumns); + } + } + + /** + * 批量生成代码(下载方式) + * + * @param tableNames 表数组 + * @return 数据 + */ + public byte[] downloadCode(String[] tableNames) + { + ByteArrayOutputStream outputStream = new ByteArrayOutputStream(); + ZipOutputStream zip = new ZipOutputStream(outputStream); + for (String tableName : tableNames) + { + generatorCode(tableName, zip); + } + IOUtils.closeQuietly(zip); + return outputStream.toByteArray(); + } + + /** + * 查询表信息并生成代码 + */ + private void generatorCode(String tableName, ZipOutputStream zip) + { + // 查询表信息 + GenTable table = baseMapper.selectGenTableByName(tableName); + // 设置主子表信息 + setSubTable(table); + // 设置主键列信息 + setPkColumn(table); + + VelocityInitializer.initVelocity(); + + VelocityContext context = VelocityUtils.prepareContext(table); + + // 获取模板列表 + List<String> templates = VelocityUtils.getTemplateList(table.getTplCategory()); + for (String template : templates) + { + // 渲染模板 + StringWriter sw = new StringWriter(); + Template tpl = Velocity.getTemplate(template, Constants.UTF8); + tpl.merge(context, sw); + try + { + // 添加到zip + zip.putNextEntry(new ZipEntry(VelocityUtils.getFileName(template, table))); + IOUtils.write(sw.toString(), zip, Constants.UTF8); + IOUtils.closeQuietly(sw); + zip.flush(); + zip.closeEntry(); + } + catch (IOException e) + { + log.error("渲染模板失败,表名:" + table.getTableName(), e); + } + } + } + + /** + * 修改保存参数校验 + * + * @param genTable 业务信息 + */ + public void validateEdit(GenTable genTable) + { + if (GenConstants.TPL_TREE.equals(genTable.getTplCategory())) + { + String options = JSON.toJSONString(genTable.getParams()); + JSONObject paramsObj = JSON.parseObject(options); + if (StringUtils.isEmpty(paramsObj.getString(GenConstants.TREE_CODE))) + { + throw new ServiceException("树编码字段不能为空"); + } + else if (StringUtils.isEmpty(paramsObj.getString(GenConstants.TREE_PARENT_CODE))) + { + throw new ServiceException("树父编码字段不能为空"); + } + else if (StringUtils.isEmpty(paramsObj.getString(GenConstants.TREE_NAME))) + { + throw new ServiceException("树名称字段不能为空"); + } + else if (GenConstants.TPL_SUB.equals(genTable.getTplCategory())) + { + if (StringUtils.isEmpty(genTable.getSubTableName())) + { + throw new ServiceException("关联子表的表名不能为空"); + } + else if (StringUtils.isEmpty(genTable.getSubTableFkName())) + { + throw new ServiceException("子表关联的外键名不能为空"); + } + } + } + } + + /** + * 设置主键列信息 + * + * @param table 业务表信息 + */ + public void setPkColumn(GenTable table) + { + for (GenTableColumn column : table.getColumns()) + { + if (column.isPk()) + { + table.setPkColumn(column); + break; + } + } + if (StringUtils.isNull(table.getPkColumn())) + { + table.setPkColumn(table.getColumns().get(0)); + } + if (GenConstants.TPL_SUB.equals(table.getTplCategory())) + { + for (GenTableColumn column : table.getSubTable().getColumns()) + { + if (column.isPk()) + { + table.getSubTable().setPkColumn(column); + break; + } + } + if (StringUtils.isNull(table.getSubTable().getPkColumn())) + { + table.getSubTable().setPkColumn(table.getSubTable().getColumns().get(0)); + } + } + } + + /** + * 设置主子表信息 + * + * @param table 业务表信息 + */ + public void setSubTable(GenTable table) + { + String subTableName = table.getSubTableName(); + if (StringUtils.isNotEmpty(subTableName)) + { + table.setSubTable(baseMapper.selectGenTableByName(subTableName)); + } + } + + /** + * 设置代码生成其他选项值 + * + * @param genTable 设置后的生成对象 + */ + public void setTableFromOptions(GenTable genTable) + { + JSONObject paramsObj = JSON.parseObject(genTable.getOptions()); + if (StringUtils.isNotNull(paramsObj)) + { + String treeCode = paramsObj.getString(GenConstants.TREE_CODE); + String treeParentCode = paramsObj.getString(GenConstants.TREE_PARENT_CODE); + String treeName = paramsObj.getString(GenConstants.TREE_NAME); + String parentMenuId = paramsObj.getString(GenConstants.PARENT_MENU_ID); + String parentMenuName = paramsObj.getString(GenConstants.PARENT_MENU_NAME); + + genTable.setTreeCode(treeCode); + genTable.setTreeParentCode(treeParentCode); + genTable.setTreeName(treeName); + genTable.setParentMenuId(parentMenuId); + genTable.setParentMenuName(parentMenuName); + } + } + + /** + * 获取代码生成地址 + * + * @param table 业务表信息 + * @param template 模板文件路径 + * @return 生成地址 + */ + public static String getGenPath(GenTable table, String template) + { + String genPath = table.getGenPath(); + if (StringUtils.equals(genPath, "/")) + { + return System.getProperty("user.dir") + File.separator + "src" + File.separator + VelocityUtils.getFileName(template, table); + } + return genPath + File.separator + VelocityUtils.getFileName(template, table); + } +} \ No newline at end of file diff --git a/dc-generator/src/main/java/com/dc/generator/util/GenUtils.java b/dc-generator/src/main/java/com/dc/generator/util/GenUtils.java new file mode 100644 index 0000000..a082414 --- /dev/null +++ b/dc-generator/src/main/java/com/dc/generator/util/GenUtils.java @@ -0,0 +1,258 @@ +package com.dc.generator.util; + +import com.dc.common.utils.StringUtils; +import com.dc.generator.config.GenConfig; +import com.dc.generator.domain.GenTable; +import com.dc.generator.domain.GenTableColumn; +import com.dc.common.constant.GenConstants; +import org.apache.commons.lang3.RegExUtils; + +import java.util.Arrays; + +/** + * 代码生成器 工具类 + * + * @author win + */ +public class GenUtils +{ + /** + * 初始化表信息 + */ + public static void initTable(GenTable genTable, String operName) + { + genTable.setClassName(convertClassName(genTable.getTableName())); + genTable.setPackageName(GenConfig.getPackageName()); + genTable.setModuleName(getModuleName(GenConfig.getPackageName())); + genTable.setBusinessName(getBusinessName(genTable.getTableName())); + genTable.setFunctionName(replaceText(genTable.getTableComment())); + genTable.setFunctionAuthor(GenConfig.getAuthor()); + genTable.setCreateBy(operName); + } + + /** + * 初始化列属性字段 + */ + public static void initColumnField(GenTableColumn column, GenTable table) + { + String dataType = getDbType(column.getColumnType()); + String columnName = column.getColumnName(); + column.setTableId(table.getTableId()); + column.setCreateBy(table.getCreateBy()); + // 设置java字段名 + column.setJavaField(StringUtils.toCamelCase(columnName)); + // 设置默认类型 + column.setJavaType(GenConstants.TYPE_STRING); + column.setQueryType(GenConstants.QUERY_EQ); + + if (arraysContains(GenConstants.COLUMNTYPE_STR, dataType) || arraysContains(GenConstants.COLUMNTYPE_TEXT, dataType)) + { + // 字符串长度超过500设置为文本域 + Integer columnLength = getColumnLength(column.getColumnType()); + String htmlType = columnLength >= 500 || arraysContains(GenConstants.COLUMNTYPE_TEXT, dataType) ? GenConstants.HTML_TEXTAREA : GenConstants.HTML_INPUT; + column.setHtmlType(htmlType); + } + else if (arraysContains(GenConstants.COLUMNTYPE_TIME, dataType)) + { + column.setJavaType(GenConstants.TYPE_DATE); + column.setHtmlType(GenConstants.HTML_DATETIME); + } + else if (arraysContains(GenConstants.COLUMNTYPE_NUMBER, dataType)) + { + column.setHtmlType(GenConstants.HTML_INPUT); + + // 如果是浮点型 统一用BigDecimal + String[] str = StringUtils.split(StringUtils.substringBetween(column.getColumnType(), "(", ")"), ","); + if (str != null && str.length == 2 && Integer.parseInt(str[1]) > 0) + { + column.setJavaType(GenConstants.TYPE_BIGDECIMAL); + } + // 如果是整形 + else if (str != null && str.length == 1 && Integer.parseInt(str[0]) <= 10) + { + column.setJavaType(GenConstants.TYPE_INTEGER); + } + // 长整形 + else + { + column.setJavaType(GenConstants.TYPE_LONG); + } + } + + // 插入字段(默认所有字段都需要插入) + column.setIsInsert(GenConstants.REQUIRE); + + // 编辑字段 + if (!arraysContains(GenConstants.COLUMNNAME_NOT_EDIT, columnName) && !column.isPk()) + { + column.setIsEdit(GenConstants.REQUIRE); + } + // 列表字段 + if (!arraysContains(GenConstants.COLUMNNAME_NOT_LIST, columnName) && !column.isPk()) + { + column.setIsList(GenConstants.REQUIRE); + } + // 查询字段 + if (!arraysContains(GenConstants.COLUMNNAME_NOT_QUERY, columnName) && !column.isPk()) + { + column.setIsQuery(GenConstants.REQUIRE); + } + + // 查询字段类型 + if (StringUtils.endsWithIgnoreCase(columnName, "name")) + { + column.setQueryType(GenConstants.QUERY_LIKE); + } + // 状态字段设置单选框 + if (StringUtils.endsWithIgnoreCase(columnName, "status")) + { + column.setHtmlType(GenConstants.HTML_RADIO); + } + // 类型&性别字段设置下拉框 + else if (StringUtils.endsWithIgnoreCase(columnName, "type") + || StringUtils.endsWithIgnoreCase(columnName, "sex")) + { + column.setHtmlType(GenConstants.HTML_SELECT); + } + // 图片字段设置图片上传控件 + else if (StringUtils.endsWithIgnoreCase(columnName, "image")) + { + column.setHtmlType(GenConstants.HTML_IMAGE_UPLOAD); + } + // 文件字段设置文件上传控件 + else if (StringUtils.endsWithIgnoreCase(columnName, "file")) + { + column.setHtmlType(GenConstants.HTML_FILE_UPLOAD); + } + // 内容字段设置富文本控件 + else if (StringUtils.endsWithIgnoreCase(columnName, "content")) + { + column.setHtmlType(GenConstants.HTML_EDITOR); + } + } + + /** + * 校验数组是否包含指定值 + * + * @param arr 数组 + * @param targetValue 值 + * @return 是否包含 + */ + public static boolean arraysContains(String[] arr, String targetValue) + { + return Arrays.asList(arr).contains(targetValue); + } + + /** + * 获取模块名 + * + * @param packageName 包名 + * @return 模块名 + */ + public static String getModuleName(String packageName) + { + int lastIndex = packageName.lastIndexOf("."); + int nameLength = packageName.length(); + return StringUtils.substring(packageName, lastIndex + 1, nameLength); + } + + /** + * 获取业务名 + * + * @param tableName 表名 + * @return 业务名 + */ + public static String getBusinessName(String tableName) + { + int lastIndex = tableName.lastIndexOf("_"); + int nameLength = tableName.length(); + return StringUtils.substring(tableName, lastIndex + 1, nameLength); + } + + /** + * 表名转换成Java类名 + * + * @param tableName 表名称 + * @return 类名 + */ + public static String convertClassName(String tableName) + { + boolean autoRemovePre = GenConfig.getAutoRemovePre(); + String tablePrefix = GenConfig.getTablePrefix(); + if (autoRemovePre && StringUtils.isNotEmpty(tablePrefix)) + { + String[] searchList = StringUtils.split(tablePrefix, ","); + tableName = replaceFirst(tableName, searchList); + } + return StringUtils.convertToCamelCase(tableName); + } + + /** + * 批量替换前缀 + * + * @param replacementm 替换值 + * @param searchList 替换列表 + * @return + */ + public static String replaceFirst(String replacementm, String[] searchList) + { + String text = replacementm; + for (String searchString : searchList) + { + if (replacementm.startsWith(searchString)) + { + text = replacementm.replaceFirst(searchString, ""); + break; + } + } + return text; + } + + /** + * 关键字替换 + * + * @param text 需要被替换的名字 + * @return 替换后的名字 + */ + public static String replaceText(String text) + { + return RegExUtils.replaceAll(text, "(?:表|若依)", ""); + } + + /** + * 获取数据库类型字段 + * + * @param columnType 列类型 + * @return 截取后的列类型 + */ + public static String getDbType(String columnType) + { + if (StringUtils.indexOf(columnType, "(") > 0) + { + return StringUtils.substringBefore(columnType, "("); + } + else + { + return columnType; + } + } + + /** + * 获取字段长度 + * + * @param columnType 列类型 + * @return 截取后的列类型 + */ + public static Integer getColumnLength(String columnType) + { + if (StringUtils.indexOf(columnType, "(") > 0) + { + String length = StringUtils.substringBetween(columnType, "(", ")"); + return Integer.valueOf(length); + } + else + { + return 0; + } + } +} diff --git a/dc-generator/src/main/java/com/dc/generator/util/VelocityInitializer.java b/dc-generator/src/main/java/com/dc/generator/util/VelocityInitializer.java new file mode 100644 index 0000000..0685e41 --- /dev/null +++ b/dc-generator/src/main/java/com/dc/generator/util/VelocityInitializer.java @@ -0,0 +1,35 @@ +package com.dc.generator.util; + +import com.dc.common.constant.Constants; +import org.apache.velocity.app.Velocity; + +import java.util.Properties; + +/** + * VelocityEngine工厂 + * + * @author win + */ +public class VelocityInitializer +{ + /** + * 初始化vm方法 + */ + public static void initVelocity() + { + Properties p = new Properties(); + try + { + // 加载classpath目录下的vm文件 + p.setProperty("resource.loader.file.class", "org.apache.velocity.runtime.resource.loader.ClasspathResourceLoader"); + // 定义字符集 + p.setProperty(Velocity.INPUT_ENCODING, Constants.UTF8); + // 初始化Velocity引擎,指定配置Properties + Velocity.init(p); + } + catch (Exception e) + { + throw new RuntimeException(e); + } + } +} diff --git a/dc-generator/src/main/java/com/dc/generator/util/VelocityUtils.java b/dc-generator/src/main/java/com/dc/generator/util/VelocityUtils.java new file mode 100644 index 0000000..f3df14e --- /dev/null +++ b/dc-generator/src/main/java/com/dc/generator/util/VelocityUtils.java @@ -0,0 +1,398 @@ +package com.dc.generator.util; + +import com.alibaba.fastjson2.JSON; +import com.alibaba.fastjson2.JSONObject; +import com.dc.common.utils.StringUtils; +import com.dc.generator.domain.GenTable; +import com.dc.generator.domain.GenTableColumn; +import com.dc.common.constant.GenConstants; +import com.dc.common.utils.DateUtils; +import org.apache.velocity.VelocityContext; + +import java.util.ArrayList; +import java.util.HashSet; +import java.util.List; +import java.util.Set; + +/** + * 模板处理工具类 + * + * @author win + */ +public class VelocityUtils +{ + /** 项目空间路径 */ + private static final String PROJECT_PATH = "main/java"; + + /** mybatis空间路径 */ + private static final String MYBATIS_PATH = "main/resources/mapper"; + + /** 默认上级菜单,系统工具 */ + private static final String DEFAULT_PARENT_MENU_ID = "3"; + + /** + * 设置模板变量信息 + * + * @return 模板列表 + */ + public static VelocityContext prepareContext(GenTable genTable) + { + String moduleName = genTable.getModuleName(); + String businessName = genTable.getBusinessName(); + String packageName = genTable.getPackageName(); + String tplCategory = genTable.getTplCategory(); + String functionName = genTable.getFunctionName(); + + VelocityContext velocityContext = new VelocityContext(); + velocityContext.put("tplCategory", genTable.getTplCategory()); + velocityContext.put("tableName", genTable.getTableName()); + velocityContext.put("functionName", StringUtils.isNotEmpty(functionName) ? functionName : "【请填写功能名称】"); + velocityContext.put("ClassName", genTable.getClassName()); + velocityContext.put("className", StringUtils.uncapitalize(genTable.getClassName())); + velocityContext.put("moduleName", genTable.getModuleName()); + velocityContext.put("BusinessName", StringUtils.capitalize(genTable.getBusinessName())); + velocityContext.put("businessName", genTable.getBusinessName()); + velocityContext.put("basePackage", getPackagePrefix(packageName)); + velocityContext.put("packageName", packageName); + velocityContext.put("author", genTable.getFunctionAuthor()); + velocityContext.put("datetime", DateUtils.getDate()); + velocityContext.put("pkColumn", genTable.getPkColumn()); + velocityContext.put("importList", getImportList(genTable)); + velocityContext.put("permissionPrefix", getPermissionPrefix(moduleName, businessName)); + velocityContext.put("columns", genTable.getColumns()); + velocityContext.put("table", genTable); + velocityContext.put("dicts", getDicts(genTable)); + setMenuVelocityContext(velocityContext, genTable); + if (GenConstants.TPL_TREE.equals(tplCategory)) + { + setTreeVelocityContext(velocityContext, genTable); + } + if (GenConstants.TPL_SUB.equals(tplCategory)) + { + setSubVelocityContext(velocityContext, genTable); + } + return velocityContext; + } + + public static void setMenuVelocityContext(VelocityContext context, GenTable genTable) + { + String options = genTable.getOptions(); + JSONObject paramsObj = JSON.parseObject(options); + String parentMenuId = getParentMenuId(paramsObj); + context.put("parentMenuId", parentMenuId); + } + + public static void setTreeVelocityContext(VelocityContext context, GenTable genTable) + { + String options = genTable.getOptions(); + JSONObject paramsObj = JSON.parseObject(options); + String treeCode = getTreecode(paramsObj); + String treeParentCode = getTreeParentCode(paramsObj); + String treeName = getTreeName(paramsObj); + + context.put("treeCode", treeCode); + context.put("treeParentCode", treeParentCode); + context.put("treeName", treeName); + context.put("expandColumn", getExpandColumn(genTable)); + if (paramsObj.containsKey(GenConstants.TREE_PARENT_CODE)) + { + context.put("tree_parent_code", paramsObj.getString(GenConstants.TREE_PARENT_CODE)); + } + if (paramsObj.containsKey(GenConstants.TREE_NAME)) + { + context.put("tree_name", paramsObj.getString(GenConstants.TREE_NAME)); + } + } + + public static void setSubVelocityContext(VelocityContext context, GenTable genTable) + { + GenTable subTable = genTable.getSubTable(); + String subTableName = genTable.getSubTableName(); + String subTableFkName = genTable.getSubTableFkName(); + String subClassName = genTable.getSubTable().getClassName(); + String subTableFkClassName = StringUtils.convertToCamelCase(subTableFkName); + + context.put("subTable", subTable); + context.put("subTableName", subTableName); + context.put("subTableFkName", subTableFkName); + context.put("subTableFkClassName", subTableFkClassName); + context.put("subTableFkclassName", StringUtils.uncapitalize(subTableFkClassName)); + context.put("subClassName", subClassName); + context.put("subclassName", StringUtils.uncapitalize(subClassName)); + context.put("subImportList", getImportList(genTable.getSubTable())); + } + + /** + * 获取模板信息 + * + * @return 模板列表 + */ + public static List<String> getTemplateList(String tplCategory) + { + List<String> templates = new ArrayList<String>(); + templates.add("vm/java/domain.java.vm"); + templates.add("vm/java/mapper.java.vm"); + templates.add("vm/java/service.java.vm"); + templates.add("vm/java/controller.java.vm"); + templates.add("vm/xml/mapper.xml.vm"); + templates.add("vm/sql/sql.vm"); + templates.add("vm/js/api.js.vm"); + if (GenConstants.TPL_CRUD.equals(tplCategory)) + { + templates.add("vm/vue/index.vue.vm"); + } + else if (GenConstants.TPL_TREE.equals(tplCategory)) + { + templates.add("vm/vue/index-tree.vue.vm"); + } + else if (GenConstants.TPL_SUB.equals(tplCategory)) + { + templates.add("vm/vue/index.vue.vm"); + templates.add("vm/java/sub-domain.java.vm"); + } + return templates; + } + + /** + * 获取文件名 + */ + public static String getFileName(String template, GenTable genTable) + { + // 文件名称 + String fileName = ""; + // 包路径 + String packageName = genTable.getPackageName(); + // 模块名 + String moduleName = genTable.getModuleName(); + // 大写类名 + String className = genTable.getClassName(); + // 业务名称 + String businessName = genTable.getBusinessName(); + + String javaPath = PROJECT_PATH + "/" + StringUtils.replace(packageName, ".", "/"); + String mybatisPath = MYBATIS_PATH + "/" + moduleName; + String vuePath = "vue"; + + if (template.contains("domain.java.vm")) + { + fileName = StringUtils.format("{}/domain/{}.java", javaPath, className); + } + if (template.contains("sub-domain.java.vm") && StringUtils.equals(GenConstants.TPL_SUB, genTable.getTplCategory())) + { + fileName = StringUtils.format("{}/domain/{}.java", javaPath, genTable.getSubTable().getClassName()); + } + else if (template.contains("mapper.java.vm")) + { + fileName = StringUtils.format("{}/mapper/{}Mapper.java", javaPath, className); + } + else if (template.contains("service.java.vm")) + { + fileName = StringUtils.format("{}/service/{}Service.java", javaPath, className); + } + else if (template.contains("controller.java.vm")) + { + fileName = StringUtils.format("{}/controller/{}Controller.java", javaPath, className); + } + else if (template.contains("mapper.xml.vm")) + { + fileName = StringUtils.format("{}/{}Mapper.xml", mybatisPath, className); + } + else if (template.contains("sql.vm")) + { + fileName = businessName + "Menu.sql"; + } + else if (template.contains("api.js.vm")) + { + fileName = StringUtils.format("{}/api/{}/{}.js", vuePath, moduleName, businessName); + } + else if (template.contains("index.vue.vm")) + { + fileName = StringUtils.format("{}/views/{}/{}/index.vue", vuePath, moduleName, businessName); + } + else if (template.contains("index-tree.vue.vm")) + { + fileName = StringUtils.format("{}/views/{}/{}/index.vue", vuePath, moduleName, businessName); + } + return fileName; + } + + /** + * 获取包前缀 + * + * @param packageName 包名称 + * @return 包前缀名称 + */ + public static String getPackagePrefix(String packageName) + { + int lastIndex = packageName.lastIndexOf("."); + return StringUtils.substring(packageName, 0, lastIndex); + } + + /** + * 根据列类型获取导入包 + * + * @param genTable 业务表对象 + * @return 返回需要导入的包列表 + */ + public static HashSet<String> getImportList(GenTable genTable) + { + List<GenTableColumn> columns = genTable.getColumns(); + GenTable subGenTable = genTable.getSubTable(); + HashSet<String> importList = new HashSet<String>(); + if (StringUtils.isNotNull(subGenTable)) + { + importList.add("java.util.List"); + } + for (GenTableColumn column : columns) + { + if (!column.isSuperColumn() && GenConstants.TYPE_DATE.equals(column.getJavaType())) + { + importList.add("java.util.Date"); + importList.add("com.fasterxml.jackson.annotation.JsonFormat"); + } + else if (!column.isSuperColumn() && GenConstants.TYPE_BIGDECIMAL.equals(column.getJavaType())) + { + importList.add("java.math.BigDecimal"); + } + } + return importList; + } + + /** + * 根据列类型获取字典组 + * + * @param genTable 业务表对象 + * @return 返回字典组 + */ + public static String getDicts(GenTable genTable) + { + List<GenTableColumn> columns = genTable.getColumns(); + Set<String> dicts = new HashSet<String>(); + addDicts(dicts, columns); + if (StringUtils.isNotNull(genTable.getSubTable())) + { + List<GenTableColumn> subColumns = genTable.getSubTable().getColumns(); + addDicts(dicts, subColumns); + } + return StringUtils.join(dicts, ", "); + } + + /** + * 添加字典列表 + * + * @param dicts 字典列表 + * @param columns 列集合 + */ + public static void addDicts(Set<String> dicts, List<GenTableColumn> columns) + { + for (GenTableColumn column : columns) + { + if (!column.isSuperColumn() && StringUtils.isNotEmpty(column.getDictType()) && StringUtils.equalsAny( + column.getHtmlType(), + new String[] { GenConstants.HTML_SELECT, GenConstants.HTML_RADIO, GenConstants.HTML_CHECKBOX })) + { + dicts.add("'" + column.getDictType() + "'"); + } + } + } + + /** + * 获取权限前缀 + * + * @param moduleName 模块名称 + * @param businessName 业务名称 + * @return 返回权限前缀 + */ + public static String getPermissionPrefix(String moduleName, String businessName) + { + return StringUtils.format("{}:{}", moduleName, businessName); + } + + /** + * 获取上级菜单ID字段 + * + * @param paramsObj 生成其他选项 + * @return 上级菜单ID字段 + */ + public static String getParentMenuId(JSONObject paramsObj) + { + if (StringUtils.isNotEmpty(paramsObj) && paramsObj.containsKey(GenConstants.PARENT_MENU_ID) + && StringUtils.isNotEmpty(paramsObj.getString(GenConstants.PARENT_MENU_ID))) + { + return paramsObj.getString(GenConstants.PARENT_MENU_ID); + } + return DEFAULT_PARENT_MENU_ID; + } + + /** + * 获取树编码 + * + * @param paramsObj 生成其他选项 + * @return 树编码 + */ + public static String getTreecode(JSONObject paramsObj) + { + if (paramsObj.containsKey(GenConstants.TREE_CODE)) + { + return StringUtils.toCamelCase(paramsObj.getString(GenConstants.TREE_CODE)); + } + return StringUtils.EMPTY; + } + + /** + * 获取树父编码 + * + * @param paramsObj 生成其他选项 + * @return 树父编码 + */ + public static String getTreeParentCode(JSONObject paramsObj) + { + if (paramsObj.containsKey(GenConstants.TREE_PARENT_CODE)) + { + return StringUtils.toCamelCase(paramsObj.getString(GenConstants.TREE_PARENT_CODE)); + } + return StringUtils.EMPTY; + } + + /** + * 获取树名称 + * + * @param paramsObj 生成其他选项 + * @return 树名称 + */ + public static String getTreeName(JSONObject paramsObj) + { + if (paramsObj.containsKey(GenConstants.TREE_NAME)) + { + return StringUtils.toCamelCase(paramsObj.getString(GenConstants.TREE_NAME)); + } + return StringUtils.EMPTY; + } + + /** + * 获取需要在哪一列上面显示展开按钮 + * + * @param genTable 业务表对象 + * @return 展开按钮列序号 + */ + public static int getExpandColumn(GenTable genTable) + { + String options = genTable.getOptions(); + JSONObject paramsObj = JSON.parseObject(options); + String treeName = paramsObj.getString(GenConstants.TREE_NAME); + int num = 0; + for (GenTableColumn column : genTable.getColumns()) + { + if (column.isList()) + { + num++; + String columnName = column.getColumnName(); + if (columnName.equals(treeName)) + { + break; + } + } + } + return num; + } +} diff --git a/dc-generator/src/main/resources/generator.yml b/dc-generator/src/main/resources/generator.yml new file mode 100644 index 0000000..89d0325 --- /dev/null +++ b/dc-generator/src/main/resources/generator.yml @@ -0,0 +1,10 @@ +# 代码生成 +gen: + # 作者 + author: win + # 默认生成包路径 system 需改成自己的模块名称 如 system monitor tool + packageName: com.dc.system + # 自动去除表前缀,默认是false + autoRemovePre: false + # 表前缀(生成类名不会包含表前缀,多个用逗号分隔) + tablePrefix: sys_ \ No newline at end of file diff --git a/dc-generator/src/main/resources/mapper/generator/GenTableColumnMapper.xml b/dc-generator/src/main/resources/mapper/generator/GenTableColumnMapper.xml new file mode 100644 index 0000000..fc36a55 --- /dev/null +++ b/dc-generator/src/main/resources/mapper/generator/GenTableColumnMapper.xml @@ -0,0 +1,128 @@ +<?xml version="1.0" encoding="UTF-8" ?> +<!DOCTYPE mapper + PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" + "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> + <mapper namespace="com.dc.generator.mapper.GenTableColumnMapper"> + + <resultMap type="GenTableColumn" id="GenTableColumnResult"> + <id property="columnId" column="column_id"/> + <result property="tableId" column="table_id"/> + <result property="columnName" column="column_name"/> + <result property="columnComment" column="column_comment"/> + <result property="columnType" column="column_type"/> + <result property="javaType" column="java_type"/> + <result property="javaField" column="java_field"/> + <result property="isPk" column="is_pk"/> + <result property="isIncrement" column="is_increment"/> + <result property="isRequired" column="is_required"/> + <result property="isInsert" column="is_insert"/> + <result property="isEdit" column="is_edit"/> + <result property="isList" column="is_list"/> + <result property="isQuery" column="is_query"/> + <result property="queryType" column="query_type"/> + <result property="htmlType" column="html_type"/> + <result property="dictType" column="dict_type"/> + <result property="sort" column="sort"/> + <result property="createBy" column="create_by"/> + <result property="createTime" column="create_time"/> + <result property="updateBy" column="update_by"/> + <result property="updateTime" column="update_time"/> + </resultMap> + + <sql id="selectGenTableColumnVo"> + select column_id, table_id, column_name, column_comment, column_type, java_type, java_field, is_pk, + is_increment, is_required, is_insert, is_edit, is_list, is_query, query_type, html_type, dict_type, sort, + create_by, create_time, update_by, update_time from gen_table_column + </sql> + + <select id="selectGenTableColumnListByTableId" parameterType="Long" resultMap="GenTableColumnResult"> + <include refid="selectGenTableColumnVo"/> + where table_id::bigint = #{tableId} + order by sort + </select> + + <select id="selectDbTableColumnsByName" parameterType="String" resultMap="GenTableColumnResult"> + select column_name, is_required, is_pk, sort, column_comment, is_increment, column_type + from list_column where table_name = (#{tableName}) + </select> + + <insert id="insertGenTableColumn" parameterType="GenTableColumn" useGeneratedKeys="true" keyProperty="columnId"> + insert into gen_table_column ( + <if test="tableId != null and tableId != ''">table_id,</if> + <if test="columnName != null and columnName != ''">column_name,</if> + <if test="columnComment != null and columnComment != ''">column_comment,</if> + <if test="columnType != null and columnType != ''">column_type,</if> + <if test="javaType != null and javaType != ''">java_type,</if> + <if test="javaField != null and javaField != ''">java_field,</if> + <if test="isPk != null and isPk != ''">is_pk,</if> + <if test="isIncrement != null and isIncrement != ''">is_increment,</if> + <if test="isRequired != null and isRequired != ''">is_required,</if> + <if test="isInsert != null and isInsert != ''">is_insert,</if> + <if test="isEdit != null and isEdit != ''">is_edit,</if> + <if test="isList != null and isList != ''">is_list,</if> + <if test="isQuery != null and isQuery != ''">is_query,</if> + <if test="queryType != null and queryType != ''">query_type,</if> + <if test="htmlType != null and htmlType != ''">html_type,</if> + <if test="dictType != null and dictType != ''">dict_type,</if> + <if test="sort != null">sort,</if> + <if test="createBy != null and createBy != ''">create_by,</if> + create_time + )values( + <if test="tableId != null and tableId != ''">#{tableId},</if> + <if test="columnName != null and columnName != ''">#{columnName},</if> + <if test="columnComment != null and columnComment != ''">#{columnComment},</if> + <if test="columnType != null and columnType != ''">#{columnType},</if> + <if test="javaType != null and javaType != ''">#{javaType},</if> + <if test="javaField != null and javaField != ''">#{javaField},</if> + <if test="isPk != null and isPk != ''">#{isPk},</if> + <if test="isIncrement != null and isIncrement != ''">#{isIncrement},</if> + <if test="isRequired != null and isRequired != ''">#{isRequired},</if> + <if test="isInsert != null and isInsert != ''">#{isInsert},</if> + <if test="isEdit != null and isEdit != ''">#{isEdit},</if> + <if test="isList != null and isList != ''">#{isList},</if> + <if test="isQuery != null and isQuery != ''">#{isQuery},</if> + <if test="queryType != null and queryType != ''">#{queryType},</if> + <if test="htmlType != null and htmlType != ''">#{htmlType},</if> + <if test="dictType != null and dictType != ''">#{dictType},</if> + <if test="sort != null">#{sort},</if> + <if test="createBy != null and createBy != ''">#{createBy},</if> + current_timestamp + ) + </insert> + + <update id="updateGenTableColumn" parameterType="GenTableColumn"> + update gen_table_column + <set> + <if test="columnComment != null">column_comment = #{columnComment},</if> + <if test="javaType != null">java_type = #{javaType},</if> + <if test="javaField != null">java_field = #{javaField},</if> + <if test="isInsert != null">is_insert = #{isInsert},</if> + <if test="isEdit != null">is_edit = #{isEdit},</if> + <if test="isList != null">is_list = #{isList},</if> + <if test="isQuery != null">is_query = #{isQuery},</if> + <if test="isRequired != null">is_required = #{isRequired},</if> + <if test="queryType != null">query_type = #{queryType},</if> + <if test="htmlType != null">html_type = #{htmlType},</if> + <if test="dictType != null">dict_type = #{dictType},</if> + <if test="sort != null">sort = #{sort},</if> + <if test="updateBy != null">update_by = #{updateBy},</if> + update_time = current_timestamp + </set> + where column_id = #{columnId} + </update> + + <delete id="deleteGenTableColumnByIds" parameterType="Long"> + delete from gen_table_column where table_id::bigint in + <foreach collection="array" item="tableId" open="(" separator="," close=")"> + #{tableId} + </foreach> + </delete> + + <delete id="deleteGenTableColumns"> + delete from gen_table_column where column_id::bigint in + <foreach collection="list" item="item" open="(" separator="," close=")"> + #{item.columnId} + </foreach> + </delete> + +</mapper> diff --git a/dc-generator/src/main/resources/mapper/generator/GenTableMapper.xml b/dc-generator/src/main/resources/mapper/generator/GenTableMapper.xml new file mode 100644 index 0000000..52797d8 --- /dev/null +++ b/dc-generator/src/main/resources/mapper/generator/GenTableMapper.xml @@ -0,0 +1,217 @@ +<?xml version="1.0" encoding="UTF-8" ?> +<!DOCTYPE mapper + PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" + "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> +<mapper namespace="com.dc.generator.mapper.GenTableMapper"> + + <resultMap type="GenTable" id="GenTableResult"> + <id property="tableId" column="table_id"/> + <result property="tableName" column="table_name"/> + <result property="tableComment" column="table_comment"/> + <result property="subTableName" column="sub_table_name"/> + <result property="subTableFkName" column="sub_table_fk_name"/> + <result property="className" column="class_name"/> + <result property="tplCategory" column="tpl_category"/> + <result property="packageName" column="package_name"/> + <result property="moduleName" column="module_name"/> + <result property="businessName" column="business_name"/> + <result property="functionName" column="function_name"/> + <result property="functionAuthor" column="function_author"/> + <result property="genType" column="gen_type"/> + <result property="genPath" column="gen_path"/> + <result property="options" column="options"/> + <result property="createBy" column="create_by"/> + <result property="createTime" column="create_time"/> + <result property="updateBy" column="update_by"/> + <result property="updateTime" column="update_time"/> + <result property="remark" column="remark"/> + <collection property="columns" javaType="java.util.List" resultMap="GenTableColumnResult"/> + </resultMap> + + <resultMap type="GenTableColumn" id="GenTableColumnResult"> + <id property="columnId" column="column_id"/> + <result property="tableId" column="table_id"/> + <result property="columnName" column="column_name"/> + <result property="columnComment" column="column_comment"/> + <result property="columnType" column="column_type"/> + <result property="javaType" column="java_type"/> + <result property="javaField" column="java_field"/> + <result property="isPk" column="is_pk"/> + <result property="isIncrement" column="is_increment"/> + <result property="isRequired" column="is_required"/> + <result property="isInsert" column="is_insert"/> + <result property="isEdit" column="is_edit"/> + <result property="isList" column="is_list"/> + <result property="isQuery" column="is_query"/> + <result property="queryType" column="query_type"/> + <result property="htmlType" column="html_type"/> + <result property="dictType" column="dict_type"/> + <result property="sort" column="sort"/> + <result property="createBy" column="create_by"/> + <result property="createTime" column="create_time"/> + <result property="updateBy" column="update_by"/> + <result property="updateTime" column="update_time"/> + </resultMap> + + <sql id="selectGenTableVo"> + select table_id, table_name, table_comment, sub_table_name, sub_table_fk_name, class_name, tpl_category, + package_name, module_name, business_name, function_name, function_author, gen_type, gen_path, options, + create_by, create_time, update_by, update_time, remark from gen_table + </sql> + + <select id="selectGenTableList" parameterType="GenTable" resultMap="GenTableResult"> + <include refid="selectGenTableVo"/> + <where> + <if test="tableName != null and tableName != ''"> + AND lower(table_name) like lower(concat('%', #{tableName}, '%')) + </if> + <if test="tableComment != null and tableComment != ''"> + AND lower(table_comment) like lower(concat('%', #{tableComment}, '%')) + </if> + <if test="params.beginTime != null and params.beginTime != ''"><!-- 开始时间检索 --> + and to_char(create_time,'yyyy-MM-dd') >= to_char(#{params.beginTime},'yyyy-MM-dd') + </if> + <if test="params.endTime != null and params.endTime != ''"><!-- 结束时间检索 --> + and to_char(create_time,'yyyy-MM-dd') <= to_char(#{params.endTime},'yyyy-MM-dd') + </if> + </where> + </select> + + <select id="selectDbTableList" parameterType="GenTable" resultMap="GenTableResult"> + SELECT table_name, table_comment, create_time, update_time + FROM list_table + WHERE table_name NOT LIKE 'qrtz_%' AND table_name NOT LIKE 'gen_%' + AND table_name NOT IN (select table_name from gen_table) + <if test="tableName != null and tableName != ''"> + AND lower(table_name) like lower(concat('%', #{tableName}, '%')) + </if> + <if test="tableComment != null and tableComment != ''"> + AND lower(table_comment) like lower(concat('%', #{tableComment}, '%')) + </if> + <if test="params.beginTime != null and params.beginTime != ''"><!-- 开始时间检索 --> + and create_time::date >= to_date(#{params.beginTime},'yyyy-MM-dd') + </if> + <if test="params.endTime != null and params.endTime != ''"><!-- 结束时间检索 --> + and create_time::date <= to_date(#{params.endTime},'yyyy-MM-dd') + </if> + order by create_time desc + </select> + + <select id="selectDbTableListByNames" resultMap="GenTableResult"> + SELECT table_name, table_comment, create_time, update_time + FROM list_table + where table_name NOT LIKE 'qrtz_%' AND table_name NOT LIKE 'gen_%' + and table_name in + <foreach collection="array" item="name" open="(" separator="," close=")"> + #{name} + </foreach> + </select> + + <select id="selectTableByName" parameterType="String" resultMap="GenTableResult"> + SELECT table_name, table_comment, create_time, update_time + FROM list_table + where table_name = #{tableName} + </select> + + <select id="selectGenTableById" parameterType="Long" resultMap="GenTableResult"> + SELECT t.table_id, t.table_name, t.table_comment, t.sub_table_name, t.sub_table_fk_name, t.class_name, + t.tpl_category, t.package_name, t.module_name, t.business_name, t.function_name, t.function_author, t.gen_type, + t.gen_path, t.options, t.remark, + c.column_id, c.column_name, c.column_comment, c.column_type, c.java_type, c.java_field, c.is_pk, c.is_increment, + c.is_required, c.is_insert, c.is_edit, c.is_list, c.is_query, c.query_type, c.html_type, + coalesce(c.dict_type,'') as dict_type, c.sort + FROM gen_table t + LEFT JOIN gen_table_column c ON t.table_id = c.table_id::bigint + where t.table_id = #{tableId} order by c.sort + </select> + + <select id="selectGenTableByName" parameterType="String" resultMap="GenTableResult"> + SELECT t.table_id, t.table_name, t.table_comment, t.sub_table_name, t.sub_table_fk_name, t.class_name, + t.tpl_category, t.package_name, t.module_name, t.business_name, t.function_name, t.function_author, t.gen_type, + t.gen_path, t.options, t.remark, + c.column_id, c.column_name, c.column_comment, c.column_type, c.java_type, c.java_field, c.is_pk, c.is_increment, + c.is_required, c.is_insert, c.is_edit, c.is_list, c.is_query, c.query_type, c.html_type, + coalesce(c.dict_type,'') as dict_type, c.sort + FROM gen_table t + LEFT JOIN gen_table_column c ON t.table_id = c.table_id::bigint + where t.table_name = #{tableName} order by c.sort + </select> + + <select id="selectGenTableAll" parameterType="String" resultMap="GenTableResult"> + SELECT t.table_id, t.table_name, t.table_comment, t.sub_table_name, t.sub_table_fk_name, t.class_name, + t.tpl_category, t.package_name, t.module_name, t.business_name, t.function_name, t.function_author, t.options, + t.remark, + c.column_id, c.column_name, c.column_comment, c.column_type, c.java_type, c.java_field, c.is_pk, c.is_increment, + c.is_required, c.is_insert, c.is_edit, c.is_list, c.is_query, c.query_type, c.html_type, + coalesce(c.dict_type,'') as dict_type, c.sort + FROM gen_table t + LEFT JOIN gen_table_column c ON t.table_id = c.table_id::bigint + order by c.sort + </select> + + <insert id="insertGenTable" parameterType="GenTable" useGeneratedKeys="true" keyProperty="tableId"> + insert into gen_table ( + <if test="tableName != null">table_name,</if> + <if test="tableComment != null and tableComment != ''">table_comment,</if> + <if test="className != null and className != ''">class_name,</if> + <if test="tplCategory != null and tplCategory != ''">tpl_category,</if> + <if test="packageName != null and packageName != ''">package_name,</if> + <if test="moduleName != null and moduleName != ''">module_name,</if> + <if test="businessName != null and businessName != ''">business_name,</if> + <if test="functionName != null and functionName != ''">function_name,</if> + <if test="functionAuthor != null and functionAuthor != ''">function_author,</if> + <if test="genType != null and genType != ''">gen_type,</if> + <if test="genPath != null and genPath != ''">gen_path,</if> + <if test="remark != null and remark != ''">remark,</if> + <if test="createBy != null and createBy != ''">create_by,</if> + create_time + )values( + <if test="tableName != null">#{tableName},</if> + <if test="tableComment != null and tableComment != ''">#{tableComment},</if> + <if test="className != null and className != ''">#{className},</if> + <if test="tplCategory != null and tplCategory != ''">#{tplCategory},</if> + <if test="packageName != null and packageName != ''">#{packageName},</if> + <if test="moduleName != null and moduleName != ''">#{moduleName},</if> + <if test="businessName != null and businessName != ''">#{businessName},</if> + <if test="functionName != null and functionName != ''">#{functionName},</if> + <if test="functionAuthor != null and functionAuthor != ''">#{functionAuthor},</if> + <if test="genType != null and genType != ''">#{genType},</if> + <if test="genPath != null and genPath != ''">#{genPath},</if> + <if test="remark != null and remark != ''">#{remark},</if> + <if test="createBy != null and createBy != ''">#{createBy},</if> + current_timestamp + ) + </insert> + + <update id="updateGenTable" parameterType="GenTable"> + update gen_table + <set> + <if test="tableName != null">table_name = #{tableName},</if> + <if test="tableComment != null and tableComment != ''">table_comment = #{tableComment},</if> + <if test="subTableName != null">sub_table_name = #{subTableName},</if> + <if test="subTableFkName != null">sub_table_fk_name = #{subTableFkName},</if> + <if test="className != null and className != ''">class_name = #{className},</if> + <if test="functionAuthor != null and functionAuthor != ''">function_author = #{functionAuthor},</if> + <if test="genType != null and genType != ''">gen_type = #{genType},</if> + <if test="genPath != null and genPath != ''">gen_path = #{genPath},</if> + <if test="tplCategory != null and tplCategory != ''">tpl_category = #{tplCategory},</if> + <if test="packageName != null and packageName != ''">package_name = #{packageName},</if> + <if test="moduleName != null and moduleName != ''">module_name = #{moduleName},</if> + <if test="businessName != null and businessName != ''">business_name = #{businessName},</if> + <if test="functionName != null and functionName != ''">function_name = #{functionName},</if> + <if test="options != null and options != ''">options = #{options},</if> + <if test="updateBy != null and updateBy != ''">update_by = #{updateBy},</if> + <if test="remark != null">remark = #{remark},</if> + update_time = current_timestamp + </set> + where table_id = #{tableId} + </update> + + <delete id="deleteGenTableByIds" parameterType="Long"> + delete from gen_table where table_id::bigint in + <foreach collection="array" item="tableId" open="(" separator="," close=")"> + #{tableId} + </foreach> + </delete> + +</mapper> diff --git a/dc-generator/src/main/resources/vm/doc/doc.md.vm b/dc-generator/src/main/resources/vm/doc/doc.md.vm new file mode 100644 index 0000000..f05bc5a --- /dev/null +++ b/dc-generator/src/main/resources/vm/doc/doc.md.vm @@ -0,0 +1,172 @@ +#set($mark ="#") +[TOC] +$mark$mark$mark 查询${functionName}列表 + +**请求URL:** +- ` /${baseUrl}/list ` + +**请求方式:** +- GET + +**参数:** + +|参数名|必选|类型|说明| +|:---- |:---|:----- |----- | +#foreach ($column in $columns) +#if(!$column.pk) +#if(!$column.superColumn) +|$column.javaField | 否|$column.javaType |$column.columnComment | +#end +#end +#end +|pageNum | 否 |int |页码 | +|pageSize | 否 |int |行数 | + + **返回示例** +``` + { + "code": 0, + "msg": "success", + "rows": [] + } +``` + **返回参数说明** + +|参数名|类型|说明| +|:----- |:-----|----- | +#foreach ($column in $columns) +|$column.javaField |$column.javaType |$column.columnComment | +#end + + **备注** + +- 更多返回错误代码请看首页的错误代码描述 + +--- + +$mark$mark$mark 查询${functionName}详情 + +**请求URL:** +- ` /${baseUrl}/{${pkColumn.javaField}} ` + +**请求方式:** +- GET + +**参数:** + +|参数名|必选|类型|说明| +|:---- |:---|:----- |----- | +|${pkColumn.javaField} |是 |${pkColumn.javaType} |${pkColumn.columnName} | + + **返回示例** +``` + { + "code": 0, + "msg": "success", + "data": {} + } +``` + **返回参数说明** + +|参数名|类型|说明| +|:----- |:-----|----- | +#foreach ($column in $columns) +|$column.javaField |$column.javaType |$column.columnComment | +#end + + **备注** + +- 更多返回错误代码请看首页的错误代码描述 + +--- +$mark$mark$mark 新增${functionName} + +**请求URL:** +- ` /${baseUrl} ` + +**请求方式:** +- POST + +**参数:** + +|参数名|必选|类型|说明| +|:---- |:---|:----- |----- | +#foreach ($column in $columns) +#if(!$column.pk) +#if(!$column.superColumn) +|$column.javaField |#if($column.required) 是 #else 否 #end|$column.javaType |$column.columnComment | +#end +#end +#end + + **返回示例** +``` + { + "code": 0, + "msg": "success" + } +``` + + **备注** + +- 更多返回错误代码请看首页的错误代码描述 + +--- + +$mark$mark$mark 修改${functionName} + +**请求URL:** +- ` /${baseUrl} ` + +**请求方式:** +- PUT + +**参数:** + +|参数名|必选|类型|说明| +|:---- |:---|:----- |----- | +#foreach ($column in $columns) +#if(!$column.superColumn) +|$column.javaField |#if($column.pk) 是 #else 否 #end |$column.javaType |$column.columnComment | +#end +#end + + **返回示例** +``` + { + "code": 0, + "msg": "success" + } +``` + + **备注** + +- 更多返回错误代码请看首页的错误代码描述 + +--- + +$mark$mark$mark 删除${functionName} + +**请求URL:** +- ` /${baseUrl}/{${pkColumn.javaField}s} ` + +**请求方式:** +- DELETE + +**参数:** + +|参数名|必选|类型|说明| +|:---- |:---|:----- |----- | +|${pkColumn.javaField}s |是 |${pkColumn.javaType} |${pkColumn.columnName} 英文逗号间隔 | + + **返回示例** +``` + { + "code": 0, + "msg": "success" + } +``` + + **备注** + +- 更多返回错误代码请看首页的错误代码描述 \ No newline at end of file diff --git a/dc-generator/src/main/resources/vm/java/controller.java.vm b/dc-generator/src/main/resources/vm/java/controller.java.vm new file mode 100644 index 0000000..738d496 --- /dev/null +++ b/dc-generator/src/main/resources/vm/java/controller.java.vm @@ -0,0 +1,264 @@ +package com.dc.controller.base; + +import java.time.LocalDateTime; +import java.util.List; + +import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; +import Log; +import BaseController; +import AjaxResult; +import TableDataInfo; +import BusinessType; +import BeanValidators; +import ExcelUtil; +import ${packageName}.domain.${ClassName}; +import ${packageName}.service.${ClassName}Service; +import io.swagger.annotations.ApiOperation; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.web.bind.annotation.GetMapping; +import org.springframework.web.bind.annotation.PostMapping; +import org.springframework.web.bind.annotation.PutMapping; +import org.springframework.web.bind.annotation.DeleteMapping; +import org.springframework.web.bind.annotation.PathVariable; +import org.springframework.web.bind.annotation.RequestBody; +import org.springframework.web.bind.annotation.RequestMapping; +import org.springframework.web.bind.annotation.RestController; + +import javax.servlet.http.HttpServletResponse; +import javax.validation.Valid; +import javax.validation.Validator; + +/** + * ${functionName}Controller + * + * @author ${author} + * @date ${datetime} + */ +@RestController +@RequestMapping("/base/${className}") +public class ${ClassName}Controller extends BaseController { + + @Autowired + protected Validator validator; + @Autowired + private ${ClassName}Service ${className}Service; + + /** + * 查询${functionName}列表 + */ + @ApiOperation("查询${functionName}列表") + @GetMapping("/list") +#if($table.crud || $table.sub) + public TableDataInfo list(${ClassName} ${className}) { + startPage(); + QueryWrapper<${ClassName}> queryWrapper = new QueryWrapper<>(); + queryWrapper.isNull("delete_time"); + #foreach($column in $columns) + #set($queryType=$column.queryType) + #set($javaField=$column.javaField) + #set($javaType=$column.javaType) + #set($columnName=$column.columnName) + #set($AttrName=$column.javaField.substring(0,1).toUpperCase() + ${column.javaField.substring(1)}) + #if($column.query) + #if($column.queryType == "EQ") + if(${className}.get$AttrName() != null && !${className}.get$AttrName().equals("")) { + queryWrapper.eq("$columnName", ${className}.get$AttrName()); + } + #elseif($queryType == "NE") + if(${className}.get$AttrName() != null && !${className}.get$AttrName().equals("")) { + queryWrapper.ne("$columnName", ${className}.get$AttrName()); + } + #elseif($queryType == "GT") + if(${className}.get$AttrName() != null && !${className}.get$AttrName().equals("")) { + queryWrapper.gt("$columnName", ${className}.get$AttrName()); + } + #elseif($queryType == "GTE") + if(${className}.get$AttrName() != null && !${className}.get$AttrName().equals("")) { + queryWrapper.ge("$columnName", ${className}.get$AttrName()); + } + #elseif($queryType == "LT") + if(${className}.get$AttrName() != null && !${className}.get$AttrName().equals("")) { + queryWrapper.lt("$columnName", ${className}.get$AttrName()); + } + #elseif($queryType == "LTE") + if(${className}.get$AttrName() != null && !${className}.get$AttrName().equals("")) { + queryWrapper.le("$columnName", ${className}.get$AttrName()); + } + #elseif($queryType == "LIKE") + if(${className}.get$AttrName() != null && !${className}.get$AttrName().equals("")) { + queryWrapper.like("$columnName", ${className}.get$AttrName()); + } + #elseif($queryType == "BETWEEN") + if(${className}.getBegin$AttrName() != null && !${className}.getBegin$AttrName().equals("") && ${className}.getEnd$AttrName() != null && !${className}.getEnd$AttrName().equals("")) { + queryWrapper.between("$columnName", ${className}.getBegin$AttrName(), ${className}.getEnd$AttrName()); + } + #end + #end + #end + List<${ClassName}> list = ${className}Service.list(queryWrapper); + return getDataTable(list); + } +#elseif($table.tree) + public AjaxResult list(${ClassName} ${className}) { + QueryWrapper<${ClassName}> queryWrapper = new QueryWrapper<>(); + queryWrapper.isNull("delete_time"); + #foreach($column in $columns) + #set($queryType=$column.queryType) + #set($javaField=$column.javaField) + #set($javaType=$column.javaType) + #set($columnName=$column.columnName) + #set($AttrName=$column.javaField.substring(0,1).toUpperCase() + ${column.javaField.substring(1)}) + #if($column.query) + #if($column.queryType == "EQ") + if(${className}.get$AttrName() != null && !${className}.get$AttrName().equals("")) { + queryWrapper.eq("$columnName", ${className}.get$AttrName()); + } + #elseif($queryType == "NE") + if(${className}.get$AttrName() != null && !${className}.get$AttrName().equals("")) { + queryWrapper.ne("$columnName", ${className}.get$AttrName()); + } + #elseif($queryType == "GT") + if(${className}.get$AttrName() != null && !${className}.get$AttrName().equals("")) { + queryWrapper.gt("$columnName", ${className}.get$AttrName()); + } + #elseif($queryType == "GTE") + if(${className}.get$AttrName() != null && !${className}.get$AttrName().equals("")) { + queryWrapper.ge("$columnName", ${className}.get$AttrName()); + } + #elseif($queryType == "LT") + if(${className}.get$AttrName() != null && !${className}.get$AttrName().equals("")) { + queryWrapper.lt("$columnName", ${className}.get$AttrName()); + } + #elseif($queryType == "LTE") + if(${className}.get$AttrName() != null && !${className}.get$AttrName().equals("")) { + queryWrapper.le("$columnName", ${className}.get$AttrName()); + } + #elseif($queryType == "LIKE") + if(${className}.get$AttrName() != null && !${className}.get$AttrName().equals("")) { + queryWrapper.like("$columnName", ${className}.get$AttrName()); + } + #elseif($queryType == "BETWEEN") + if(${className}.getBegin$AttrName() != null && !${className}.getBegin$AttrName().equals("") && ${className}.getEnd$AttrName() != null && !${className}.getEnd$AttrName().equals("")) { + queryWrapper.between("$columnName", ${className}.getBegin$AttrName(), ${className}.getEnd$AttrName()); + } + #end + #end + #end + List<${ClassName}> list = ${className}Service.list(queryWrapper); + return AjaxResult.success(list); + } +#end + + /** + * 导出${functionName}列表 + */ + @ApiOperation("导出${functionName}列表") + @PostMapping("/export") + public void export(HttpServletResponse response, ${ClassName} ${className}) { + QueryWrapper<${ClassName}> queryWrapper = new QueryWrapper<>(); + queryWrapper.isNull("delete_time"); + #foreach($column in $columns) + #set($queryType=$column.queryType) + #set($javaField=$column.javaField) + #set($javaType=$column.javaType) + #set($columnName=$column.columnName) + #set($AttrName=$column.javaField.substring(0,1).toUpperCase() + ${column.javaField.substring(1)}) + #if($column.query) + #if($column.queryType == "EQ") + if(${className}.get$AttrName() != null && !${className}.get$AttrName().equals("")) { + queryWrapper.eq("$columnName", ${className}.get$AttrName()); + } + #elseif($queryType == "NE") + if(${className}.get$AttrName() != null && !${className}.get$AttrName().equals("")) { + queryWrapper.ne("$columnName", ${className}.get$AttrName()); + } + #elseif($queryType == "GT") + if(${className}.get$AttrName() != null && !${className}.get$AttrName().equals("")) { + queryWrapper.gt("$columnName", ${className}.get$AttrName()); + } + #elseif($queryType == "GTE") + if(${className}.get$AttrName() != null && !${className}.get$AttrName().equals("")) { + queryWrapper.ge("$columnName", ${className}.get$AttrName()); + } + #elseif($queryType == "LT") + if(${className}.get$AttrName() != null && !${className}.get$AttrName().equals("")) { + queryWrapper.lt("$columnName", ${className}.get$AttrName()); + } + #elseif($queryType == "LTE") + if(${className}.get$AttrName() != null && !${className}.get$AttrName().equals("")) { + queryWrapper.le("$columnName", ${className}.get$AttrName()); + } + #elseif($queryType == "LIKE") + if(${className}.get$AttrName() != null && !${className}.get$AttrName().equals("")) { + queryWrapper.like("$columnName", ${className}.get$AttrName()); + } + #elseif($queryType == "BETWEEN") + if(${className}.getBegin$AttrName() != null && !${className}.getBegin$AttrName().equals("") && ${className}.getEnd$AttrName() != null && !${className}.getEnd$AttrName().equals("")) { + queryWrapper.between("$columnName", ${className}.getBegin$AttrName(), ${className}.getEnd$AttrName()); + } + #end + #end + #end + List<${ClassName}> list = ${className}Service.list(queryWrapper); + ExcelUtil<${ClassName}> util = new ExcelUtil<>(${ClassName}.class); + util.exportExcel(response, list, "${functionName}数据"); + } + + /** + * 导入${functionName} + */ + @ApiOperation("导入${functionName}模板") + @PostMapping("/importTemplate") + public void importTemplate(HttpServletResponse response) { + ExcelUtil<${ClassName}> util = new ExcelUtil<>(${ClassName}.class); + util.importTemplateExcel(response, "${functionName}数据"); + } + + /** + * 获取${functionName}详细信息 + */ + @ApiOperation("获取${functionName}详细信息") + @GetMapping(value = "/{${pkColumn.javaField}}") + public AjaxResult getInfo(@PathVariable("${pkColumn.javaField}") ${pkColumn.javaType} ${pkColumn.javaField}) { + return AjaxResult.success(${className}Service.getById(${pkColumn.javaField})); + } + + /** + * 新增${functionName} + */ + @ApiOperation("新增${functionName}") + @Log(title = "${functionName}", businessType = BusinessType.INSERT) + @PostMapping + public AjaxResult add(@Valid @RequestBody ${ClassName} ${className}) { + BeanValidators.validateWithException(validator, ${className}); + ${className}.setDeptId(getDeptId()); + ${className}.setUserId(getUserId()); + ${className}.setCreateBy(getUserId()); + ${className}.setCreateTime(LocalDateTime.now()); + return toAjax(${className}Service.save(${className})); + } + + /** + * 修改${functionName} + */ + @ApiOperation("修改${functionName}") + @Log(title = "${functionName}", businessType = BusinessType.UPDATE) + @PutMapping + public AjaxResult edit(@Valid @RequestBody ${ClassName} ${className}) { + BeanValidators.validateWithException(validator, ${className}); + ${className}.setUpdateBy(getUserId()); + ${className}.setUpdateTime(LocalDateTime.now()); + return toAjax(${className}Service.updateById(${className})); + } + + /** + * 批量删除${functionName} + */ + @ApiOperation("批量删除${functionName}") + @Log(title = "${functionName}", businessType = BusinessType.DELETE) + @DeleteMapping("/{${pkColumn.javaField}s}") + public AjaxResult batchRemove(@PathVariable ${pkColumn.javaType}[] ${pkColumn.javaField}s) { + return toAjax(${className}Service.delete${ClassName}ByIds(ids, getUserId())); + } + +} diff --git a/dc-generator/src/main/resources/vm/java/domain.java.vm b/dc-generator/src/main/resources/vm/java/domain.java.vm new file mode 100644 index 0000000..8310f68 --- /dev/null +++ b/dc-generator/src/main/resources/vm/java/domain.java.vm @@ -0,0 +1,59 @@ +package ${packageName}.domain; + +import Excel; +import BaseEntity; +import lombok.AllArgsConstructor; +import lombok.Data; +import lombok.NoArgsConstructor; +import lombok.experimental.Accessors; + +/** + * ${functionName}对象 ${tableName} + * + * @author ${author} + * @date ${datetime} + */ +#if($table.crud || $table.sub) + +#set($Entity="BaseEntity") +#elseif($table.tree) +#set($Entity="TreeEntity") +#end +@Data +@NoArgsConstructor +@AllArgsConstructor +@Accessors(chain = true) +public class ${ClassName} extends BaseEntity<${ClassName}> { + + private static final long serialVersionUID = 1L; + +#foreach ($column in $columns) + /** $column.columnComment */ +#if($column.pk) + @TableId +#end +#if($column.list) +#set($parentheseIndex=$column.columnComment.indexOf("(")) +#if($parentheseIndex != -1) +#set($comment=$column.columnComment.substring(0, $parentheseIndex)) +#else +#set($comment=$column.columnComment) +#end +#if($parentheseIndex != -1) + @Excel(name = "${comment}", readConverterExp = "$column.readConverterExp()") +#elseif($column.javaType == 'Date') + @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss") + @Excel(name = "${comment}", width = 30, dateFormat = "yyyy-MM-dd HH:mm:ss") +#else + @Excel(name = "${comment}") +#end +#end + private $column.javaType $column.javaField; + +#end +#if($table.sub) + /** $table.subTable.functionName信息 */ + private List<${subClassName}> ${subclassName}List; + +#end +} diff --git a/dc-generator/src/main/resources/vm/java/mapper.java.vm b/dc-generator/src/main/resources/vm/java/mapper.java.vm new file mode 100644 index 0000000..e02315b --- /dev/null +++ b/dc-generator/src/main/resources/vm/java/mapper.java.vm @@ -0,0 +1,19 @@ +package ${packageName}.mapper; + +import com.baomidou.mybatisplus.annotation.InterceptorIgnore; +import com.baomidou.mybatisplus.core.mapper.BaseMapper; +import ${packageName}.domain.${ClassName}; +#if($table.sub) +import com.dc.system.domain.${subClassName}; +#end + +/** + * ${functionName}Mapper接口 + * + * @author ${author} + * @date ${datetime} + */ + @InterceptorIgnore(tenantLine = "true") +public interface ${ClassName}Mapper extends BaseMapper<${ClassName}> { + +} diff --git a/dc-generator/src/main/resources/vm/java/service.java.vm b/dc-generator/src/main/resources/vm/java/service.java.vm new file mode 100644 index 0000000..c854037 --- /dev/null +++ b/dc-generator/src/main/resources/vm/java/service.java.vm @@ -0,0 +1,46 @@ +package ${packageName}.service; + +import com.baomidou.mybatisplus.extension.service.IService; +import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; +import lombok.extern.slf4j.Slf4j; +import org.springframework.stereotype.Service; +#if($table.sub) +import java.util.ArrayList; +import StringUtils; +import ${packageName}.domain.${subClassName}; +#end +import ${packageName}.mapper.${ClassName}Mapper; +import ${packageName}.domain.${ClassName}; +import org.springframework.transaction.annotation.Transactional; + +import java.time.LocalDateTime; + +/** + * ${functionName}Service业务层处理 + * + * @author ${author} + * @date ${datetime} + */ +@Slf4j +@Service +public class ${ClassName}Service extends ServiceImpl<${ClassName}Mapper, ${ClassName}> implements IService<${ClassName}> { + + /** + * 批量删除${functionName} + * + * @param ${pkColumn.javaField}s 需要删除的${functionName}主键 + * @return 删除的数量 + */ + @Transactional + public int delete${ClassName}By$pkColumn.javaField.substring(0,1).toUpperCase()${pkColumn.javaField.substring(1)}s(${pkColumn.javaType}[] ${pkColumn.javaField}s, Long userId) { + int result = 0; + for(${pkColumn.javaType} id : ${pkColumn.javaField}s) { + ${ClassName} ${className} = baseMapper.selectById(id); + ${className}.setDeleteBy(userId); + ${className}.setDeleteTime(LocalDateTime.now()); + result += baseMapper.updateById(${className}); + } + return result; + } + +} \ No newline at end of file diff --git a/dc-generator/src/main/resources/vm/java/sub-domain.java.vm b/dc-generator/src/main/resources/vm/java/sub-domain.java.vm new file mode 100644 index 0000000..0012c14 --- /dev/null +++ b/dc-generator/src/main/resources/vm/java/sub-domain.java.vm @@ -0,0 +1,80 @@ +package ${packageName}.domain; + +#foreach ($import in $subImportList) +import ${import}; +#end +import lombok.AllArgsConstructor; +import lombok.Data; +import lombok.NoArgsConstructor; +import lombok.experimental.Accessors; +import org.apache.commons.lang3.builder.ToStringBuilder; +import org.apache.commons.lang3.builder.ToStringStyle; +import Excel; +import WinBaseEntity; + +/** + * ${subTable.functionName}对象 ${subTableName} + * + * @author ${author} + * @date ${datetime} + */ +public class ${subClassName} extends BaseEntity +{ + private static final long serialVersionUID = 1L; + +#foreach ($column in $subTable.columns) +#if(!$table.isSuperColumn($column.javaField)) + /** $column.columnComment */ +#if($column.list) +#set($parentheseIndex=$column.columnComment.indexOf("(")) +#if($parentheseIndex != -1) +#set($comment=$column.columnComment.substring(0, $parentheseIndex)) +#else +#set($comment=$column.columnComment) +#end +#if($parentheseIndex != -1) + @Excel(name = "${comment}", readConverterExp = "$column.readConverterExp()") +#elseif($column.javaType == 'Date') + @JsonFormat(pattern = "yyyy-MM-dd") + @Excel(name = "${comment}", width = 30, dateFormat = "yyyy-MM-dd") +#else + @Excel(name = "${comment}") +#end +#end + private $column.javaType $column.javaField; + +#end +#end +#foreach ($column in $subTable.columns) +#if(!$table.isSuperColumn($column.javaField)) +#if($column.javaField.length() > 2 && $column.javaField.substring(1,2).matches("[A-Z]")) +#set($AttrName=$column.javaField) +#else +#set($AttrName=$column.javaField.substring(0,1).toUpperCase() + ${column.javaField.substring(1)}) +#end + public void set${AttrName}($column.javaType $column.javaField) + { + this.$column.javaField = $column.javaField; + } + + public $column.javaType get${AttrName}() + { + return $column.javaField; + } +#end +#end + + @Override + public String toString() { + return new ToStringBuilder(this,ToStringStyle.MULTI_LINE_STYLE) +#foreach ($column in $subTable.columns) +#if($column.javaField.length() > 2 && $column.javaField.substring(1,2).matches("[A-Z]")) +#set($AttrName=$column.javaField) +#else +#set($AttrName=$column.javaField.substring(0,1).toUpperCase() + ${column.javaField.substring(1)}) +#end + .append("${column.javaField}", get${AttrName}()) +#end + .toString(); + } +} diff --git a/dc-generator/src/main/resources/vm/js/api.js.vm b/dc-generator/src/main/resources/vm/js/api.js.vm new file mode 100644 index 0000000..2c78f8b --- /dev/null +++ b/dc-generator/src/main/resources/vm/js/api.js.vm @@ -0,0 +1,53 @@ +import request from '@/utils/request' + +// 查询${functionName}列表 +export function list${BusinessName}(query) { + return request({ + url: '/${baseUrl}/list', + method: 'get', + params: query + }) +} + +// 查询${functionName}详细 +export function get${BusinessName}(${pkColumn.javaField}) { + return request({ + url: '/${baseUrl}/' + ${pkColumn.javaField}, + method: 'get' + }) +} + +// 新增${functionName} +export function add${BusinessName}(data) { + return request({ + url: '/${baseUrl}', + method: 'post', + data: data + }) +} + +// 修改${functionName} +export function update${BusinessName}(data) { + return request({ + url: '/${baseUrl}', + method: 'put', + data: data + }) +} + +// 删除${functionName} +export function del${BusinessName}(${pkColumn.javaField}) { + return request({ + url: '/${baseUrl}/' + ${pkColumn.javaField}, + method: 'delete' + }) +} + +// 导出${functionName} +export function export${BusinessName}(query) { + return request({ + url: '/${baseUrl}/export', + method: 'get', + params: query + }) +} \ No newline at end of file diff --git a/dc-generator/src/main/resources/vm/sql/sql.vm b/dc-generator/src/main/resources/vm/sql/sql.vm new file mode 100644 index 0000000..e262e21 --- /dev/null +++ b/dc-generator/src/main/resources/vm/sql/sql.vm @@ -0,0 +1,27 @@ +-- 菜单 SQL +insert into sys_menu (menu_name, parent_id, order_num, path, component, is_frame, is_cache, menu_type, visible, status, perms, icon, create_by, create_time, update_by, update_time, remark) +values('${functionName}', '${parentMenuId}', '1', '${businessName}', '${moduleName}/${businessName}/index', 1, 0, 'C', '0', '0', '${permissionPrefix}:list', '#', 'admin', current_timestamp, '', null, '${functionName}菜单'); + +-- 按钮父菜单ID +--SELECT @parentId := LAST_INSERT_ID(); +select max(menu_id) into @parentId from sys_menu; + +/* + 全局替换 @parentId 为 上面语句查询出来的 max(menu_id) +*/ + +-- 按钮 SQL +insert into sys_menu (menu_name, parent_id, order_num, path, component, is_frame, is_cache, menu_type, visible, status, perms, icon, create_by, create_time, update_by, update_time, remark) +values('${functionName}查询', @parentId, '1', '#', '', 1, 0, 'F', '0', '0', '${permissionPrefix}:query', '#', 'admin', current_timestamp, '', null, ''); + +insert into sys_menu (menu_name, parent_id, order_num, path, component, is_frame, is_cache, menu_type, visible, status, perms, icon, create_by, create_time, update_by, update_time, remark) +values('${functionName}新增', @parentId, '2', '#', '', 1, 0, 'F', '0', '0', '${permissionPrefix}:add', '#', 'admin', current_timestamp, '', null, ''); + +insert into sys_menu (menu_name, parent_id, order_num, path, component, is_frame, is_cache, menu_type, visible, status, perms, icon, create_by, create_time, update_by, update_time, remark) +values('${functionName}修改', @parentId, '3', '#', '', 1, 0, 'F', '0', '0', '${permissionPrefix}:edit', '#', 'admin', current_timestamp, '', null, ''); + +insert into sys_menu (menu_name, parent_id, order_num, path, component, is_frame, is_cache, menu_type, visible, status, perms, icon, create_by, create_time, update_by, update_time, remark) +values('${functionName}删除', @parentId, '4', '#', '', 1, 0, 'F', '0', '0', '${permissionPrefix}:remove', '#', 'admin', current_timestamp, '', null, ''); + +insert into sys_menu (menu_name, parent_id, order_num, path, component, is_frame, is_cache, menu_type, visible, status, perms, icon, create_by, create_time, update_by, update_time, remark) +values('${functionName}导出', @parentId, '5', '#', '', 1, 0, 'F', '0', '0', '${permissionPrefix}:export', '#', 'admin', current_timestamp, '', null, ''); \ No newline at end of file diff --git a/dc-generator/src/main/resources/vm/vue/index-tree.vue.vm b/dc-generator/src/main/resources/vm/vue/index-tree.vue.vm new file mode 100644 index 0000000..237d899 --- /dev/null +++ b/dc-generator/src/main/resources/vm/vue/index-tree.vue.vm @@ -0,0 +1,486 @@ +<template> + <div class="app-container"> + <el-form :model="queryParams" ref="queryRef" :inline="true" v-show="showSearch" label-width="68px"> +#foreach($column in $columns) +#if($column.query) +#set($dictType=$column.dictType) +#set($AttrName=$column.javaField.substring(0,1).toUpperCase() + ${column.javaField.substring(1)}) +#set($parentheseIndex=$column.columnComment.indexOf("(")) +#if($parentheseIndex != -1) +#set($comment=$column.columnComment.substring(0, $parentheseIndex)) +#else +#set($comment=$column.columnComment) +#end +#if($column.htmlType == "input") + <el-form-item label="${comment}" prop="${column.javaField}"> + <el-input + v-model="queryParams.${column.javaField}" + placeholder="请输入${comment}" + clearable + @keyup.enter="handleQuery" + /> + </el-form-item> +#elseif(($column.htmlType == "select" || $column.htmlType == "radio") && "" != $dictType) + <el-form-item label="${comment}" prop="${column.javaField}"> + <el-select v-model="queryParams.${column.javaField}" placeholder="请选择${comment}" clearable> + <el-option + v-for="dict in ${dictType}" + :key="dict.value" + :label="dict.label" + :value="dict.value" + /> + </el-select> + </el-form-item> +#elseif(($column.htmlType == "select" || $column.htmlType == "radio") && $dictType) + <el-form-item label="${comment}" prop="${column.javaField}"> + <el-select v-model="queryParams.${column.javaField}" placeholder="请选择${comment}" clearable> + <el-option label="请选择字典生成" value="" /> + </el-select> + </el-form-item> +#elseif($column.htmlType == "datetime" && $column.queryType != "BETWEEN") + <el-form-item label="${comment}" prop="${column.javaField}"> + <el-date-picker clearable + v-model="queryParams.${column.javaField}" + type="date" + value-format="YYYY-MM-DD" + placeholder="选择${comment}"> + </el-date-picker> + </el-form-item> +#elseif($column.htmlType == "datetime" && $column.queryType == "BETWEEN") + <el-form-item label="${comment}" style="width: 308px"> + <el-date-picker + v-model="daterange${AttrName}" + value-format="YYYY-MM-DD" + type="daterange" + range-separator="-" + start-placeholder="开始日期" + end-placeholder="结束日期" + ></el-date-picker> + </el-form-item> +#end +#end +#end + <el-form-item> + <el-button type="primary" icon="Search" @click="handleQuery">搜索</el-button> + <el-button icon="Refresh" @click="resetQuery">重置</el-button> + </el-form-item> + </el-form> + + <el-row :gutter="10" class="mb8"> + <el-col :span="1.5"> + <el-button + type="primary" + plain + icon="Plus" + @click="handleAdd" + v-hasPermi="['${moduleName}:${businessName}:add']" + >新增</el-button> + </el-col> + <el-col :span="1.5"> + <el-button + type="info" + plain + icon="Sort" + @click="toggleExpandAll" + >展开/折叠</el-button> + </el-col> + <right-toolbar v-model:showSearch="showSearch" @queryTable="getList"></right-toolbar> + </el-row> + + <el-table + v-if="refreshTable" + v-loading="loading" + :data="${businessName}List" + row-key="${treeCode}" + :default-expand-all="isExpandAll" + :tree-props="{children: 'children', hasChildren: 'hasChildren'}" + > +#foreach($column in $columns) +#set($javaField=$column.javaField) +#set($parentheseIndex=$column.columnComment.indexOf("(")) +#if($parentheseIndex != -1) +#set($comment=$column.columnComment.substring(0, $parentheseIndex)) +#else +#set($comment=$column.columnComment) +#end +#if($column.pk) +#elseif($column.list && $column.htmlType == "datetime") + <el-table-column label="${comment}" align="center" prop="${javaField}" width="180"> + <template #default="scope"> + <span>{{ parseTime(scope.row.${javaField}, '{y}-{m}-{d}') }}</span> + </template> + </el-table-column> +#elseif($column.list && $column.htmlType == "imageUpload") + <el-table-column label="${comment}" align="center" prop="${javaField}" width="100"> + <template #default="scope"> + <image-preview :src="scope.row.${javaField}" :width="50" :height="50"/> + </template> + </el-table-column> +#elseif($column.list && "" != $column.dictType) + <el-table-column label="${comment}" align="center" prop="${javaField}"> + <template #default="scope"> +#if($column.htmlType == "checkbox") + <dict-tag :options="${column.dictType}" :value="scope.row.${javaField} ? scope.row.${javaField}.split(',') : []"/> +#else + <dict-tag :options="${column.dictType}" :value="scope.row.${javaField}"/> +#end + </template> + </el-table-column> +#elseif($column.list && "" != $javaField) +#if(${foreach.index} == 1) + <el-table-column label="${comment}" prop="${javaField}" /> +#else + <el-table-column label="${comment}" align="center" prop="${javaField}" /> +#end +#end +#end + <el-table-column label="操作" align="center" class-name="small-padding fixed-width"> + <template #default="scope"> + <el-button + type="text" + icon="Edit" + @click="handleUpdate(scope.row)" + v-hasPermi="['${moduleName}:${businessName}:edit']" + >修改</el-button> + <el-button + type="text" + icon="Plus" + @click="handleAdd(scope.row)" + v-hasPermi="['${moduleName}:${businessName}:add']" + >新增</el-button> + <el-button + type="text" + icon="Delete" + @click="handleDelete(scope.row)" + v-hasPermi="['${moduleName}:${businessName}:remove']" + >删除</el-button> + </template> + </el-table-column> + </el-table> + + <!-- 添加或修改${functionName}对话框 --> + <el-dialog :title="title" v-model="open" width="500px" append-to-body> + <el-form ref="${businessName}Ref" :model="form" :rules="rules" label-width="80px"> +#foreach($column in $columns) +#set($field=$column.javaField) +#if($column.insert && !$column.pk) +#if(($column.usableColumn) || (!$column.superColumn)) +#set($parentheseIndex=$column.columnComment.indexOf("(")) +#if($parentheseIndex != -1) +#set($comment=$column.columnComment.substring(0, $parentheseIndex)) +#else +#set($comment=$column.columnComment) +#end +#set($dictType=$column.dictType) +#if("" != $treeParentCode && $column.javaField == $treeParentCode) + <el-form-item label="${comment}" prop="${treeParentCode}"> + <el-tree-select + v-model="form.${treeParentCode}" + :data="${businessName}Options" + :props="{ value: '${treeCode}', label: '${treeName}', children: 'children' }" + value-key="${treeCode}" + placeholder="请选择${comment}" + check-strictly + /> + </el-form-item> +#elseif($column.htmlType == "input") + <el-form-item label="${comment}" prop="${field}"> + <el-input v-model="form.${field}" placeholder="请输入${comment}" /> + </el-form-item> +#elseif($column.htmlType == "imageUpload") + <el-form-item label="${comment}"> + <image-upload v-model="form.${field}"/> + </el-form-item> +#elseif($column.htmlType == "fileUpload") + <el-form-item label="${comment}"> + <file-upload v-model="form.${field}"/> + </el-form-item> +#elseif($column.htmlType == "editor") + <el-form-item label="${comment}"> + <editor v-model="form.${field}" :min-height="192"/> + </el-form-item> +#elseif($column.htmlType == "select" && "" != $dictType) + <el-form-item label="${comment}" prop="${field}"> + <el-select v-model="form.${field}" placeholder="请选择${comment}"> + <el-option + v-for="dict in ${dictType}" + :key="dict.value" + :label="dict.label" + #if($column.javaType == "Integer" || $column.javaType == "Long"):value="parseInt(dict.value)"#else:value="dict.value"#end + + ></el-option> + </el-select> + </el-form-item> +#elseif($column.htmlType == "select" && $dictType) + <el-form-item label="${comment}" prop="${field}"> + <el-select v-model="form.${field}" placeholder="请选择${comment}"> + <el-option label="请选择字典生成" value="" /> + </el-select> + </el-form-item> +#elseif($column.htmlType == "checkbox" && "" != $dictType) + <el-form-item label="${comment}"> + <el-checkbox-group v-model="form.${field}"> + <el-checkbox + v-for="dict in ${dictType}" + :key="dict.value" + :label="dict.value"> + {{dict.label}} + </el-checkbox> + </el-checkbox-group> + </el-form-item> +#elseif($column.htmlType == "checkbox" && $dictType) + <el-form-item label="${comment}"> + <el-checkbox-group v-model="form.${field}"> + <el-checkbox>请选择字典生成</el-checkbox> + </el-checkbox-group> + </el-form-item> +#elseif($column.htmlType == "radio" && "" != $dictType) + <el-form-item label="${comment}"> + <el-radio-group v-model="form.${field}"> + <el-radio + v-for="dict in ${dictType}" + :key="dict.value" + #if($column.javaType == "Integer" || $column.javaType == "Long"):label="parseInt(dict.value)"#else:label="dict.value"#end + + >{{dict.label}}</el-radio> + </el-radio-group> + </el-form-item> +#elseif($column.htmlType == "radio" && $dictType) + <el-form-item label="${comment}"> + <el-radio-group v-model="form.${field}"> + <el-radio label="1">请选择字典生成</el-radio> + </el-radio-group> + </el-form-item> +#elseif($column.htmlType == "datetime") + <el-form-item label="${comment}" prop="${field}"> + <el-date-picker clearable + v-model="form.${field}" + type="date" + value-format="YYYY-MM-DD" + placeholder="选择${comment}"> + </el-date-picker> + </el-form-item> +#elseif($column.htmlType == "textarea") + <el-form-item label="${comment}" prop="${field}"> + <el-input v-model="form.${field}" type="textarea" placeholder="请输入内容" /> + </el-form-item> +#end +#end +#end +#end + </el-form> + <template #footer> + <div class="dialog-footer"> + <el-button type="primary" @click="submitForm">确 定</el-button> + <el-button @click="cancel">取 消</el-button> + </div> + </template> + </el-dialog> + </div> +</template> + +<script setup name="${BusinessName}"> +import { list${BusinessName}, get${BusinessName}, del${BusinessName}, add${BusinessName}, update${BusinessName} } from "@/api/${moduleName}/${businessName}"; + +const { proxy } = getCurrentInstance(); +#if(${dicts} != '') +#set($dictsNoSymbol=$dicts.replace("'", "")) +const { ${dictsNoSymbol} } = proxy.useDict(${dicts}); +#end + +const ${businessName}List = ref([]); +const ${businessName}Options = ref([]); +const open = ref(false); +const loading = ref(true); +const showSearch = ref(true); +const title = ref(""); +const isExpandAll = ref(true); +const refreshTable = ref(true); +#foreach ($column in $columns) +#if($column.htmlType == "datetime" && $column.queryType == "BETWEEN") +#set($AttrName=$column.javaField.substring(0,1).toUpperCase() + ${column.javaField.substring(1)}) +const daterange${AttrName} = ref([]); +#end +#end + +const data = reactive({ + form: {}, + queryParams: { + #foreach ($column in $columns) +#if($column.query) + $column.javaField: null#if($foreach.count != $columns.size()),#end +#end +#end + }, + rules: { + #foreach ($column in $columns) +#if($column.required) +#set($parentheseIndex=$column.columnComment.indexOf("(")) +#if($parentheseIndex != -1) +#set($comment=$column.columnComment.substring(0, $parentheseIndex)) +#else +#set($comment=$column.columnComment) +#end + $column.javaField: [ + { required: true, message: "$comment不能为空", trigger: #if($column.htmlType == "select")"change"#else"blur"#end } + ]#if($foreach.count != $columns.size()),#end +#end +#end + } +}); + +const { queryParams, form, rules } = toRefs(data); + +/** 查询${functionName}列表 */ +function getList() { + loading.value = true; +#foreach ($column in $columns) +#if($column.htmlType == "datetime" && $column.queryType == "BETWEEN") + queryParams.value.params = {}; +#break +#end +#end +#foreach ($column in $columns) +#if($column.htmlType == "datetime" && $column.queryType == "BETWEEN") +#set($AttrName=$column.javaField.substring(0,1).toUpperCase() + ${column.javaField.substring(1)}) + if (null != daterange${AttrName} && '' != daterange${AttrName}) { + queryParams.value.params["begin${AttrName}"] = daterange${AttrName}.value[0]; + queryParams.value.params["end${AttrName}"] = daterange${AttrName}.value[1]; + } +#end +#end + list${BusinessName}(queryParams.value).then(response => { + ${businessName}List.value = proxy.handleTree(response.data, "${treeCode}", "${treeParentCode}"); + loading.value = false; + }); +} + +/** 查询${functionName}下拉树结构 */ +function getTreeselect() { + list${BusinessName}().then(response => { + ${businessName}Options.value = []; + const data = { ${treeCode}: 0, ${treeName}: '顶级节点', children: [] }; + data.children = proxy.handleTree(response.data, "${treeCode}", "${treeParentCode}"); + ${businessName}Options.value.push(data); + }); +} + +// 取消按钮 +function cancel() { + open.value = false; + reset(); +} + +// 表单重置 +function reset() { + form.value = { +#foreach ($column in $columns) +#if($column.htmlType == "radio") + $column.javaField: #if($column.javaType == "Integer" || $column.javaType == "Long")0#else"0"#end#if($foreach.count != $columns.size()),#end + +#elseif($column.htmlType == "checkbox") + $column.javaField: []#if($foreach.count != $columns.size()),#end +#else + $column.javaField: null#if($foreach.count != $columns.size()),#end +#end +#end + }; + proxy.resetForm("${businessName}Ref"); +} + +/** 搜索按钮操作 */ +function handleQuery() { + getList(); +} + +/** 重置按钮操作 */ +function resetQuery() { +#foreach ($column in $columns) +#if($column.htmlType == "datetime" && $column.queryType == "BETWEEN") +#set($AttrName=$column.javaField.substring(0,1).toUpperCase() + ${column.javaField.substring(1)}) + daterange${AttrName}.value = []; +#end +#end + proxy.resetForm("queryRef"); + handleQuery(); +} + +/** 新增按钮操作 */ +function handleAdd(row) { + reset(); + getTreeselect(); + if (row != null && row.${treeCode}) { + form.value.${treeParentCode} = row.${treeCode}; + } else { + form.value.${treeParentCode} = 0; + } + open.value = true; + title.value = "添加${functionName}"; +} + +/** 展开/折叠操作 */ +function toggleExpandAll() { + refreshTable.value = false; + isExpandAll.value = !isExpandAll.value; + nextTick(() => { + refreshTable.value = true; + }); +} + +/** 修改按钮操作 */ +async function handleUpdate(row) { + reset(); + await getTreeselect(); + if (row != null) { + form.value.${treeParentCode} = row.${treeCode}; + } + get${BusinessName}(row.${pkColumn.javaField}).then(response => { + form.value = response.data; +#foreach ($column in $columns) +#if($column.htmlType == "checkbox") + form.value.$column.javaField = form.value.${column.javaField}.split(","); +#end +#end + open.value = true; + title.value = "修改${functionName}"; + }); +} + +/** 提交按钮 */ +function submitForm() { + proxy.#[[$]]#refs["${businessName}Ref"].validate(valid => { + if (valid) { +#foreach ($column in $columns) +#if($column.htmlType == "checkbox") + form.value.$column.javaField = form.value.${column.javaField}.join(","); +#end +#end + if (form.value.${pkColumn.javaField} != null) { + update${BusinessName}(form.value).then(response => { + proxy.#[[$modal]]#.msgSuccess("修改成功"); + open.value = false; + getList(); + }); + } else { + add${BusinessName}(form.value).then(response => { + proxy.#[[$modal]]#.msgSuccess("新增成功"); + open.value = false; + getList(); + }); + } + } + }); +} + +/** 删除按钮操作 */ +function handleDelete(row) { + proxy.#[[$modal]]#.confirm('是否确认删除${functionName}编号为"' + row.${pkColumn.javaField} + '"的数据项?').then(function() { + return del${BusinessName}(row.${pkColumn.javaField}); + }).then(() => { + getList(); + proxy.#[[$modal]]#.msgSuccess("删除成功"); + }).catch(() => {}); +} + +getList(); +</script> diff --git a/dc-generator/src/main/resources/vm/vue/index.vue.vm b/dc-generator/src/main/resources/vm/vue/index.vue.vm new file mode 100644 index 0000000..33b720c --- /dev/null +++ b/dc-generator/src/main/resources/vm/vue/index.vue.vm @@ -0,0 +1,611 @@ +<template> + <div class="app-container"> + <el-form :model="queryParams" ref="queryRef" :inline="true" v-show="showSearch" label-width="68px"> +#foreach($column in $columns) +#if($column.query) +#set($dictType=$column.dictType) +#set($AttrName=$column.javaField.substring(0,1).toUpperCase() + ${column.javaField.substring(1)}) +#set($parentheseIndex=$column.columnComment.indexOf("(")) +#if($parentheseIndex != -1) +#set($comment=$column.columnComment.substring(0, $parentheseIndex)) +#else +#set($comment=$column.columnComment) +#end +#if($column.htmlType == "input") + <el-form-item label="${comment}" prop="${column.javaField}"> + <el-input + v-model="queryParams.${column.javaField}" + placeholder="请输入${comment}" + clearable + @keyup.enter="handleQuery" + /> + </el-form-item> +#elseif(($column.htmlType == "select" || $column.htmlType == "radio") && "" != $dictType) + <el-form-item label="${comment}" prop="${column.javaField}"> + <el-select v-model="queryParams.${column.javaField}" placeholder="请选择${comment}" clearable> + <el-option + v-for="dict in ${dictType}" + :key="dict.value" + :label="dict.label" + :value="dict.value" + /> + </el-select> + </el-form-item> +#elseif(($column.htmlType == "select" || $column.htmlType == "radio") && $dictType) + <el-form-item label="${comment}" prop="${column.javaField}"> + <el-select v-model="queryParams.${column.javaField}" placeholder="请选择${comment}" clearable> + <el-option label="请选择字典生成" value="" /> + </el-select> + </el-form-item> +#elseif($column.htmlType == "datetime" && $column.queryType != "BETWEEN") + <el-form-item label="${comment}" prop="${column.javaField}"> + <el-date-picker clearable + v-model="queryParams.${column.javaField}" + type="date" + value-format="YYYY-MM-DD" + placeholder="请选择${comment}"> + </el-date-picker> + </el-form-item> +#elseif($column.htmlType == "datetime" && $column.queryType == "BETWEEN") + <el-form-item label="${comment}" style="width: 308px"> + <el-date-picker + v-model="daterange${AttrName}" + value-format="YYYY-MM-DD" + type="daterange" + range-separator="-" + start-placeholder="开始日期" + end-placeholder="结束日期" + ></el-date-picker> + </el-form-item> +#end +#end +#end + <el-form-item> + <el-button type="primary" icon="Search" @click="handleQuery">搜索</el-button> + <el-button type="info" plain icon="Refresh" @click="resetQuery">重置</el-button> + </el-form-item> + </el-form> + + <el-row :gutter="10" class="mb8"> + <el-col :span="1.5"> + <el-button + type="success" + icon="Plus" + @click="handleAdd" + >新增</el-button> + </el-col> + <el-col :span="1.5"> + <el-button + type="success" + icon="Edit" + @click="handleUpdate" + >修改</el-button> + </el-col> + <el-col :span="1.5"> + <el-button + type="success" + icon="Delete" + @click="handleDelete" + >删除</el-button> + </el-col> + <el-col :span="1.5"> + <el-button + type="warning" + icon="Download" + @click="handleExport" + >导出</el-button> + </el-col> + <right-toolbar v-model:showSearch="showSearch" @queryTable="getList"></right-toolbar> + </el-row> + + <el-table v-loading="loading" :data="${businessName}List" @selection-change="handleSelectionChange"> + <el-table-column type="selection" width="55" align="center" /> +#foreach($column in $columns) +#set($javaField=$column.javaField) +#set($parentheseIndex=$column.columnComment.indexOf("(")) +#if($parentheseIndex != -1) +#set($comment=$column.columnComment.substring(0, $parentheseIndex)) +#else +#set($comment=$column.columnComment) +#end +#if($column.pk) + <el-table-column label="${comment}" align="center" prop="${javaField}" /> +#elseif($column.list && $column.htmlType == "datetime") + <el-table-column label="${comment}" align="center" prop="${javaField}" width="180"> + <template #default="scope"> + <span>{{ parseTime(scope.row.${javaField}, '{y}-{m}-{d}') }}</span> + </template> + </el-table-column> +#elseif($column.list && $column.htmlType == "imageUpload") + <el-table-column label="${comment}" align="center" prop="${javaField}" width="100"> + <template #default="scope"> + <image-preview :src="scope.row.${javaField}" :width="50" :height="50"/> + </template> + </el-table-column> +#elseif($column.list && "" != $column.dictType) + <el-table-column label="${comment}" align="center" prop="${javaField}"> + <template #default="scope"> +#if($column.htmlType == "checkbox") + <dict-tag :options="${column.dictType}" :value="scope.row.${javaField} ? scope.row.${javaField}.split(',') : []"/> +#else + <dict-tag :options="${column.dictType}" :value="scope.row.${javaField}"/> +#end + </template> + </el-table-column> +#elseif($column.list && "" != $javaField) + <el-table-column label="${comment}" align="center" prop="${javaField}" /> +#end +#end + <el-table-column label="操作" align="center" class-name="small-padding fixed-width"> + <template #default="scope"> + <el-button + type="text" + icon="Edit" + @click="handleUpdate(scope.row)" + >修改</el-button> + <el-button + type="text" + icon="Delete" + @click="handleDelete(scope.row)" + >删除</el-button> + </template> + </el-table-column> + </el-table> + + <pagination + v-show="total>0" + :total="total" + v-model:page="queryParams.pageNum" + v-model:limit="queryParams.pageSize" + @pagination="getList" + /> + + <!-- 添加或修改${functionName}对话框 --> + <el-dialog :title="title" v-model="open" width="500px" append-to-body> + <el-form ref="${businessName}Ref" :model="form" :rules="rules" label-width="80px"> + +<el-row> +#foreach($column in $columns) +#set($field=$column.javaField) +#if($column.insert && !$column.pk) +#if(($column.usableColumn) || (!$column.superColumn)) +#set($parentheseIndex=$column.columnComment.indexOf("(")) +#if($parentheseIndex != -1) +#set($comment=$column.columnComment.substring(0, $parentheseIndex)) +#else +#set($comment=$column.columnComment) +#end +#set($dictType=$column.dictType) +#if($column.htmlType == "input") + <el-col :span="12"> + <el-form-item label="${comment}" prop="${field}"> + <el-input v-model="form.${field}" placeholder="请输入${comment}" /> + </el-form-item> + </el-col> +#elseif($column.htmlType == "imageUpload") + <el-col :span="12"> + <el-form-item label="${comment}"> + <image-upload v-model="form.${field}"/> + </el-form-item> + </el-col> +#elseif($column.htmlType == "fileUpload") + <el-col :span="12"> + <el-form-item label="${comment}"> + <file-upload v-model="form.${field}"/> + </el-form-item> + </el-col> +#elseif($column.htmlType == "editor") + <el-col :span="12"> + <el-form-item label="${comment}"> + <editor v-model="form.${field}" :min-height="192"/> + </el-form-item> + </el-col> +#elseif($column.htmlType == "select" && "" != $dictType) + <el-col :span="12"> + <el-form-item label="${comment}" prop="${field}"> + <el-select v-model="form.${field}" placeholder="请选择${comment}"> + <el-option + v-for="dict in ${dictType}" + :key="dict.value" + :label="dict.label" + #if($column.javaType == "Integer" || $column.javaType == "Long"):value="parseInt(dict.value)"#else:value="dict.value"#end + ></el-option> + </el-select> + </el-form-item> + </el-col> +#elseif($column.htmlType == "select" && $dictType) + <el-col :span="12"> + <el-form-item label="${comment}" prop="${field}"> + <el-select v-model="form.${field}" placeholder="请选择${comment}"> + <el-option label="请选择字典生成" value="" /> + </el-select> + </el-form-item> + </el-col> +#elseif($column.htmlType == "checkbox" && "" != $dictType) + <el-col :span="12"> + <el-form-item label="${comment}"> + <el-checkbox-group v-model="form.${field}"> + <el-checkbox + v-for="dict in ${dictType}" + :key="dict.value" + :label="dict.value"> + {{dict.label}} + </el-checkbox> + </el-checkbox-group> + </el-form-item> + </el-col> +#elseif($column.htmlType == "checkbox" && $dictType) + <el-col :span="12"> + <el-form-item label="${comment}"> + <el-checkbox-group v-model="form.${field}"> + <el-checkbox>请选择字典生成</el-checkbox> + </el-checkbox-group> + </el-form-item> + </el-col> +#elseif($column.htmlType == "radio" && "" != $dictType) + <el-col :span="12"> + <el-form-item label="${comment}"> + <el-radio-group v-model="form.${field}"> + <el-radio + v-for="dict in ${dictType}" + :key="dict.value" + #if($column.javaType == "Integer" || $column.javaType == "Long"):label="parseInt(dict.value)"#else:label="dict.value"#end + + >{{dict.label}}</el-radio> + </el-radio-group> + </el-form-item> + </el-col> +#elseif($column.htmlType == "radio" && $dictType) + <el-col :span="12"> + <el-form-item label="${comment}"> + <el-radio-group v-model="form.${field}"> + <el-radio label="1">请选择字典生成</el-radio> + </el-radio-group> + </el-form-item> + </el-col> +#elseif($column.htmlType == "datetime") + <el-col :span="12"> + <el-form-item label="${comment}" prop="${field}"> + <el-date-picker clearable + v-model="form.${field}" + type="date" + value-format="YYYY-MM-DD" + placeholder="请选择${comment}"> + </el-date-picker> + </el-form-item> + </el-col> +#elseif($column.htmlType == "textarea") + <el-col :span="12"> + <el-form-item label="${comment}" prop="${field}"> + <el-input v-model="form.${field}" type="textarea" placeholder="请输入内容" /> + </el-form-item> + </el-col> +#end +#end +#end +#end +#if($table.sub) + <el-divider content-position="center">${subTable.functionName}信息</el-divider> + <el-row :gutter="10" class="mb8"> + <el-col :span="1.5"> + <el-button type="primary" icon="Plus" @click="handleAdd${subClassName}">添加</el-button> + </el-col> + <el-col :span="1.5"> + <el-button type="danger" icon="Delete" @click="handleDelete${subClassName}">删除</el-button> + </el-col> + </el-row> + <el-table :data="${subclassName}List" :row-class-name="row${subClassName}Index" @selection-change="handle${subClassName}SelectionChange" ref="${subclassName}"> + <el-table-column type="selection" width="50" align="center" /> + <el-table-column label="序号" align="center" prop="index" width="50"/> +#foreach($column in $subTable.columns) +#set($javaField=$column.javaField) +#set($parentheseIndex=$column.columnComment.indexOf("(")) +#if($parentheseIndex != -1) +#set($comment=$column.columnComment.substring(0, $parentheseIndex)) +#else +#set($comment=$column.columnComment) +#end +#if($column.pk || $javaField == ${subTableFkclassName}) +#elseif($column.list && $column.htmlType == "input") + <el-table-column label="$comment" prop="${javaField}" width="150"> + <template #default="scope"> + <el-input v-model="scope.row.$javaField" placeholder="请输入$comment" /> + </template> + </el-table-column> +#elseif($column.list && $column.htmlType == "datetime") + <el-table-column label="$comment" prop="${javaField}" width="240"> + <template #default="scope"> + <el-date-picker clearable + v-model="scope.row.$javaField" + type="date" + value-format="YYYY-MM-DD" + placeholder="请选择$comment"> + </el-date-picker> + </template> + </el-table-column> +#elseif($column.list && ($column.htmlType == "select" || $column.htmlType == "radio") && "" != $column.dictType) + <el-table-column label="$comment" prop="${javaField}" width="150"> + <template #default="scope"> + <el-select v-model="scope.row.$javaField" placeholder="请选择$comment"> + <el-option + v-for="dict in $column.dictType" + :key="dict.value" + :label="dict.label" + :value="dict.value" + ></el-option> + </el-select> + </template> + </el-table-column> +#elseif($column.list && ($column.htmlType == "select" || $column.htmlType == "radio") && "" == $column.dictType) + <el-table-column label="$comment" prop="${javaField}" width="150"> + <template #default="scope"> + <el-select v-model="scope.row.$javaField" placeholder="请选择$comment"> + <el-option label="请选择字典生成" value="" /> + </el-select> + </template> + </el-table-column> +#end +#end + </el-table> +#end + + </el-row> + </el-form> + <template #footer> + <div class="dialog-footer"> + <el-button type="primary" @click="submitForm">确 定</el-button> + <el-button @click="cancel">取 消</el-button> + </div> + </template> + </el-dialog> + </div> +</template> + +<script setup name="${BusinessName}"> +import { list${BusinessName}, get${BusinessName}, del${BusinessName}, add${BusinessName}, update${BusinessName} } from "@/api/${moduleName}/${businessName}"; + +const { proxy } = getCurrentInstance(); +#if(${dicts} != '') +#set($dictsNoSymbol=$dicts.replace("'", "")) +const { ${dictsNoSymbol} } = proxy.useDict(${dicts}); +#end + +const ${businessName}List = ref([]); +#if($table.sub) +const ${subclassName}List = ref([]); +#end +const open = ref(false); +const loading = ref(true); +const showSearch = ref(true); +const ids = ref([]); +#if($table.sub) +const checked${subClassName} = ref([]); +#end +const single = ref(true); +const multiple = ref(true); +const total = ref(0); +const title = ref(""); +#foreach ($column in $columns) +#if($column.htmlType == "datetime" && $column.queryType == "BETWEEN") +#set($AttrName=$column.javaField.substring(0,1).toUpperCase() + ${column.javaField.substring(1)}) +const daterange${AttrName} = ref([]); +#end +#end + +const data = reactive({ + form: {}, + queryParams: { + pageNum: 1, + pageSize: 10, + #foreach ($column in $columns) +#if($column.query) + $column.javaField: null#if($foreach.count != $columns.size()),#end +#end +#end + }, + rules: { + #foreach ($column in $columns) +#if($column.required) +#set($parentheseIndex=$column.columnComment.indexOf("(")) +#if($parentheseIndex != -1) +#set($comment=$column.columnComment.substring(0, $parentheseIndex)) +#else +#set($comment=$column.columnComment) +#end + $column.javaField: [ + { required: true, message: "$comment不能为空", trigger: #if($column.htmlType == "select")"change"#else"blur"#end } + ]#if($foreach.count != $columns.size()),#end +#end +#end + } +}); + +const { queryParams, form, rules } = toRefs(data); + +/** 查询${functionName}列表 */ +function getList() { + loading.value = true; +#foreach ($column in $columns) +#if($column.htmlType == "datetime" && $column.queryType == "BETWEEN") + queryParams.value.params = {}; +#break +#end +#end +#foreach ($column in $columns) +#if($column.htmlType == "datetime" && $column.queryType == "BETWEEN") +#set($AttrName=$column.javaField.substring(0,1).toUpperCase() + ${column.javaField.substring(1)}) + if (null != daterange${AttrName} && '' != daterange${AttrName}) { + queryParams.value.params["begin${AttrName}"] = daterange${AttrName}.value[0]; + queryParams.value.params["end${AttrName}"] = daterange${AttrName}.value[1]; + } +#end +#end + list${BusinessName}(queryParams.value).then(response => { + ${businessName}List.value = response.rows; + total.value = response.total; + loading.value = false; + }); +} + +// 取消按钮 +function cancel() { + open.value = false; + reset(); +} + +// 表单重置 +function reset() { + form.value = { +#foreach ($column in $columns) +#if($column.htmlType == "radio") + $column.javaField: #if($column.javaType == "Integer" || $column.javaType == "Long")0#else"0"#end#if($foreach.count != $columns.size()),#end +#elseif($column.htmlType == "checkbox") + $column.javaField: []#if($foreach.count != $columns.size()),#end +#else + $column.javaField: null#if($foreach.count != $columns.size()),#end +#end +#end + }; +#if($table.sub) + ${subclassName}List.value = []; +#end + proxy.resetForm("${businessName}Ref"); +} + +/** 搜索按钮操作 */ +function handleQuery() { + queryParams.value.pageNum = 1; + getList(); +} + +/** 重置按钮操作 */ +function resetQuery() { +#foreach ($column in $columns) +#if($column.htmlType == "datetime" && $column.queryType == "BETWEEN") +#set($AttrName=$column.javaField.substring(0,1).toUpperCase() + ${column.javaField.substring(1)}) + daterange${AttrName}.value = []; +#end +#end + proxy.resetForm("queryRef"); + handleQuery(); +} + +// 多选框选中数据 +function handleSelectionChange(selection) { + ids.value = selection.map(item => item.${pkColumn.javaField}); + single.value = selection.length != 1; + multiple.value = !selection.length; +} + +/** 新增按钮操作 */ +function handleAdd() { + reset(); + open.value = true; + title.value = "添加${functionName}"; +} + +/** 修改按钮操作 */ +function handleUpdate(row) { + reset(); + const _${pkColumn.javaField} = row.${pkColumn.javaField} || ids.value + get${BusinessName}(_${pkColumn.javaField}).then(response => { + form.value = response.data; +#foreach ($column in $columns) +#if($column.htmlType == "checkbox") + form.value.$column.javaField = form.value.${column.javaField}.split(","); +#end +#end +#if($table.sub) + ${subclassName}List.value = response.data.${subclassName}List; +#end + open.value = true; + title.value = "修改${functionName}"; + }); +} + +/** 提交按钮 */ +function submitForm() { + proxy.#[[$]]#refs["${businessName}Ref"].validate(valid => { + if (valid) { +#foreach ($column in $columns) +#if($column.htmlType == "checkbox") + form.value.$column.javaField = form.value.${column.javaField}.join(","); +#end +#end +#if($table.sub) + form.value.${subclassName}List = ${subclassName}List.value; +#end + if (form.value.${pkColumn.javaField} != null) { + update${BusinessName}(form.value).then(response => { + proxy.#[[$modal]]#.msgSuccess("修改成功"); + open.value = false; + getList(); + }); + } else { + add${BusinessName}(form.value).then(response => { + proxy.#[[$modal]]#.msgSuccess("新增成功"); + open.value = false; + getList(); + }); + } + } + }); +} + +/** 删除按钮操作 */ +function handleDelete(row) { + const _${pkColumn.javaField}s = row.${pkColumn.javaField} || ids.value; + proxy.#[[$modal]]#.confirm('是否确认删除${functionName}编号为"' + _${pkColumn.javaField}s + '"的数据项?').then(function() { + return del${BusinessName}(_${pkColumn.javaField}s); + }).then(() => { + getList(); + proxy.#[[$modal]]#.msgSuccess("删除成功"); + }).catch(() => {}); +} + +#if($table.sub) +/** ${subTable.functionName}序号 */ +function row${subClassName}Index({ row, rowIndex }) { + row.index = rowIndex + 1; +} + +/** ${subTable.functionName}添加按钮操作 */ +function handleAdd${subClassName}() { + let obj = {}; +#foreach($column in $subTable.columns) +#if($column.pk || $column.javaField == ${subTableFkclassName}) +#elseif($column.list && "" != $javaField) + obj.$column.javaField = ""; +#end +#end + ${subclassName}List.value.push(obj); +} + +/** ${subTable.functionName}删除按钮操作 */ +function handleDelete${subClassName}() { + if (checked${subClassName}.value.length == 0) { + proxy.#[[$modal]]#.msgError("请先选择要删除的${subTable.functionName}数据"); + } else { + const ${subclassName}s = ${subclassName}List.value; + const checked${subClassName}s = checked${subClassName}.value; + ${subclassName}List.value = ${subclassName}s.filter(function(item) { + return checked${subClassName}s.indexOf(item.index) == -1 + }); + } +} + +/** 复选框选中数据 */ +function handle${subClassName}SelectionChange(selection) { + checked${subClassName}.value = selection.map(item => item.index) +} + +#end +/** 导出按钮操作 */ +function handleExport() { + proxy.download('${moduleName}/${businessName}/export', { + ...queryParams.value + }, `${businessName}_#[[${new Date().getTime()}]]#.xlsx`) +} + +getList(); +</script> diff --git a/dc-generator/src/main/resources/vm/vue/v3/index-tree.vue.vm b/dc-generator/src/main/resources/vm/vue/v3/index-tree.vue.vm new file mode 100644 index 0000000..237d899 --- /dev/null +++ b/dc-generator/src/main/resources/vm/vue/v3/index-tree.vue.vm @@ -0,0 +1,486 @@ +<template> + <div class="app-container"> + <el-form :model="queryParams" ref="queryRef" :inline="true" v-show="showSearch" label-width="68px"> +#foreach($column in $columns) +#if($column.query) +#set($dictType=$column.dictType) +#set($AttrName=$column.javaField.substring(0,1).toUpperCase() + ${column.javaField.substring(1)}) +#set($parentheseIndex=$column.columnComment.indexOf("(")) +#if($parentheseIndex != -1) +#set($comment=$column.columnComment.substring(0, $parentheseIndex)) +#else +#set($comment=$column.columnComment) +#end +#if($column.htmlType == "input") + <el-form-item label="${comment}" prop="${column.javaField}"> + <el-input + v-model="queryParams.${column.javaField}" + placeholder="请输入${comment}" + clearable + @keyup.enter="handleQuery" + /> + </el-form-item> +#elseif(($column.htmlType == "select" || $column.htmlType == "radio") && "" != $dictType) + <el-form-item label="${comment}" prop="${column.javaField}"> + <el-select v-model="queryParams.${column.javaField}" placeholder="请选择${comment}" clearable> + <el-option + v-for="dict in ${dictType}" + :key="dict.value" + :label="dict.label" + :value="dict.value" + /> + </el-select> + </el-form-item> +#elseif(($column.htmlType == "select" || $column.htmlType == "radio") && $dictType) + <el-form-item label="${comment}" prop="${column.javaField}"> + <el-select v-model="queryParams.${column.javaField}" placeholder="请选择${comment}" clearable> + <el-option label="请选择字典生成" value="" /> + </el-select> + </el-form-item> +#elseif($column.htmlType == "datetime" && $column.queryType != "BETWEEN") + <el-form-item label="${comment}" prop="${column.javaField}"> + <el-date-picker clearable + v-model="queryParams.${column.javaField}" + type="date" + value-format="YYYY-MM-DD" + placeholder="选择${comment}"> + </el-date-picker> + </el-form-item> +#elseif($column.htmlType == "datetime" && $column.queryType == "BETWEEN") + <el-form-item label="${comment}" style="width: 308px"> + <el-date-picker + v-model="daterange${AttrName}" + value-format="YYYY-MM-DD" + type="daterange" + range-separator="-" + start-placeholder="开始日期" + end-placeholder="结束日期" + ></el-date-picker> + </el-form-item> +#end +#end +#end + <el-form-item> + <el-button type="primary" icon="Search" @click="handleQuery">搜索</el-button> + <el-button icon="Refresh" @click="resetQuery">重置</el-button> + </el-form-item> + </el-form> + + <el-row :gutter="10" class="mb8"> + <el-col :span="1.5"> + <el-button + type="primary" + plain + icon="Plus" + @click="handleAdd" + v-hasPermi="['${moduleName}:${businessName}:add']" + >新增</el-button> + </el-col> + <el-col :span="1.5"> + <el-button + type="info" + plain + icon="Sort" + @click="toggleExpandAll" + >展开/折叠</el-button> + </el-col> + <right-toolbar v-model:showSearch="showSearch" @queryTable="getList"></right-toolbar> + </el-row> + + <el-table + v-if="refreshTable" + v-loading="loading" + :data="${businessName}List" + row-key="${treeCode}" + :default-expand-all="isExpandAll" + :tree-props="{children: 'children', hasChildren: 'hasChildren'}" + > +#foreach($column in $columns) +#set($javaField=$column.javaField) +#set($parentheseIndex=$column.columnComment.indexOf("(")) +#if($parentheseIndex != -1) +#set($comment=$column.columnComment.substring(0, $parentheseIndex)) +#else +#set($comment=$column.columnComment) +#end +#if($column.pk) +#elseif($column.list && $column.htmlType == "datetime") + <el-table-column label="${comment}" align="center" prop="${javaField}" width="180"> + <template #default="scope"> + <span>{{ parseTime(scope.row.${javaField}, '{y}-{m}-{d}') }}</span> + </template> + </el-table-column> +#elseif($column.list && $column.htmlType == "imageUpload") + <el-table-column label="${comment}" align="center" prop="${javaField}" width="100"> + <template #default="scope"> + <image-preview :src="scope.row.${javaField}" :width="50" :height="50"/> + </template> + </el-table-column> +#elseif($column.list && "" != $column.dictType) + <el-table-column label="${comment}" align="center" prop="${javaField}"> + <template #default="scope"> +#if($column.htmlType == "checkbox") + <dict-tag :options="${column.dictType}" :value="scope.row.${javaField} ? scope.row.${javaField}.split(',') : []"/> +#else + <dict-tag :options="${column.dictType}" :value="scope.row.${javaField}"/> +#end + </template> + </el-table-column> +#elseif($column.list && "" != $javaField) +#if(${foreach.index} == 1) + <el-table-column label="${comment}" prop="${javaField}" /> +#else + <el-table-column label="${comment}" align="center" prop="${javaField}" /> +#end +#end +#end + <el-table-column label="操作" align="center" class-name="small-padding fixed-width"> + <template #default="scope"> + <el-button + type="text" + icon="Edit" + @click="handleUpdate(scope.row)" + v-hasPermi="['${moduleName}:${businessName}:edit']" + >修改</el-button> + <el-button + type="text" + icon="Plus" + @click="handleAdd(scope.row)" + v-hasPermi="['${moduleName}:${businessName}:add']" + >新增</el-button> + <el-button + type="text" + icon="Delete" + @click="handleDelete(scope.row)" + v-hasPermi="['${moduleName}:${businessName}:remove']" + >删除</el-button> + </template> + </el-table-column> + </el-table> + + <!-- 添加或修改${functionName}对话框 --> + <el-dialog :title="title" v-model="open" width="500px" append-to-body> + <el-form ref="${businessName}Ref" :model="form" :rules="rules" label-width="80px"> +#foreach($column in $columns) +#set($field=$column.javaField) +#if($column.insert && !$column.pk) +#if(($column.usableColumn) || (!$column.superColumn)) +#set($parentheseIndex=$column.columnComment.indexOf("(")) +#if($parentheseIndex != -1) +#set($comment=$column.columnComment.substring(0, $parentheseIndex)) +#else +#set($comment=$column.columnComment) +#end +#set($dictType=$column.dictType) +#if("" != $treeParentCode && $column.javaField == $treeParentCode) + <el-form-item label="${comment}" prop="${treeParentCode}"> + <el-tree-select + v-model="form.${treeParentCode}" + :data="${businessName}Options" + :props="{ value: '${treeCode}', label: '${treeName}', children: 'children' }" + value-key="${treeCode}" + placeholder="请选择${comment}" + check-strictly + /> + </el-form-item> +#elseif($column.htmlType == "input") + <el-form-item label="${comment}" prop="${field}"> + <el-input v-model="form.${field}" placeholder="请输入${comment}" /> + </el-form-item> +#elseif($column.htmlType == "imageUpload") + <el-form-item label="${comment}"> + <image-upload v-model="form.${field}"/> + </el-form-item> +#elseif($column.htmlType == "fileUpload") + <el-form-item label="${comment}"> + <file-upload v-model="form.${field}"/> + </el-form-item> +#elseif($column.htmlType == "editor") + <el-form-item label="${comment}"> + <editor v-model="form.${field}" :min-height="192"/> + </el-form-item> +#elseif($column.htmlType == "select" && "" != $dictType) + <el-form-item label="${comment}" prop="${field}"> + <el-select v-model="form.${field}" placeholder="请选择${comment}"> + <el-option + v-for="dict in ${dictType}" + :key="dict.value" + :label="dict.label" + #if($column.javaType == "Integer" || $column.javaType == "Long"):value="parseInt(dict.value)"#else:value="dict.value"#end + + ></el-option> + </el-select> + </el-form-item> +#elseif($column.htmlType == "select" && $dictType) + <el-form-item label="${comment}" prop="${field}"> + <el-select v-model="form.${field}" placeholder="请选择${comment}"> + <el-option label="请选择字典生成" value="" /> + </el-select> + </el-form-item> +#elseif($column.htmlType == "checkbox" && "" != $dictType) + <el-form-item label="${comment}"> + <el-checkbox-group v-model="form.${field}"> + <el-checkbox + v-for="dict in ${dictType}" + :key="dict.value" + :label="dict.value"> + {{dict.label}} + </el-checkbox> + </el-checkbox-group> + </el-form-item> +#elseif($column.htmlType == "checkbox" && $dictType) + <el-form-item label="${comment}"> + <el-checkbox-group v-model="form.${field}"> + <el-checkbox>请选择字典生成</el-checkbox> + </el-checkbox-group> + </el-form-item> +#elseif($column.htmlType == "radio" && "" != $dictType) + <el-form-item label="${comment}"> + <el-radio-group v-model="form.${field}"> + <el-radio + v-for="dict in ${dictType}" + :key="dict.value" + #if($column.javaType == "Integer" || $column.javaType == "Long"):label="parseInt(dict.value)"#else:label="dict.value"#end + + >{{dict.label}}</el-radio> + </el-radio-group> + </el-form-item> +#elseif($column.htmlType == "radio" && $dictType) + <el-form-item label="${comment}"> + <el-radio-group v-model="form.${field}"> + <el-radio label="1">请选择字典生成</el-radio> + </el-radio-group> + </el-form-item> +#elseif($column.htmlType == "datetime") + <el-form-item label="${comment}" prop="${field}"> + <el-date-picker clearable + v-model="form.${field}" + type="date" + value-format="YYYY-MM-DD" + placeholder="选择${comment}"> + </el-date-picker> + </el-form-item> +#elseif($column.htmlType == "textarea") + <el-form-item label="${comment}" prop="${field}"> + <el-input v-model="form.${field}" type="textarea" placeholder="请输入内容" /> + </el-form-item> +#end +#end +#end +#end + </el-form> + <template #footer> + <div class="dialog-footer"> + <el-button type="primary" @click="submitForm">确 定</el-button> + <el-button @click="cancel">取 消</el-button> + </div> + </template> + </el-dialog> + </div> +</template> + +<script setup name="${BusinessName}"> +import { list${BusinessName}, get${BusinessName}, del${BusinessName}, add${BusinessName}, update${BusinessName} } from "@/api/${moduleName}/${businessName}"; + +const { proxy } = getCurrentInstance(); +#if(${dicts} != '') +#set($dictsNoSymbol=$dicts.replace("'", "")) +const { ${dictsNoSymbol} } = proxy.useDict(${dicts}); +#end + +const ${businessName}List = ref([]); +const ${businessName}Options = ref([]); +const open = ref(false); +const loading = ref(true); +const showSearch = ref(true); +const title = ref(""); +const isExpandAll = ref(true); +const refreshTable = ref(true); +#foreach ($column in $columns) +#if($column.htmlType == "datetime" && $column.queryType == "BETWEEN") +#set($AttrName=$column.javaField.substring(0,1).toUpperCase() + ${column.javaField.substring(1)}) +const daterange${AttrName} = ref([]); +#end +#end + +const data = reactive({ + form: {}, + queryParams: { + #foreach ($column in $columns) +#if($column.query) + $column.javaField: null#if($foreach.count != $columns.size()),#end +#end +#end + }, + rules: { + #foreach ($column in $columns) +#if($column.required) +#set($parentheseIndex=$column.columnComment.indexOf("(")) +#if($parentheseIndex != -1) +#set($comment=$column.columnComment.substring(0, $parentheseIndex)) +#else +#set($comment=$column.columnComment) +#end + $column.javaField: [ + { required: true, message: "$comment不能为空", trigger: #if($column.htmlType == "select")"change"#else"blur"#end } + ]#if($foreach.count != $columns.size()),#end +#end +#end + } +}); + +const { queryParams, form, rules } = toRefs(data); + +/** 查询${functionName}列表 */ +function getList() { + loading.value = true; +#foreach ($column in $columns) +#if($column.htmlType == "datetime" && $column.queryType == "BETWEEN") + queryParams.value.params = {}; +#break +#end +#end +#foreach ($column in $columns) +#if($column.htmlType == "datetime" && $column.queryType == "BETWEEN") +#set($AttrName=$column.javaField.substring(0,1).toUpperCase() + ${column.javaField.substring(1)}) + if (null != daterange${AttrName} && '' != daterange${AttrName}) { + queryParams.value.params["begin${AttrName}"] = daterange${AttrName}.value[0]; + queryParams.value.params["end${AttrName}"] = daterange${AttrName}.value[1]; + } +#end +#end + list${BusinessName}(queryParams.value).then(response => { + ${businessName}List.value = proxy.handleTree(response.data, "${treeCode}", "${treeParentCode}"); + loading.value = false; + }); +} + +/** 查询${functionName}下拉树结构 */ +function getTreeselect() { + list${BusinessName}().then(response => { + ${businessName}Options.value = []; + const data = { ${treeCode}: 0, ${treeName}: '顶级节点', children: [] }; + data.children = proxy.handleTree(response.data, "${treeCode}", "${treeParentCode}"); + ${businessName}Options.value.push(data); + }); +} + +// 取消按钮 +function cancel() { + open.value = false; + reset(); +} + +// 表单重置 +function reset() { + form.value = { +#foreach ($column in $columns) +#if($column.htmlType == "radio") + $column.javaField: #if($column.javaType == "Integer" || $column.javaType == "Long")0#else"0"#end#if($foreach.count != $columns.size()),#end + +#elseif($column.htmlType == "checkbox") + $column.javaField: []#if($foreach.count != $columns.size()),#end +#else + $column.javaField: null#if($foreach.count != $columns.size()),#end +#end +#end + }; + proxy.resetForm("${businessName}Ref"); +} + +/** 搜索按钮操作 */ +function handleQuery() { + getList(); +} + +/** 重置按钮操作 */ +function resetQuery() { +#foreach ($column in $columns) +#if($column.htmlType == "datetime" && $column.queryType == "BETWEEN") +#set($AttrName=$column.javaField.substring(0,1).toUpperCase() + ${column.javaField.substring(1)}) + daterange${AttrName}.value = []; +#end +#end + proxy.resetForm("queryRef"); + handleQuery(); +} + +/** 新增按钮操作 */ +function handleAdd(row) { + reset(); + getTreeselect(); + if (row != null && row.${treeCode}) { + form.value.${treeParentCode} = row.${treeCode}; + } else { + form.value.${treeParentCode} = 0; + } + open.value = true; + title.value = "添加${functionName}"; +} + +/** 展开/折叠操作 */ +function toggleExpandAll() { + refreshTable.value = false; + isExpandAll.value = !isExpandAll.value; + nextTick(() => { + refreshTable.value = true; + }); +} + +/** 修改按钮操作 */ +async function handleUpdate(row) { + reset(); + await getTreeselect(); + if (row != null) { + form.value.${treeParentCode} = row.${treeCode}; + } + get${BusinessName}(row.${pkColumn.javaField}).then(response => { + form.value = response.data; +#foreach ($column in $columns) +#if($column.htmlType == "checkbox") + form.value.$column.javaField = form.value.${column.javaField}.split(","); +#end +#end + open.value = true; + title.value = "修改${functionName}"; + }); +} + +/** 提交按钮 */ +function submitForm() { + proxy.#[[$]]#refs["${businessName}Ref"].validate(valid => { + if (valid) { +#foreach ($column in $columns) +#if($column.htmlType == "checkbox") + form.value.$column.javaField = form.value.${column.javaField}.join(","); +#end +#end + if (form.value.${pkColumn.javaField} != null) { + update${BusinessName}(form.value).then(response => { + proxy.#[[$modal]]#.msgSuccess("修改成功"); + open.value = false; + getList(); + }); + } else { + add${BusinessName}(form.value).then(response => { + proxy.#[[$modal]]#.msgSuccess("新增成功"); + open.value = false; + getList(); + }); + } + } + }); +} + +/** 删除按钮操作 */ +function handleDelete(row) { + proxy.#[[$modal]]#.confirm('是否确认删除${functionName}编号为"' + row.${pkColumn.javaField} + '"的数据项?').then(function() { + return del${BusinessName}(row.${pkColumn.javaField}); + }).then(() => { + getList(); + proxy.#[[$modal]]#.msgSuccess("删除成功"); + }).catch(() => {}); +} + +getList(); +</script> diff --git a/dc-generator/src/main/resources/vm/vue/v3/index.vue.vm b/dc-generator/src/main/resources/vm/vue/v3/index.vue.vm new file mode 100644 index 0000000..f585c02 --- /dev/null +++ b/dc-generator/src/main/resources/vm/vue/v3/index.vue.vm @@ -0,0 +1,596 @@ +<template> + <div class="app-container"> + <el-form :model="queryParams" ref="queryRef" :inline="true" v-show="showSearch" label-width="68px"> +#foreach($column in $columns) +#if($column.query) +#set($dictType=$column.dictType) +#set($AttrName=$column.javaField.substring(0,1).toUpperCase() + ${column.javaField.substring(1)}) +#set($parentheseIndex=$column.columnComment.indexOf("(")) +#if($parentheseIndex != -1) +#set($comment=$column.columnComment.substring(0, $parentheseIndex)) +#else +#set($comment=$column.columnComment) +#end +#if($column.htmlType == "input") + <el-form-item label="${comment}" prop="${column.javaField}"> + <el-input + v-model="queryParams.${column.javaField}" + placeholder="请输入${comment}" + clearable + @keyup.enter="handleQuery" + /> + </el-form-item> +#elseif(($column.htmlType == "select" || $column.htmlType == "radio") && "" != $dictType) + <el-form-item label="${comment}" prop="${column.javaField}"> + <el-select v-model="queryParams.${column.javaField}" placeholder="请选择${comment}" clearable> + <el-option + v-for="dict in ${dictType}" + :key="dict.value" + :label="dict.label" + :value="dict.value" + /> + </el-select> + </el-form-item> +#elseif(($column.htmlType == "select" || $column.htmlType == "radio") && $dictType) + <el-form-item label="${comment}" prop="${column.javaField}"> + <el-select v-model="queryParams.${column.javaField}" placeholder="请选择${comment}" clearable> + <el-option label="请选择字典生成" value="" /> + </el-select> + </el-form-item> +#elseif($column.htmlType == "datetime" && $column.queryType != "BETWEEN") + <el-form-item label="${comment}" prop="${column.javaField}"> + <el-date-picker clearable + v-model="queryParams.${column.javaField}" + type="date" + value-format="YYYY-MM-DD" + placeholder="请选择${comment}"> + </el-date-picker> + </el-form-item> +#elseif($column.htmlType == "datetime" && $column.queryType == "BETWEEN") + <el-form-item label="${comment}" style="width: 308px"> + <el-date-picker + v-model="daterange${AttrName}" + value-format="YYYY-MM-DD" + type="daterange" + range-separator="-" + start-placeholder="开始日期" + end-placeholder="结束日期" + ></el-date-picker> + </el-form-item> +#end +#end +#end + <el-form-item> + <el-button type="primary" icon="Search" @click="handleQuery">搜索</el-button> + <el-button icon="Refresh" @click="resetQuery">重置</el-button> + </el-form-item> + </el-form> + + <el-row :gutter="10" class="mb8"> + <el-col :span="1.5"> + <el-button + type="primary" + plain + icon="Plus" + @click="handleAdd" + v-hasPermi="['${moduleName}:${businessName}:add']" + >新增</el-button> + </el-col> + <el-col :span="1.5"> + <el-button + type="success" + plain + icon="Edit" + :disabled="single" + @click="handleUpdate" + v-hasPermi="['${moduleName}:${businessName}:edit']" + >修改</el-button> + </el-col> + <el-col :span="1.5"> + <el-button + type="danger" + plain + icon="Delete" + :disabled="multiple" + @click="handleDelete" + v-hasPermi="['${moduleName}:${businessName}:remove']" + >删除</el-button> + </el-col> + <el-col :span="1.5"> + <el-button + type="warning" + plain + icon="Download" + @click="handleExport" + v-hasPermi="['${moduleName}:${businessName}:export']" + >导出</el-button> + </el-col> + <right-toolbar v-model:showSearch="showSearch" @queryTable="getList"></right-toolbar> + </el-row> + + <el-table v-loading="loading" :data="${businessName}List" @selection-change="handleSelectionChange"> + <el-table-column type="selection" width="55" align="center" /> +#foreach($column in $columns) +#set($javaField=$column.javaField) +#set($parentheseIndex=$column.columnComment.indexOf("(")) +#if($parentheseIndex != -1) +#set($comment=$column.columnComment.substring(0, $parentheseIndex)) +#else +#set($comment=$column.columnComment) +#end +#if($column.pk) + <el-table-column label="${comment}" align="center" prop="${javaField}" /> +#elseif($column.list && $column.htmlType == "datetime") + <el-table-column label="${comment}" align="center" prop="${javaField}" width="180"> + <template #default="scope"> + <span>{{ parseTime(scope.row.${javaField}, '{y}-{m}-{d}') }}</span> + </template> + </el-table-column> +#elseif($column.list && $column.htmlType == "imageUpload") + <el-table-column label="${comment}" align="center" prop="${javaField}" width="100"> + <template #default="scope"> + <image-preview :src="scope.row.${javaField}" :width="50" :height="50"/> + </template> + </el-table-column> +#elseif($column.list && "" != $column.dictType) + <el-table-column label="${comment}" align="center" prop="${javaField}"> + <template #default="scope"> +#if($column.htmlType == "checkbox") + <dict-tag :options="${column.dictType}" :value="scope.row.${javaField} ? scope.row.${javaField}.split(',') : []"/> +#else + <dict-tag :options="${column.dictType}" :value="scope.row.${javaField}"/> +#end + </template> + </el-table-column> +#elseif($column.list && "" != $javaField) + <el-table-column label="${comment}" align="center" prop="${javaField}" /> +#end +#end + <el-table-column label="操作" align="center" class-name="small-padding fixed-width"> + <template #default="scope"> + <el-button + type="text" + icon="Edit" + @click="handleUpdate(scope.row)" + v-hasPermi="['${moduleName}:${businessName}:edit']" + >修改</el-button> + <el-button + type="text" + icon="Delete" + @click="handleDelete(scope.row)" + v-hasPermi="['${moduleName}:${businessName}:remove']" + >删除</el-button> + </template> + </el-table-column> + </el-table> + + <pagination + v-show="total>0" + :total="total" + v-model:page="queryParams.pageNum" + v-model:limit="queryParams.pageSize" + @pagination="getList" + /> + + <!-- 添加或修改${functionName}对话框 --> + <el-dialog :title="title" v-model="open" width="500px" append-to-body> + <el-form ref="${businessName}Ref" :model="form" :rules="rules" label-width="80px"> +#foreach($column in $columns) +#set($field=$column.javaField) +#if($column.insert && !$column.pk) +#if(($column.usableColumn) || (!$column.superColumn)) +#set($parentheseIndex=$column.columnComment.indexOf("(")) +#if($parentheseIndex != -1) +#set($comment=$column.columnComment.substring(0, $parentheseIndex)) +#else +#set($comment=$column.columnComment) +#end +#set($dictType=$column.dictType) +#if($column.htmlType == "input") + <el-form-item label="${comment}" prop="${field}"> + <el-input v-model="form.${field}" placeholder="请输入${comment}" /> + </el-form-item> +#elseif($column.htmlType == "imageUpload") + <el-form-item label="${comment}"> + <image-upload v-model="form.${field}"/> + </el-form-item> +#elseif($column.htmlType == "fileUpload") + <el-form-item label="${comment}"> + <file-upload v-model="form.${field}"/> + </el-form-item> +#elseif($column.htmlType == "editor") + <el-form-item label="${comment}"> + <editor v-model="form.${field}" :min-height="192"/> + </el-form-item> +#elseif($column.htmlType == "select" && "" != $dictType) + <el-form-item label="${comment}" prop="${field}"> + <el-select v-model="form.${field}" placeholder="请选择${comment}"> + <el-option + v-for="dict in ${dictType}" + :key="dict.value" + :label="dict.label" + #if($column.javaType == "Integer" || $column.javaType == "Long"):value="parseInt(dict.value)"#else:value="dict.value"#end + + ></el-option> + </el-select> + </el-form-item> +#elseif($column.htmlType == "select" && $dictType) + <el-form-item label="${comment}" prop="${field}"> + <el-select v-model="form.${field}" placeholder="请选择${comment}"> + <el-option label="请选择字典生成" value="" /> + </el-select> + </el-form-item> +#elseif($column.htmlType == "checkbox" && "" != $dictType) + <el-form-item label="${comment}"> + <el-checkbox-group v-model="form.${field}"> + <el-checkbox + v-for="dict in ${dictType}" + :key="dict.value" + :label="dict.value"> + {{dict.label}} + </el-checkbox> + </el-checkbox-group> + </el-form-item> +#elseif($column.htmlType == "checkbox" && $dictType) + <el-form-item label="${comment}"> + <el-checkbox-group v-model="form.${field}"> + <el-checkbox>请选择字典生成</el-checkbox> + </el-checkbox-group> + </el-form-item> +#elseif($column.htmlType == "radio" && "" != $dictType) + <el-form-item label="${comment}"> + <el-radio-group v-model="form.${field}"> + <el-radio + v-for="dict in ${dictType}" + :key="dict.value" + #if($column.javaType == "Integer" || $column.javaType == "Long"):label="parseInt(dict.value)"#else:label="dict.value"#end + + >{{dict.label}}</el-radio> + </el-radio-group> + </el-form-item> +#elseif($column.htmlType == "radio" && $dictType) + <el-form-item label="${comment}"> + <el-radio-group v-model="form.${field}"> + <el-radio label="1">请选择字典生成</el-radio> + </el-radio-group> + </el-form-item> +#elseif($column.htmlType == "datetime") + <el-form-item label="${comment}" prop="${field}"> + <el-date-picker clearable + v-model="form.${field}" + type="date" + value-format="YYYY-MM-DD" + placeholder="请选择${comment}"> + </el-date-picker> + </el-form-item> +#elseif($column.htmlType == "textarea") + <el-form-item label="${comment}" prop="${field}"> + <el-input v-model="form.${field}" type="textarea" placeholder="请输入内容" /> + </el-form-item> +#end +#end +#end +#end +#if($table.sub) + <el-divider content-position="center">${subTable.functionName}信息</el-divider> + <el-row :gutter="10" class="mb8"> + <el-col :span="1.5"> + <el-button type="primary" icon="Plus" @click="handleAdd${subClassName}">添加</el-button> + </el-col> + <el-col :span="1.5"> + <el-button type="danger" icon="Delete" @click="handleDelete${subClassName}">删除</el-button> + </el-col> + </el-row> + <el-table :data="${subclassName}List" :row-class-name="row${subClassName}Index" @selection-change="handle${subClassName}SelectionChange" ref="${subclassName}"> + <el-table-column type="selection" width="50" align="center" /> + <el-table-column label="序号" align="center" prop="index" width="50"/> +#foreach($column in $subTable.columns) +#set($javaField=$column.javaField) +#set($parentheseIndex=$column.columnComment.indexOf("(")) +#if($parentheseIndex != -1) +#set($comment=$column.columnComment.substring(0, $parentheseIndex)) +#else +#set($comment=$column.columnComment) +#end +#if($column.pk || $javaField == ${subTableFkclassName}) +#elseif($column.list && $column.htmlType == "input") + <el-table-column label="$comment" prop="${javaField}" width="150"> + <template #default="scope"> + <el-input v-model="scope.row.$javaField" placeholder="请输入$comment" /> + </template> + </el-table-column> +#elseif($column.list && $column.htmlType == "datetime") + <el-table-column label="$comment" prop="${javaField}" width="240"> + <template #default="scope"> + <el-date-picker clearable + v-model="scope.row.$javaField" + type="date" + value-format="YYYY-MM-DD" + placeholder="请选择$comment"> + </el-date-picker> + </template> + </el-table-column> +#elseif($column.list && ($column.htmlType == "select" || $column.htmlType == "radio") && "" != $column.dictType) + <el-table-column label="$comment" prop="${javaField}" width="150"> + <template #default="scope"> + <el-select v-model="scope.row.$javaField" placeholder="请选择$comment"> + <el-option + v-for="dict in $column.dictType" + :key="dict.value" + :label="dict.label" + :value="dict.value" + ></el-option> + </el-select> + </template> + </el-table-column> +#elseif($column.list && ($column.htmlType == "select" || $column.htmlType == "radio") && "" == $column.dictType) + <el-table-column label="$comment" prop="${javaField}" width="150"> + <template #default="scope"> + <el-select v-model="scope.row.$javaField" placeholder="请选择$comment"> + <el-option label="请选择字典生成" value="" /> + </el-select> + </template> + </el-table-column> +#end +#end + </el-table> +#end + </el-form> + <template #footer> + <div class="dialog-footer"> + <el-button type="primary" @click="submitForm">确 定</el-button> + <el-button @click="cancel">取 消</el-button> + </div> + </template> + </el-dialog> + </div> +</template> + +<script setup name="${BusinessName}"> +import { list${BusinessName}, get${BusinessName}, del${BusinessName}, add${BusinessName}, update${BusinessName} } from "@/api/${moduleName}/${businessName}"; + +const { proxy } = getCurrentInstance(); +#if(${dicts} != '') +#set($dictsNoSymbol=$dicts.replace("'", "")) +const { ${dictsNoSymbol} } = proxy.useDict(${dicts}); +#end + +const ${businessName}List = ref([]); +#if($table.sub) +const ${subclassName}List = ref([]); +#end +const open = ref(false); +const loading = ref(true); +const showSearch = ref(true); +const ids = ref([]); +#if($table.sub) +const checked${subClassName} = ref([]); +#end +const single = ref(true); +const multiple = ref(true); +const total = ref(0); +const title = ref(""); +#foreach ($column in $columns) +#if($column.htmlType == "datetime" && $column.queryType == "BETWEEN") +#set($AttrName=$column.javaField.substring(0,1).toUpperCase() + ${column.javaField.substring(1)}) +const daterange${AttrName} = ref([]); +#end +#end + +const data = reactive({ + form: {}, + queryParams: { + pageNum: 1, + pageSize: 10, + #foreach ($column in $columns) +#if($column.query) + $column.javaField: null#if($foreach.count != $columns.size()),#end +#end +#end + }, + rules: { + #foreach ($column in $columns) +#if($column.required) +#set($parentheseIndex=$column.columnComment.indexOf("(")) +#if($parentheseIndex != -1) +#set($comment=$column.columnComment.substring(0, $parentheseIndex)) +#else +#set($comment=$column.columnComment) +#end + $column.javaField: [ + { required: true, message: "$comment不能为空", trigger: #if($column.htmlType == "select")"change"#else"blur"#end } + ]#if($foreach.count != $columns.size()),#end +#end +#end + } +}); + +const { queryParams, form, rules } = toRefs(data); + +/** 查询${functionName}列表 */ +function getList() { + loading.value = true; +#foreach ($column in $columns) +#if($column.htmlType == "datetime" && $column.queryType == "BETWEEN") + queryParams.value.params = {}; +#break +#end +#end +#foreach ($column in $columns) +#if($column.htmlType == "datetime" && $column.queryType == "BETWEEN") +#set($AttrName=$column.javaField.substring(0,1).toUpperCase() + ${column.javaField.substring(1)}) + if (null != daterange${AttrName} && '' != daterange${AttrName}) { + queryParams.value.params["begin${AttrName}"] = daterange${AttrName}.value[0]; + queryParams.value.params["end${AttrName}"] = daterange${AttrName}.value[1]; + } +#end +#end + list${BusinessName}(queryParams.value).then(response => { + ${businessName}List.value = response.rows; + total.value = response.total; + loading.value = false; + }); +} + +// 取消按钮 +function cancel() { + open.value = false; + reset(); +} + +// 表单重置 +function reset() { + form.value = { +#foreach ($column in $columns) +#if($column.htmlType == "radio") + $column.javaField: #if($column.javaType == "Integer" || $column.javaType == "Long")0#else"0"#end#if($foreach.count != $columns.size()),#end +#elseif($column.htmlType == "checkbox") + $column.javaField: []#if($foreach.count != $columns.size()),#end +#else + $column.javaField: null#if($foreach.count != $columns.size()),#end +#end +#end + }; +#if($table.sub) + ${subclassName}List.value = []; +#end + proxy.resetForm("${businessName}Ref"); +} + +/** 搜索按钮操作 */ +function handleQuery() { + queryParams.value.pageNum = 1; + getList(); +} + +/** 重置按钮操作 */ +function resetQuery() { +#foreach ($column in $columns) +#if($column.htmlType == "datetime" && $column.queryType == "BETWEEN") +#set($AttrName=$column.javaField.substring(0,1).toUpperCase() + ${column.javaField.substring(1)}) + daterange${AttrName}.value = []; +#end +#end + proxy.resetForm("queryRef"); + handleQuery(); +} + +// 多选框选中数据 +function handleSelectionChange(selection) { + ids.value = selection.map(item => item.${pkColumn.javaField}); + single.value = selection.length != 1; + multiple.value = !selection.length; +} + +/** 新增按钮操作 */ +function handleAdd() { + reset(); + open.value = true; + title.value = "添加${functionName}"; +} + +/** 修改按钮操作 */ +function handleUpdate(row) { + reset(); + const _${pkColumn.javaField} = row.${pkColumn.javaField} || ids.value + get${BusinessName}(_${pkColumn.javaField}).then(response => { + form.value = response.data; +#foreach ($column in $columns) +#if($column.htmlType == "checkbox") + form.value.$column.javaField = form.value.${column.javaField}.split(","); +#end +#end +#if($table.sub) + ${subclassName}List.value = response.data.${subclassName}List; +#end + open.value = true; + title.value = "修改${functionName}"; + }); +} + +/** 提交按钮 */ +function submitForm() { + proxy.#[[$]]#refs["${businessName}Ref"].validate(valid => { + if (valid) { +#foreach ($column in $columns) +#if($column.htmlType == "checkbox") + form.value.$column.javaField = form.value.${column.javaField}.join(","); +#end +#end +#if($table.sub) + form.value.${subclassName}List = ${subclassName}List.value; +#end + if (form.value.${pkColumn.javaField} != null) { + update${BusinessName}(form.value).then(response => { + proxy.#[[$modal]]#.msgSuccess("修改成功"); + open.value = false; + getList(); + }); + } else { + add${BusinessName}(form.value).then(response => { + proxy.#[[$modal]]#.msgSuccess("新增成功"); + open.value = false; + getList(); + }); + } + } + }); +} + +/** 删除按钮操作 */ +function handleDelete(row) { + const _${pkColumn.javaField}s = row.${pkColumn.javaField} || ids.value; + proxy.#[[$modal]]#.confirm('是否确认删除${functionName}编号为"' + _${pkColumn.javaField}s + '"的数据项?').then(function() { + return del${BusinessName}(_${pkColumn.javaField}s); + }).then(() => { + getList(); + proxy.#[[$modal]]#.msgSuccess("删除成功"); + }).catch(() => {}); +} + +#if($table.sub) +/** ${subTable.functionName}序号 */ +function row${subClassName}Index({ row, rowIndex }) { + row.index = rowIndex + 1; +} + +/** ${subTable.functionName}添加按钮操作 */ +function handleAdd${subClassName}() { + let obj = {}; +#foreach($column in $subTable.columns) +#if($column.pk || $column.javaField == ${subTableFkclassName}) +#elseif($column.list && "" != $javaField) + obj.$column.javaField = ""; +#end +#end + ${subclassName}List.value.push(obj); +} + +/** ${subTable.functionName}删除按钮操作 */ +function handleDelete${subClassName}() { + if (checked${subClassName}.value.length == 0) { + proxy.#[[$modal]]#.msgError("请先选择要删除的${subTable.functionName}数据"); + } else { + const ${subclassName}s = ${subclassName}List.value; + const checked${subClassName}s = checked${subClassName}.value; + ${subclassName}List.value = ${subclassName}s.filter(function(item) { + return checked${subClassName}s.indexOf(item.index) == -1 + }); + } +} + +/** 复选框选中数据 */ +function handle${subClassName}SelectionChange(selection) { + checked${subClassName}.value = selection.map(item => item.index) +} + +#end +/** 导出按钮操作 */ +function handleExport() { + proxy.download('${moduleName}/${businessName}/export', { + ...queryParams.value + }, `${businessName}_#[[${new Date().getTime()}]]#.xlsx`) +} + +getList(); +</script> diff --git a/dc-generator/src/main/resources/vm/vue/v3/readme.txt b/dc-generator/src/main/resources/vm/vue/v3/readme.txt new file mode 100644 index 0000000..a099146 --- /dev/null +++ b/dc-generator/src/main/resources/vm/vue/v3/readme.txt @@ -0,0 +1 @@ +���ʹ�õ���Win-Vue3ǰ�ˣ���ô��Ҫ����һ�´�Ŀ¼��ģ��index.vue.vm��index-tree.vue.vm�ļ����ϼ�vueĿ¼�� \ No newline at end of file diff --git a/dc-generator/src/main/resources/vm/xml/mapper.xml.vm b/dc-generator/src/main/resources/vm/xml/mapper.xml.vm new file mode 100644 index 0000000..9cbcc50 --- /dev/null +++ b/dc-generator/src/main/resources/vm/xml/mapper.xml.vm @@ -0,0 +1,29 @@ +<?xml version="1.0" encoding="UTF-8" ?> +<!DOCTYPE mapper +PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" +"http://mybatis.org/dtd/mybatis-3-mapper.dtd"> +<mapper namespace="com.dc.system.mapper.${ClassName}Mapper"> + + <resultMap type="${ClassName}" id="${ClassName}Result"> +#foreach ($column in $columns) + <result property="${column.javaField}" column="${column.columnName}" /> +#end + </resultMap> +#if($table.sub) + + <resultMap id="${ClassName}${subClassName}Result" type="${ClassName}" extends="${ClassName}Result"> + <collection property="${subclassName}List" notNullColumn="sub_${subTable.pkColumn.columnName}" javaType="java.util.List" resultMap="${subClassName}Result" /> + </resultMap> + + <resultMap type="${subClassName}" id="${subClassName}Result"> +#foreach ($column in $subTable.columns) + <result property="${column.javaField}" column="sub_${column.columnName}" /> +#end + </resultMap> +#end + + <sql id="select${ClassName}Vo"> + select#foreach($column in $columns) $column.columnName#if($foreach.count != $columns.size()),#end#end from ${tableName} + </sql> + +</mapper> \ No newline at end of file diff --git a/dc-model/pom.xml b/dc-model/pom.xml new file mode 100644 index 0000000..884fdc6 --- /dev/null +++ b/dc-model/pom.xml @@ -0,0 +1,12 @@ +<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" + xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd"> + <modelVersion>4.0.0</modelVersion> + <parent> + <groupId>com.dc</groupId> + <artifactId>dc</artifactId> + <version>1.0.0</version> + </parent> + <artifactId>dc-model</artifactId> + <name>Archetype - dc-model</name> + <url>http://maven.apache.org</url> +</project> diff --git a/dc-model/src/main/resources/META-INF/maven/archetype.xml b/dc-model/src/main/resources/META-INF/maven/archetype.xml new file mode 100644 index 0000000..c589517 --- /dev/null +++ b/dc-model/src/main/resources/META-INF/maven/archetype.xml @@ -0,0 +1,9 @@ +<archetype> + <id>dc-model</id> + <sources> + <source>src/main/java/App.java</source> + </sources> + <testSources> + <source>src/test/java/AppTest.java</source> + </testSources> +</archetype> diff --git a/dc-model/src/main/resources/archetype-resources/pom.xml b/dc-model/src/main/resources/archetype-resources/pom.xml new file mode 100644 index 0000000..6463aae --- /dev/null +++ b/dc-model/src/main/resources/archetype-resources/pom.xml @@ -0,0 +1,15 @@ +<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" + xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd"> + <modelVersion>4.0.0</modelVersion> + <groupId>$com.dc</groupId> + <artifactId>$dc-model</artifactId> + <version>$1.0.0</version> + <dependencies> + <dependency> + <groupId>junit</groupId> + <artifactId>junit</artifactId> + <version>3.8.1</version> + <scope>test</scope> + </dependency> + </dependencies> +</project> diff --git a/dc-model/src/main/resources/archetype-resources/src/main/java/App.java b/dc-model/src/main/resources/archetype-resources/src/main/java/App.java new file mode 100644 index 0000000..a9cb75c --- /dev/null +++ b/dc-model/src/main/resources/archetype-resources/src/main/java/App.java @@ -0,0 +1,13 @@ +package $com.dc; + +/** + * Hello world! + * + */ +public class App +{ + public static void main( String[] args ) + { + System.out.println( "Hello World!" ); + } +} diff --git a/dc-model/src/main/resources/archetype-resources/src/test/java/AppTest.java b/dc-model/src/main/resources/archetype-resources/src/test/java/AppTest.java new file mode 100644 index 0000000..423e223 --- /dev/null +++ b/dc-model/src/main/resources/archetype-resources/src/test/java/AppTest.java @@ -0,0 +1,38 @@ +package $com.dc; + +import junit.framework.Test; +import junit.framework.TestCase; +import junit.framework.TestSuite; + +/** + * Unit test for simple App. + */ +public class AppTest + extends TestCase +{ + /** + * Create the test case + * + * @param testName name of the test case + */ + public AppTest( String testName ) + { + super( testName ); + } + + /** + * @return the suite of tests being tested + */ + public static Test suite() + { + return new TestSuite( AppTest.class ); + } + + /** + * Rigourous Test :-) + */ + public void testApp() + { + assertTrue( true ); + } +} diff --git a/dc-quartz/pom.xml b/dc-quartz/pom.xml new file mode 100644 index 0000000..78f0e11 --- /dev/null +++ b/dc-quartz/pom.xml @@ -0,0 +1,40 @@ +<?xml version="1.0" encoding="UTF-8"?> +<project xmlns="http://maven.apache.org/POM/4.0.0" + xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" + xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> + <parent> + <artifactId>dc</artifactId> + <groupId>com.dc</groupId> + <version>1.0.0</version> + </parent> + <modelVersion>4.0.0</modelVersion> + + <artifactId>dc-quartz</artifactId> + + <description> + quartz定时任务 + </description> + + <dependencies> + + <!-- 定时任务 --> + <dependency> + <groupId>org.quartz-scheduler</groupId> + <artifactId>quartz</artifactId> + <exclusions> + <exclusion> + <groupId>com.mchange</groupId> + <artifactId>c3p0</artifactId> + </exclusion> + </exclusions> + </dependency> + + <!-- 通用工具--> + <dependency> + <groupId>com.dc</groupId> + <artifactId>dc-common</artifactId> + </dependency> + + </dependencies> + +</project> \ No newline at end of file diff --git a/dc-quartz/src/main/java/com/dc/quartz/config/ScheduleConfig.java b/dc-quartz/src/main/java/com/dc/quartz/config/ScheduleConfig.java new file mode 100644 index 0000000..8465447 --- /dev/null +++ b/dc-quartz/src/main/java/com/dc/quartz/config/ScheduleConfig.java @@ -0,0 +1,57 @@ +//package com.dc.quartz.config; +// +//import org.springframework.context.annotation.Bean; +//import org.springframework.context.annotation.Configuration; +//import org.springframework.scheduling.quartz.SchedulerFactoryBean; +//import javax.sql.DataSource; +//import java.util.Properties; +// +///** +// * 定时任务配置(单机部署建议删除此类和qrtz数据库表,默认走内存会最高效) +// * +// * @author win +// */ +//@Configuration +//public class ScheduleConfig +//{ +// @Bean +// public SchedulerFactoryBean schedulerFactoryBean(DataSource dataSource) +// { +// SchedulerFactoryBean factory = new SchedulerFactoryBean(); +// factory.setDataSource(dataSource); +// +// // quartz参数 +// Properties prop = new Properties(); +// prop.put("org.quartz.scheduler.instanceName", "WinScheduler"); +// prop.put("org.quartz.scheduler.instanceId", "AUTO"); +// // 线程池配置 +// prop.put("org.quartz.threadPool.class", "org.quartz.simpl.SimpleThreadPool"); +// prop.put("org.quartz.threadPool.threadCount", "20"); +// prop.put("org.quartz.threadPool.threadPriority", "5"); +// // JobStore配置 +// prop.put("org.quartz.jobStore.class", "org.springframework.scheduling.quartz.LocalDataSourceJobStore"); +// // 集群配置 +// prop.put("org.quartz.jobStore.isClustered", "true"); +// prop.put("org.quartz.jobStore.clusterCheckinInterval", "15000"); +// prop.put("org.quartz.jobStore.maxMisfiresToHandleAtATime", "1"); +// prop.put("org.quartz.jobStore.txIsolationLevelSerializable", "true"); +// +// // sqlserver 启用 +// // prop.put("org.quartz.jobStore.selectWithLockSQL", "SELECT * FROM {0}LOCKS UPDLOCK WHERE LOCK_NAME = ?"); +// prop.put("org.quartz.jobStore.misfireThreshold", "12000"); +// prop.put("org.quartz.jobStore.tablePrefix", "QRTZ_"); +// factory.setQuartzProperties(prop); +// +// factory.setSchedulerName("WinScheduler"); +// // 延时启动 +// factory.setStartupDelay(1); +// factory.setApplicationContextSchedulerContextKey("applicationContextKey"); +// // 可选,QuartzScheduler +// // 启动时更新己存在的Job,这样就不用每次修改targetObject后删除qrtz_job_details表对应记录了 +// factory.setOverwriteExistingJobs(true); +// // 设置自动启动,默认为true +// factory.setAutoStartup(true); +// +// return factory; +// } +//} diff --git a/dc-quartz/src/main/java/com/dc/quartz/controller/SysJobController.java b/dc-quartz/src/main/java/com/dc/quartz/controller/SysJobController.java new file mode 100644 index 0000000..e84237b --- /dev/null +++ b/dc-quartz/src/main/java/com/dc/quartz/controller/SysJobController.java @@ -0,0 +1,179 @@ +package com.dc.quartz.controller; + +import com.dc.common.annotation.Log; +import com.dc.common.constant.Constants; +import com.dc.common.core.controller.BaseController; +import com.dc.common.core.domain.AjaxResult; +import com.dc.common.core.page.TableDataInfo; +import com.dc.common.enums.BusinessType; +import com.dc.common.exception.job.TaskException; +import com.dc.common.utils.StringUtils; +import com.dc.common.utils.poi.ExcelUtil; +import com.dc.quartz.domain.SysJob; +import com.dc.quartz.service.SysJobService; +import com.dc.quartz.util.CronUtils; +import com.dc.quartz.util.ScheduleUtils; +import org.quartz.SchedulerException; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.security.access.prepost.PreAuthorize; +import org.springframework.web.bind.annotation.*; + +import javax.servlet.http.HttpServletResponse; +import java.util.List; + +/** + * 调度任务信息操作处理 + * + * @author win + */ +@RestController +@RequestMapping("/monitor/job") +public class SysJobController extends BaseController +{ + @Autowired + private SysJobService jobService; + + /** + * 查询定时任务列表 + */ + @PreAuthorize("@ss.hasPermi('monitor:job:list')") + @GetMapping("/list") + public TableDataInfo list(SysJob sysJob) + { + startPage(); + List<SysJob> list = jobService.selectJobList(sysJob); + return getDataTable(list); + } + + /** + * 导出定时任务列表 + */ + @PreAuthorize("@ss.hasPermi('monitor:job:export')") + @Log(title = "定时任务", businessType = BusinessType.EXPORT) + @PostMapping("/export") + public void export(HttpServletResponse response, SysJob sysJob) + { + List<SysJob> list = jobService.selectJobList(sysJob); + ExcelUtil<SysJob> util = new ExcelUtil<SysJob>(SysJob.class); + util.exportExcel(response, list, "定时任务"); + } + + /** + * 获取定时任务详细信息 + */ + @PreAuthorize("@ss.hasPermi('monitor:job:query')") + @GetMapping(value = "/{jobId}") + public AjaxResult getInfo(@PathVariable("jobId") Long jobId) + { + return success(jobService.selectJobById(jobId)); + } + + /** + * 新增定时任务 + */ + @PreAuthorize("@ss.hasPermi('monitor:job:add')") + @Log(title = "定时任务", businessType = BusinessType.INSERT) + @PostMapping + public AjaxResult add(@RequestBody SysJob job) throws SchedulerException, TaskException + { + if (!CronUtils.isValid(job.getCronExpression())) + { + return error("新增任务'" + job.getJobName() + "'失败,Cron表达式不正确"); + } + else if (StringUtils.containsIgnoreCase(job.getInvokeTarget(), Constants.LOOKUP_RMI)) + { + return error("新增任务'" + job.getJobName() + "'失败,目标字符串不允许'rmi'调用"); + } + else if (StringUtils.containsAnyIgnoreCase(job.getInvokeTarget(), new String[] { Constants.LOOKUP_LDAP, Constants.LOOKUP_LDAPS })) + { + return error("新增任务'" + job.getJobName() + "'失败,目标字符串不允许'ldap(s)'调用"); + } + else if (StringUtils.containsAnyIgnoreCase(job.getInvokeTarget(), new String[] { Constants.HTTP, Constants.HTTPS })) + { + return error("新增任务'" + job.getJobName() + "'失败,目标字符串不允许'http(s)'调用"); + } + else if (StringUtils.containsAnyIgnoreCase(job.getInvokeTarget(), Constants.JOB_ERROR_STR)) + { + return error("新增任务'" + job.getJobName() + "'失败,目标字符串存在违规"); + } + else if (!ScheduleUtils.whiteList(job.getInvokeTarget())) + { + return error("新增任务'" + job.getJobName() + "'失败,目标字符串不在白名单内"); + } + job.setCreateBy(getUsername()); + return toAjax(jobService.insertJob(job)); + } + + /** + * 修改定时任务 + */ + @PreAuthorize("@ss.hasPermi('monitor:job:edit')") + @Log(title = "定时任务", businessType = BusinessType.UPDATE) + @PutMapping + public AjaxResult edit(@RequestBody SysJob job) throws SchedulerException, TaskException + { + if (!CronUtils.isValid(job.getCronExpression())) + { + return error("修改任务'" + job.getJobName() + "'失败,Cron表达式不正确"); + } + else if (StringUtils.containsIgnoreCase(job.getInvokeTarget(), Constants.LOOKUP_RMI)) + { + return error("修改任务'" + job.getJobName() + "'失败,目标字符串不允许'rmi'调用"); + } + else if (StringUtils.containsAnyIgnoreCase(job.getInvokeTarget(), new String[] { Constants.LOOKUP_LDAP, Constants.LOOKUP_LDAPS })) + { + return error("修改任务'" + job.getJobName() + "'失败,目标字符串不允许'ldap(s)'调用"); + } + else if (StringUtils.containsAnyIgnoreCase(job.getInvokeTarget(), new String[] { Constants.HTTP, Constants.HTTPS })) + { + return error("修改任务'" + job.getJobName() + "'失败,目标字符串不允许'http(s)'调用"); + } + else if (StringUtils.containsAnyIgnoreCase(job.getInvokeTarget(), Constants.JOB_ERROR_STR)) + { + return error("修改任务'" + job.getJobName() + "'失败,目标字符串存在违规"); + } + else if (!ScheduleUtils.whiteList(job.getInvokeTarget())) + { + return error("修改任务'" + job.getJobName() + "'失败,目标字符串不在白名单内"); + } + job.setUpdateBy(getUsername()); + return toAjax(jobService.updateJob(job)); + } + + /** + * 定时任务状态修改 + */ + @PreAuthorize("@ss.hasPermi('monitor:job:changeStatus')") + @Log(title = "定时任务", businessType = BusinessType.UPDATE) + @PutMapping("/changeStatus") + public AjaxResult changeStatus(@RequestBody SysJob job) throws SchedulerException + { + SysJob newJob = jobService.selectJobById(job.getJobId()); + newJob.setStatus(job.getStatus()); + return toAjax(jobService.changeStatus(newJob)); + } + + /** + * 定时任务立即执行一次 + */ + @PreAuthorize("@ss.hasPermi('monitor:job:changeStatus')") + @Log(title = "定时任务", businessType = BusinessType.UPDATE) + @PutMapping("/run") + public AjaxResult run(@RequestBody SysJob job) throws SchedulerException + { + boolean result = jobService.run(job); + return result ? success() : error("任务不存在或已过期!"); + } + + /** + * 删除定时任务 + */ + @PreAuthorize("@ss.hasPermi('monitor:job:remove')") + @Log(title = "定时任务", businessType = BusinessType.DELETE) + @DeleteMapping("/{jobIds}") + public AjaxResult remove(@PathVariable Long[] jobIds) throws SchedulerException, TaskException + { + jobService.deleteJobByIds(jobIds); + return success(); + } +} diff --git a/dc-quartz/src/main/java/com/dc/quartz/controller/SysJobLogController.java b/dc-quartz/src/main/java/com/dc/quartz/controller/SysJobLogController.java new file mode 100644 index 0000000..7b8e5dd --- /dev/null +++ b/dc-quartz/src/main/java/com/dc/quartz/controller/SysJobLogController.java @@ -0,0 +1,88 @@ +package com.dc.quartz.controller; + +import com.dc.common.annotation.Log; +import com.dc.common.core.controller.BaseController; +import com.dc.common.core.domain.AjaxResult; +import com.dc.common.core.page.TableDataInfo; +import com.dc.common.enums.BusinessType; +import com.dc.common.utils.poi.ExcelUtil; +import com.dc.quartz.domain.SysJobLog; +import com.dc.quartz.service.SysJobLogService; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.security.access.prepost.PreAuthorize; +import org.springframework.web.bind.annotation.*; + +import javax.servlet.http.HttpServletResponse; +import java.util.List; + +/** + * 调度日志操作处理 + * + * @author win + */ +@RestController +@RequestMapping("/monitor/jobLog") +public class SysJobLogController extends BaseController +{ + @Autowired + private SysJobLogService jobLogService; + + /** + * 查询定时任务调度日志列表 + */ + @PreAuthorize("@ss.hasPermi('monitor:job:list')") + @GetMapping("/list") + public TableDataInfo list(SysJobLog sysJobLog) + { + startPage(); + List<SysJobLog> list = jobLogService.selectJobLogList(sysJobLog); + return getDataTable(list); + } + + /** + * 导出定时任务调度日志列表 + */ + @PreAuthorize("@ss.hasPermi('monitor:job:export')") + @Log(title = "任务调度日志", businessType = BusinessType.EXPORT) + @PostMapping("/export") + public void export(HttpServletResponse response, SysJobLog sysJobLog) + { + List<SysJobLog> list = jobLogService.selectJobLogList(sysJobLog); + ExcelUtil<SysJobLog> util = new ExcelUtil<SysJobLog>(SysJobLog.class); + util.exportExcel(response, list, "调度日志"); + } + + /** + * 根据调度编号获取详细信息 + */ + @PreAuthorize("@ss.hasPermi('monitor:job:query')") + @GetMapping(value = "/{jobLogId}") + public AjaxResult getInfo(@PathVariable Long jobLogId) + { + return success(jobLogService.selectJobLogById(jobLogId)); + } + + + /** + * 删除定时任务调度日志 + */ + @PreAuthorize("@ss.hasPermi('monitor:job:remove')") + @Log(title = "定时任务调度日志", businessType = BusinessType.DELETE) + @DeleteMapping("/{jobLogIds}") + public AjaxResult remove(@PathVariable Long[] jobLogIds) + { + return toAjax(jobLogService.deleteJobLogByIds(jobLogIds)); + } + + /** + * 清空定时任务调度日志 + */ + @PreAuthorize("@ss.hasPermi('monitor:job:remove')") + @Log(title = "调度日志", businessType = BusinessType.CLEAN) + @DeleteMapping("/clean") + public AjaxResult clean() + { + jobLogService.cleanJobLog(); + return success(); + } +} diff --git a/dc-quartz/src/main/java/com/dc/quartz/domain/SysJob.java b/dc-quartz/src/main/java/com/dc/quartz/domain/SysJob.java new file mode 100644 index 0000000..5a04356 --- /dev/null +++ b/dc-quartz/src/main/java/com/dc/quartz/domain/SysJob.java @@ -0,0 +1,171 @@ +package com.dc.quartz.domain; + +import com.fasterxml.jackson.annotation.JsonFormat; +import com.dc.common.annotation.Excel; +import com.dc.common.constant.ScheduleConstants; +import com.dc.common.core.domain.WinBaseEntity; +import com.dc.common.utils.StringUtils; +import com.dc.quartz.util.CronUtils; +import org.apache.commons.lang3.builder.ToStringBuilder; +import org.apache.commons.lang3.builder.ToStringStyle; + +import javax.validation.constraints.NotBlank; +import javax.validation.constraints.Size; +import java.util.Date; + +/** + * 定时任务调度表 sys_job + * + * @author win + */ +public class SysJob extends WinBaseEntity +{ + private static final long serialVersionUID = 1L; + + /** 任务ID */ + @Excel(name = "任务序号", cellType = Excel.ColumnType.NUMERIC) + private Long jobId; + + /** 任务名称 */ + @Excel(name = "任务名称") + private String jobName; + + /** 任务组名 */ + @Excel(name = "任务组名") + private String jobGroup; + + /** 调用目标字符串 */ + @Excel(name = "调用目标字符串") + private String invokeTarget; + + /** cron执行表达式 */ + @Excel(name = "执行表达式 ") + private String cronExpression; + + /** cron计划策略 */ + @Excel(name = "计划策略 ", readConverterExp = "0=默认,1=立即触发执行,2=触发一次执行,3=不触发立即执行") + private String misfirePolicy = ScheduleConstants.MISFIRE_DEFAULT; + + /** 是否并发执行(0允许 1禁止) */ + @Excel(name = "并发执行", readConverterExp = "0=允许,1=禁止") + private String concurrent; + + /** 任务状态(0正常 1暂停) */ + @Excel(name = "任务状态", readConverterExp = "0=正常,1=暂停") + private String status; + + public Long getJobId() + { + return jobId; + } + + public void setJobId(Long jobId) + { + this.jobId = jobId; + } + + @NotBlank(message = "任务名称不能为空") + @Size(min = 0, max = 64, message = "任务名称不能超过64个字符") + public String getJobName() + { + return jobName; + } + + public void setJobName(String jobName) + { + this.jobName = jobName; + } + + public String getJobGroup() + { + return jobGroup; + } + + public void setJobGroup(String jobGroup) + { + this.jobGroup = jobGroup; + } + + @NotBlank(message = "调用目标字符串不能为空") + @Size(min = 0, max = 500, message = "调用目标字符串长度不能超过500个字符") + public String getInvokeTarget() + { + return invokeTarget; + } + + public void setInvokeTarget(String invokeTarget) + { + this.invokeTarget = invokeTarget; + } + + @NotBlank(message = "Cron执行表达式不能为空") + @Size(min = 0, max = 255, message = "Cron执行表达式不能超过255个字符") + public String getCronExpression() + { + return cronExpression; + } + + public void setCronExpression(String cronExpression) + { + this.cronExpression = cronExpression; + } + + @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss") + public Date getNextValidTime() + { + if (StringUtils.isNotEmpty(cronExpression)) + { + return CronUtils.getNextExecution(cronExpression); + } + return null; + } + + public String getMisfirePolicy() + { + return misfirePolicy; + } + + public void setMisfirePolicy(String misfirePolicy) + { + this.misfirePolicy = misfirePolicy; + } + + public String getConcurrent() + { + return concurrent; + } + + public void setConcurrent(String concurrent) + { + this.concurrent = concurrent; + } + + public String getStatus() + { + return status; + } + + public void setStatus(String status) + { + this.status = status; + } + + @Override + public String toString() { + return new ToStringBuilder(this,ToStringStyle.MULTI_LINE_STYLE) + .append("jobId", getJobId()) + .append("jobName", getJobName()) + .append("jobGroup", getJobGroup()) + .append("cronExpression", getCronExpression()) + .append("nextValidTime", getNextValidTime()) + .append("misfirePolicy", getMisfirePolicy()) + .append("concurrent", getConcurrent()) + .append("status", getStatus()) + .append("createBy", getCreateBy()) + .append("createTime", getCreateTime()) + .append("updateBy", getUpdateBy()) + .append("updateTime", getUpdateTime()) + .append("remark", getRemark()) + .toString(); + } +} diff --git a/dc-quartz/src/main/java/com/dc/quartz/domain/SysJobLog.java b/dc-quartz/src/main/java/com/dc/quartz/domain/SysJobLog.java new file mode 100644 index 0000000..19d15f4 --- /dev/null +++ b/dc-quartz/src/main/java/com/dc/quartz/domain/SysJobLog.java @@ -0,0 +1,156 @@ +package com.dc.quartz.domain; + +import com.dc.common.annotation.Excel; +import com.dc.common.core.domain.WinBaseEntity; +import org.apache.commons.lang3.builder.ToStringBuilder; +import org.apache.commons.lang3.builder.ToStringStyle; + +import java.util.Date; + +/** + * 定时任务调度日志表 sys_job_log + * + * @author win + */ +public class SysJobLog extends WinBaseEntity +{ + private static final long serialVersionUID = 1L; + + /** ID */ + @Excel(name = "日志序号") + private Long jobLogId; + + /** 任务名称 */ + @Excel(name = "任务名称") + private String jobName; + + /** 任务组名 */ + @Excel(name = "任务组名") + private String jobGroup; + + /** 调用目标字符串 */ + @Excel(name = "调用目标字符串") + private String invokeTarget; + + /** 日志信息 */ + @Excel(name = "日志信息") + private String jobMessage; + + /** 执行状态(0正常 1失败) */ + @Excel(name = "执行状态", readConverterExp = "0=正常,1=失败") + private String status; + + /** 异常信息 */ + @Excel(name = "异常信息") + private String exceptionInfo; + + /** 开始时间 */ + private Date startTime; + + /** 停止时间 */ + private Date stopTime; + + public Long getJobLogId() + { + return jobLogId; + } + + public void setJobLogId(Long jobLogId) + { + this.jobLogId = jobLogId; + } + + public String getJobName() + { + return jobName; + } + + public void setJobName(String jobName) + { + this.jobName = jobName; + } + + public String getJobGroup() + { + return jobGroup; + } + + public void setJobGroup(String jobGroup) + { + this.jobGroup = jobGroup; + } + + public String getInvokeTarget() + { + return invokeTarget; + } + + public void setInvokeTarget(String invokeTarget) + { + this.invokeTarget = invokeTarget; + } + + public String getJobMessage() + { + return jobMessage; + } + + public void setJobMessage(String jobMessage) + { + this.jobMessage = jobMessage; + } + + public String getStatus() + { + return status; + } + + public void setStatus(String status) + { + this.status = status; + } + + public String getExceptionInfo() + { + return exceptionInfo; + } + + public void setExceptionInfo(String exceptionInfo) + { + this.exceptionInfo = exceptionInfo; + } + + public Date getStartTime() + { + return startTime; + } + + public void setStartTime(Date startTime) + { + this.startTime = startTime; + } + + public Date getStopTime() + { + return stopTime; + } + + public void setStopTime(Date stopTime) + { + this.stopTime = stopTime; + } + + @Override + public String toString() { + return new ToStringBuilder(this,ToStringStyle.MULTI_LINE_STYLE) + .append("jobLogId", getJobLogId()) + .append("jobName", getJobName()) + .append("jobGroup", getJobGroup()) + .append("jobMessage", getJobMessage()) + .append("status", getStatus()) + .append("exceptionInfo", getExceptionInfo()) + .append("startTime", getStartTime()) + .append("stopTime", getStopTime()) + .toString(); + } +} diff --git a/dc-quartz/src/main/java/com/dc/quartz/mapper/SysJobLogMapper.java b/dc-quartz/src/main/java/com/dc/quartz/mapper/SysJobLogMapper.java new file mode 100644 index 0000000..7a73c71 --- /dev/null +++ b/dc-quartz/src/main/java/com/dc/quartz/mapper/SysJobLogMapper.java @@ -0,0 +1,66 @@ +package com.dc.quartz.mapper; + +import com.baomidou.mybatisplus.core.mapper.BaseMapper; +import com.dc.quartz.domain.SysJobLog; + +import java.util.List; + +/** + * 调度任务日志信息 数据层 + * + * @author win + */ +public interface SysJobLogMapper extends BaseMapper<SysJobLog> +{ + /** + * 获取quartz调度器日志的计划任务 + * + * @param jobLog 调度日志信息 + * @return 调度任务日志集合 + */ + public List<SysJobLog> selectJobLogList(SysJobLog jobLog); + + /** + * 查询所有调度任务日志 + * + * @return 调度任务日志列表 + */ + public List<SysJobLog> selectJobLogAll(); + + /** + * 通过调度任务日志ID查询调度信息 + * + * @param jobLogId 调度任务日志ID + * @return 调度任务日志对象信息 + */ + public SysJobLog selectJobLogById(Long jobLogId); + + /** + * 新增任务日志 + * + * @param jobLog 调度日志信息 + * @return 结果 + */ + public int insertJobLog(SysJobLog jobLog); + + /** + * 批量删除调度日志信息 + * + * @param logIds 需要删除的数据ID + * @return 结果 + */ + public int deleteJobLogByIds(Long[] logIds); + + /** + * 删除任务日志 + * + * @param jobId 调度日志ID + * @return 结果 + */ + public int deleteJobLogById(Long jobId); + + /** + * 清空任务日志 + */ + public void cleanJobLog(); +} diff --git a/dc-quartz/src/main/java/com/dc/quartz/mapper/SysJobMapper.java b/dc-quartz/src/main/java/com/dc/quartz/mapper/SysJobMapper.java new file mode 100644 index 0000000..ed30937 --- /dev/null +++ b/dc-quartz/src/main/java/com/dc/quartz/mapper/SysJobMapper.java @@ -0,0 +1,69 @@ +package com.dc.quartz.mapper; + +import com.baomidou.mybatisplus.core.mapper.BaseMapper; +import com.dc.quartz.domain.SysJob; + +import java.util.List; + +/** + * 调度任务信息 数据层 + * + * @author win + */ +public interface SysJobMapper extends BaseMapper<SysJob> +{ + /** + * 查询调度任务日志集合 + * + * @param job 调度信息 + * @return 操作日志集合 + */ + public List<SysJob> selectJobList(SysJob job); + + /** + * 查询所有调度任务 + * + * @return 调度任务列表 + */ + public List<SysJob> selectJobAll(); + + /** + * 通过调度ID查询调度任务信息 + * + * @param jobId 调度ID + * @return 角色对象信息 + */ + public SysJob selectJobById(Long jobId); + + /** + * 通过调度ID删除调度任务信息 + * + * @param jobId 调度ID + * @return 结果 + */ + public int deleteJobById(Long jobId); + + /** + * 批量删除调度任务信息 + * + * @param ids 需要删除的数据ID + * @return 结果 + */ + public int deleteJobByIds(Long[] ids); + + /** + * 修改调度任务信息 + * + * @param job 调度任务信息 + * @return 结果 + */ + public int updateJob(SysJob job); + + /** + * 新增调度任务信息 + * + * @param job 调度任务信息 + * @return 结果 + */ + public int insertJob(SysJob job); +} diff --git a/dc-quartz/src/main/java/com/dc/quartz/service/SysJobLogService.java b/dc-quartz/src/main/java/com/dc/quartz/service/SysJobLogService.java new file mode 100644 index 0000000..f21b5cb --- /dev/null +++ b/dc-quartz/src/main/java/com/dc/quartz/service/SysJobLogService.java @@ -0,0 +1,79 @@ +package com.dc.quartz.service; + +import com.baomidou.mybatisplus.extension.service.IService; +import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; +import com.dc.quartz.domain.SysJobLog; +import com.dc.quartz.mapper.SysJobLogMapper; +import org.springframework.stereotype.Service; + +import java.util.List; + +/** + * 定时任务调度日志信息 服务层 + * + * @author win + */ +@Service +public class SysJobLogService extends ServiceImpl<SysJobLogMapper, SysJobLog> implements IService<SysJobLog> +{ + /** + * 获取quartz调度器日志的计划任务 + * + * @param jobLog 调度日志信息 + * @return 调度任务日志集合 + */ + public List<SysJobLog> selectJobLogList(SysJobLog jobLog) + { + return baseMapper.selectJobLogList(jobLog); + } + + /** + * 通过调度任务日志ID查询调度信息 + * + * @param jobLogId 调度任务日志ID + * @return 调度任务日志对象信息 + */ + public SysJobLog selectJobLogById(Long jobLogId) + { + return baseMapper.selectJobLogById(jobLogId); + } + + /** + * 新增任务日志 + * + * @param jobLog 调度日志信息 + */ + public void addJobLog(SysJobLog jobLog) + { + baseMapper.insertJobLog(jobLog); + } + + /** + * 批量删除调度日志信息 + * + * @param logIds 需要删除的数据ID + * @return 结果 + */ + public int deleteJobLogByIds(Long[] logIds) + { + return baseMapper.deleteJobLogByIds(logIds); + } + + /** + * 删除任务日志 + * + * @param jobId 调度日志ID + */ + public int deleteJobLogById(Long jobId) + { + return baseMapper.deleteJobLogById(jobId); + } + + /** + * 清空任务日志 + */ + public void cleanJobLog() + { + baseMapper.cleanJobLog(); + } +} diff --git a/dc-quartz/src/main/java/com/dc/quartz/service/SysJobService.java b/dc-quartz/src/main/java/com/dc/quartz/service/SysJobService.java new file mode 100644 index 0000000..1dbaa31 --- /dev/null +++ b/dc-quartz/src/main/java/com/dc/quartz/service/SysJobService.java @@ -0,0 +1,249 @@ +package com.dc.quartz.service; + +import com.baomidou.mybatisplus.extension.service.IService; +import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; +import com.dc.common.constant.ScheduleConstants; +import com.dc.common.exception.job.TaskException; +import com.dc.quartz.util.CronUtils; +import com.dc.quartz.util.ScheduleUtils; +import com.dc.quartz.domain.SysJob; +import com.dc.quartz.mapper.SysJobMapper; +import org.quartz.JobDataMap; +import org.quartz.JobKey; +import org.quartz.Scheduler; +import org.quartz.SchedulerException; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.stereotype.Service; +import org.springframework.transaction.annotation.Transactional; + +import javax.annotation.PostConstruct; +import java.util.List; + +/** + * 定时任务调度信息 服务层 + * + * @author win + */ +@Service +public class SysJobService extends ServiceImpl<SysJobMapper, SysJob> implements IService<SysJob> +{ + @Autowired + private Scheduler scheduler; + + /** + * 项目启动时,初始化定时器 主要是防止手动修改数据库导致未同步到定时任务处理(注:不能手动修改数据库ID和任务组名,否则会导致脏数据) + */ + @PostConstruct + public void init() throws SchedulerException, TaskException + { + scheduler.clear(); + List<SysJob> jobList = baseMapper.selectJobAll(); + for (SysJob job : jobList) + { + ScheduleUtils.createScheduleJob(scheduler, job); + } + } + + /** + * 获取quartz调度器的计划任务列表 + * + * @param job 调度信息 + * @return + */ + public List<SysJob> selectJobList(SysJob job) + { + return baseMapper.selectJobList(job); + } + + /** + * 通过调度任务ID查询调度信息 + * + * @param jobId 调度任务ID + * @return 调度任务对象信息 + */ + public SysJob selectJobById(Long jobId) + { + return baseMapper.selectJobById(jobId); + } + + /** + * 暂停任务 + * + * @param job 调度信息 + */ + @Transactional(rollbackFor = Exception.class) + public int pauseJob(SysJob job) throws SchedulerException + { + Long jobId = job.getJobId(); + String jobGroup = job.getJobGroup(); + job.setStatus(ScheduleConstants.Status.PAUSE.getValue()); + int rows = baseMapper.updateJob(job); + if (rows > 0) + { + scheduler.pauseJob(ScheduleUtils.getJobKey(jobId, jobGroup)); + } + return rows; + } + + /** + * 恢复任务 + * + * @param job 调度信息 + */ + @Transactional(rollbackFor = Exception.class) + public int resumeJob(SysJob job) throws SchedulerException + { + Long jobId = job.getJobId(); + String jobGroup = job.getJobGroup(); + job.setStatus(ScheduleConstants.Status.NORMAL.getValue()); + int rows = baseMapper.updateJob(job); + if (rows > 0) + { + scheduler.resumeJob(ScheduleUtils.getJobKey(jobId, jobGroup)); + } + return rows; + } + + /** + * 删除任务后,所对应的trigger也将被删除 + * + * @param job 调度信息 + */ + @Transactional(rollbackFor = Exception.class) + public int deleteJob(SysJob job) throws SchedulerException + { + Long jobId = job.getJobId(); + String jobGroup = job.getJobGroup(); + int rows = baseMapper.deleteJobById(jobId); + if (rows > 0) + { + scheduler.deleteJob(ScheduleUtils.getJobKey(jobId, jobGroup)); + } + return rows; + } + + /** + * 批量删除调度信息 + * + * @param jobIds 需要删除的任务ID + * @return 结果 + */ + @Transactional(rollbackFor = Exception.class) + public void deleteJobByIds(Long[] jobIds) throws SchedulerException + { + for (Long jobId : jobIds) + { + SysJob job = baseMapper.selectJobById(jobId); + deleteJob(job); + } + } + + /** + * 任务调度状态修改 + * + * @param job 调度信息 + */ + @Transactional(rollbackFor = Exception.class) + public int changeStatus(SysJob job) throws SchedulerException + { + int rows = 0; + String status = job.getStatus(); + if (ScheduleConstants.Status.NORMAL.getValue().equals(status)) + { + rows = resumeJob(job); + } + else if (ScheduleConstants.Status.PAUSE.getValue().equals(status)) + { + rows = pauseJob(job); + } + return rows; + } + + /** + * 立即运行任务 + * + * @param job 调度信息 + */ + @Transactional(rollbackFor = Exception.class) + public boolean run(SysJob job) throws SchedulerException + { + boolean result = false; + Long jobId = job.getJobId(); + String jobGroup = job.getJobGroup(); + SysJob properties = selectJobById(job.getJobId()); + // 参数 + JobDataMap dataMap = new JobDataMap(); + dataMap.put(ScheduleConstants.TASK_PROPERTIES, properties); + JobKey jobKey = ScheduleUtils.getJobKey(jobId, jobGroup); + if (scheduler.checkExists(jobKey)) + { + result = true; + scheduler.triggerJob(jobKey, dataMap); + } + return result; + } + + /** + * 新增任务 + * + * @param job 调度信息 调度信息 + */ + @Transactional(rollbackFor = Exception.class) + public int insertJob(SysJob job) throws SchedulerException, TaskException + { + job.setStatus(ScheduleConstants.Status.PAUSE.getValue()); + int rows = baseMapper.insertJob(job); + if (rows > 0) + { + ScheduleUtils.createScheduleJob(scheduler, job); + } + return rows; + } + + /** + * 更新任务的时间表达式 + * + * @param job 调度信息 + */ + @Transactional(rollbackFor = Exception.class) + public int updateJob(SysJob job) throws SchedulerException, TaskException + { + SysJob properties = selectJobById(job.getJobId()); + int rows = baseMapper.updateJob(job); + if (rows > 0) + { + updateSchedulerJob(job, properties.getJobGroup()); + } + return rows; + } + + /** + * 更新任务 + * + * @param job 任务对象 + * @param jobGroup 任务组名 + */ + public void updateSchedulerJob(SysJob job, String jobGroup) throws SchedulerException, TaskException + { + Long jobId = job.getJobId(); + // 判断是否存在 + JobKey jobKey = ScheduleUtils.getJobKey(jobId, jobGroup); + if (scheduler.checkExists(jobKey)) + { + // 防止创建时存在数据问题 先移除,然后在执行创建操作 + scheduler.deleteJob(jobKey); + } + ScheduleUtils.createScheduleJob(scheduler, job); + } + + /** + * 校验cron表达式是否有效 + * + * @param cronExpression 表达式 + * @return 结果 + */ + public boolean checkCronExpressionIsValid(String cronExpression) + { + return CronUtils.isValid(cronExpression); + } +} diff --git a/dc-quartz/src/main/java/com/dc/quartz/task/RyTask.java b/dc-quartz/src/main/java/com/dc/quartz/task/RyTask.java new file mode 100644 index 0000000..777b751 --- /dev/null +++ b/dc-quartz/src/main/java/com/dc/quartz/task/RyTask.java @@ -0,0 +1,28 @@ +package com.dc.quartz.task; + +import com.dc.common.utils.StringUtils; +import org.springframework.stereotype.Component; + +/** + * 定时任务调度测试 + * + * @author win + */ +@Component("ryTask") +public class RyTask +{ + public void ryMultipleParams(String s, Boolean b, Long l, Double d, Integer i) + { + System.out.println(StringUtils.format("执行多参方法: 字符串类型{},布尔类型{},长整型{},浮点型{},整形{}", s, b, l, d, i)); + } + + public void ryParams(String params) + { + System.out.println("执行有参方法:" + params); + } + + public void ryNoParams() + { + System.out.println("执行无参方法"); + } +} diff --git a/dc-quartz/src/main/java/com/dc/quartz/util/AbstractQuartzJob.java b/dc-quartz/src/main/java/com/dc/quartz/util/AbstractQuartzJob.java new file mode 100644 index 0000000..f489276 --- /dev/null +++ b/dc-quartz/src/main/java/com/dc/quartz/util/AbstractQuartzJob.java @@ -0,0 +1,108 @@ +package com.dc.quartz.util; + +import com.dc.common.constant.Constants; +import com.dc.common.constant.ScheduleConstants; +import com.dc.common.utils.ExceptionUtil; +import com.dc.common.utils.StringUtils; +import com.dc.common.utils.bean.BeanUtils; +import com.dc.common.utils.spring.SpringUtils; +import com.dc.quartz.domain.SysJobLog; +import com.dc.quartz.domain.SysJob; +import com.dc.quartz.service.SysJobLogService; +import org.quartz.Job; +import org.quartz.JobExecutionContext; +import org.quartz.JobExecutionException; +import org.slf4j.Logger; +import org.slf4j.LoggerFactory; + +import java.util.Date; + +/** + * 抽象quartz调用 + * + * @author win + */ +public abstract class AbstractQuartzJob implements Job +{ + private static final Logger log = LoggerFactory.getLogger(AbstractQuartzJob.class); + + /** + * 线程本地变量 + */ + private static ThreadLocal<Date> threadLocal = new ThreadLocal<>(); + + @Override + public void execute(JobExecutionContext context) throws JobExecutionException + { + SysJob sysJob = new SysJob(); + BeanUtils.copyBeanProp(sysJob, context.getMergedJobDataMap().get(ScheduleConstants.TASK_PROPERTIES)); + try + { + before(context, sysJob); + if (sysJob != null) + { + doExecute(context, sysJob); + } + after(context, sysJob, null); + } + catch (Exception e) + { + log.error("任务执行异常 - :", e); + after(context, sysJob, e); + } + } + + /** + * 执行前 + * + * @param context 工作执行上下文对象 + * @param sysJob 系统计划任务 + */ + protected void before(JobExecutionContext context, SysJob sysJob) + { + threadLocal.set(new Date()); + } + + /** + * 执行后 + * + * @param context 工作执行上下文对象 + * @param sysJob 系统计划任务 + */ + protected void after(JobExecutionContext context, SysJob sysJob, Exception e) + { + Date startTime = threadLocal.get(); + threadLocal.remove(); + + final SysJobLog sysJobLog = new SysJobLog(); + sysJobLog.setJobName(sysJob.getJobName()); + sysJobLog.setJobGroup(sysJob.getJobGroup()); + sysJobLog.setInvokeTarget(sysJob.getInvokeTarget()); + sysJobLog.setStartTime(startTime); + sysJobLog.setStopTime(new Date()); + long runMs = sysJobLog.getStopTime().getTime() - sysJobLog.getStartTime().getTime(); + sysJobLog.setJobMessage(sysJobLog.getJobName() + " 总共耗时:" + runMs + "毫秒"); + if (e != null) + { + sysJobLog.setStatus(Constants.FAIL); + String errorMsg = StringUtils.substring(ExceptionUtil.getExceptionMessage(e), 0, 2000); + sysJobLog.setExceptionInfo(errorMsg); + } + else + { + sysJobLog.setStatus(Constants.SUCCESS); + } + + // 写入数据库当中 + SpringUtils.getBean(SysJobLogService.class).addJobLog(sysJobLog); + } + + /** + * 执行方法,由子类重载 + * + * @param context 工作执行上下文对象 + * @param sysJob 系统计划任务 + * @throws Exception 执行过程中的异常 + */ + protected abstract void doExecute(JobExecutionContext context, SysJob sysJob) throws Exception; +} diff --git a/dc-quartz/src/main/java/com/dc/quartz/util/CronUtils.java b/dc-quartz/src/main/java/com/dc/quartz/util/CronUtils.java new file mode 100644 index 0000000..97f4fb7 --- /dev/null +++ b/dc-quartz/src/main/java/com/dc/quartz/util/CronUtils.java @@ -0,0 +1,64 @@ +package com.dc.quartz.util; + +import org.quartz.CronExpression; + +import java.text.ParseException; +import java.util.Date; + +/** + * cron表达式工具类 + * + * @author win + * + */ +public class CronUtils +{ + /** + * 返回一个布尔值代表一个给定的Cron表达式的有效性 + * + * @param cronExpression Cron表达式 + * @return boolean 表达式是否有效 + */ + public static boolean isValid(String cronExpression) + { + return CronExpression.isValidExpression(cronExpression); + } + + /** + * 返回一个字符串值,表示该消息无效Cron表达式给出有效性 + * + * @param cronExpression Cron表达式 + * @return String 无效时返回表达式错误描述,如果有效返回null + */ + public static String getInvalidMessage(String cronExpression) + { + try + { + new CronExpression(cronExpression); + return null; + } + catch (ParseException pe) + { + return pe.getMessage(); + } + } + + /** + * 返回下一个执行时间根据给定的Cron表达式 + * + * @param cronExpression Cron表达式 + * @return Date 下次Cron表达式执行时间 + */ + public static Date getNextExecution(String cronExpression) + { + try + { + CronExpression cron = new CronExpression(cronExpression); + return cron.getNextValidTimeAfter(new Date(System.currentTimeMillis())); + } + catch (ParseException e) + { + throw new IllegalArgumentException(e.getMessage()); + } + } +} diff --git a/dc-quartz/src/main/java/com/dc/quartz/util/JobInvokeUtil.java b/dc-quartz/src/main/java/com/dc/quartz/util/JobInvokeUtil.java new file mode 100644 index 0000000..fc646d0 --- /dev/null +++ b/dc-quartz/src/main/java/com/dc/quartz/util/JobInvokeUtil.java @@ -0,0 +1,183 @@ +package com.dc.quartz.util; + +import com.dc.common.utils.StringUtils; +import com.dc.common.utils.spring.SpringUtils; +import com.dc.quartz.domain.SysJob; + +import java.lang.reflect.InvocationTargetException; +import java.lang.reflect.Method; +import java.util.LinkedList; +import java.util.List; + +/** + * 任务执行工具 + * + * @author win + */ +public class JobInvokeUtil +{ + /** + * 执行方法 + * + * @param sysJob 系统任务 + */ + public static void invokeMethod(SysJob sysJob) throws Exception + { + String invokeTarget = sysJob.getInvokeTarget(); + String beanName = getBeanName(invokeTarget); + String methodName = getMethodName(invokeTarget); + List<Object[]> methodParams = getMethodParams(invokeTarget); + + if (!isValidClassName(beanName)) + { + Object bean = SpringUtils.getBean(beanName); + invokeMethod(bean, methodName, methodParams); + } + else + { + Object bean = Class.forName(beanName).newInstance(); + invokeMethod(bean, methodName, methodParams); + } + } + + /** + * 调用任务方法 + * + * @param bean 目标对象 + * @param methodName 方法名称 + * @param methodParams 方法参数 + */ + private static void invokeMethod(Object bean, String methodName, List<Object[]> methodParams) + throws NoSuchMethodException, SecurityException, IllegalAccessException, IllegalArgumentException, + InvocationTargetException + { + if (StringUtils.isNotNull(methodParams) && methodParams.size() > 0) + { + Method method = bean.getClass().getMethod(methodName, getMethodParamsType(methodParams)); + method.invoke(bean, getMethodParamsValue(methodParams)); + } + else + { + Method method = bean.getClass().getMethod(methodName); + method.invoke(bean); + } + } + + /** + * 校验是否为为class包名 + * + * @param invokeTarget 名称 + * @return true是 false否 + */ + public static boolean isValidClassName(String invokeTarget) + { + return StringUtils.countMatches(invokeTarget, ".") > 1; + } + + /** + * 获取bean名称 + * + * @param invokeTarget 目标字符串 + * @return bean名称 + */ + public static String getBeanName(String invokeTarget) + { + String beanName = StringUtils.substringBefore(invokeTarget, "("); + return StringUtils.substringBeforeLast(beanName, "."); + } + + /** + * 获取bean方法 + * + * @param invokeTarget 目标字符串 + * @return method方法 + */ + public static String getMethodName(String invokeTarget) + { + String methodName = StringUtils.substringBefore(invokeTarget, "("); + return StringUtils.substringAfterLast(methodName, "."); + } + + /** + * 获取method方法参数相关列表 + * + * @param invokeTarget 目标字符串 + * @return method方法相关参数列表 + */ + public static List<Object[]> getMethodParams(String invokeTarget) + { + String methodStr = StringUtils.substringBetween(invokeTarget, "(", ")"); + if (StringUtils.isEmpty(methodStr)) + { + return null; + } + String[] methodParams = methodStr.split(",(?=([^\"']*[\"'][^\"']*[\"'])*[^\"']*$)"); + List<Object[]> classs = new LinkedList<>(); + for (int i = 0; i < methodParams.length; i++) + { + String str = StringUtils.trimToEmpty(methodParams[i]); + // String字符串类型,以'或"开头 + if (StringUtils.startsWithAny(str, "'", "\"")) + { + classs.add(new Object[] { StringUtils.substring(str, 1, str.length() - 1), String.class }); + } + // boolean布尔类型,等于true或者false + else if ("true".equalsIgnoreCase(str) || "false".equalsIgnoreCase(str)) + { + classs.add(new Object[] { Boolean.valueOf(str), Boolean.class }); + } + // long长整形,以L结尾 + else if (StringUtils.endsWith(str, "L")) + { + classs.add(new Object[] { Long.valueOf(StringUtils.substring(str, 0, str.length() - 1)), Long.class }); + } + // double浮点类型,以D结尾 + else if (StringUtils.endsWith(str, "D")) + { + classs.add(new Object[] { Double.valueOf(StringUtils.substring(str, 0, str.length() - 1)), Double.class }); + } + // 其他类型归类为整形 + else + { + classs.add(new Object[] { Integer.valueOf(str), Integer.class }); + } + } + return classs; + } + + /** + * 获取参数类型 + * + * @param methodParams 参数相关列表 + * @return 参数类型列表 + */ + public static Class<?>[] getMethodParamsType(List<Object[]> methodParams) + { + Class<?>[] classs = new Class<?>[methodParams.size()]; + int index = 0; + for (Object[] os : methodParams) + { + classs[index] = (Class<?>) os[1]; + index++; + } + return classs; + } + + /** + * 获取参数值 + * + * @param methodParams 参数相关列表 + * @return 参数值列表 + */ + public static Object[] getMethodParamsValue(List<Object[]> methodParams) + { + Object[] classs = new Object[methodParams.size()]; + int index = 0; + for (Object[] os : methodParams) + { + classs[index] = (Object) os[0]; + index++; + } + return classs; + } +} diff --git a/dc-quartz/src/main/java/com/dc/quartz/util/QuartzDisallowConcurrentExecution.java b/dc-quartz/src/main/java/com/dc/quartz/util/QuartzDisallowConcurrentExecution.java new file mode 100644 index 0000000..1bb83e6 --- /dev/null +++ b/dc-quartz/src/main/java/com/dc/quartz/util/QuartzDisallowConcurrentExecution.java @@ -0,0 +1,21 @@ +package com.dc.quartz.util; + +import org.quartz.DisallowConcurrentExecution; +import org.quartz.JobExecutionContext; +import com.dc.quartz.domain.SysJob; + +/** + * 定时任务处理(禁止并发执行) + * + * @author win + * + */ +@DisallowConcurrentExecution +public class QuartzDisallowConcurrentExecution extends AbstractQuartzJob +{ + @Override + protected void doExecute(JobExecutionContext context, SysJob sysJob) throws Exception + { + JobInvokeUtil.invokeMethod(sysJob); + } +} diff --git a/dc-quartz/src/main/java/com/dc/quartz/util/QuartzJobExecution.java b/dc-quartz/src/main/java/com/dc/quartz/util/QuartzJobExecution.java new file mode 100644 index 0000000..8931a2c --- /dev/null +++ b/dc-quartz/src/main/java/com/dc/quartz/util/QuartzJobExecution.java @@ -0,0 +1,19 @@ +package com.dc.quartz.util; + +import org.quartz.JobExecutionContext; +import com.dc.quartz.domain.SysJob; + +/** + * 定时任务处理(允许并发执行) + * + * @author win + * + */ +public class QuartzJobExecution extends AbstractQuartzJob +{ + @Override + protected void doExecute(JobExecutionContext context, SysJob sysJob) throws Exception + { + JobInvokeUtil.invokeMethod(sysJob); + } +} diff --git a/dc-quartz/src/main/java/com/dc/quartz/util/ScheduleUtils.java b/dc-quartz/src/main/java/com/dc/quartz/util/ScheduleUtils.java new file mode 100644 index 0000000..279e081 --- /dev/null +++ b/dc-quartz/src/main/java/com/dc/quartz/util/ScheduleUtils.java @@ -0,0 +1,138 @@ +package com.dc.quartz.util; + +import com.dc.common.constant.Constants; +import com.dc.common.constant.ScheduleConstants; +import com.dc.common.exception.job.TaskException; +import com.dc.common.utils.StringUtils; +import com.dc.common.utils.spring.SpringUtils; +import org.quartz.CronScheduleBuilder; +import org.quartz.CronTrigger; +import org.quartz.Job; +import org.quartz.JobBuilder; +import org.quartz.JobDetail; +import org.quartz.JobKey; +import org.quartz.Scheduler; +import org.quartz.SchedulerException; +import org.quartz.TriggerBuilder; +import org.quartz.TriggerKey; +import com.dc.quartz.domain.SysJob; + +/** + * 定时任务工具类 + * + * @author win + * + */ +public class ScheduleUtils +{ + /** + * 得到quartz任务类 + * + * @param sysJob 执行计划 + * @return 具体执行任务类 + */ + private static Class<? extends Job> getQuartzJobClass(SysJob sysJob) + { + boolean isConcurrent = "0".equals(sysJob.getConcurrent()); + return isConcurrent ? QuartzJobExecution.class : QuartzDisallowConcurrentExecution.class; + } + + /** + * 构建任务触发对象 + */ + public static TriggerKey getTriggerKey(Long jobId, String jobGroup) + { + return TriggerKey.triggerKey(ScheduleConstants.TASK_CLASS_NAME + jobId, jobGroup); + } + + /** + * 构建任务键对象 + */ + public static JobKey getJobKey(Long jobId, String jobGroup) + { + return JobKey.jobKey(ScheduleConstants.TASK_CLASS_NAME + jobId, jobGroup); + } + + /** + * 创建定时任务 + */ + public static void createScheduleJob(Scheduler scheduler, SysJob job) throws SchedulerException, TaskException + { + Class<? extends Job> jobClass = getQuartzJobClass(job); + // 构建job信息 + Long jobId = job.getJobId(); + String jobGroup = job.getJobGroup(); + JobDetail jobDetail = JobBuilder.newJob(jobClass).withIdentity(getJobKey(jobId, jobGroup)).build(); + + // 表达式调度构建器 + CronScheduleBuilder cronScheduleBuilder = CronScheduleBuilder.cronSchedule(job.getCronExpression()); + cronScheduleBuilder = handleCronScheduleMisfirePolicy(job, cronScheduleBuilder); + + // 按新的cronExpression表达式构建一个新的trigger + CronTrigger trigger = TriggerBuilder.newTrigger().withIdentity(getTriggerKey(jobId, jobGroup)) + .withSchedule(cronScheduleBuilder).build(); + + // 放入参数,运行时的方法可以获取 + jobDetail.getJobDataMap().put(ScheduleConstants.TASK_PROPERTIES, job); + + // 判断是否存在 + if (scheduler.checkExists(getJobKey(jobId, jobGroup))) + { + // 防止创建时存在数据问题 先移除,然后在执行创建操作 + scheduler.deleteJob(getJobKey(jobId, jobGroup)); + } + + // 判断任务是否过期 + if (StringUtils.isNotNull(CronUtils.getNextExecution(job.getCronExpression()))) + { + // 执行调度任务 + scheduler.scheduleJob(jobDetail, trigger); + } + + // 暂停任务 + if (job.getStatus().equals(ScheduleConstants.Status.PAUSE.getValue())) + { + scheduler.pauseJob(ScheduleUtils.getJobKey(jobId, jobGroup)); + } + } + + /** + * 设置定时任务策略 + */ + public static CronScheduleBuilder handleCronScheduleMisfirePolicy(SysJob job, CronScheduleBuilder cb) + throws TaskException + { + switch (job.getMisfirePolicy()) + { + case ScheduleConstants.MISFIRE_DEFAULT: + return cb; + case ScheduleConstants.MISFIRE_IGNORE_MISFIRES: + return cb.withMisfireHandlingInstructionIgnoreMisfires(); + case ScheduleConstants.MISFIRE_FIRE_AND_PROCEED: + return cb.withMisfireHandlingInstructionFireAndProceed(); + case ScheduleConstants.MISFIRE_DO_NOTHING: + return cb.withMisfireHandlingInstructionDoNothing(); + default: + throw new TaskException("The task misfire policy '" + job.getMisfirePolicy() + + "' cannot be used in cron schedule tasks", TaskException.Code.CONFIG_ERROR); + } + } + + /** + * 检查包名是否为白名单配置 + * + * @param invokeTarget 目标字符串 + * @return 结果 + */ + public static boolean whiteList(String invokeTarget) + { + String packageName = StringUtils.substringBefore(invokeTarget, "("); + int count = StringUtils.countMatches(packageName, "."); + if (count > 1) + { + return StringUtils.containsAnyIgnoreCase(invokeTarget, Constants.JOB_WHITELIST_STR); + } + Object obj = SpringUtils.getBean(StringUtils.split(invokeTarget, ".")[0]); + return StringUtils.containsAnyIgnoreCase(obj.getClass().getPackage().getName(), Constants.JOB_WHITELIST_STR); + } +} diff --git a/dc-quartz/src/main/resources/mapper/quartz/SysJobLogMapper.xml b/dc-quartz/src/main/resources/mapper/quartz/SysJobLogMapper.xml new file mode 100644 index 0000000..52f76a8 --- /dev/null +++ b/dc-quartz/src/main/resources/mapper/quartz/SysJobLogMapper.xml @@ -0,0 +1,93 @@ +<?xml version="1.0" encoding="UTF-8" ?> +<!DOCTYPE mapper +PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" +"http://mybatis.org/dtd/mybatis-3-mapper.dtd"> +<mapper namespace="com.dc.quartz.mapper.SysJobLogMapper"> + + <resultMap type="SysJobLog" id="SysJobLogResult"> + <id property="jobLogId" column="job_log_id" /> + <result property="jobName" column="job_name" /> + <result property="jobGroup" column="job_group" /> + <result property="invokeTarget" column="invoke_target" /> + <result property="jobMessage" column="job_message" /> + <result property="status" column="status" /> + <result property="exceptionInfo" column="exception_info" /> + <result property="createTime" column="create_time" /> + </resultMap> + + <sql id="selectJobLogVo"> + select job_log_id, job_name, job_group, invoke_target, job_message, status, exception_info, create_time + from sys_job_log + </sql> + + <select id="selectJobLogList" parameterType="SysJobLog" resultMap="SysJobLogResult"> + <include refid="selectJobLogVo"/> + <where> + <if test="jobName != null and jobName != ''"> + AND job_name like concat('%', #{jobName}, '%') + </if> + <if test="jobGroup != null and jobGroup != ''"> + AND job_group = #{jobGroup} + </if> + <if test="status != null and status != ''"> + AND status = #{status} + </if> + <if test="invokeTarget != null and invokeTarget != ''"> + AND invoke_target like concat('%', #{invokeTarget}, '%') + </if> + <if test="params.beginTime != null and params.beginTime != ''"><!-- 开始时间检索 --> + and date_format(create_time,'%y%m%d') >= date_format(#{params.beginTime},'%y%m%d') + </if> + <if test="params.endTime != null and params.endTime != ''"><!-- 结束时间检索 --> + and date_format(create_time,'%y%m%d') <= date_format(#{params.endTime},'%y%m%d') + </if> + </where> + </select> + + <select id="selectJobLogAll" resultMap="SysJobLogResult"> + <include refid="selectJobLogVo"/> + </select> + + <select id="selectJobLogById" parameterType="Long" resultMap="SysJobLogResult"> + <include refid="selectJobLogVo"/> + where job_log_id = #{jobLogId} + </select> + + <delete id="deleteJobLogById" parameterType="Long"> + delete from sys_job_log where job_log_id = #{jobLogId} + </delete> + + <delete id="deleteJobLogByIds" parameterType="Long"> + delete from sys_job_log where job_log_id in + <foreach collection="array" item="jobLogId" open="(" separator="," close=")"> + #{jobLogId} + </foreach> + </delete> + + <update id="cleanJobLog"> + truncate table sys_job_log + </update> + + <insert id="insertJobLog" parameterType="SysJobLog"> + insert into sys_job_log( + <if test="jobLogId != null and jobLogId != 0">job_log_id,</if> + <if test="jobName != null and jobName != ''">job_name,</if> + <if test="jobGroup != null and jobGroup != ''">job_group,</if> + <if test="invokeTarget != null and invokeTarget != ''">invoke_target,</if> + <if test="jobMessage != null and jobMessage != ''">job_message,</if> + <if test="status != null and status != ''">status,</if> + <if test="exceptionInfo != null and exceptionInfo != ''">exception_info,</if> + create_time + )values( + <if test="jobLogId != null and jobLogId != 0">#{jobLogId},</if> + <if test="jobName != null and jobName != ''">#{jobName},</if> + <if test="jobGroup != null and jobGroup != ''">#{jobGroup},</if> + <if test="invokeTarget != null and invokeTarget != ''">#{invokeTarget},</if> + <if test="jobMessage != null and jobMessage != ''">#{jobMessage},</if> + <if test="status != null and status != ''">#{status},</if> + <if test="exceptionInfo != null and exceptionInfo != ''">#{exceptionInfo},</if> + now() + ) + </insert> + +</mapper> \ No newline at end of file diff --git a/dc-quartz/src/main/resources/mapper/quartz/SysJobMapper.xml b/dc-quartz/src/main/resources/mapper/quartz/SysJobMapper.xml new file mode 100644 index 0000000..49679d5 --- /dev/null +++ b/dc-quartz/src/main/resources/mapper/quartz/SysJobMapper.xml @@ -0,0 +1,111 @@ +<?xml version="1.0" encoding="UTF-8" ?> +<!DOCTYPE mapper +PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" +"http://mybatis.org/dtd/mybatis-3-mapper.dtd"> +<mapper namespace="com.dc.quartz.mapper.SysJobMapper"> + + <resultMap type="SysJob" id="SysJobResult"> + <id property="jobId" column="job_id" /> + <result property="jobName" column="job_name" /> + <result property="jobGroup" column="job_group" /> + <result property="invokeTarget" column="invoke_target" /> + <result property="cronExpression" column="cron_expression" /> + <result property="misfirePolicy" column="misfire_policy" /> + <result property="concurrent" column="concurrent" /> + <result property="status" column="status" /> + <result property="createBy" column="create_by" /> + <result property="createTime" column="create_time" /> + <result property="updateBy" column="update_by" /> + <result property="updateTime" column="update_time" /> + <result property="remark" column="remark" /> + </resultMap> + + <sql id="selectJobVo"> + select job_id, job_name, job_group, invoke_target, cron_expression, misfire_policy, concurrent, status, create_by, create_time, remark + from sys_job + </sql> + + <select id="selectJobList" parameterType="SysJob" resultMap="SysJobResult"> + <include refid="selectJobVo"/> + <where> + <if test="jobName != null and jobName != ''"> + AND job_name like concat('%', #{jobName}, '%') + </if> + <if test="jobGroup != null and jobGroup != ''"> + AND job_group = #{jobGroup} + </if> + <if test="status != null and status != ''"> + AND status = #{status} + </if> + <if test="invokeTarget != null and invokeTarget != ''"> + AND invoke_target like concat('%', #{invokeTarget}, '%') + </if> + </where> + </select> + + <select id="selectJobAll" resultMap="SysJobResult"> + <include refid="selectJobVo"/> + </select> + + <select id="selectJobById" parameterType="Long" resultMap="SysJobResult"> + <include refid="selectJobVo"/> + where job_id = #{jobId} + </select> + + <delete id="deleteJobById" parameterType="Long"> + delete from sys_job where job_id = #{jobId} + </delete> + + <delete id="deleteJobByIds" parameterType="Long"> + delete from sys_job where job_id in + <foreach collection="array" item="jobId" open="(" separator="," close=")"> + #{jobId} + </foreach> + </delete> + + <update id="updateJob" parameterType="SysJob"> + update sys_job + <set> + <if test="jobName != null and jobName != ''">job_name = #{jobName},</if> + <if test="jobGroup != null and jobGroup != ''">job_group = #{jobGroup},</if> + <if test="invokeTarget != null and invokeTarget != ''">invoke_target = #{invokeTarget},</if> + <if test="cronExpression != null and cronExpression != ''">cron_expression = #{cronExpression},</if> + <if test="misfirePolicy != null and misfirePolicy != ''">misfire_policy = #{misfirePolicy},</if> + <if test="concurrent != null and concurrent != ''">concurrent = #{concurrent},</if> + <if test="status !=null">status = #{status},</if> + <if test="remark != null and remark != ''">remark = #{remark},</if> + <if test="updateBy != null and updateBy != ''">update_by = #{updateBy},</if> + update_time = now() + </set> + where job_id = #{jobId} + </update> + + <insert id="insertJob" parameterType="SysJob" useGeneratedKeys="true" keyProperty="jobId"> + insert into sys_job( + <if test="jobId != null and jobId != 0">job_id,</if> + <if test="jobName != null and jobName != ''">job_name,</if> + <if test="jobGroup != null and jobGroup != ''">job_group,</if> + <if test="invokeTarget != null and invokeTarget != ''">invoke_target,</if> + <if test="cronExpression != null and cronExpression != ''">cron_expression,</if> + <if test="misfirePolicy != null and misfirePolicy != ''">misfire_policy,</if> + <if test="concurrent != null and concurrent != ''">concurrent,</if> + <if test="status != null and status != ''">status,</if> + <if test="remark != null and remark != ''">remark,</if> + <if test="createBy != null and createBy != ''">create_by,</if> + create_time + )values( + <if test="jobId != null and jobId != 0">#{jobId},</if> + <if test="jobName != null and jobName != ''">#{jobName},</if> + <if test="jobGroup != null and jobGroup != ''">#{jobGroup},</if> + <if test="invokeTarget != null and invokeTarget != ''">#{invokeTarget},</if> + <if test="cronExpression != null and cronExpression != ''">#{cronExpression},</if> + <if test="misfirePolicy != null and misfirePolicy != ''">#{misfirePolicy},</if> + <if test="concurrent != null and concurrent != ''">#{concurrent},</if> + <if test="status != null and status != ''">#{status},</if> + <if test="remark != null and remark != ''">#{remark},</if> + <if test="createBy != null and createBy != ''">#{createBy},</if> + now() + ) + </insert> + +</mapper> \ No newline at end of file diff --git a/dc-system/pom.xml b/dc-system/pom.xml new file mode 100644 index 0000000..49c6ca4 --- /dev/null +++ b/dc-system/pom.xml @@ -0,0 +1,41 @@ +<?xml version="1.0" encoding="UTF-8"?> +<project xmlns="http://maven.apache.org/POM/4.0.0" + xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" + xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> + <parent> + <artifactId>dc</artifactId> + <groupId>com.dc</groupId> + <version>1.0.0</version> + </parent> + <modelVersion>4.0.0</modelVersion> + + <artifactId>dc-system</artifactId> + + <description> + system系统模块 + </description> + + <dependencies> + + <!-- 防止进入swagger页面报类型转换错误,排除3.0.0中的引用,手动增加1.6.2版本 --> + <dependency> + <groupId>io.swagger</groupId> + <artifactId>swagger-models</artifactId> + </dependency> + + <!-- 通用工具--> + <dependency> + <groupId>com.dc</groupId> + <artifactId>dc-common</artifactId> + </dependency> + + <!-- easyexcel工具类--> + <dependency> + <groupId>com.alibaba</groupId> + <artifactId>easyexcel</artifactId> + <version>3.1.0</version> + </dependency> + + </dependencies> + +</project> \ No newline at end of file diff --git a/dc-system/src/main/java/com/dc/system/domain/Accessory.java b/dc-system/src/main/java/com/dc/system/domain/Accessory.java new file mode 100644 index 0000000..460c108 --- /dev/null +++ b/dc-system/src/main/java/com/dc/system/domain/Accessory.java @@ -0,0 +1,45 @@ +package com.dc.system.domain; + +import com.dc.common.annotation.Excel; +import com.dc.common.core.domain.BaseEntity; +import lombok.AllArgsConstructor; +import lombok.Data; +import lombok.NoArgsConstructor; +import lombok.experimental.Accessors; + +/** + * 附件对象 accessory + * + * @author win + * @date 2023-04-10 + */ + +@Data +@NoArgsConstructor +@AllArgsConstructor +@Accessors(chain = true) +public class Accessory extends BaseEntity<Accessory> { + + private static final long serialVersionUID = 1L; + + /** 附件url */ + @Excel(name = "附件url") + private String url; + + /** 附件名 */ + @Excel(name = "附件名") + private String name; + + /** 后缀 */ + @Excel(name = "后缀") + private String suffix; + + /** 类型1订单提货2订单交货3在途事件4合同附件5司机头像6问题反馈7基本信息8身份证正面9身份证反面10驾驶证11车辆行驶证12车辆营运证 */ + @Excel(name = "类型") + private Integer type; + + /** 对应数据的编号 */ + @Excel(name = "对应数据的编号") + private String objectNo; + +} \ No newline at end of file diff --git a/dc-system/src/main/java/com/dc/system/domain/SysCache.java b/dc-system/src/main/java/com/dc/system/domain/SysCache.java new file mode 100644 index 0000000..4e2e891 --- /dev/null +++ b/dc-system/src/main/java/com/dc/system/domain/SysCache.java @@ -0,0 +1,45 @@ +package com.dc.system.domain; + +import com.dc.common.utils.StringUtils; +import lombok.AllArgsConstructor; +import lombok.Data; +import lombok.NoArgsConstructor; +import lombok.experimental.Accessors; + +/** + * 缓存信息 + * + * @author win + */ +@Data +@NoArgsConstructor +@AllArgsConstructor +@Accessors(chain = true) +public class SysCache +{ + /** 缓存名称 */ + private String cacheName = ""; + + /** 缓存键名 */ + private String cacheKey = ""; + + /** 缓存内容 */ + private String cacheValue = ""; + + /** 备注 */ + private String remark = ""; + + public SysCache(String cacheName, String remark) + { + this.cacheName = cacheName; + this.remark = remark; + } + + public SysCache(String cacheName, String cacheKey, String cacheValue) + { + this.cacheName = StringUtils.replace(cacheName, ":", ""); + this.cacheKey = StringUtils.replace(cacheKey, cacheName, ""); + this.cacheValue = cacheValue; + } + +} diff --git a/dc-system/src/main/java/com/dc/system/domain/SysCity.java b/dc-system/src/main/java/com/dc/system/domain/SysCity.java new file mode 100644 index 0000000..a8f7719 --- /dev/null +++ b/dc-system/src/main/java/com/dc/system/domain/SysCity.java @@ -0,0 +1,37 @@ +package com.dc.system.domain; + +import com.dc.common.annotation.Excel; +import com.dc.common.core.domain.BaseEntity; +import lombok.AllArgsConstructor; +import lombok.Data; +import lombok.NoArgsConstructor; +import lombok.experimental.Accessors; + +/** + * 省市区对象 sys_city + * + * @author win + * @date 2023-03-14 + */ + +@Data +@NoArgsConstructor +@AllArgsConstructor +@Accessors(chain = true) +public class SysCity extends BaseEntity<SysCity> { + + private static final long serialVersionUID = 1L; + + /** 父级标识 */ + @Excel(name = "父级标识") + private Long pid; + + /** 行政区名称 */ + @Excel(name = "行政区名称") + private String areaName; + + /** 等级 1:省 2:市 3:区 */ + @Excel(name = "等级 1:省 2:市 3:区") + private Integer grade; + +} diff --git a/dc-system/src/main/java/com/dc/system/domain/SysConfig.java b/dc-system/src/main/java/com/dc/system/domain/SysConfig.java new file mode 100644 index 0000000..a68be98 --- /dev/null +++ b/dc-system/src/main/java/com/dc/system/domain/SysConfig.java @@ -0,0 +1,115 @@ +package com.dc.system.domain; + +import com.baomidou.mybatisplus.annotation.IdType; +import com.baomidou.mybatisplus.annotation.TableId; +import com.dc.common.annotation.Excel; +import com.dc.common.annotation.Excel.ColumnType; +import com.dc.common.core.domain.WinBaseEntity; +import org.apache.commons.lang3.builder.ToStringBuilder; +import org.apache.commons.lang3.builder.ToStringStyle; + +import javax.validation.constraints.NotBlank; +import javax.validation.constraints.Size; + +/** + * 参数配置表 sys_config + * + * @author win + */ +public class SysConfig extends WinBaseEntity +{ + private static final long serialVersionUID = 1L; + + /** 参数主键 */ + @Excel(name = "参数主键", cellType = ColumnType.NUMERIC) + @TableId(type = IdType.AUTO) + private Long configId; + + /** 参数名称 */ + @Excel(name = "参数名称") + private String configName; + + /** 参数键名 */ + @Excel(name = "参数键名") + private String configKey; + + /** 参数键值 */ + @Excel(name = "参数键值") + private String configValue; + + /** 系统内置(Y是 N否) */ + @Excel(name = "系统内置", readConverterExp = "Y=是,N=否") + private String configType; + + public Long getConfigId() + { + return configId; + } + + public void setConfigId(Long configId) + { + this.configId = configId; + } + + @NotBlank(message = "参数名称不能为空") + @Size(min = 0, max = 100, message = "参数名称不能超过100个字符") + public String getConfigName() + { + return configName; + } + + public void setConfigName(String configName) + { + this.configName = configName; + } + + @NotBlank(message = "参数键名长度不能为空") + @Size(min = 0, max = 100, message = "参数键名长度不能超过100个字符") + public String getConfigKey() + { + return configKey; + } + + public void setConfigKey(String configKey) + { + this.configKey = configKey; + } + + @NotBlank(message = "参数键值不能为空") + @Size(min = 0, max = 500, message = "参数键值长度不能超过500个字符") + public String getConfigValue() + { + return configValue; + } + + public void setConfigValue(String configValue) + { + this.configValue = configValue; + } + + public String getConfigType() + { + return configType; + } + + public void setConfigType(String configType) + { + this.configType = configType; + } + + @Override + public String toString() { + return new ToStringBuilder(this,ToStringStyle.MULTI_LINE_STYLE) + .append("configId", getConfigId()) + .append("configName", getConfigName()) + .append("configKey", getConfigKey()) + .append("configValue", getConfigValue()) + .append("configType", getConfigType()) + .append("createBy", getCreateBy()) + .append("createTime", getCreateTime()) + .append("updateBy", getUpdateBy()) + .append("updateTime", getUpdateTime()) + .append("remark", getRemark()) + .toString(); + } +} diff --git a/dc-system/src/main/java/com/dc/system/domain/SysLogininfor.java b/dc-system/src/main/java/com/dc/system/domain/SysLogininfor.java new file mode 100644 index 0000000..94d664a --- /dev/null +++ b/dc-system/src/main/java/com/dc/system/domain/SysLogininfor.java @@ -0,0 +1,67 @@ +package com.dc.system.domain; + +import com.baomidou.mybatisplus.annotation.IdType; +import com.baomidou.mybatisplus.annotation.TableId; +import com.fasterxml.jackson.annotation.JsonFormat; +import com.dc.common.annotation.Excel; +import com.dc.common.annotation.Excel.ColumnType; +import com.dc.common.core.domain.WinBaseEntity; +import lombok.AllArgsConstructor; +import lombok.Data; +import lombok.NoArgsConstructor; +import lombok.experimental.Accessors; + +import java.util.Date; + +/** + * 系统访问记录表 sys_logininfor + * + * @author win + */ +@Data +@NoArgsConstructor +@AllArgsConstructor +@Accessors(chain = true) +public class SysLogininfor extends WinBaseEntity +{ + private static final long serialVersionUID = 1L; + + /** ID */ + @Excel(name = "序号", cellType = ColumnType.NUMERIC) + @TableId(type = IdType.AUTO) + private Long infoId; + + /** 用户账号 */ + @Excel(name = "用户账号") + private String userName; + + /** 登录状态 0成功 1失败 */ + @Excel(name = "登录状态", readConverterExp = "0=成功,1=失败") + private String status; + + /** 登录IP地址 */ + @Excel(name = "登录地址") + private String ipaddr; + + /** 登录地点 */ + @Excel(name = "登录地点") + private String loginLocation; + + /** 浏览器类型 */ + @Excel(name = "浏览器") + private String browser; + + /** 操作系统 */ + @Excel(name = "操作系统") + private String os; + + /** 提示消息 */ + @Excel(name = "提示消息") + private String msg; + + /** 访问时间 */ + @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss") + @Excel(name = "访问时间", width = 30, dateFormat = "yyyy-MM-dd HH:mm:ss") + private Date loginTime; + +} diff --git a/dc-system/src/main/java/com/dc/system/domain/SysNotice.java b/dc-system/src/main/java/com/dc/system/domain/SysNotice.java new file mode 100644 index 0000000..8655b08 --- /dev/null +++ b/dc-system/src/main/java/com/dc/system/domain/SysNotice.java @@ -0,0 +1,106 @@ +package com.dc.system.domain; + +import com.baomidou.mybatisplus.annotation.IdType; +import com.baomidou.mybatisplus.annotation.TableId; +import com.dc.common.core.domain.WinBaseEntity; +import com.dc.common.xss.Xss; +import org.apache.commons.lang3.builder.ToStringBuilder; +import org.apache.commons.lang3.builder.ToStringStyle; + +import javax.validation.constraints.NotBlank; +import javax.validation.constraints.Size; + +/** + * 通知公告表 sys_notice + * + * @author win + */ +public class SysNotice extends WinBaseEntity +{ + private static final long serialVersionUID = 1L; + + /** 公告ID */ + @TableId(type = IdType.AUTO) + private Long noticeId; + + /** 公告标题 */ + private String noticeTitle; + + /** 公告类型(1通知 2公告) */ + private String noticeType; + + /** 公告内容 */ + private String noticeContent; + + /** 公告状态(0正常 1关闭) */ + private String status; + + public Long getNoticeId() + { + return noticeId; + } + + public void setNoticeId(Long noticeId) + { + this.noticeId = noticeId; + } + + public void setNoticeTitle(String noticeTitle) + { + this.noticeTitle = noticeTitle; + } + + @Xss(message = "公告标题不能包含脚本字符") + @NotBlank(message = "公告标题不能为空") + @Size(min = 0, max = 50, message = "公告标题不能超过50个字符") + public String getNoticeTitle() + { + return noticeTitle; + } + + public void setNoticeType(String noticeType) + { + this.noticeType = noticeType; + } + + public String getNoticeType() + { + return noticeType; + } + + public void setNoticeContent(String noticeContent) + { + this.noticeContent = noticeContent; + } + + public String getNoticeContent() + { + return noticeContent; + } + + public void setStatus(String status) + { + this.status = status; + } + + public String getStatus() + { + return status; + } + + @Override + public String toString() { + return new ToStringBuilder(this,ToStringStyle.MULTI_LINE_STYLE) + .append("noticeId", getNoticeId()) + .append("noticeTitle", getNoticeTitle()) + .append("noticeType", getNoticeType()) + .append("noticeContent", getNoticeContent()) + .append("status", getStatus()) + .append("createBy", getCreateBy()) + .append("createTime", getCreateTime()) + .append("updateBy", getUpdateBy()) + .append("updateTime", getUpdateTime()) + .append("remark", getRemark()) + .toString(); + } +} diff --git a/dc-system/src/main/java/com/dc/system/domain/SysOperLog.java b/dc-system/src/main/java/com/dc/system/domain/SysOperLog.java new file mode 100644 index 0000000..2ac4795 --- /dev/null +++ b/dc-system/src/main/java/com/dc/system/domain/SysOperLog.java @@ -0,0 +1,98 @@ +package com.dc.system.domain; + +import com.baomidou.mybatisplus.annotation.IdType; +import com.baomidou.mybatisplus.annotation.TableId; +import com.fasterxml.jackson.annotation.JsonFormat; +import com.dc.common.annotation.Excel; +import com.dc.common.annotation.Excel.ColumnType; +import com.dc.common.core.domain.WinBaseEntity; +import lombok.AllArgsConstructor; +import lombok.Data; +import lombok.NoArgsConstructor; +import lombok.experimental.Accessors; + +import java.util.Date; + +/** + * 操作日志记录表 oper_log + * + * @author win + */ +@Data +@NoArgsConstructor +@AllArgsConstructor +@Accessors(chain = true) +public class SysOperLog extends WinBaseEntity +{ + private static final long serialVersionUID = 1L; + + /** 日志主键 */ + @Excel(name = "操作序号", cellType = ColumnType.NUMERIC) + @TableId(type = IdType.AUTO) + private Long operId; + + /** 操作模块 */ + @Excel(name = "操作模块") + private String title; + + /** 业务类型(0其它 1新增 2修改 3删除) */ + @Excel(name = "业务类型", readConverterExp = "0=其它,1=新增,2=修改,3=删除,4=授权,5=导出,6=导入,7=强退,8=生成代码,9=清空数据") + private Integer businessType; + + /** 业务类型数组 */ + private Integer[] businessTypes; + + /** 请求方法 */ + @Excel(name = "请求方法") + private String method; + + /** 请求方式 */ + @Excel(name = "请求方式") + private String requestMethod; + + /** 操作类别(0其它 1后台用户 2手机端用户) */ + @Excel(name = "操作类别", readConverterExp = "0=其它,1=后台用户,2=手机端用户") + private Integer operatorType; + + /** 操作人员 */ + @Excel(name = "操作人员") + private String operName; + + /** 部门名称 */ + @Excel(name = "部门名称") + private String deptName; + + /** 请求url */ + @Excel(name = "请求地址") + private String operUrl; + + /** 操作地址 */ + @Excel(name = "操作地址") + private String operIp; + + /** 操作地点 */ + @Excel(name = "操作地点") + private String operLocation; + + /** 请求参数 */ + @Excel(name = "请求参数") + private String operParam; + + /** 返回参数 */ + @Excel(name = "返回参数") + private String jsonResult; + + /** 操作状态(0正常 1异常) */ + @Excel(name = "状态", readConverterExp = "0=正常,1=异常") + private Integer status; + + /** 错误消息 */ + @Excel(name = "错误消息") + private String errorMsg; + + /** 操作时间 */ + @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss") + @Excel(name = "操作时间", width = 30, dateFormat = "yyyy-MM-dd HH:mm:ss") + private Date operTime; + +} diff --git a/dc-system/src/main/java/com/dc/system/domain/SysPost.java b/dc-system/src/main/java/com/dc/system/domain/SysPost.java new file mode 100644 index 0000000..7570e4d --- /dev/null +++ b/dc-system/src/main/java/com/dc/system/domain/SysPost.java @@ -0,0 +1,128 @@ +package com.dc.system.domain; + +import com.baomidou.mybatisplus.annotation.IdType; +import com.baomidou.mybatisplus.annotation.TableId; +import com.dc.common.annotation.Excel; +import com.dc.common.annotation.Excel.ColumnType; +import com.dc.common.core.domain.WinBaseEntity; +import org.apache.commons.lang3.builder.ToStringBuilder; +import org.apache.commons.lang3.builder.ToStringStyle; + +import javax.validation.constraints.NotBlank; +import javax.validation.constraints.NotNull; +import javax.validation.constraints.Size; + +/** + * 岗位表 sys_post + * + * @author win + */ +public class SysPost extends WinBaseEntity +{ + private static final long serialVersionUID = 1L; + + /** 岗位序号 */ + @Excel(name = "岗位序号", cellType = ColumnType.NUMERIC) + @TableId(type = IdType.AUTO) + private Long postId; + + /** 岗位编码 */ + @Excel(name = "岗位编码") + private String postCode; + + /** 岗位名称 */ + @Excel(name = "岗位名称") + private String postName; + + /** 岗位排序 */ + @Excel(name = "岗位排序") + private Integer postSort; + + /** 状态(0正常 1停用) */ + @Excel(name = "状态", readConverterExp = "0=正常,1=停用") + private String status; + + /** 用户是否存在此岗位标识 默认不存在 */ + private boolean flag = false; + + public Long getPostId() + { + return postId; + } + + public void setPostId(Long postId) + { + this.postId = postId; + } + + @NotBlank(message = "岗位编码不能为空") + @Size(min = 0, max = 64, message = "岗位编码长度不能超过64个字符") + public String getPostCode() + { + return postCode; + } + + public void setPostCode(String postCode) + { + this.postCode = postCode; + } + + @NotBlank(message = "岗位名称不能为空") + @Size(min = 0, max = 50, message = "岗位名称长度不能超过50个字符") + public String getPostName() + { + return postName; + } + + public void setPostName(String postName) + { + this.postName = postName; + } + + @NotNull(message = "显示顺序不能为空") + public Integer getPostSort() + { + return postSort; + } + + public void setPostSort(Integer postSort) + { + this.postSort = postSort; + } + + public String getStatus() + { + return status; + } + + public void setStatus(String status) + { + this.status = status; + } + + public boolean isFlag() + { + return flag; + } + + public void setFlag(boolean flag) + { + this.flag = flag; + } + + @Override + public String toString() { + return new ToStringBuilder(this,ToStringStyle.MULTI_LINE_STYLE) + .append("postId", getPostId()) + .append("postCode", getPostCode()) + .append("postName", getPostName()) + .append("postSort", getPostSort()) + .append("status", getStatus()) + .append("createBy", getCreateBy()) + .append("createTime", getCreateTime()) + .append("updateBy", getUpdateBy()) + .append("updateTime", getUpdateTime()) + .append("remark", getRemark()) + .toString(); + } +} diff --git a/dc-system/src/main/java/com/dc/system/domain/SysRoleDept.java b/dc-system/src/main/java/com/dc/system/domain/SysRoleDept.java new file mode 100644 index 0000000..655f1ea --- /dev/null +++ b/dc-system/src/main/java/com/dc/system/domain/SysRoleDept.java @@ -0,0 +1,25 @@ +package com.dc.system.domain; + +import lombok.AllArgsConstructor; +import lombok.Data; +import lombok.NoArgsConstructor; +import lombok.experimental.Accessors; + +/** + * 角色和部门关联 sys_role_dept + * + * @author win + */ +@Data +@NoArgsConstructor +@AllArgsConstructor +@Accessors(chain = true) +public class SysRoleDept +{ + /** 角色ID */ + private Long roleId; + + /** 部门ID */ + private Long deptId; + +} diff --git a/dc-system/src/main/java/com/dc/system/domain/SysRoleMenu.java b/dc-system/src/main/java/com/dc/system/domain/SysRoleMenu.java new file mode 100644 index 0000000..3ff8df6 --- /dev/null +++ b/dc-system/src/main/java/com/dc/system/domain/SysRoleMenu.java @@ -0,0 +1,25 @@ +package com.dc.system.domain; + +import lombok.AllArgsConstructor; +import lombok.Data; +import lombok.NoArgsConstructor; +import lombok.experimental.Accessors; + +/** + * 角色和菜单关联 sys_role_menu + * + * @author win + */ +@Data +@NoArgsConstructor +@AllArgsConstructor +@Accessors(chain = true) +public class SysRoleMenu +{ + /** 角色ID */ + private Long roleId; + + /** 菜单ID */ + private Long menuId; + +} diff --git a/dc-system/src/main/java/com/dc/system/domain/SysTaskForm.java b/dc-system/src/main/java/com/dc/system/domain/SysTaskForm.java new file mode 100644 index 0000000..60a35bb --- /dev/null +++ b/dc-system/src/main/java/com/dc/system/domain/SysTaskForm.java @@ -0,0 +1,66 @@ +package com.dc.system.domain; + +import com.dc.common.annotation.Excel; +import com.dc.common.core.domain.WinBaseEntity; +import org.apache.commons.lang3.builder.ToStringBuilder; +import org.apache.commons.lang3.builder.ToStringStyle; + +/** + * 流程任务关联单对象 sys_task_form + * + * @author Tony + * @date 2021-04-03 + */ +public class SysTaskForm extends WinBaseEntity { + private static final long serialVersionUID = 1L; + + /** + * 主键 + */ + private Long id; + + /** + * 表单主键 + */ + @Excel(name = "表单主键") + private Long formId; + + /** + * 所属任务 + */ + @Excel(name = "所属任务") + private String taskId; + + public void setId(Long id) { + this.id = id; + } + + public Long getId() { + return id; + } + + public void setFormId(Long formId) { + this.formId = formId; + } + + public Long getFormId() { + return formId; + } + + public void setTaskId(String taskId) { + this.taskId = taskId; + } + + public String getTaskId() { + return taskId; + } + + @Override + public String toString() { + return new ToStringBuilder(this, ToStringStyle.MULTI_LINE_STYLE) + .append("id", getId()) + .append("formId", getFormId()) + .append("taskId", getTaskId()) + .toString(); + } +} diff --git a/dc-system/src/main/java/com/dc/system/domain/SysUserOnline.java b/dc-system/src/main/java/com/dc/system/domain/SysUserOnline.java new file mode 100644 index 0000000..ce25066 --- /dev/null +++ b/dc-system/src/main/java/com/dc/system/domain/SysUserOnline.java @@ -0,0 +1,43 @@ +package com.dc.system.domain; + +import lombok.AllArgsConstructor; +import lombok.Data; +import lombok.NoArgsConstructor; +import lombok.experimental.Accessors; + +/** + * 当前在线会话 + * + * @author win + */ +@Data +@NoArgsConstructor +@AllArgsConstructor +@Accessors(chain = true) +public class SysUserOnline +{ + /** 会话编号 */ + private String tokenId; + + /** 部门名称 */ + private String deptName; + + /** 用户名称 */ + private String userName; + + /** 登录IP地址 */ + private String ipaddr; + + /** 登录地址 */ + private String loginLocation; + + /** 浏览器类型 */ + private String browser; + + /** 操作系统 */ + private String os; + + /** 登录时间 */ + private Long loginTime; + +} diff --git a/dc-system/src/main/java/com/dc/system/domain/SysUserPost.java b/dc-system/src/main/java/com/dc/system/domain/SysUserPost.java new file mode 100644 index 0000000..cbb84d2 --- /dev/null +++ b/dc-system/src/main/java/com/dc/system/domain/SysUserPost.java @@ -0,0 +1,25 @@ +package com.dc.system.domain; + +import lombok.AllArgsConstructor; +import lombok.Data; +import lombok.NoArgsConstructor; +import lombok.experimental.Accessors; + +/** + * 用户和岗位关联 sys_user_post + * + * @author win + */ +@Data +@NoArgsConstructor +@AllArgsConstructor +@Accessors(chain = true) +public class SysUserPost +{ + /** 用户ID */ + private Long userId; + + /** 岗位ID */ + private Long postId; + +} diff --git a/dc-system/src/main/java/com/dc/system/domain/SysUserRole.java b/dc-system/src/main/java/com/dc/system/domain/SysUserRole.java new file mode 100644 index 0000000..c6d4b13 --- /dev/null +++ b/dc-system/src/main/java/com/dc/system/domain/SysUserRole.java @@ -0,0 +1,25 @@ +package com.dc.system.domain; + +import lombok.AllArgsConstructor; +import lombok.Data; +import lombok.NoArgsConstructor; +import lombok.experimental.Accessors; + +/** + * 用户和角色关联 sys_user_role + * + * @author win + */ +@Data +@NoArgsConstructor +@AllArgsConstructor +@Accessors(chain = true) +public class SysUserRole +{ + /** 用户ID */ + private Long userId; + + /** 角色ID */ + private Long roleId; + +} diff --git a/dc-system/src/main/java/com/dc/system/domain/vo/MetaVo.java b/dc-system/src/main/java/com/dc/system/domain/vo/MetaVo.java new file mode 100644 index 0000000..3fdcfe6 --- /dev/null +++ b/dc-system/src/main/java/com/dc/system/domain/vo/MetaVo.java @@ -0,0 +1,106 @@ +package com.dc.system.domain.vo; + +import com.dc.common.utils.StringUtils; + +/** + * 路由显示信息 + * + * @author win + */ +public class MetaVo +{ + /** + * 设置该路由在侧边栏和面包屑中展示的名字 + */ + private String title; + + /** + * 设置该路由的图标,对应路径src/assets/icons/svg + */ + private String icon; + + /** + * 设置为true,则不会被 <keep-alive>缓存 + */ + private boolean noCache; + + /** + * 内链地址(http(s)://开头) + */ + private String link; + + public MetaVo() + { + } + + public MetaVo(String title, String icon) + { + this.title = title; + this.icon = icon; + } + + public MetaVo(String title, String icon, boolean noCache) + { + this.title = title; + this.icon = icon; + this.noCache = noCache; + } + + public MetaVo(String title, String icon, String link) + { + this.title = title; + this.icon = icon; + this.link = link; + } + + public MetaVo(String title, String icon, boolean noCache, String link) + { + this.title = title; + this.icon = icon; + this.noCache = noCache; + if (StringUtils.ishttp(link)) + { + this.link = link; + } + } + + public boolean isNoCache() + { + return noCache; + } + + public void setNoCache(boolean noCache) + { + this.noCache = noCache; + } + + public String getTitle() + { + return title; + } + + public void setTitle(String title) + { + this.title = title; + } + + public String getIcon() + { + return icon; + } + + public void setIcon(String icon) + { + this.icon = icon; + } + + public String getLink() + { + return link; + } + + public void setLink(String link) + { + this.link = link; + } +} diff --git a/dc-system/src/main/java/com/dc/system/domain/vo/RouterVo.java b/dc-system/src/main/java/com/dc/system/domain/vo/RouterVo.java new file mode 100644 index 0000000..c10d2b5 --- /dev/null +++ b/dc-system/src/main/java/com/dc/system/domain/vo/RouterVo.java @@ -0,0 +1,148 @@ +package com.dc.system.domain.vo; + +import com.fasterxml.jackson.annotation.JsonInclude; +import java.util.List; + +/** + * 路由配置信息 + * + * @author win + */ +@JsonInclude(JsonInclude.Include.NON_EMPTY) +public class RouterVo +{ + /** + * 路由名字 + */ + private String name; + + /** + * 路由地址 + */ + private String path; + + /** + * 是否隐藏路由,当设置 true 的时候该路由不会再侧边栏出现 + */ + private boolean hidden; + + /** + * 重定向地址,当设置 noRedirect 的时候该路由在面包屑导航中不可被点击 + */ + private String redirect; + + /** + * 组件地址 + */ + private String component; + + /** + * 路由参数:如 {"id": 1, "name": "ry"} + */ + private String query; + + /** + * 当你一个路由下面的 children 声明的路由大于1个时,自动会变成嵌套的模式--如组件页面 + */ + private Boolean alwaysShow; + + /** + * 其他元素 + */ + private MetaVo meta; + + /** + * 子路由 + */ + private List<RouterVo> children; + + public String getName() + { + return name; + } + + public void setName(String name) + { + this.name = name; + } + + public String getPath() + { + return path; + } + + public void setPath(String path) + { + this.path = path; + } + + public boolean getHidden() + { + return hidden; + } + + public void setHidden(boolean hidden) + { + this.hidden = hidden; + } + + public String getRedirect() + { + return redirect; + } + + public void setRedirect(String redirect) + { + this.redirect = redirect; + } + + public String getComponent() + { + return component; + } + + public void setComponent(String component) + { + this.component = component; + } + + public String getQuery() + { + return query; + } + + public void setQuery(String query) + { + this.query = query; + } + + public Boolean getAlwaysShow() + { + return alwaysShow; + } + + public void setAlwaysShow(Boolean alwaysShow) + { + this.alwaysShow = alwaysShow; + } + + public MetaVo getMeta() + { + return meta; + } + + public void setMeta(MetaVo meta) + { + this.meta = meta; + } + + public List<RouterVo> getChildren() + { + return children; + } + + public void setChildren(List<RouterVo> children) + { + this.children = children; + } +} diff --git a/dc-system/src/main/java/com/dc/system/mapper/AccessoryMapper.java b/dc-system/src/main/java/com/dc/system/mapper/AccessoryMapper.java new file mode 100644 index 0000000..b9dc0d3 --- /dev/null +++ b/dc-system/src/main/java/com/dc/system/mapper/AccessoryMapper.java @@ -0,0 +1,17 @@ +package com.dc.system.mapper; + +import com.baomidou.mybatisplus.annotation.InterceptorIgnore; +import com.baomidou.mybatisplus.core.mapper.BaseMapper; +import com.dc.system.domain.Accessory; + +/** + * 附件Mapper接口 + * + * @author win + * @date 2023-04-10 + */ +//@CacheNamespace +@InterceptorIgnore(tenantLine = "true") +public interface AccessoryMapper extends BaseMapper<Accessory> { + +} \ No newline at end of file diff --git a/dc-system/src/main/java/com/dc/system/mapper/SysCityMapper.java b/dc-system/src/main/java/com/dc/system/mapper/SysCityMapper.java new file mode 100644 index 0000000..e259d06 --- /dev/null +++ b/dc-system/src/main/java/com/dc/system/mapper/SysCityMapper.java @@ -0,0 +1,16 @@ +package com.dc.system.mapper; + +import com.baomidou.mybatisplus.annotation.InterceptorIgnore; +import com.baomidou.mybatisplus.core.mapper.BaseMapper; +import com.dc.system.domain.SysCity; + +/** + * 省市区Mapper接口 + * + * @author win + * @date 2023-03-14 + */ + @InterceptorIgnore(tenantLine = "true") +public interface SysCityMapper extends BaseMapper<SysCity> { + +} diff --git a/dc-system/src/main/java/com/dc/system/mapper/SysConfigMapper.java b/dc-system/src/main/java/com/dc/system/mapper/SysConfigMapper.java new file mode 100644 index 0000000..cab8634 --- /dev/null +++ b/dc-system/src/main/java/com/dc/system/mapper/SysConfigMapper.java @@ -0,0 +1,78 @@ +package com.dc.system.mapper; + +import com.baomidou.mybatisplus.core.mapper.BaseMapper; +import com.dc.system.domain.SysConfig; + +import java.util.List; + +/** + * 参数配置 数据层 + * + * @author win + */ +//@CacheNamespace +public interface SysConfigMapper extends BaseMapper<SysConfig> { + /** + * 查询参数配置信息 + * + * @param config 参数配置信息 + * @return 参数配置信息 + */ + public SysConfig selectConfig(SysConfig config); + + /** + * 通过ID查询配置 + * + * @param configId 参数ID + * @return 参数配置信息 + */ + public SysConfig selectConfigById(Long configId); + + /** + * 查询参数配置列表 + * + * @param config 参数配置信息 + * @return 参数配置集合 + */ + public List<SysConfig> selectConfigList(SysConfig config); + + /** + * 根据键名查询参数配置信息 + * + * @param configKey 参数键名 + * @return 参数配置信息 + */ + public SysConfig checkConfigKeyUnique(String configKey); + + /** + * 新增参数配置 + * + * @param config 参数配置信息 + * @return 结果 + */ + public int insertConfig(SysConfig config); + + /** + * 修改参数配置 + * + * @param config 参数配置信息 + * @return 结果 + */ + public int updateConfig(SysConfig config); + + /** + * 删除参数配置 + * + * @param configId 参数ID + * @return 结果 + */ + public int deleteConfigById(Long configId); + + /** + * 批量删除参数信息 + * + * @param configIds 需要删除的参数ID + * @return 结果 + */ + public int deleteConfigByIds(Long[] configIds); +} diff --git a/dc-system/src/main/java/com/dc/system/mapper/SysDeptMapper.java b/dc-system/src/main/java/com/dc/system/mapper/SysDeptMapper.java new file mode 100644 index 0000000..adf40c2 --- /dev/null +++ b/dc-system/src/main/java/com/dc/system/mapper/SysDeptMapper.java @@ -0,0 +1,120 @@ +package com.dc.system.mapper; + +import com.baomidou.mybatisplus.core.mapper.BaseMapper; +import com.dc.common.core.domain.entity.SysDept; +import org.apache.ibatis.annotations.Param; + +import java.util.List; + +/** + * 部门管理 数据层 + * + * @author win + */ +//@CacheNamespace +public interface SysDeptMapper extends BaseMapper<SysDept> { + /** + * 查询部门管理数据 + * + * @param dept 部门信息 + * @return 部门信息集合 + */ + public List<SysDept> selectDeptList(SysDept dept); + + /** + * 根据角色ID查询部门树信息 + * + * @param roleId 角色ID + * @param deptCheckStrictly 部门树选择项是否关联显示 + * @return 选中部门列表 + */ + public List<Long> selectDeptListByRoleId(@Param("roleId") Long roleId, @Param("deptCheckStrictly") boolean deptCheckStrictly); + + /** + * 根据部门ID查询信息 + * + * @param deptId 部门ID + * @return 部门信息 + */ + public SysDept selectDeptById(Long deptId); + + /** + * 根据ID查询所有子部门 + * + * @param deptId 部门ID + * @return 部门列表 + */ + public List<SysDept> selectChildrenDeptById(Long deptId); + + /** + * 根据ID查询所有子部门(正常状态) + * + * @param deptId 部门ID + * @return 子部门数 + */ + public int selectNormalChildrenDeptById(Long deptId); + + /** + * 是否存在子节点 + * + * @param deptId 部门ID + * @return 结果 + */ + public int hasChildByDeptId(Long deptId); + + /** + * 查询部门是否存在用户 + * + * @param deptId 部门ID + * @return 结果 + */ + public int checkDeptExistUser(Long deptId); + + /** + * 校验部门名称是否唯一 + * + * @param deptName 部门名称 + * @param parentId 父部门ID + * @return 结果 + */ + public SysDept checkDeptNameUnique(@Param("deptName") String deptName, @Param("parentId") Long parentId); + + /** + * 新增部门信息 + * + * @param dept 部门信息 + * @return 结果 + */ + public int insertDept(SysDept dept); + + /** + * 修改部门信息 + * + * @param dept 部门信息 + * @return 结果 + */ + public int updateDept(SysDept dept); + + /** + * 修改所在部门正常状态 + * + * @param deptIds 部门ID组 + */ + public void updateDeptStatusNormal(Long[] deptIds); + + /** + * 修改子元素关系 + * + * @param depts 子元素 + * @return 结果 + */ + public int updateDeptChildren(@Param("depts") List<SysDept> depts); + + /** + * 删除部门管理信息 + * + * @param deptId 部门ID + * @return 结果 + */ + public int deleteDeptById(Long deptId); +} diff --git a/dc-system/src/main/java/com/dc/system/mapper/SysDictDataMapper.java b/dc-system/src/main/java/com/dc/system/mapper/SysDictDataMapper.java new file mode 100644 index 0000000..024c53f --- /dev/null +++ b/dc-system/src/main/java/com/dc/system/mapper/SysDictDataMapper.java @@ -0,0 +1,97 @@ +package com.dc.system.mapper; + +import com.baomidou.mybatisplus.core.mapper.BaseMapper; +import com.dc.common.core.domain.entity.SysDictData; +import org.apache.ibatis.annotations.Param; + +import java.util.List; + +/** + * 字典表 数据层 + * + * @author win + */ +//@CacheNamespace +public interface SysDictDataMapper extends BaseMapper<SysDictData> { + /** + * 根据条件分页查询字典数据 + * + * @param dictData 字典数据信息 + * @return 字典数据集合信息 + */ + public List<SysDictData> selectDictDataList(SysDictData dictData); + + /** + * 根据字典类型查询字典数据 + * + * @param dictType 字典类型 + * @return 字典数据集合信息 + */ + public List<SysDictData> selectDictDataByType(String dictType); + + /** + * 根据字典类型和字典键值查询字典数据信息 + * + * @param dictType 字典类型 + * @param dictValue 字典键值 + * @return 字典标签 + */ + public String selectDictLabel(@Param("dictType") String dictType, @Param("dictValue") String dictValue); + + /** + * 根据字典数据ID查询信息 + * + * @param dictCode 字典数据ID + * @return 字典数据 + */ + public SysDictData selectDictDataById(Long dictCode); + + /** + * 查询字典数据 + * + * @param dictType 字典类型 + * @return 字典数据 + */ + public int countDictDataByType(String dictType); + + /** + * 通过字典ID删除字典数据信息 + * + * @param dictCode 字典数据ID + * @return 结果 + */ + public int deleteDictDataById(Long dictCode); + + /** + * 批量删除字典数据信息 + * + * @param dictCodes 需要删除的字典数据ID + * @return 结果 + */ + public int deleteDictDataByIds(Long[] dictCodes); + + /** + * 新增字典数据信息 + * + * @param dictData 字典数据信息 + * @return 结果 + */ + public int insertDictData(SysDictData dictData); + + /** + * 修改字典数据信息 + * + * @param dictData 字典数据信息 + * @return 结果 + */ + public int updateDictData(SysDictData dictData); + + /** + * 同步修改字典类型 + * + * @param oldDictType 旧字典类型 + * @param newDictType 新旧字典类型 + * @return 结果 + */ + public int updateDictDataType(@Param("oldDictType") String oldDictType, @Param("newDictType") String newDictType); +} diff --git a/dc-system/src/main/java/com/dc/system/mapper/SysDictTypeMapper.java b/dc-system/src/main/java/com/dc/system/mapper/SysDictTypeMapper.java new file mode 100644 index 0000000..05db358 --- /dev/null +++ b/dc-system/src/main/java/com/dc/system/mapper/SysDictTypeMapper.java @@ -0,0 +1,85 @@ +package com.dc.system.mapper; + +import com.baomidou.mybatisplus.core.mapper.BaseMapper; +import com.dc.common.core.domain.entity.SysDictType; + +import java.util.List; + +/** + * 字典表 数据层 + * + * @author win + */ +//@CacheNamespace +public interface SysDictTypeMapper extends BaseMapper<SysDictType> { + /** + * 根据条件分页查询字典类型 + * + * @param dictType 字典类型信息 + * @return 字典类型集合信息 + */ + public List<SysDictType> selectDictTypeList(SysDictType dictType); + + /** + * 根据所有字典类型 + * + * @return 字典类型集合信息 + */ + public List<SysDictType> selectDictTypeAll(); + + /** + * 根据字典类型ID查询信息 + * + * @param dictId 字典类型ID + * @return 字典类型 + */ + public SysDictType selectDictTypeById(Long dictId); + + /** + * 根据字典类型查询信息 + * + * @param dictType 字典类型 + * @return 字典类型 + */ + public SysDictType selectDictTypeByType(String dictType); + + /** + * 通过字典ID删除字典信息 + * + * @param dictId 字典ID + * @return 结果 + */ + public int deleteDictTypeById(Long dictId); + + /** + * 批量删除字典类型信息 + * + * @param dictIds 需要删除的字典ID + * @return 结果 + */ + public int deleteDictTypeByIds(Long[] dictIds); + + /** + * 新增字典类型信息 + * + * @param dictType 字典类型信息 + * @return 结果 + */ + public int insertDictType(SysDictType dictType); + + /** + * 修改字典类型信息 + * + * @param dictType 字典类型信息 + * @return 结果 + */ + public int updateDictType(SysDictType dictType); + + /** + * 校验字典类型称是否唯一 + * + * @param dictType 字典类型 + * @return 结果 + */ + public SysDictType checkDictTypeUnique(String dictType); +} diff --git a/dc-system/src/main/java/com/dc/system/mapper/SysLogininforMapper.java b/dc-system/src/main/java/com/dc/system/mapper/SysLogininforMapper.java new file mode 100644 index 0000000..5a15400 --- /dev/null +++ b/dc-system/src/main/java/com/dc/system/mapper/SysLogininforMapper.java @@ -0,0 +1,44 @@ +package com.dc.system.mapper; + +import com.baomidou.mybatisplus.core.mapper.BaseMapper; +import com.dc.system.domain.SysLogininfor; + +import java.util.List; + +/** + * 系统访问日志情况信息 数据层 + * + * @author win + */ +//@CacheNamespace +public interface SysLogininforMapper extends BaseMapper<SysLogininfor> { + /** + * 新增系统登录日志 + * + * @param logininfor 访问日志对象 + */ + public void insertLogininfor(SysLogininfor logininfor); + + /** + * 查询系统登录日志集合 + * + * @param logininfor 访问日志对象 + * @return 登录记录集合 + */ + public List<SysLogininfor> selectLogininforList(SysLogininfor logininfor); + + /** + * 批量删除系统登录日志 + * + * @param infoIds 需要删除的登录日志ID + * @return 结果 + */ + public int deleteLogininforByIds(Long[] infoIds); + + /** + * 清空系统登录日志 + * + * @return 结果 + */ + public int cleanLogininfor(); +} diff --git a/dc-system/src/main/java/com/dc/system/mapper/SysMenuMapper.java b/dc-system/src/main/java/com/dc/system/mapper/SysMenuMapper.java new file mode 100644 index 0000000..19b33dd --- /dev/null +++ b/dc-system/src/main/java/com/dc/system/mapper/SysMenuMapper.java @@ -0,0 +1,136 @@ +package com.dc.system.mapper; + +import com.baomidou.mybatisplus.core.mapper.BaseMapper; +import com.dc.common.core.domain.entity.SysMenu; +import org.apache.ibatis.annotations.Param; + +import java.util.List; + +/** + * 菜单表 数据层 + * + * @author win + */ +//@CacheNamespace +public interface SysMenuMapper extends BaseMapper<SysMenu> { + /** + * 查询系统菜单列表 + * + * @param menu 菜单信息 + * @return 菜单列表 + */ + public List<SysMenu> selectMenuList(SysMenu menu); + + /** + * 根据用户所有权限 + * + * @return 权限列表 + */ + public List<String> selectMenuPerms(); + + /** + * 根据用户查询系统菜单列表 + * + * @param menu 菜单信息 + * @return 菜单列表 + */ + public List<SysMenu> selectMenuListByUserId(SysMenu menu); + + /** + * 根据角色ID查询权限 + * + * @param roleId 角色ID + * @return 权限列表 + */ + public List<String> selectMenuPermsByRoleId(Long roleId); + + /** + * 根据用户ID查询权限 + * + * @param userId 用户ID + * @return 权限列表 + */ + public List<String> selectMenuPermsByUserId(Long userId); + + /** + * 根据用户ID查询菜单 + * + * @return 菜单列表 + */ + public List<SysMenu> selectMenuTreeAll(); + + /** + * 根据用户ID查询菜单 + * + * @param userId 用户ID + * @return 菜单列表 + */ + public List<SysMenu> selectMenuTreeByUserId(Long userId); + + /** + * 根据角色ID查询菜单树信息 + * + * @param roleId 角色ID + * @param menuCheckStrictly 菜单树选择项是否关联显示 + * @return 选中菜单列表 + */ + public List<Long> selectMenuListByRoleId(@Param("roleId") Long roleId, @Param("menuCheckStrictly") boolean menuCheckStrictly); + + /** + * 根据角色ID查询菜单树信息 + * + * @param roleId 角色ID + * @param menuCheckStrictly 菜单树选择项是否关联显示 + * @return 选中菜单列表 + */ + public List<SysMenu> selectMenuList1ByRoleId(@Param("roleId") Long roleId, @Param("menuCheckStrictly") boolean menuCheckStrictly); + + /** + * 根据菜单ID查询信息 + * + * @param menuId 菜单ID + * @return 菜单信息 + */ + public SysMenu selectMenuById(Long menuId); + + /** + * 是否存在菜单子节点 + * + * @param menuId 菜单ID + * @return 结果 + */ + public int hasChildByMenuId(Long menuId); + + /** + * 新增菜单信息 + * + * @param menu 菜单信息 + * @return 结果 + */ + public int insertMenu(SysMenu menu); + + /** + * 修改菜单信息 + * + * @param menu 菜单信息 + * @return 结果 + */ + public int updateMenu(SysMenu menu); + + /** + * 删除菜单管理信息 + * + * @param menuId 菜单ID + * @return 结果 + */ + public int deleteMenuById(Long menuId); + + /** + * 校验菜单名称是否唯一 + * + * @param menuName 菜单名称 + * @param parentId 父菜单ID + * @return 结果 + */ + public SysMenu checkMenuNameUnique(@Param("menuName") String menuName, @Param("parentId") Long parentId); +} diff --git a/dc-system/src/main/java/com/dc/system/mapper/SysNoticeMapper.java b/dc-system/src/main/java/com/dc/system/mapper/SysNoticeMapper.java new file mode 100644 index 0000000..4caa263 --- /dev/null +++ b/dc-system/src/main/java/com/dc/system/mapper/SysNoticeMapper.java @@ -0,0 +1,62 @@ +package com.dc.system.mapper; + +import com.baomidou.mybatisplus.core.mapper.BaseMapper; +import com.dc.system.domain.SysNotice; + +import java.util.List; + +/** + * 通知公告表 数据层 + * + * @author win + */ +//@CacheNamespace +public interface SysNoticeMapper extends BaseMapper<SysNotice> { + /** + * 查询公告信息 + * + * @param noticeId 公告ID + * @return 公告信息 + */ + public SysNotice selectNoticeById(Long noticeId); + + /** + * 查询公告列表 + * + * @param notice 公告信息 + * @return 公告集合 + */ + public List<SysNotice> selectNoticeList(SysNotice notice); + + /** + * 新增公告 + * + * @param notice 公告信息 + * @return 结果 + */ + public int insertNotice(SysNotice notice); + + /** + * 修改公告 + * + * @param notice 公告信息 + * @return 结果 + */ + public int updateNotice(SysNotice notice); + + /** + * 批量删除公告 + * + * @param noticeId 公告ID + * @return 结果 + */ + public int deleteNoticeById(Long noticeId); + + /** + * 批量删除公告信息 + * + * @param noticeIds 需要删除的公告ID + * @return 结果 + */ + public int deleteNoticeByIds(Long[] noticeIds); +} diff --git a/dc-system/src/main/java/com/dc/system/mapper/SysOperLogMapper.java b/dc-system/src/main/java/com/dc/system/mapper/SysOperLogMapper.java new file mode 100644 index 0000000..bb3e0df --- /dev/null +++ b/dc-system/src/main/java/com/dc/system/mapper/SysOperLogMapper.java @@ -0,0 +1,50 @@ +package com.dc.system.mapper; + +import com.baomidou.mybatisplus.core.mapper.BaseMapper; +import com.dc.system.domain.SysOperLog; + +import java.util.List; + +/** + * 操作日志 数据层 + * + * @author win + */ +//@CacheNamespace +public interface SysOperLogMapper extends BaseMapper<SysOperLog> { + /** + * 新增操作日志 + * + * @param operLog 操作日志对象 + */ + public void insertOperlog(SysOperLog operLog); + + /** + * 查询系统操作日志集合 + * + * @param operLog 操作日志对象 + * @return 操作日志集合 + */ + public List<SysOperLog> selectOperLogList(SysOperLog operLog); + + /** + * 批量删除系统操作日志 + * + * @param operIds 需要删除的操作日志ID + * @return 结果 + */ + public int deleteOperLogByIds(Long[] operIds); + + /** + * 查询操作日志详细 + * + * @param operId 操作ID + * @return 操作日志对象 + */ + public SysOperLog selectOperLogById(Long operId); + + /** + * 清空操作日志 + */ + public void cleanOperLog(); +} diff --git a/dc-system/src/main/java/com/dc/system/mapper/SysPostMapper.java b/dc-system/src/main/java/com/dc/system/mapper/SysPostMapper.java new file mode 100644 index 0000000..9e3e52e --- /dev/null +++ b/dc-system/src/main/java/com/dc/system/mapper/SysPostMapper.java @@ -0,0 +1,101 @@ +package com.dc.system.mapper; + +import com.baomidou.mybatisplus.core.mapper.BaseMapper; +import com.dc.system.domain.SysPost; + +import java.util.List; + +/** + * 岗位信息 数据层 + * + * @author win + */ +//@CacheNamespace +public interface SysPostMapper extends BaseMapper<SysPost> { + /** + * 查询岗位数据集合 + * + * @param post 岗位信息 + * @return 岗位数据集合 + */ + public List<SysPost> selectPostList(SysPost post); + + /** + * 查询所有岗位 + * + * @return 岗位列表 + */ + public List<SysPost> selectPostAll(); + + /** + * 通过岗位ID查询岗位信息 + * + * @param postId 岗位ID + * @return 角色对象信息 + */ + public SysPost selectPostById(Long postId); + + /** + * 根据用户ID获取岗位选择框列表 + * + * @param userId 用户ID + * @return 选中岗位ID列表 + */ + public List<Long> selectPostListByUserId(Long userId); + + /** + * 查询用户所属岗位组 + * + * @param userName 用户名 + * @return 结果 + */ + public List<SysPost> selectPostsByUserName(String userName); + + /** + * 删除岗位信息 + * + * @param postId 岗位ID + * @return 结果 + */ + public int deletePostById(Long postId); + + /** + * 批量删除岗位信息 + * + * @param postIds 需要删除的岗位ID + * @return 结果 + */ + public int deletePostByIds(Long[] postIds); + + /** + * 修改岗位信息 + * + * @param post 岗位信息 + * @return 结果 + */ + public int updatePost(SysPost post); + + /** + * 新增岗位信息 + * + * @param post 岗位信息 + * @return 结果 + */ + public int insertPost(SysPost post); + + /** + * 校验岗位名称 + * + * @param postName 岗位名称 + * @return 结果 + */ + public SysPost checkPostNameUnique(String postName); + + /** + * 校验岗位编码 + * + * @param postCode 岗位编码 + * @return 结果 + */ + public SysPost checkPostCodeUnique(String postCode); +} diff --git a/dc-system/src/main/java/com/dc/system/mapper/SysRoleDeptMapper.java b/dc-system/src/main/java/com/dc/system/mapper/SysRoleDeptMapper.java new file mode 100644 index 0000000..54319c1 --- /dev/null +++ b/dc-system/src/main/java/com/dc/system/mapper/SysRoleDeptMapper.java @@ -0,0 +1,46 @@ +package com.dc.system.mapper; + +import com.baomidou.mybatisplus.core.mapper.BaseMapper; +import com.dc.system.domain.SysRoleDept; + +import java.util.List; + +/** + * 角色与部门关联表 数据层 + * + * @author win + */ +//@CacheNamespace +public interface SysRoleDeptMapper extends BaseMapper<SysRoleDept> { + /** + * 通过角色ID删除角色和部门关联 + * + * @param roleId 角色ID + * @return 结果 + */ + public int deleteRoleDeptByRoleId(Long roleId); + + /** + * 批量删除角色部门关联信息 + * + * @param ids 需要删除的数据ID + * @return 结果 + */ + public int deleteRoleDept(Long[] ids); + + /** + * 查询部门使用数量 + * + * @param deptId 部门ID + * @return 结果 + */ + public int selectCountRoleDeptByDeptId(Long deptId); + + /** + * 批量新增角色部门信息 + * + * @param roleDeptList 角色部门列表 + * @return 结果 + */ + public int batchRoleDept(List<SysRoleDept> roleDeptList); +} diff --git a/dc-system/src/main/java/com/dc/system/mapper/SysRoleMapper.java b/dc-system/src/main/java/com/dc/system/mapper/SysRoleMapper.java new file mode 100644 index 0000000..c0ee878 --- /dev/null +++ b/dc-system/src/main/java/com/dc/system/mapper/SysRoleMapper.java @@ -0,0 +1,109 @@ +package com.dc.system.mapper; + +import com.baomidou.mybatisplus.core.mapper.BaseMapper; +import com.dc.common.core.domain.entity.SysRole; + +import java.util.List; + +/** + * 角色表 数据层 + * + * @author win + */ +//@CacheNamespace +public interface SysRoleMapper extends BaseMapper<SysRole> { + /** + * 根据条件分页查询角色数据 + * + * @param role 角色信息 + * @return 角色数据集合信息 + */ + public List<SysRole> selectRoleList(SysRole role); + + /** + * 根据用户ID查询角色 + * + * @param userId 用户ID + * @return 角色列表 + */ + public List<SysRole> selectRolePermissionByUserId(Long userId); + + /** + * 查询所有角色 + * + * @return 角色列表 + */ + public List<SysRole> selectRoleAll(); + + /** + * 根据用户ID获取角色选择框列表 + * + * @param userId 用户ID + * @return 选中角色ID列表 + */ + public List<Long> selectRoleListByUserId(Long userId); + + /** + * 通过角色ID查询角色 + * + * @param roleId 角色ID + * @return 角色对象信息 + */ + public SysRole selectRoleById(Long roleId); + + /** + * 根据用户ID查询角色 + * + * @param userName 用户名 + * @return 角色列表 + */ + public List<SysRole> selectRolesByUserName(String userName); + + /** + * 校验角色名称是否唯一 + * + * @param roleName 角色名称 + * @return 角色信息 + */ + public SysRole checkRoleNameUnique(String roleName); + + /** + * 校验角色权限是否唯一 + * + * @param roleKey 角色权限 + * @return 角色信息 + */ + public SysRole checkRoleKeyUnique(String roleKey); + + /** + * 修改角色信息 + * + * @param role 角色信息 + * @return 结果 + */ + public int updateRole(SysRole role); + + /** + * 新增角色信息 + * + * @param role 角色信息 + * @return 结果 + */ + public int insertRole(SysRole role); + + /** + * 通过角色ID删除角色 + * + * @param roleId 角色ID + * @return 结果 + */ + public int deleteRoleById(Long roleId); + + /** + * 批量删除角色信息 + * + * @param roleIds 需要删除的角色ID + * @return 结果 + */ + public int deleteRoleByIds(Long[] roleIds); +} diff --git a/dc-system/src/main/java/com/dc/system/mapper/SysRoleMenuMapper.java b/dc-system/src/main/java/com/dc/system/mapper/SysRoleMenuMapper.java new file mode 100644 index 0000000..1106f19 --- /dev/null +++ b/dc-system/src/main/java/com/dc/system/mapper/SysRoleMenuMapper.java @@ -0,0 +1,46 @@ +package com.dc.system.mapper; + +import com.baomidou.mybatisplus.core.mapper.BaseMapper; +import com.dc.system.domain.SysRoleMenu; + +import java.util.List; + +/** + * 角色与菜单关联表 数据层 + * + * @author win + */ +//@CacheNamespace +public interface SysRoleMenuMapper extends BaseMapper<SysRoleMenu> { + /** + * 查询菜单使用数量 + * + * @param menuId 菜单ID + * @return 结果 + */ + public int checkMenuExistRole(Long menuId); + + /** + * 通过角色ID删除角色和菜单关联 + * + * @param roleId 角色ID + * @return 结果 + */ + public int deleteRoleMenuByRoleId(Long roleId); + + /** + * 批量删除角色菜单关联信息 + * + * @param ids 需要删除的数据ID + * @return 结果 + */ + public int deleteRoleMenu(Long[] ids); + + /** + * 批量新增角色菜单信息 + * + * @param roleMenuList 角色菜单列表 + * @return 结果 + */ + public int batchRoleMenu(List<SysRoleMenu> roleMenuList); +} diff --git a/dc-system/src/main/java/com/dc/system/mapper/SysTaskFormMapper.java b/dc-system/src/main/java/com/dc/system/mapper/SysTaskFormMapper.java new file mode 100644 index 0000000..765f2fc --- /dev/null +++ b/dc-system/src/main/java/com/dc/system/mapper/SysTaskFormMapper.java @@ -0,0 +1,61 @@ +package com.dc.system.mapper; + +import com.dc.system.domain.SysTaskForm; + +import java.util.List; + +/** + * 流程任务关联单Mapper接口 + * + * @author Tony + * @date 2021-04-03 + */ +public interface SysTaskFormMapper { + /** + * 查询流程任务关联单 + * + * @param id 流程任务关联单ID + * @return 流程任务关联单 + */ + public SysTaskForm selectSysTaskFormById(Long id); + + /** + * 查询流程任务关联单列表 + * + * @param sysTaskForm 流程任务关联单 + * @return 流程任务关联单集合 + */ + public List<SysTaskForm> selectSysTaskFormList(SysTaskForm sysTaskForm); + + /** + * 新增流程任务关联单 + * + * @param sysTaskForm 流程任务关联单 + * @return 结果 + */ + public int insertSysTaskForm(SysTaskForm sysTaskForm); + + /** + * 修改流程任务关联单 + * + * @param sysTaskForm 流程任务关联单 + * @return 结果 + */ + public int updateSysTaskForm(SysTaskForm sysTaskForm); + + /** + * 删除流程任务关联单 + * + * @param id 流程任务关联单ID + * @return 结果 + */ + public int deleteSysTaskFormById(Long id); + + /** + * 批量删除流程任务关联单 + * + * @param ids 需要删除的数据ID + * @return 结果 + */ + public int deleteSysTaskFormByIds(Long[] ids); +} diff --git a/dc-system/src/main/java/com/dc/system/mapper/SysUserMapper.java b/dc-system/src/main/java/com/dc/system/mapper/SysUserMapper.java new file mode 100644 index 0000000..5b3a495 --- /dev/null +++ b/dc-system/src/main/java/com/dc/system/mapper/SysUserMapper.java @@ -0,0 +1,137 @@ +package com.dc.system.mapper; + +import com.baomidou.mybatisplus.core.mapper.BaseMapper; +import com.dc.common.core.domain.entity.SysUser; +import org.apache.ibatis.annotations.Param; + +import java.util.List; + +/** + * 用户表 数据层 + * + * @author win + */ +//@CacheNamespace +public interface SysUserMapper extends BaseMapper<SysUser> { + /** + * 根据条件分页查询用户列表 + * + * @param sysUser 用户信息 + * @return 用户信息集合信息 + */ + public List<SysUser> selectUserList(SysUser sysUser); + + /** + * 根据条件分页查询已配用户角色列表 + * + * @param user 用户信息 + * @return 用户信息集合信息 + */ + public List<SysUser> selectAllocatedList(SysUser user); + + /** + * 根据条件分页查询未分配用户角色列表 + * + * @param user 用户信息 + * @return 用户信息集合信息 + */ + public List<SysUser> selectUnallocatedList(SysUser user); + + /** + * 通过用户名查询用户 + * + * @param userName 用户名 + * @return 用户对象信息 + */ + public SysUser selectUserByUserName(String userName); + + /** + * 通过用户ID查询用户 + * + * @param userId 用户ID + * @return 用户对象信息 + */ + public SysUser selectUserById(Long userId); + + /** + * 通过用户ID只查询用户 + * + * @param userId 用户ID + * @return 用户对象信息 + */ + public SysUser selectSingleUserById(Long userId); + + /** + * 新增用户信息 + * + * @param user 用户信息 + * @return 结果 + */ + public int insertUser(SysUser user); + + /** + * 修改用户信息 + * + * @param user 用户信息 + * @return 结果 + */ + public int updateUser(SysUser user); + + /** + * 修改用户头像 + * + * @param userName 用户名 + * @param avatar 头像地址 + * @return 结果 + */ + public int updateUserAvatar(@Param("userName") String userName, @Param("avatar") String avatar); + + /** + * 重置用户密码 + * + * @param userName 用户名 + * @param password 密码 + * @return 结果 + */ + public int resetUserPwd(@Param("userName") String userName, @Param("password") String password); + + /** + * 通过用户ID删除用户 + * + * @param userId 用户ID + * @return 结果 + */ + public int deleteUserById(Long userId); + + /** + * 批量删除用户信息 + * + * @param userIds 需要删除的用户ID + * @return 结果 + */ + public int deleteUserByIds(Long[] userIds); + + /** + * 校验用户名称是否唯一 + * + * @param userName 用户名称 + * @return 结果 + */ + public SysUser checkUserNameUnique(String userName); + + /** + * 校验手机号码是否唯一 + * + * @param phonenumber 手机号码 + * @return 结果 + */ + public SysUser checkPhoneUnique(String phonenumber); + + /** + * 校验email是否唯一 + * + * @param email 用户邮箱 + * @return 结果 + */ + public SysUser checkEmailUnique(String email); +} diff --git a/dc-system/src/main/java/com/dc/system/mapper/SysUserPostMapper.java b/dc-system/src/main/java/com/dc/system/mapper/SysUserPostMapper.java new file mode 100644 index 0000000..cfcfb3a --- /dev/null +++ b/dc-system/src/main/java/com/dc/system/mapper/SysUserPostMapper.java @@ -0,0 +1,46 @@ +package com.dc.system.mapper; + +import com.baomidou.mybatisplus.core.mapper.BaseMapper; +import com.dc.system.domain.SysUserPost; + +import java.util.List; + +/** + * 用户与岗位关联表 数据层 + * + * @author win + */ +//@CacheNamespace +public interface SysUserPostMapper extends BaseMapper<SysUserPost> { + /** + * 通过用户ID删除用户和岗位关联 + * + * @param userId 用户ID + * @return 结果 + */ + public int deleteUserPostByUserId(Long userId); + + /** + * 通过岗位ID查询岗位使用数量 + * + * @param postId 岗位ID + * @return 结果 + */ + public int countUserPostById(Long postId); + + /** + * 批量删除用户和岗位关联 + * + * @param ids 需要删除的数据ID + * @return 结果 + */ + public int deleteUserPost(Long[] ids); + + /** + * 批量新增用户岗位信息 + * + * @param userPostList 用户角色列表 + * @return 结果 + */ + public int batchUserPost(List<SysUserPost> userPostList); +} diff --git a/dc-system/src/main/java/com/dc/system/mapper/SysUserRoleMapper.java b/dc-system/src/main/java/com/dc/system/mapper/SysUserRoleMapper.java new file mode 100644 index 0000000..3734f74 --- /dev/null +++ b/dc-system/src/main/java/com/dc/system/mapper/SysUserRoleMapper.java @@ -0,0 +1,66 @@ +package com.dc.system.mapper; + +import com.baomidou.mybatisplus.annotation.TableName; +import com.baomidou.mybatisplus.core.mapper.BaseMapper; +import com.dc.system.domain.SysUserRole; +import org.apache.ibatis.annotations.Param; + +import java.util.List; + +/** + * 用户与角色关联表 数据层 + * + * @author win + */ +//@CacheNamespace +@TableName("lottery_city") +public interface SysUserRoleMapper extends BaseMapper<SysUserRole> { + /** + * 通过用户ID删除用户和角色关联 + * + * @param userId 用户ID + * @return 结果 + */ + public int deleteUserRoleByUserId(Long userId); + + /** + * 批量删除用户和角色关联 + * + * @param ids 需要删除的数据ID + * @return 结果 + */ + public int deleteUserRole(Long[] ids); + + /** + * 通过角色ID查询角色使用数量 + * + * @param roleId 角色ID + * @return 结果 + */ + public int countUserRoleByRoleId(Long roleId); + + /** + * 批量新增用户角色信息 + * + * @param userRoleList 用户角色列表 + * @return 结果 + */ + public int batchUserRole(List<SysUserRole> userRoleList); + + /** + * 删除用户和角色关联信息 + * + * @param userRole 用户和角色关联信息 + * @return 结果 + */ + public int deleteUserRoleInfo(SysUserRole userRole); + + /** + * 批量取消授权用户角色 + * + * @param roleId 角色ID + * @param userIds 需要删除的用户数据ID + * @return 结果 + */ + public int deleteUserRoleInfos(@Param("roleId") Long roleId, @Param("userIds") Long[] userIds); +} diff --git a/dc-system/src/main/java/com/dc/system/service/AccessoryService.java b/dc-system/src/main/java/com/dc/system/service/AccessoryService.java new file mode 100644 index 0000000..cf6b3e5 --- /dev/null +++ b/dc-system/src/main/java/com/dc/system/service/AccessoryService.java @@ -0,0 +1,41 @@ +package com.dc.system.service; + +import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; +import com.baomidou.mybatisplus.extension.service.IService; +import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; +import com.dc.system.domain.Accessory; +import com.dc.system.mapper.AccessoryMapper; +import lombok.extern.slf4j.Slf4j; +import org.springframework.stereotype.Service; + +import java.util.List; + +/** + * 附件Service业务层处理 + * + * @author win + * @date 2023-04-10 + */ +@Slf4j +@Service +public class AccessoryService extends ServiceImpl<AccessoryMapper, Accessory> implements IService<Accessory> { + + public List<Accessory> getAccessoryListByType(String objectNo, Integer type) { + QueryWrapper<Accessory> queryWrapper = new QueryWrapper<>(); + queryWrapper.isNull("delete_time"); + queryWrapper.eq("object_no", objectNo); + queryWrapper.eq("type", type); + List<Accessory> list = baseMapper.selectList(queryWrapper); + return list; + } + + public Accessory getAccessoryByType(String objectNo, Integer type) { + QueryWrapper<Accessory> queryWrapper = new QueryWrapper<>(); + queryWrapper.isNull("delete_time"); + queryWrapper.eq("object_no", objectNo); + queryWrapper.eq("type", type); + Accessory accessory = baseMapper.selectOne(queryWrapper); + return accessory; + } + +} \ No newline at end of file diff --git a/dc-system/src/main/java/com/dc/system/service/SysCityService.java b/dc-system/src/main/java/com/dc/system/service/SysCityService.java new file mode 100644 index 0000000..3e0cc23 --- /dev/null +++ b/dc-system/src/main/java/com/dc/system/service/SysCityService.java @@ -0,0 +1,18 @@ +package com.dc.system.service; + +import com.baomidou.mybatisplus.extension.service.IService; +import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; +import com.dc.system.domain.SysCity; +import com.dc.system.mapper.SysCityMapper; +import lombok.extern.slf4j.Slf4j; + +/** + * 省市区Service业务层处理 + * + * @author win + * @date 2023-03-14 + */ +@Slf4j +public class SysCityService extends ServiceImpl<SysCityMapper, SysCity> implements IService<SysCity> { + +} \ No newline at end of file diff --git a/dc-system/src/main/java/com/dc/system/service/SysConfigService.java b/dc-system/src/main/java/com/dc/system/service/SysConfigService.java new file mode 100644 index 0000000..690c5ba --- /dev/null +++ b/dc-system/src/main/java/com/dc/system/service/SysConfigService.java @@ -0,0 +1,219 @@ +package com.dc.system.service; + +import com.baomidou.mybatisplus.extension.service.IService; +import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; +import com.dc.common.core.redis.RedisCache; +import com.dc.common.core.text.Convert; +import com.dc.common.utils.StringUtils; +import com.dc.system.domain.SysConfig; +import com.dc.system.mapper.SysConfigMapper; +import com.dc.common.constant.CacheConstants; +import com.dc.common.constant.UserConstants; +import com.dc.common.exception.ServiceException; +import lombok.extern.slf4j.Slf4j; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.stereotype.Service; + +import javax.annotation.PostConstruct; +import java.util.Collection; +import java.util.List; + +/** + * 参数配置 服务层实现 + * + * @author win + */ +@Slf4j +@Service +public class SysConfigService extends ServiceImpl<SysConfigMapper, SysConfig> implements IService<SysConfig> +{ + @Autowired + private RedisCache redisCache; + + /** + * 项目启动时,初始化参数到缓存 + */ + @PostConstruct + public void init() + { + loadingConfigCache(); + } + + /** + * 查询参数配置信息 + * + * @param configId 参数配置ID + * @return 参数配置信息 + */ + public SysConfig selectConfigById(Long configId) + { + SysConfig config = new SysConfig(); + config.setConfigId(configId); + return baseMapper.selectConfig(config); + } + + /** + * 根据键名查询参数配置信息 + * + * @param configKey 参数key + * @return 参数键值 + */ + public String selectConfigByKey(String configKey) + { + String configValue = Convert.toStr(redisCache.getCacheObject(getCacheKey(configKey))); + if (StringUtils.isNotEmpty(configValue)) + { + return configValue; + } + SysConfig config = new SysConfig(); + config.setConfigKey(configKey); + SysConfig retConfig = baseMapper.selectConfig(config); + if (StringUtils.isNotNull(retConfig)) + { + redisCache.setCacheObject(getCacheKey(configKey), retConfig.getConfigValue()); + return retConfig.getConfigValue(); + } + return StringUtils.EMPTY; + } + + /** + * 获取验证码开关 + * + * @return true开启,false关闭 + */ + public boolean selectCaptchaEnabled() + { + String captchaEnabled = selectConfigByKey("sys.account.captchaEnabled"); + if (StringUtils.isEmpty(captchaEnabled)) + { + return true; + } + return Convert.toBool(captchaEnabled); + } + + /** + * 查询参数配置列表 + * + * @param config 参数配置信息 + * @return 参数配置集合 + */ + public List<SysConfig> selectConfigList(SysConfig config) + { + return baseMapper.selectConfigList(config); + } + + /** + * 新增参数配置 + * + * @param config 参数配置信息 + * @return 结果 + */ + public int insertConfig(SysConfig config) + { + int row = baseMapper.insertConfig(config); + if (row > 0) + { + redisCache.setCacheObject(getCacheKey(config.getConfigKey()), config.getConfigValue()); + } + return row; + } + + /** + * 修改参数配置 + * + * @param config 参数配置信息 + * @return 结果 + */ + public int updateConfig(SysConfig config) + { + SysConfig temp = baseMapper.selectConfigById(config.getConfigId()); + if (!StringUtils.equals(temp.getConfigKey(), config.getConfigKey())) + { + redisCache.deleteObject(getCacheKey(temp.getConfigKey())); + } + + int row = baseMapper.updateConfig(config); + if (row > 0) + { + redisCache.setCacheObject(getCacheKey(config.getConfigKey()), config.getConfigValue()); + } + return row; + } + + /** + * 批量删除参数信息 + * + * @param configIds 需要删除的参数ID + */ + public void deleteConfigByIds(Long[] configIds) + { + for (Long configId : configIds) + { + SysConfig config = selectConfigById(configId); + if (StringUtils.equals(UserConstants.YES, config.getConfigType())) + { + throw new ServiceException(String.format("内置参数【%1$s】不能删除 ", config.getConfigKey())); + } + baseMapper.deleteConfigById(configId); + redisCache.deleteObject(getCacheKey(config.getConfigKey())); + } + } + + /** + * 加载参数缓存数据 + */ + public void loadingConfigCache() + { + List<SysConfig> configsList = baseMapper.selectConfigList(new SysConfig()); + for (SysConfig config : configsList) + { + redisCache.setCacheObject(getCacheKey(config.getConfigKey()), config.getConfigValue()); + } + } + + /** + * 清空参数缓存数据 + */ + public void clearConfigCache() + { + Collection<String> keys = redisCache.keys(CacheConstants.SYS_CONFIG_KEY + "*"); + redisCache.deleteObject(keys); + } + + /** + * 重置参数缓存数据 + */ + public void resetConfigCache() + { + clearConfigCache(); + loadingConfigCache(); + } + + /** + * 校验参数键名是否唯一 + * + * @param config 参数配置信息 + * @return 结果 + */ + public String checkConfigKeyUnique(SysConfig config) + { + Long configId = StringUtils.isNull(config.getConfigId()) ? -1L : config.getConfigId(); + SysConfig info = baseMapper.checkConfigKeyUnique(config.getConfigKey()); + if (StringUtils.isNotNull(info) && info.getConfigId().longValue() != configId.longValue()) + { + return UserConstants.NOT_UNIQUE; + } + return UserConstants.UNIQUE; + } + + /** + * 设置cache key + * + * @param configKey 参数键 + * @return 缓存键key + */ + private String getCacheKey(String configKey) + { + return CacheConstants.SYS_CONFIG_KEY + configKey; + } +} diff --git a/dc-system/src/main/java/com/dc/system/service/SysDeptService.java b/dc-system/src/main/java/com/dc/system/service/SysDeptService.java new file mode 100644 index 0000000..5babe2f --- /dev/null +++ b/dc-system/src/main/java/com/dc/system/service/SysDeptService.java @@ -0,0 +1,325 @@ +package com.dc.system.service; + +import com.baomidou.mybatisplus.extension.service.IService; +import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; +import com.dc.common.annotation.DataScope; +import com.dc.common.constant.UserConstants; +import com.dc.common.core.domain.TreeSelect; +import com.dc.common.core.domain.entity.SysRole; +import com.dc.common.core.domain.entity.SysUser; +import com.dc.common.core.text.Convert; +import com.dc.common.exception.ServiceException; +import com.dc.common.utils.SecurityUtils; +import com.dc.common.utils.StringUtils; +import com.dc.common.utils.spring.SpringUtils; +import com.dc.system.mapper.SysDeptMapper; +import com.dc.system.mapper.SysRoleMapper; +import com.dc.common.core.domain.entity.SysDept; +import lombok.extern.slf4j.Slf4j; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.stereotype.Service; + +import java.util.ArrayList; +import java.util.Iterator; +import java.util.List; +import java.util.stream.Collectors; + +/** + * 部门管理 服务实现 + * + * @author win + */ +@Slf4j +@Service +public class SysDeptService extends ServiceImpl<SysDeptMapper, SysDept> implements IService<SysDept> +{ + @Autowired + private SysRoleMapper roleMapper; + + /** + * 查询部门管理数据 + * + * @param dept 部门信息 + * @return 部门信息集合 + */ + @DataScope(deptAlias = "d") + public List<SysDept> selectDeptList(SysDept dept) + { + return baseMapper.selectDeptList(dept); + } + + /** + * 查询部门树结构信息 + * + * @param dept 部门信息 + * @return 部门树信息集合 + */ + public List<TreeSelect> selectDeptTreeList(SysDept dept) + { + List<SysDept> depts = SpringUtils.getAopProxy(this).selectDeptList(dept); + return buildDeptTreeSelect(depts); + } + + /** + * 构建前端所需要树结构 + * + * @param depts 部门列表 + * @return 树结构列表 + */ + public List<SysDept> buildDeptTree(List<SysDept> depts) + { + List<SysDept> returnList = new ArrayList<SysDept>(); + List<Long> tempList = depts.stream().map(SysDept::getDeptId).collect(Collectors.toList()); + for (SysDept dept : depts) + { + // 如果是顶级节点, 遍历该父节点的所有子节点 + if (!tempList.contains(dept.getParentId())) + { + recursionFn(depts, dept); + returnList.add(dept); + } + } + if (returnList.isEmpty()) + { + returnList = depts; + } + return returnList; + } + + /** + * 构建前端所需要下拉树结构 + * + * @param depts 部门列表 + * @return 下拉树结构列表 + */ + public List<TreeSelect> buildDeptTreeSelect(List<SysDept> depts) + { + List<SysDept> deptTrees = buildDeptTree(depts); + return deptTrees.stream().map(TreeSelect::new).collect(Collectors.toList()); + } + + /** + * 根据角色ID查询部门树信息 + * + * @param roleId 角色ID + * @return 选中部门列表 + */ + public List<Long> selectDeptListByRoleId(Long roleId) + { + SysRole role = roleMapper.selectRoleById(roleId); + return baseMapper.selectDeptListByRoleId(roleId, role.isDeptCheckStrictly()); + } + + /** + * 根据部门ID查询信息 + * + * @param deptId 部门ID + * @return 部门信息 + */ + public SysDept selectDeptById(Long deptId) + { + return baseMapper.selectDeptById(deptId); + } + + /** + * 根据ID查询所有子部门(正常状态) + * + * @param deptId 部门ID + * @return 子部门数 + */ + public int selectNormalChildrenDeptById(Long deptId) + { + return baseMapper.selectNormalChildrenDeptById(deptId); + } + + /** + * 是否存在子节点 + * + * @param deptId 部门ID + * @return 结果 + */ + public boolean hasChildByDeptId(Long deptId) + { + int result = baseMapper.hasChildByDeptId(deptId); + return result > 0; + } + + /** + * 查询部门是否存在用户 + * + * @param deptId 部门ID + * @return 结果 true 存在 false 不存在 + */ + public boolean checkDeptExistUser(Long deptId) + { + int result = baseMapper.checkDeptExistUser(deptId); + return result > 0; + } + + /** + * 校验部门名称是否唯一 + * + * @param dept 部门信息 + * @return 结果 + */ + public String checkDeptNameUnique(SysDept dept) + { + Long deptId = StringUtils.isNull(dept.getDeptId()) ? -1L : dept.getDeptId(); + SysDept info = baseMapper.checkDeptNameUnique(dept.getDeptName(), dept.getParentId()); + if (StringUtils.isNotNull(info) && info.getDeptId().longValue() != deptId.longValue()) + { + return UserConstants.NOT_UNIQUE; + } + return UserConstants.UNIQUE; + } + + /** + * 校验部门是否有数据权限 + * + * @param deptId 部门id + */ + public void checkDeptDataScope(Long deptId) + { + if (!SysUser.isAdmin(SecurityUtils.getUserId())) + { + SysDept dept = new SysDept(); + dept.setDeptId(deptId); + List<SysDept> depts = SpringUtils.getAopProxy(this).selectDeptList(dept); + if (StringUtils.isEmpty(depts)) + { + throw new ServiceException("没有权限访问部门数据!"); + } + } + } + + /** + * 新增保存部门信息 + * + * @param dept 部门信息 + * @return 结果 + */ + public int insertDept(SysDept dept) + { + SysDept info = baseMapper.selectDeptById(dept.getParentId()); + // 如果父节点不为正常状态,则不允许新增子节点 + if (!UserConstants.DEPT_NORMAL.equals(info.getStatus())) + { + throw new ServiceException("部门停用,不允许新增"); + } + dept.setAncestors(info.getAncestors() + "," + dept.getParentId()); + return baseMapper.insertDept(dept); + } + + /** + * 修改保存部门信息 + * + * @param dept 部门信息 + * @return 结果 + */ + public int updateDept(SysDept dept) + { + SysDept newParentDept = baseMapper.selectDeptById(dept.getParentId()); + SysDept oldDept = baseMapper.selectDeptById(dept.getDeptId()); + if (StringUtils.isNotNull(newParentDept) && StringUtils.isNotNull(oldDept)) + { + String newAncestors = newParentDept.getAncestors() + "," + newParentDept.getDeptId(); + String oldAncestors = oldDept.getAncestors(); + dept.setAncestors(newAncestors); + updateDeptChildren(dept.getDeptId(), newAncestors, oldAncestors); + } + int result = baseMapper.updateDept(dept); + if (UserConstants.DEPT_NORMAL.equals(dept.getStatus()) && StringUtils.isNotEmpty(dept.getAncestors()) + && !StringUtils.equals("0", dept.getAncestors())) + { + // 如果该部门是启用状态,则启用该部门的所有上级部门 + updateParentDeptStatusNormal(dept); + } + return result; + } + + /** + * 修改该部门的父级部门状态 + * + * @param dept 当前部门 + */ + private void updateParentDeptStatusNormal(SysDept dept) + { + String ancestors = dept.getAncestors(); + Long[] deptIds = Convert.toLongArray(ancestors); + baseMapper.updateDeptStatusNormal(deptIds); + } + + /** + * 修改子元素关系 + * + * @param deptId 被修改的部门ID + * @param newAncestors 新的父ID集合 + * @param oldAncestors 旧的父ID集合 + */ + public void updateDeptChildren(Long deptId, String newAncestors, String oldAncestors) + { + List<SysDept> children = baseMapper.selectChildrenDeptById(deptId); + for (SysDept child : children) + { + child.setAncestors(child.getAncestors().replaceFirst(oldAncestors, newAncestors)); + } + if (children.size() > 0) + { + baseMapper.updateDeptChildren(children); + } + } + + /** + * 删除部门管理信息 + * + * @param deptId 部门ID + * @return 结果 + */ + public int deleteDeptById(Long deptId) + { + return baseMapper.deleteDeptById(deptId); + } + + /** + * 递归列表 + */ + private void recursionFn(List<SysDept> list, SysDept t) + { + // 得到子节点列表 + List<SysDept> childList = getChildList(list, t); + t.setChildren(childList); + for (SysDept tChild : childList) + { + if (hasChild(list, tChild)) + { + recursionFn(list, tChild); + } + } + } + + /** + * 得到子节点列表 + */ + private List<SysDept> getChildList(List<SysDept> list, SysDept t) + { + List<SysDept> tlist = new ArrayList<SysDept>(); + Iterator<SysDept> it = list.iterator(); + while (it.hasNext()) + { + SysDept n = (SysDept) it.next(); + if (StringUtils.isNotNull(n.getParentId()) && n.getParentId().longValue() == t.getDeptId().longValue()) + { + tlist.add(n); + } + } + return tlist; + } + + /** + * 判断是否有子节点 + */ + private boolean hasChild(List<SysDept> list, SysDept t) + { + return getChildList(list, t).size() > 0; + } +} diff --git a/dc-system/src/main/java/com/dc/system/service/SysDictDataService.java b/dc-system/src/main/java/com/dc/system/service/SysDictDataService.java new file mode 100644 index 0000000..d79071a --- /dev/null +++ b/dc-system/src/main/java/com/dc/system/service/SysDictDataService.java @@ -0,0 +1,105 @@ +package com.dc.system.service; + +import com.baomidou.mybatisplus.extension.service.IService; +import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; +import com.dc.common.core.domain.entity.SysDictData; +import com.dc.system.mapper.SysDictDataMapper; +import com.dc.common.utils.DictUtils; +import lombok.extern.slf4j.Slf4j; +import org.springframework.stereotype.Service; + +import java.util.List; + +/** + * 字典 业务层处理 + * + * @author win + */ +@Slf4j +@Service +public class SysDictDataService extends ServiceImpl<SysDictDataMapper, SysDictData> implements IService<SysDictData> +{ + /** + * 根据条件分页查询字典数据 + * + * @param dictData 字典数据信息 + * @return 字典数据集合信息 + */ + public List<SysDictData> selectDictDataList(SysDictData dictData) + { + return baseMapper.selectDictDataList(dictData); + } + + /** + * 根据字典类型和字典键值查询字典数据信息 + * + * @param dictType 字典类型 + * @param dictValue 字典键值 + * @return 字典标签 + */ + public String selectDictLabel(String dictType, String dictValue) + { + return baseMapper.selectDictLabel(dictType, dictValue); + } + + /** + * 根据字典数据ID查询信息 + * + * @param dictCode 字典数据ID + * @return 字典数据 + */ + public SysDictData selectDictDataById(Long dictCode) + { + return baseMapper.selectDictDataById(dictCode); + } + + /** + * 批量删除字典数据信息 + * + * @param dictCodes 需要删除的字典数据ID + */ + public void deleteDictDataByIds(Long[] dictCodes) + { + for (Long dictCode : dictCodes) + { + SysDictData data = selectDictDataById(dictCode); + baseMapper.deleteDictDataById(dictCode); + List<SysDictData> dictDatas = baseMapper.selectDictDataByType(data.getDictType()); + DictUtils.setDictCache(data.getDictType(), dictDatas); + } + } + + /** + * 新增保存字典数据信息 + * + * @param data 字典数据信息 + * @return 结果 + */ + public int insertDictData(SysDictData data) + { + int row = baseMapper.insertDictData(data); + if (row > 0) + { + List<SysDictData> dictDatas = baseMapper.selectDictDataByType(data.getDictType()); + DictUtils.setDictCache(data.getDictType(), dictDatas); + } + return row; + } + + /** + * 修改保存字典数据信息 + * + * @param data 字典数据信息 + * @return 结果 + */ + public int updateDictData(SysDictData data) + { + int row = baseMapper.updateDictData(data); + if (row > 0) + { + List<SysDictData> dictDatas = baseMapper.selectDictDataByType(data.getDictType()); + DictUtils.setDictCache(data.getDictType(), dictDatas); + } + return row; + } +} diff --git a/dc-system/src/main/java/com/dc/system/service/SysDictTypeService.java b/dc-system/src/main/java/com/dc/system/service/SysDictTypeService.java new file mode 100644 index 0000000..84828cb --- /dev/null +++ b/dc-system/src/main/java/com/dc/system/service/SysDictTypeService.java @@ -0,0 +1,202 @@ +package com.dc.system.service; + +import com.baomidou.mybatisplus.extension.service.IService; +import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; +import com.dc.common.core.domain.entity.SysDictData; +import com.dc.common.core.domain.entity.SysDictType; +import com.dc.common.utils.DictUtils; +import com.dc.common.utils.StringUtils; +import com.dc.system.mapper.SysDictDataMapper; +import com.dc.system.mapper.SysDictTypeMapper; +import com.dc.common.constant.UserConstants; +import com.dc.common.exception.ServiceException; +import lombok.extern.slf4j.Slf4j; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.stereotype.Service; +import org.springframework.transaction.annotation.Transactional; + +import java.util.Comparator; +import java.util.List; +import java.util.Map; +import java.util.stream.Collectors; + +/** + * 字典 业务层处理 + * + * @author win + */ +@Slf4j +@Service +public class SysDictTypeService extends ServiceImpl<SysDictTypeMapper, SysDictType> implements IService<SysDictType> +{ + @Autowired + private SysDictDataMapper dictDataMapper; + + /** + * 根据条件分页查询字典类型 + * + * @param dictType 字典类型信息 + * @return 字典类型集合信息 + */ + public List<SysDictType> selectDictTypeList(SysDictType dictType) + { + return baseMapper.selectDictTypeList(dictType); + } + + /** + * 根据所有字典类型 + * + * @return 字典类型集合信息 + */ + public List<SysDictType> selectDictTypeAll() + { + return baseMapper.selectDictTypeAll(); + } + + /** + * 根据字典类型查询字典数据 + * + * @param dictType 字典类型 + * @return 字典数据集合信息 + */ + public List<SysDictData> selectDictDataByType(String dictType) + { + List<SysDictData> dictDatas = DictUtils.getDictCache(dictType); + if (StringUtils.isNotEmpty(dictDatas)) + { + return dictDatas; + } + dictDatas = dictDataMapper.selectDictDataByType(dictType); + if (StringUtils.isNotEmpty(dictDatas)) + { + DictUtils.setDictCache(dictType, dictDatas); + return dictDatas; + } + return null; + } + + /** + * 根据字典类型ID查询信息 + * + * @param dictId 字典类型ID + * @return 字典类型 + */ + public SysDictType selectDictTypeById(Long dictId) + { + return baseMapper.selectDictTypeById(dictId); + } + + /** + * 根据字典类型查询信息 + * + * @param dictType 字典类型 + * @return 字典类型 + */ + public SysDictType selectDictTypeByType(String dictType) + { + return baseMapper.selectDictTypeByType(dictType); + } + + /** + * 批量删除字典类型信息 + * + * @param dictIds 需要删除的字典ID + */ + public void deleteDictTypeByIds(Long[] dictIds) + { + for (Long dictId : dictIds) + { + SysDictType dictType = selectDictTypeById(dictId); + if (dictDataMapper.countDictDataByType(dictType.getDictType()) > 0) + { + throw new ServiceException(String.format("%1$s已分配,不能删除", dictType.getDictName())); + } + baseMapper.deleteDictTypeById(dictId); + DictUtils.removeDictCache(dictType.getDictType()); + } + } + + /** + * 加载字典缓存数据 + */ + public void loadingDictCache() + { + SysDictData dictData = new SysDictData(); + dictData.setStatus("0"); + Map<String, List<SysDictData>> dictDataMap = dictDataMapper.selectDictDataList(dictData).stream().collect(Collectors.groupingBy(SysDictData::getDictType)); + for (Map.Entry<String, List<SysDictData>> entry : dictDataMap.entrySet()) + { + DictUtils.setDictCache(entry.getKey(), entry.getValue().stream().sorted(Comparator.comparing(SysDictData::getDictSort)).collect(Collectors.toList())); + } + } + + /** + * 清空字典缓存数据 + */ + public void clearDictCache() + { + DictUtils.clearDictCache(); + } + + /** + * 重置字典缓存数据 + */ + public void resetDictCache() + { + clearDictCache(); + loadingDictCache(); + } + + /** + * 新增保存字典类型信息 + * + * @param dict 字典类型信息 + * @return 结果 + */ + public int insertDictType(SysDictType dict) + { + int row = baseMapper.insertDictType(dict); + if (row > 0) + { + DictUtils.setDictCache(dict.getDictType(), null); + } + return row; + } + + /** + * 修改保存字典类型信息 + * + * @param dict 字典类型信息 + * @return 结果 + */ + @Transactional + public int updateDictType(SysDictType dict) + { + SysDictType oldDict = baseMapper.selectDictTypeById(dict.getDictId()); + dictDataMapper.updateDictDataType(oldDict.getDictType(), dict.getDictType()); + int row = baseMapper.updateDictType(dict); + if (row > 0) + { + List<SysDictData> dictDatas = dictDataMapper.selectDictDataByType(dict.getDictType()); + DictUtils.setDictCache(dict.getDictType(), dictDatas); + } + return row; + } + + /** + * 校验字典类型称是否唯一 + * + * @param dict 字典类型 + * @return 结果 + */ + public String checkDictTypeUnique(SysDictType dict) + { + Long dictId = StringUtils.isNull(dict.getDictId()) ? -1L : dict.getDictId(); + SysDictType dictType = baseMapper.checkDictTypeUnique(dict.getDictType()); + if (StringUtils.isNotNull(dictType) && dictType.getDictId().longValue() != dictId.longValue()) + { + return UserConstants.NOT_UNIQUE; + } + return UserConstants.UNIQUE; + } +} diff --git a/dc-system/src/main/java/com/dc/system/service/SysLogininforService.java b/dc-system/src/main/java/com/dc/system/service/SysLogininforService.java new file mode 100644 index 0000000..83f9d3d --- /dev/null +++ b/dc-system/src/main/java/com/dc/system/service/SysLogininforService.java @@ -0,0 +1,61 @@ +package com.dc.system.service; + +import com.baomidou.mybatisplus.extension.service.IService; +import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; +import com.dc.system.domain.SysLogininfor; +import com.dc.system.mapper.SysLogininforMapper; +import lombok.extern.slf4j.Slf4j; +import org.springframework.stereotype.Service; + +import java.util.List; + +/** + * 系统访问日志情况信息 服务层处理 + * + * @author win + */ +@Slf4j +@Service +public class SysLogininforService extends ServiceImpl<SysLogininforMapper, SysLogininfor> implements IService<SysLogininfor> +{ + + /** + * 新增系统登录日志 + * + * @param logininfor 访问日志对象 + */ + public void insertLogininfor(SysLogininfor logininfor) + { + baseMapper.insertLogininfor(logininfor); + } + + /** + * 查询系统登录日志集合 + * + * @param logininfor 访问日志对象 + * @return 登录记录集合 + */ + public List<SysLogininfor> selectLogininforList(SysLogininfor logininfor) + { + return baseMapper.selectLogininforList(logininfor); + } + + /** + * 批量删除系统登录日志 + * + * @param infoIds 需要删除的登录日志ID + * @return 结果 + */ + public int deleteLogininforByIds(Long[] infoIds) + { + return baseMapper.deleteLogininforByIds(infoIds); + } + + /** + * 清空系统登录日志 + */ + public void cleanLogininfor() + { + baseMapper.cleanLogininfor(); + } +} diff --git a/dc-system/src/main/java/com/dc/system/service/SysMenuService.java b/dc-system/src/main/java/com/dc/system/service/SysMenuService.java new file mode 100644 index 0000000..4912387 --- /dev/null +++ b/dc-system/src/main/java/com/dc/system/service/SysMenuService.java @@ -0,0 +1,458 @@ +package com.dc.system.service; + +import com.baomidou.mybatisplus.extension.service.IService; +import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; +import com.dc.common.constant.Constants; +import com.dc.common.constant.UserConstants; +import com.dc.common.core.domain.TreeSelect; +import com.dc.common.core.domain.entity.SysMenu; +import com.dc.common.core.domain.entity.SysRole; +import com.dc.common.core.domain.entity.SysUser; +import com.dc.common.utils.SecurityUtils; +import com.dc.common.utils.StringUtils; +import com.dc.system.domain.vo.MetaVo; +import com.dc.system.domain.vo.RouterVo; +import com.dc.system.mapper.SysMenuMapper; +import com.dc.system.mapper.SysRoleMapper; +import com.dc.system.mapper.SysRoleMenuMapper; +import lombok.extern.slf4j.Slf4j; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.stereotype.Service; + +import java.util.*; +import java.util.stream.Collectors; + +/** + * 菜单 业务层处理 + * + * @author win + */ +@Slf4j +@Service +public class SysMenuService extends ServiceImpl<SysMenuMapper, SysMenu> implements IService<SysMenu> { + public static final String PREMISSION_STRING = "perms[\"{0}\"]"; + + @Autowired + private SysRoleMapper roleMapper; + + @Autowired + private SysRoleMenuMapper roleMenuMapper; + + /** + * 根据用户查询系统菜单列表 + * + * @param userId 用户ID + * @return 菜单列表 + */ + public List<SysMenu> selectMenuList(Long userId) { + return selectMenuList(new SysMenu(), userId); + } + + /** + * 查询系统菜单列表 + * + * @param menu 菜单信息 + * @return 菜单列表 + */ + public List<SysMenu> selectMenuList(SysMenu menu, Long userId) { + List<SysMenu> menuList = null; + // 管理员显示所有菜单信息 + if (SysUser.isAdmin(userId)) { + menuList = baseMapper.selectMenuList(menu); + } else { + menu.getParams().put("userId", userId); + menuList = baseMapper.selectMenuListByUserId(menu); + } + return menuList; + } + + /** + * 根据用户ID查询权限 + * + * @param userId 用户ID + * @return 权限列表 + */ + public Set<String> selectMenuPermsByUserId(Long userId) { + List<String> perms = baseMapper.selectMenuPermsByUserId(userId); + Set<String> permsSet = new HashSet<>(); + for (String perm : perms) { + if (StringUtils.isNotEmpty(perm)) { + permsSet.addAll(Arrays.asList(perm.trim().split(","))); + } + } + return permsSet; + } + + /** + * 根据角色ID查询权限 + * + * @param roleId 角色ID + * @return 权限列表 + */ + public Set<String> selectMenuPermsByRoleId(Long roleId) { + List<String> perms = baseMapper.selectMenuPermsByRoleId(roleId); + Set<String> permsSet = new HashSet<>(); + for (String perm : perms) { + if (StringUtils.isNotEmpty(perm)) { + permsSet.addAll(Arrays.asList(perm.trim().split(","))); + } + } + return permsSet; + } + + /** + * 根据用户ID查询菜单 + * + * @param userId 用户名称 + * @return 菜单列表 + */ + public List<SysMenu> selectMenuTreeByUserId(Long userId) { + List<SysMenu> menus = null; + if (SecurityUtils.isAdmin(userId)) { + menus = baseMapper.selectMenuTreeAll(); + } else { + menus = baseMapper.selectMenuTreeByUserId(userId); + } + return getChildPerms(menus, 0); + } + + /** + * 根据角色ID查询菜单树信息 + * + * @param roleId 角色ID + * @return 选中菜单列表 + */ + public List<Long> selectMenuListByRoleId(Long roleId) { + SysRole role = roleMapper.selectRoleById(roleId); + return baseMapper.selectMenuListByRoleId(roleId, role.isMenuCheckStrictly()); + } + + /** + * 根据角色ID查询菜单树信息 + * + * @param roleId 角色ID + * @return 选中菜单列表 + */ + public List<SysMenu> selectMenuList1ByRoleId(Long roleId) { + SysRole role = roleMapper.selectRoleById(roleId); + return baseMapper.selectMenuList1ByRoleId(roleId, role.isMenuCheckStrictly()); + } + + /** + * 构建前端路由所需要的菜单 + * + * @param menus 菜单列表 + * @return 路由列表 + */ + public List<RouterVo> buildMenus(List<SysMenu> menus) { + List<RouterVo> routers = new LinkedList<RouterVo>(); + for (SysMenu menu : menus) { + RouterVo router = new RouterVo(); + router.setHidden("1".equals(menu.getVisible())); + router.setName(getRouteName(menu)); + router.setPath(getRouterPath(menu)); + router.setComponent(getComponent(menu)); + router.setQuery(menu.getQuery()); + router.setMeta(new MetaVo(menu.getMenuName(), menu.getIcon(), StringUtils.equals("1", menu.getIsCache()), menu.getPath())); + List<SysMenu> cMenus = menu.getChildren(); + if (!cMenus.isEmpty() && cMenus.size() > 0 && UserConstants.TYPE_DIR.equals(menu.getMenuType())) { + router.setAlwaysShow(true); + router.setRedirect("noRedirect"); + router.setChildren(buildMenus(cMenus)); + } else if (isMenuFrame(menu)) { + router.setMeta(null); + List<RouterVo> childrenList = new ArrayList<RouterVo>(); + RouterVo children = new RouterVo(); + children.setPath(menu.getPath()); + children.setComponent(menu.getComponent()); + children.setName(StringUtils.capitalize(menu.getPath())); + children.setMeta(new MetaVo(menu.getMenuName(), menu.getIcon(), StringUtils.equals("1", menu.getIsCache()), menu.getPath())); + children.setQuery(menu.getQuery()); + childrenList.add(children); + router.setChildren(childrenList); + } else if (menu.getParentId().intValue() == 0 && isInnerLink(menu)) { + router.setMeta(new MetaVo(menu.getMenuName(), menu.getIcon())); + router.setPath("/"); + List<RouterVo> childrenList = new ArrayList<RouterVo>(); + RouterVo children = new RouterVo(); + String routerPath = innerLinkReplaceEach(menu.getPath()); + children.setPath(routerPath); + children.setComponent(UserConstants.INNER_LINK); + children.setName(StringUtils.capitalize(routerPath)); + children.setMeta(new MetaVo(menu.getMenuName(), menu.getIcon(), menu.getPath())); + childrenList.add(children); + router.setChildren(childrenList); + } + routers.add(router); + } + return routers; + } + + /** + * 构建前端所需要树结构 + * + * @param menus 菜单列表 + * @return 树结构列表 + */ + public List<SysMenu> buildMenuTree(List<SysMenu> menus) { + List<SysMenu> returnList = new ArrayList<SysMenu>(); + List<Long> tempList = menus.stream().map(SysMenu::getMenuId).collect(Collectors.toList()); + for (Iterator<SysMenu> iterator = menus.iterator(); iterator.hasNext(); ) { + SysMenu menu = (SysMenu) iterator.next(); + // 如果是顶级节点, 遍历该父节点的所有子节点 + if (!tempList.contains(menu.getParentId())) { + recursionFn(menus, menu); + returnList.add(menu); + } + } + if (returnList.isEmpty()) { + returnList = menus; + } + return returnList; + } + + /** + * 构建前端所需要下拉树结构 + * + * @param menus 菜单列表 + * @return 下拉树结构列表 + */ + public List<TreeSelect> buildMenuTreeSelect(List<SysMenu> menus) { + List<SysMenu> menuTrees = buildMenuTree(menus); + return menuTrees.stream().map(TreeSelect::new).collect(Collectors.toList()); + } + + /** + * 根据菜单ID查询信息 + * + * @param menuId 菜单ID + * @return 菜单信息 + */ + public SysMenu selectMenuById(Long menuId) { + return baseMapper.selectMenuById(menuId); + } + + /** + * 是否存在菜单子节点 + * + * @param menuId 菜单ID + * @return 结果 + */ + public boolean hasChildByMenuId(Long menuId) { + int result = baseMapper.hasChildByMenuId(menuId); + return result > 0; + } + + /** + * 查询菜单使用数量 + * + * @param menuId 菜单ID + * @return 结果 + */ + public boolean checkMenuExistRole(Long menuId) { + int result = roleMenuMapper.checkMenuExistRole(menuId); + return result > 0; + } + + /** + * 新增保存菜单信息 + * + * @param menu 菜单信息 + * @return 结果 + */ + public int insertMenu(SysMenu menu) { + return baseMapper.insertMenu(menu); + } + + /** + * 修改保存菜单信息 + * + * @param menu 菜单信息 + * @return 结果 + */ + public int updateMenu(SysMenu menu) { + return baseMapper.updateMenu(menu); + } + + /** + * 删除菜单管理信息 + * + * @param menuId 菜单ID + * @return 结果 + */ + public int deleteMenuById(Long menuId) { + return baseMapper.deleteMenuById(menuId); + } + + /** + * 校验菜单名称是否唯一 + * + * @param menu 菜单信息 + * @return 结果 + */ + public String checkMenuNameUnique(SysMenu menu) { + Long menuId = StringUtils.isNull(menu.getMenuId()) ? -1L : menu.getMenuId(); + SysMenu info = baseMapper.checkMenuNameUnique(menu.getMenuName(), menu.getParentId()); + if (StringUtils.isNotNull(info) && info.getMenuId().longValue() != menuId.longValue()) { + return UserConstants.NOT_UNIQUE; + } + return UserConstants.UNIQUE; + } + + /** + * 获取路由名称 + * + * @param menu 菜单信息 + * @return 路由名称 + */ + public String getRouteName(SysMenu menu) { + String routerName = StringUtils.capitalize(menu.getPath()); + // 非外链并且是一级目录(类型为目录) + if (isMenuFrame(menu)) { + routerName = StringUtils.EMPTY; + } + return routerName; + } + + /** + * 获取路由地址 + * + * @param menu 菜单信息 + * @return 路由地址 + */ + public String getRouterPath(SysMenu menu) { + String routerPath = menu.getPath(); + // 内链打开外网方式 + if (menu.getParentId().intValue() != 0 && isInnerLink(menu)) { + routerPath = innerLinkReplaceEach(routerPath); + } + // 非外链并且是一级目录(类型为目录) + if (0 == menu.getParentId().intValue() && UserConstants.TYPE_DIR.equals(menu.getMenuType()) + && UserConstants.NO_FRAME.equals(menu.getIsFrame())) { + routerPath = "/" + menu.getPath(); + } + // 非外链并且是一级目录(类型为菜单) + else if (isMenuFrame(menu)) { + routerPath = "/"; + } + return routerPath; + } + + /** + * 获取组件信息 + * + * @param menu 菜单信息 + * @return 组件信息 + */ + public String getComponent(SysMenu menu) { + String component = UserConstants.LAYOUT; + if (StringUtils.isNotEmpty(menu.getComponent()) && !isMenuFrame(menu)) { + component = menu.getComponent(); + } else if (StringUtils.isEmpty(menu.getComponent()) && menu.getParentId().intValue() != 0 && isInnerLink(menu)) { + component = UserConstants.INNER_LINK; + } else if (StringUtils.isEmpty(menu.getComponent()) && isParentView(menu)) { + component = UserConstants.PARENT_VIEW; + } + return component; + } + + /** + * 是否为菜单内部跳转 + * + * @param menu 菜单信息 + * @return 结果 + */ + public boolean isMenuFrame(SysMenu menu) { + return menu.getParentId().intValue() == 0 && UserConstants.TYPE_MENU.equals(menu.getMenuType()) + && menu.getIsFrame().equals(UserConstants.NO_FRAME); + } + + /** + * 是否为内链组件 + * + * @param menu 菜单信息 + * @return 结果 + */ + public boolean isInnerLink(SysMenu menu) { + return menu.getIsFrame().equals(UserConstants.NO_FRAME) && StringUtils.ishttp(menu.getPath()); + } + + /** + * 是否为parent_view组件 + * + * @param menu 菜单信息 + * @return 结果 + */ + public boolean isParentView(SysMenu menu) { + return menu.getParentId().intValue() != 0 && UserConstants.TYPE_DIR.equals(menu.getMenuType()); + } + + /** + * 根据父节点的ID获取所有子节点 + * + * @param list 分类表 + * @param parentId 传入的父节点ID + * @return String + */ + public List<SysMenu> getChildPerms(List<SysMenu> list, int parentId) { + List<SysMenu> returnList = new ArrayList<SysMenu>(); + for (Iterator<SysMenu> iterator = list.iterator(); iterator.hasNext(); ) { + SysMenu t = (SysMenu) iterator.next(); + // 一、根据传入的某个父节点ID,遍历该父节点的所有子节点 + if (t.getParentId() == parentId) { + recursionFn(list, t); + returnList.add(t); + } + } + return returnList; + } + + /** + * 递归列表 + * + * @param list + * @param t + */ + private void recursionFn(List<SysMenu> list, SysMenu t) { + // 得到子节点列表 + List<SysMenu> childList = getChildList(list, t); + t.setChildren(childList); + for (SysMenu tChild : childList) { + if (hasChild(list, tChild)) { + recursionFn(list, tChild); + } + } + } + + /** + * 得到子节点列表 + */ + private List<SysMenu> getChildList(List<SysMenu> list, SysMenu t) { + List<SysMenu> tlist = new ArrayList<SysMenu>(); + Iterator<SysMenu> it = list.iterator(); + while (it.hasNext()) { + SysMenu n = (SysMenu) it.next(); + if (n.getParentId().longValue() == t.getMenuId().longValue()) { + tlist.add(n); + } + } + return tlist; + } + + /** + * 判断是否有子节点 + */ + private boolean hasChild(List<SysMenu> list, SysMenu t) { + return getChildList(list, t).size() > 0; + } + + /** + * 内链域名特殊字符替换 + * + * @return + */ + public String innerLinkReplaceEach(String path) { + return StringUtils.replaceEach(path, new String[]{Constants.HTTP, Constants.HTTPS, Constants.WWW, "."}, + new String[]{"", "", "", "/"}); + } +} diff --git a/dc-system/src/main/java/com/dc/system/service/SysNoticeService.java b/dc-system/src/main/java/com/dc/system/service/SysNoticeService.java new file mode 100644 index 0000000..8e2ce81 --- /dev/null +++ b/dc-system/src/main/java/com/dc/system/service/SysNoticeService.java @@ -0,0 +1,86 @@ +package com.dc.system.service; + +import com.baomidou.mybatisplus.extension.service.IService; +import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; +import com.dc.system.domain.SysNotice; +import com.dc.system.mapper.SysNoticeMapper; +import lombok.extern.slf4j.Slf4j; +import org.springframework.stereotype.Service; + +import java.util.List; + +/** + * 公告 服务层实现 + * + * @author win + */ +@Slf4j +@Service +public class SysNoticeService extends ServiceImpl<SysNoticeMapper, SysNotice> implements IService<SysNotice> +{ + /** + * 查询公告信息 + * + * @param noticeId 公告ID + * @return 公告信息 + */ + public SysNotice selectNoticeById(Long noticeId) + { + return baseMapper.selectNoticeById(noticeId); + } + + /** + * 查询公告列表 + * + * @param notice 公告信息 + * @return 公告集合 + */ + public List<SysNotice> selectNoticeList(SysNotice notice) + { + return baseMapper.selectNoticeList(notice); + } + + /** + * 新增公告 + * + * @param notice 公告信息 + * @return 结果 + */ + public int insertNotice(SysNotice notice) + { + return baseMapper.insertNotice(notice); + } + + /** + * 修改公告 + * + * @param notice 公告信息 + * @return 结果 + */ + public int updateNotice(SysNotice notice) + { + return baseMapper.updateNotice(notice); + } + + /** + * 删除公告对象 + * + * @param noticeId 公告ID + * @return 结果 + */ + public int deleteNoticeById(Long noticeId) + { + return baseMapper.deleteNoticeById(noticeId); + } + + /** + * 批量删除公告信息 + * + * @param noticeIds 需要删除的公告ID + * @return 结果 + */ + public int deleteNoticeByIds(Long[] noticeIds) + { + return baseMapper.deleteNoticeByIds(noticeIds); + } +} diff --git a/dc-system/src/main/java/com/dc/system/service/SysOperLogService.java b/dc-system/src/main/java/com/dc/system/service/SysOperLogService.java new file mode 100644 index 0000000..2f0ee94 --- /dev/null +++ b/dc-system/src/main/java/com/dc/system/service/SysOperLogService.java @@ -0,0 +1,71 @@ +package com.dc.system.service; + +import com.baomidou.mybatisplus.extension.service.IService; +import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; +import com.dc.system.domain.SysOperLog; +import com.dc.system.mapper.SysOperLogMapper; +import lombok.extern.slf4j.Slf4j; +import org.springframework.stereotype.Service; + +import java.util.List; + +/** + * 操作日志 服务层处理 + * + * @author win + */ +@Slf4j +@Service +public class SysOperLogService extends ServiceImpl<SysOperLogMapper, SysOperLog> implements IService<SysOperLog> +{ + /** + * 新增操作日志 + * + * @param operLog 操作日志对象 + */ + public void insertOperlog(SysOperLog operLog) + { + baseMapper.insertOperlog(operLog); + } + + /** + * 查询系统操作日志集合 + * + * @param operLog 操作日志对象 + * @return 操作日志集合 + */ + public List<SysOperLog> selectOperLogList(SysOperLog operLog) + { + return baseMapper.selectOperLogList(operLog); + } + + /** + * 批量删除系统操作日志 + * + * @param operIds 需要删除的操作日志ID + * @return 结果 + */ + public int deleteOperLogByIds(Long[] operIds) + { + return baseMapper.deleteOperLogByIds(operIds); + } + + /** + * 查询操作日志详细 + * + * @param operId 操作ID + * @return 操作日志对象 + */ + public SysOperLog selectOperLogById(Long operId) + { + return baseMapper.selectOperLogById(operId); + } + + /** + * 清空操作日志 + */ + public void cleanOperLog() + { + baseMapper.cleanOperLog(); + } +} diff --git a/dc-system/src/main/java/com/dc/system/service/SysPostService.java b/dc-system/src/main/java/com/dc/system/service/SysPostService.java new file mode 100644 index 0000000..d5da486 --- /dev/null +++ b/dc-system/src/main/java/com/dc/system/service/SysPostService.java @@ -0,0 +1,168 @@ +package com.dc.system.service; + +import com.baomidou.mybatisplus.extension.service.IService; +import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; +import com.dc.common.utils.StringUtils; +import com.dc.system.domain.SysPost; +import com.dc.system.mapper.SysPostMapper; +import com.dc.system.mapper.SysUserPostMapper; +import com.dc.common.constant.UserConstants; +import com.dc.common.exception.ServiceException; +import lombok.extern.slf4j.Slf4j; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.stereotype.Service; + +import java.util.List; + +/** + * 岗位信息 服务层处理 + * + * @author win + */ +@Slf4j +@Service +public class SysPostService extends ServiceImpl<SysPostMapper, SysPost> implements IService<SysPost> +{ + @Autowired + private SysUserPostMapper userPostMapper; + + /** + * 查询岗位信息集合 + * + * @param post 岗位信息 + * @return 岗位信息集合 + */ + public List<SysPost> selectPostList(SysPost post) + { + return baseMapper.selectPostList(post); + } + + /** + * 查询所有岗位 + * + * @return 岗位列表 + */ + public List<SysPost> selectPostAll() + { + return baseMapper.selectPostAll(); + } + + /** + * 通过岗位ID查询岗位信息 + * + * @param postId 岗位ID + * @return 角色对象信息 + */ + public SysPost selectPostById(Long postId) + { + return baseMapper.selectPostById(postId); + } + + /** + * 根据用户ID获取岗位选择框列表 + * + * @param userId 用户ID + * @return 选中岗位ID列表 + */ + public List<Long> selectPostListByUserId(Long userId) + { + return baseMapper.selectPostListByUserId(userId); + } + + /** + * 校验岗位名称是否唯一 + * + * @param post 岗位信息 + * @return 结果 + */ + public String checkPostNameUnique(SysPost post) + { + Long postId = StringUtils.isNull(post.getPostId()) ? -1L : post.getPostId(); + SysPost info = baseMapper.checkPostNameUnique(post.getPostName()); + if (StringUtils.isNotNull(info) && info.getPostId().longValue() != postId.longValue()) + { + return UserConstants.NOT_UNIQUE; + } + return UserConstants.UNIQUE; + } + + /** + * 校验岗位编码是否唯一 + * + * @param post 岗位信息 + * @return 结果 + */ + public String checkPostCodeUnique(SysPost post) + { + Long postId = StringUtils.isNull(post.getPostId()) ? -1L : post.getPostId(); + SysPost info = baseMapper.checkPostCodeUnique(post.getPostCode()); + if (StringUtils.isNotNull(info) && info.getPostId().longValue() != postId.longValue()) + { + return UserConstants.NOT_UNIQUE; + } + return UserConstants.UNIQUE; + } + + /** + * 通过岗位ID查询岗位使用数量 + * + * @param postId 岗位ID + * @return 结果 + */ + public int countUserPostById(Long postId) + { + return userPostMapper.countUserPostById(postId); + } + + /** + * 删除岗位信息 + * + * @param postId 岗位ID + * @return 结果 + */ + public int deletePostById(Long postId) + { + return baseMapper.deletePostById(postId); + } + + /** + * 批量删除岗位信息 + * + * @param postIds 需要删除的岗位ID + * @return 结果 + */ + public int deletePostByIds(Long[] postIds) + { + for (Long postId : postIds) + { + SysPost post = selectPostById(postId); + if (countUserPostById(postId) > 0) + { + throw new ServiceException(String.format("%1$s已分配,不能删除", post.getPostName())); + } + } + return baseMapper.deletePostByIds(postIds); + } + + /** + * 新增保存岗位信息 + * + * @param post 岗位信息 + * @return 结果 + */ + public int insertPost(SysPost post) + { + return baseMapper.insertPost(post); + } + + /** + * 修改保存岗位信息 + * + * @param post 岗位信息 + * @return 结果 + */ + public int updatePost(SysPost post) + { + return baseMapper.updatePost(post); + } +} diff --git a/dc-system/src/main/java/com/dc/system/service/SysRoleService.java b/dc-system/src/main/java/com/dc/system/service/SysRoleService.java new file mode 100644 index 0000000..db4cea8 --- /dev/null +++ b/dc-system/src/main/java/com/dc/system/service/SysRoleService.java @@ -0,0 +1,401 @@ +package com.dc.system.service; + +import com.baomidou.mybatisplus.extension.service.IService; +import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; +import com.dc.common.core.domain.entity.SysRole; +import com.dc.common.core.domain.entity.SysUser; +import com.dc.common.utils.SecurityUtils; +import com.dc.common.utils.StringUtils; +import com.dc.system.domain.SysRoleDept; +import com.dc.system.domain.SysRoleMenu; +import com.dc.system.domain.SysUserRole; +import com.dc.system.mapper.SysRoleDeptMapper; +import com.dc.system.mapper.SysRoleMapper; +import com.dc.system.mapper.SysRoleMenuMapper; +import com.dc.system.mapper.SysUserRoleMapper; +import com.dc.common.annotation.DataScope; +import com.dc.common.constant.UserConstants; +import com.dc.common.exception.ServiceException; +import com.dc.common.utils.spring.SpringUtils; +import lombok.extern.slf4j.Slf4j; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.stereotype.Service; +import org.springframework.transaction.annotation.Transactional; + +import java.util.*; + +/** + * 角色 业务层处理 + * + * @author win + */ +@Slf4j +@Service +public class SysRoleService extends ServiceImpl<SysRoleMapper, SysRole> implements IService<SysRole> +{ + @Autowired + private SysRoleMenuMapper roleMenuMapper; + + @Autowired + private SysUserRoleMapper userRoleMapper; + + @Autowired + private SysRoleDeptMapper roleDeptMapper; + + /** + * 根据条件分页查询角色数据 + * + * @param role 角色信息 + * @return 角色数据集合信息 + */ + @DataScope(deptAlias = "d") + public List<SysRole> selectRoleList(SysRole role) + { + return baseMapper.selectRoleList(role); + } + + /** + * 根据用户ID查询角色 + * + * @param userId 用户ID + * @return 角色列表 + */ + public List<SysRole> selectRolesByUserId(Long userId) + { + List<SysRole> userRoles = baseMapper.selectRolePermissionByUserId(userId); + List<SysRole> roles = selectRoleAll(); + for (SysRole role : roles) + { + for (SysRole userRole : userRoles) + { + if (role.getRoleId().longValue() == userRole.getRoleId().longValue()) + { + role.setFlag(true); + break; + } + } + } + return roles; + } + + /** + * 根据用户ID查询权限 + * + * @param userId 用户ID + * @return 权限列表 + */ + public Set<String> selectRolePermissionByUserId(Long userId) + { + List<SysRole> perms = baseMapper.selectRolePermissionByUserId(userId); + Set<String> permsSet = new HashSet<>(); + for (SysRole perm : perms) + { + if (StringUtils.isNotNull(perm)) + { + permsSet.addAll(Arrays.asList(perm.getRoleKey().trim().split(","))); + } + } + return permsSet; + } + + /** + * 查询所有角色 + * + * @return 角色列表 + */ + public List<SysRole> selectRoleAll() + { + return SpringUtils.getAopProxy(this).selectRoleList(new SysRole()); + } + + /** + * 根据用户ID获取角色选择框列表 + * + * @param userId 用户ID + * @return 选中角色ID列表 + */ + public List<Long> selectRoleListByUserId(Long userId) + { + return baseMapper.selectRoleListByUserId(userId); + } + + /** + * 通过角色ID查询角色 + * + * @param roleId 角色ID + * @return 角色对象信息 + */ + public SysRole selectRoleById(Long roleId) + { + return baseMapper.selectRoleById(roleId); + } + + /** + * 校验角色名称是否唯一 + * + * @param role 角色信息 + * @return 结果 + */ + public String checkRoleNameUnique(SysRole role) + { + Long roleId = StringUtils.isNull(role.getRoleId()) ? -1L : role.getRoleId(); + SysRole info = baseMapper.checkRoleNameUnique(role.getRoleName()); + if (StringUtils.isNotNull(info) && info.getRoleId().longValue() != roleId.longValue()) + { + return UserConstants.NOT_UNIQUE; + } + return UserConstants.UNIQUE; + } + + /** + * 校验角色权限是否唯一 + * + * @param role 角色信息 + * @return 结果 + */ + public String checkRoleKeyUnique(SysRole role) + { + Long roleId = StringUtils.isNull(role.getRoleId()) ? -1L : role.getRoleId(); + SysRole info = baseMapper.checkRoleKeyUnique(role.getRoleKey()); + if (StringUtils.isNotNull(info) && info.getRoleId().longValue() != roleId.longValue()) + { + return UserConstants.NOT_UNIQUE; + } + return UserConstants.UNIQUE; + } + + /** + * 校验角色是否允许操作 + * + * @param role 角色信息 + */ + public void checkRoleAllowed(SysRole role) + { + if (StringUtils.isNotNull(role.getRoleId()) && role.isAdmin()) + { + throw new ServiceException("不允许操作超级管理员角色"); + } + } + + /** + * 校验角色是否有数据权限 + * + * @param roleId 角色id + */ + public void checkRoleDataScope(Long roleId) + { + if (!SysUser.isAdmin(SecurityUtils.getUserId())) + { + SysRole role = new SysRole(); + role.setRoleId(roleId); + List<SysRole> roles = SpringUtils.getAopProxy(this).selectRoleList(role); + if (StringUtils.isEmpty(roles)) + { + throw new ServiceException("没有权限访问角色数据!"); + } + } + } + + /** + * 通过角色ID查询角色使用数量 + * + * @param roleId 角色ID + * @return 结果 + */ + public int countUserRoleByRoleId(Long roleId) + { + return userRoleMapper.countUserRoleByRoleId(roleId); + } + + /** + * 新增保存角色信息 + * + * @param role 角色信息 + * @return 结果 + */ + @Transactional + public int insertRole(SysRole role) + { + // 新增角色信息 + baseMapper.insertRole(role); + return insertRoleMenu(role); + } + + /** + * 修改保存角色信息 + * + * @param role 角色信息 + * @return 结果 + */ + @Transactional + public int updateRole(SysRole role) + { + // 修改角色信息 + baseMapper.updateRole(role); + // 删除角色与菜单关联 + roleMenuMapper.deleteRoleMenuByRoleId(role.getRoleId()); + return insertRoleMenu(role); + } + + /** + * 修改角色状态 + * + * @param role 角色信息 + * @return 结果 + */ + public int updateRoleStatus(SysRole role) + { + return baseMapper.updateRole(role); + } + + /** + * 修改数据权限信息 + * + * @param role 角色信息 + * @return 结果 + */ + @Transactional + public int authDataScope(SysRole role) + { + // 修改角色信息 + baseMapper.updateRole(role); + // 删除角色与部门关联 + roleDeptMapper.deleteRoleDeptByRoleId(role.getRoleId()); + // 新增角色和部门信息(数据权限) + return insertRoleDept(role); + } + + /** + * 新增角色菜单信息 + * + * @param role 角色对象 + */ + public int insertRoleMenu(SysRole role) + { + int rows = 1; + // 新增用户与角色管理 + List<SysRoleMenu> list = new ArrayList<SysRoleMenu>(); + for (Long menuId : role.getMenuIds()) + { + SysRoleMenu rm = new SysRoleMenu(); + rm.setRoleId(role.getRoleId()); + rm.setMenuId(menuId); + list.add(rm); + } + if (list.size() > 0) + { + rows = roleMenuMapper.batchRoleMenu(list); + } + return rows; + } + + /** + * 新增角色部门信息(数据权限) + * + * @param role 角色对象 + */ + public int insertRoleDept(SysRole role) + { + int rows = 1; + // 新增角色与部门(数据权限)管理 + List<SysRoleDept> list = new ArrayList<SysRoleDept>(); + for (Long deptId : role.getDeptIds()) + { + SysRoleDept rd = new SysRoleDept(); + rd.setRoleId(role.getRoleId()); + rd.setDeptId(deptId); + list.add(rd); + } + if (list.size() > 0) + { + rows = roleDeptMapper.batchRoleDept(list); + } + return rows; + } + + /** + * 通过角色ID删除角色 + * + * @param roleId 角色ID + * @return 结果 + */ + @Transactional + public int deleteRoleById(Long roleId) + { + // 删除角色与菜单关联 + roleMenuMapper.deleteRoleMenuByRoleId(roleId); + // 删除角色与部门关联 + roleDeptMapper.deleteRoleDeptByRoleId(roleId); + return baseMapper.deleteRoleById(roleId); + } + + /** + * 批量删除角色信息 + * + * @param roleIds 需要删除的角色ID + * @return 结果 + */ + @Transactional + public int deleteRoleByIds(Long[] roleIds) + { + for (Long roleId : roleIds) + { + checkRoleAllowed(new SysRole(roleId)); + checkRoleDataScope(roleId); + SysRole role = selectRoleById(roleId); + if (countUserRoleByRoleId(roleId) > 0) + { + throw new ServiceException(String.format("%1$s已分配,不能删除", role.getRoleName())); + } + } + // 删除角色与菜单关联 + roleMenuMapper.deleteRoleMenu(roleIds); + // 删除角色与部门关联 + roleDeptMapper.deleteRoleDept(roleIds); + return baseMapper.deleteRoleByIds(roleIds); + } + + /** + * 取消授权用户角色 + * + * @param userRole 用户和角色关联信息 + * @return 结果 + */ + public int deleteAuthUser(SysUserRole userRole) + { + return userRoleMapper.deleteUserRoleInfo(userRole); + } + + /** + * 批量取消授权用户角色 + * + * @param roleId 角色ID + * @param userIds 需要取消授权的用户数据ID + * @return 结果 + */ + public int deleteAuthUsers(Long roleId, Long[] userIds) + { + return userRoleMapper.deleteUserRoleInfos(roleId, userIds); + } + + /** + * 批量选择授权用户角色 + * + * @param roleId 角色ID + * @param userIds 需要授权的用户数据ID + * @return 结果 + */ + public int insertAuthUsers(Long roleId, Long[] userIds) + { + // 新增用户与角色管理 + List<SysUserRole> list = new ArrayList<SysUserRole>(); + for (Long userId : userIds) + { + SysUserRole ur = new SysUserRole(); + ur.setUserId(userId); + ur.setRoleId(roleId); + list.add(ur); + } + return userRoleMapper.batchUserRole(list); + } +} diff --git a/dc-system/src/main/java/com/dc/system/service/SysUserOnlineService.java b/dc-system/src/main/java/com/dc/system/service/SysUserOnlineService.java new file mode 100644 index 0000000..4c16e10 --- /dev/null +++ b/dc-system/src/main/java/com/dc/system/service/SysUserOnlineService.java @@ -0,0 +1,91 @@ +package com.dc.system.service; + +import com.dc.common.core.domain.model.LoginUser; +import com.dc.common.utils.StringUtils; +import com.dc.system.domain.SysUserOnline; +import org.springframework.stereotype.Service; + +/** + * 在线用户 服务层处理 + * + * @author win + */ +@Service +public class SysUserOnlineService +{ + /** + * 通过登录地址查询信息 + * + * @param ipaddr 登录地址 + * @param user 用户信息 + * @return 在线用户信息 + */ + public SysUserOnline selectOnlineByIpaddr(String ipaddr, LoginUser user) + { + if (StringUtils.equals(ipaddr, user.getIpaddr())) + { + return loginUserToUserOnline(user); + } + return null; + } + + /** + * 通过用户名称查询信息 + * + * @param userName 用户名称 + * @param user 用户信息 + * @return 在线用户信息 + */ + public SysUserOnline selectOnlineByUserName(String userName, LoginUser user) + { + if (StringUtils.equals(userName, user.getUsername())) + { + return loginUserToUserOnline(user); + } + return null; + } + + /** + * 通过登录地址/用户名称查询信息 + * + * @param ipaddr 登录地址 + * @param userName 用户名称 + * @param user 用户信息 + * @return 在线用户信息 + */ + public SysUserOnline selectOnlineByInfo(String ipaddr, String userName, LoginUser user) + { + if (StringUtils.equals(ipaddr, user.getIpaddr()) && StringUtils.equals(userName, user.getUsername())) + { + return loginUserToUserOnline(user); + } + return null; + } + + /** + * 设置在线用户信息 + * + * @param user 用户信息 + * @return 在线用户 + */ + public SysUserOnline loginUserToUserOnline(LoginUser user) + { + if (StringUtils.isNull(user) || StringUtils.isNull(user.getUser())) + { + return null; + } + SysUserOnline sysUserOnline = new SysUserOnline(); + sysUserOnline.setTokenId(user.getToken()); + sysUserOnline.setUserName(user.getUsername()); + sysUserOnline.setIpaddr(user.getIpaddr()); + sysUserOnline.setLoginLocation(user.getLoginLocation()); + sysUserOnline.setBrowser(user.getBrowser()); + sysUserOnline.setOs(user.getOs()); + sysUserOnline.setLoginTime(user.getLoginTime()); + if (StringUtils.isNotNull(user.getUser().getDept())) + { + sysUserOnline.setDeptName(user.getUser().getDept().getDeptName()); + } + return sysUserOnline; + } +} diff --git a/dc-system/src/main/java/com/dc/system/service/SysUserService.java b/dc-system/src/main/java/com/dc/system/service/SysUserService.java new file mode 100644 index 0000000..e744311 --- /dev/null +++ b/dc-system/src/main/java/com/dc/system/service/SysUserService.java @@ -0,0 +1,522 @@ +package com.dc.system.service; + +import com.baomidou.mybatisplus.extension.service.IService; +import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; +import com.dc.common.annotation.DataScope; +import com.dc.common.constant.UserConstants; +import com.dc.common.core.domain.entity.SysRole; +import com.dc.common.core.domain.entity.SysUser; +import com.dc.common.exception.ServiceException; +import com.dc.common.utils.SecurityUtils; +import com.dc.common.utils.StringUtils; +import com.dc.common.utils.bean.BeanValidators; +import com.dc.common.utils.spring.SpringUtils; +import com.dc.system.domain.SysPost; +import com.dc.system.domain.SysUserPost; +import com.dc.system.domain.SysUserRole; +import com.dc.system.mapper.*; +import lombok.extern.slf4j.Slf4j; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.stereotype.Service; +import org.springframework.transaction.annotation.Transactional; +import org.springframework.util.CollectionUtils; + +import javax.validation.Validator; +import java.util.ArrayList; +import java.util.List; +import java.util.stream.Collectors; + +/** + * 用户 业务层处理 + * + * @author win + */ +@Slf4j +@Service +public class SysUserService extends ServiceImpl<SysUserMapper, SysUser> implements IService<SysUser> +{ + @Autowired + private SysRoleMapper roleMapper; + + @Autowired + private SysPostMapper postMapper; + + @Autowired + private SysUserRoleMapper userRoleMapper; + + @Autowired + private SysUserPostMapper userPostMapper; + + @Autowired + private SysConfigService configService; + + @Autowired + protected Validator validator; + + /** + * 根据条件分页查询用户列表 + * + * @param user 用户信息 + * @return 用户信息集合信息 + */ + @DataScope(deptAlias = "d", userAlias = "u") + public List<SysUser> selectUserList(SysUser user) + { + return baseMapper.selectUserList(user); + } + + /** + * 根据条件分页查询已分配用户角色列表 + * + * @param user 用户信息 + * @return 用户信息集合信息 + */ + @DataScope(deptAlias = "d", userAlias = "u") + public List<SysUser> selectAllocatedList(SysUser user) + { + return baseMapper.selectAllocatedList(user); + } + + /** + * 根据条件分页查询未分配用户角色列表 + * + * @param user 用户信息 + * @return 用户信息集合信息 + */ + @DataScope(deptAlias = "d", userAlias = "u") + public List<SysUser> selectUnallocatedList(SysUser user) + { + return baseMapper.selectUnallocatedList(user); + } + + /** + * 通过用户名查询用户 + * + * @param userName 用户名 + * @return 用户对象信息 + */ + public SysUser selectUserByUserName(String userName) + { + return baseMapper.selectUserByUserName(userName); + } + + /** + * 通过用户ID查询用户 + * + * @param userId 用户ID + * @return 用户对象信息 + */ + public SysUser selectUserById(Long userId) + { + return baseMapper.selectUserById(userId); + } + + /** + * 通过用户ID只查询用户 + * + * @param userId 用户ID + * @return 用户对象信息 + */ + public SysUser selectSingleUserById(Long userId) + { + return baseMapper.selectSingleUserById(userId); + } + + /** + * 查询用户所属角色组 + * + * @param userName 用户名 + * @return 结果 + */ + public String selectUserRoleGroup(String userName) + { + List<SysRole> list = roleMapper.selectRolesByUserName(userName); + if (CollectionUtils.isEmpty(list)) + { + return StringUtils.EMPTY; + } + return list.stream().map(SysRole::getRoleName).collect(Collectors.joining(",")); + } + + /** + * 查询用户所属岗位组 + * + * @param userName 用户名 + * @return 结果 + */ + public String selectUserPostGroup(String userName) + { + List<SysPost> list = postMapper.selectPostsByUserName(userName); + if (CollectionUtils.isEmpty(list)) + { + return StringUtils.EMPTY; + } + return list.stream().map(SysPost::getPostName).collect(Collectors.joining(",")); + } + + /** + * 校验用户名称是否唯一 + * + * @param user 用户信息 + * @return 结果 + */ + public String checkUserNameUnique(SysUser user) + { + Long userId = StringUtils.isNull(user.getUserId()) ? -1L : user.getUserId(); + SysUser info = baseMapper.checkUserNameUnique(user.getUserName()); + if (StringUtils.isNotNull(info) && info.getUserId().longValue() != userId.longValue()) + { + return UserConstants.NOT_UNIQUE; + } + return UserConstants.UNIQUE; + } + + /** + * 校验手机号码是否唯一 + * + * @param user 用户信息 + * @return + */ + public String checkPhoneUnique(SysUser user) + { + Long userId = StringUtils.isNull(user.getUserId()) ? -1L : user.getUserId(); + SysUser info = baseMapper.checkPhoneUnique(user.getPhonenumber()); + if (StringUtils.isNotNull(info) && info.getUserId().longValue() != userId.longValue()) + { + return UserConstants.NOT_UNIQUE; + } + return UserConstants.UNIQUE; + } + + /** + * 校验email是否唯一 + * + * @param user 用户信息 + * @return + */ + public String checkEmailUnique(SysUser user) + { + Long userId = StringUtils.isNull(user.getUserId()) ? -1L : user.getUserId(); + SysUser info = baseMapper.checkEmailUnique(user.getEmail()); + if (StringUtils.isNotNull(info) && info.getUserId().longValue() != userId.longValue()) + { + return UserConstants.NOT_UNIQUE; + } + return UserConstants.UNIQUE; + } + + /** + * 校验用户是否允许操作 + * + * @param user 用户信息 + */ + public void checkUserAllowed(SysUser user) + { + if (StringUtils.isNotNull(user.getUserId()) && user.isAdmin()) + { + throw new ServiceException("不允许操作超级管理员用户"); + } + } + + /** + * 校验用户是否有数据权限 + * + * @param userId 用户id + */ + public void checkUserDataScope(Long userId) + { + if (!SysUser.isAdmin(SecurityUtils.getUserId())) + { + SysUser user = new SysUser(); + user.setUserId(userId); + List<SysUser> users = SpringUtils.getAopProxy(this).selectUserList(user); + if (StringUtils.isEmpty(users)) + { + throw new ServiceException("没有权限访问用户数据!"); + } + } + } + + /** + * 新增保存用户信息 + * + * @param user 用户信息 + * @return 结果 + */ + @Transactional + public int insertUser(SysUser user) + { + // 新增用户信息 + int rows = baseMapper.insertUser(user); + // 新增用户岗位关联 + insertUserPost(user); + // 新增用户与角色管理 + insertUserRole(user); + return rows; + } + + /** + * 注册用户信息 + * + * @param user 用户信息 + * @return 结果 + */ + public boolean registerUser(SysUser user) + { + return baseMapper.insertUser(user) > 0; + } + + /** + * 修改保存用户信息 + * + * @param user 用户信息 + * @return 结果 + */ + @Transactional + public int updateUser(SysUser user) + { + Long userId = user.getUserId(); + // 删除用户与角色关联 + userRoleMapper.deleteUserRoleByUserId(userId); + // 新增用户与角色管理 + insertUserRole(user); + // 删除用户与岗位关联 + userPostMapper.deleteUserPostByUserId(userId); + // 新增用户与岗位管理 + insertUserPost(user); + return baseMapper.updateUser(user); + } + + /** + * 用户授权角色 + * + * @param userId 用户ID + * @param roleIds 角色组 + */ + @Transactional + public void insertUserAuth(Long userId, Long[] roleIds) + { + userRoleMapper.deleteUserRoleByUserId(userId); + insertUserRole(userId, roleIds); + } + + /** + * 修改用户状态 + * + * @param user 用户信息 + * @return 结果 + */ + public int updateUserStatus(SysUser user) + { + return baseMapper.updateUser(user); + } + + /** + * 修改用户基本信息 + * + * @param user 用户信息 + * @return 结果 + */ + public int updateUserProfile(SysUser user) + { + return baseMapper.updateUser(user); + } + + /** + * 修改用户头像 + * + * @param userName 用户名 + * @param avatar 头像地址 + * @return 结果 + */ + public boolean updateUserAvatar(String userName, String avatar) + { + return baseMapper.updateUserAvatar(userName, avatar) > 0; + } + + /** + * 重置用户密码 + * + * @param user 用户信息 + * @return 结果 + */ + public int resetPwd(SysUser user) + { + return baseMapper.updateUser(user); + } + + /** + * 重置用户密码 + * + * @param userName 用户名 + * @param password 密码 + * @return 结果 + */ + public int resetUserPwd(String userName, String password) + { + return baseMapper.resetUserPwd(userName, password); + } + + /** + * 新增用户角色信息 + * + * @param user 用户对象 + */ + public void insertUserRole(SysUser user) + { + this.insertUserRole(user.getUserId(), user.getRoleIds()); + } + + /** + * 新增用户岗位信息 + * + * @param user 用户对象 + */ + public void insertUserPost(SysUser user) + { + Long[] posts = user.getPostIds(); + if (StringUtils.isNotEmpty(posts)) + { + // 新增用户与岗位管理 + List<SysUserPost> list = new ArrayList<SysUserPost>(posts.length); + for (Long postId : posts) + { + SysUserPost up = new SysUserPost(); + up.setUserId(user.getUserId()); + up.setPostId(postId); + list.add(up); + } + userPostMapper.batchUserPost(list); + } + } + + /** + * 新增用户角色信息 + * + * @param userId 用户ID + * @param roleIds 角色组 + */ + public void insertUserRole(Long userId, Long[] roleIds) + { + if (StringUtils.isNotEmpty(roleIds)) + { + // 新增用户与角色管理 + List<SysUserRole> list = new ArrayList<SysUserRole>(roleIds.length); + for (Long roleId : roleIds) + { + SysUserRole ur = new SysUserRole(); + ur.setUserId(userId); + ur.setRoleId(roleId); + list.add(ur); + } + userRoleMapper.batchUserRole(list); + } + } + + /** + * 通过用户ID删除用户 + * + * @param userId 用户ID + * @return 结果 + */ + @Transactional + public int deleteUserById(Long userId) + { + // 删除用户与角色关联 + userRoleMapper.deleteUserRoleByUserId(userId); + // 删除用户与岗位表 + userPostMapper.deleteUserPostByUserId(userId); + return baseMapper.deleteUserById(userId); + } + + /** + * 批量删除用户信息 + * + * @param userIds 需要删除的用户ID + * @return 结果 + */ + @Transactional + public int deleteUserByIds(Long[] userIds) + { + for (Long userId : userIds) + { + checkUserAllowed(new SysUser(userId)); + checkUserDataScope(userId); + } + // 删除用户与角色关联 + userRoleMapper.deleteUserRole(userIds); + // 删除用户与岗位关联 + userPostMapper.deleteUserPost(userIds); + return baseMapper.deleteUserByIds(userIds); + } + + /** + * 导入用户数据 + * + * @param userList 用户数据列表 + * @param isUpdateSupport 是否更新支持,如果已存在,则进行更新数据 + * @param operName 操作用户 + * @return 结果 + */ + public String importUser(List<SysUser> userList, Boolean isUpdateSupport, String operName) + { + if (StringUtils.isNull(userList) || userList.size() == 0) + { + throw new ServiceException("导入用户数据不能为空!"); + } + int successNum = 0; + int failureNum = 0; + StringBuilder successMsg = new StringBuilder(); + StringBuilder failureMsg = new StringBuilder(); + String password = configService.selectConfigByKey("sys.user.initPassword"); + for (SysUser user : userList) + { + try + { + // 验证是否存在这个用户 + SysUser u = baseMapper.selectUserByUserName(user.getUserName()); + if (StringUtils.isNull(u)) + { + BeanValidators.validateWithException(validator, user); + user.setPassword(SecurityUtils.encryptPassword(password)); + user.setCreateBy(operName); + this.insertUser(user); + successNum++; + successMsg.append("<br/>" + successNum + "、账号 " + user.getUserName() + " 导入成功"); + } + else if (isUpdateSupport) + { + BeanValidators.validateWithException(validator, user); + checkUserAllowed(user); + checkUserDataScope(user.getUserId()); + user.setUpdateBy(operName); + this.updateUser(user); + successNum++; + successMsg.append("<br/>" + successNum + "、账号 " + user.getUserName() + " 更新成功"); + } + else + { + failureNum++; + failureMsg.append("<br/>" + failureNum + "、账号 " + user.getUserName() + " 已存在"); + } + } + catch (Exception e) + { + failureNum++; + String msg = "<br/>" + failureNum + "、账号 " + user.getUserName() + " 导入失败:"; + failureMsg.append(msg + e.getMessage()); + log.error(msg, e); + } + } + if (failureNum > 0) + { + failureMsg.insert(0, "很抱歉,导入失败!共 " + failureNum + " 条数据格式不正确,错误如下:"); + throw new ServiceException(failureMsg.toString()); + } + else + { + successMsg.insert(0, "恭喜您,数据已全部导入成功!共 " + successNum + " 条,数据如下:"); + } + return successMsg.toString(); + } +} diff --git a/dc-system/src/main/java/com/dc/system/service/cache/SysCityCache.java b/dc-system/src/main/java/com/dc/system/service/cache/SysCityCache.java new file mode 100644 index 0000000..450ff77 --- /dev/null +++ b/dc-system/src/main/java/com/dc/system/service/cache/SysCityCache.java @@ -0,0 +1,54 @@ +package com.dc.system.service.cache; + +import com.baomidou.mybatisplus.core.conditions.Wrapper; +import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; +import com.dc.common.core.redis.RedisCache; +import com.dc.system.domain.SysCity; +import com.dc.system.service.SysCityService; +import lombok.extern.slf4j.Slf4j; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.stereotype.Service; + +import java.util.List; + +/** + * 承运商Service业务层处理 + * + * @author win + * @date 2023-03-16 + */ +@Slf4j +@Service("sysCityService") +public class SysCityCache extends SysCityService { + + @Autowired + private RedisCache redisCache; + + //缓存前缀 + private String key = "sysCity"; + + @Override + public SysCity getOne(Wrapper<SysCity> wrapper) { + QueryWrapper queryWrapper = (QueryWrapper)wrapper; + String hashKey = queryWrapper.getTargetSql() + queryWrapper.getParamNameValuePairs(); + SysCity sysCity = redisCache.getCacheMapValue(key, hashKey); + if(sysCity == null) { + sysCity = super.getOne(queryWrapper); + redisCache.setCacheMapValue(key, hashKey, sysCity); + } + return sysCity; + } + + @Override + public List<SysCity> list(Wrapper<SysCity> queryWrapper) { + QueryWrapper<SysCity> queryWrapper1 = (QueryWrapper)queryWrapper; + queryWrapper1.select("id"); + List<SysCity> list = super.list(queryWrapper); + for(int i = 0; i < list.size(); i++) { + SysCity sysCity = list.get(i); + list.set(i, this.getById(sysCity.getId())); + } + return list; + } + +} \ No newline at end of file diff --git a/dc-system/src/main/resources/mapper/system/AccessoryMapper.xml b/dc-system/src/main/resources/mapper/system/AccessoryMapper.xml new file mode 100644 index 0000000..c9415c1 --- /dev/null +++ b/dc-system/src/main/resources/mapper/system/AccessoryMapper.xml @@ -0,0 +1,29 @@ +<?xml version="1.0" encoding="UTF-8" ?> +<!DOCTYPE mapper + PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" + "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> +<mapper namespace="com.dc.system.mapper.AccessoryMapper"> + + <resultMap type="Accessory" id="AccessoryResult"> + <result property="id" column="id" /> + <result property="url" column="url" /> + <result property="name" column="name" /> + <result property="suffix" column="suffix" /> + <result property="type" column="type" /> + <result property="objectNo" column="object_no" /> + <result property="deptId" column="dept_id" /> + <result property="userId" column="user_id" /> + <result property="version" column="version" /> + <result property="createBy" column="create_by" /> + <result property="createTime" column="create_time" /> + <result property="updateBy" column="update_by" /> + <result property="updateTime" column="update_time" /> + <result property="deleteBy" column="delete_by" /> + <result property="deleteTime" column="delete_time" /> + </resultMap> + + <sql id="selectAccessoryVo"> + select id, url, name, suffix, type, object_no, dept_id, user_id, version, create_by, create_time, update_by, update_time, delete_by, delete_time from accessory + </sql> + +</mapper> \ No newline at end of file diff --git a/dc-system/src/main/resources/mapper/system/SysCityMapper.xml b/dc-system/src/main/resources/mapper/system/SysCityMapper.xml new file mode 100644 index 0000000..95d9063 --- /dev/null +++ b/dc-system/src/main/resources/mapper/system/SysCityMapper.xml @@ -0,0 +1,25 @@ +<?xml version="1.0" encoding="UTF-8" ?> +<!DOCTYPE mapper +PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" +"http://mybatis.org/dtd/mybatis-3-mapper.dtd"> +<mapper namespace="com.dc.system.mapper.SysCityMapper"> + + <resultMap type="SysCity" id="SysCityResult"> + <result property="id" column="id" /> + <result property="pid" column="pid" /> + <result property="areaName" column="area_name" /> + <result property="grade" column="grade" /> + <result property="version" column="version" /> + <result property="createBy" column="create_by" /> + <result property="createTime" column="create_time" /> + <result property="updateBy" column="update_by" /> + <result property="updateTime" column="update_time" /> + <result property="deleteBy" column="delete_by" /> + <result property="deleteTime" column="delete_time" /> + </resultMap> + + <sql id="selectSysCityVo"> + select id, pid, area_name, grade, version, create_by, create_time, update_by, update_time, delete_by, delete_time from sys_city + </sql> + +</mapper> \ No newline at end of file diff --git a/dc-system/src/main/resources/mapper/system/SysConfigMapper.xml b/dc-system/src/main/resources/mapper/system/SysConfigMapper.xml new file mode 100644 index 0000000..5f28d3d --- /dev/null +++ b/dc-system/src/main/resources/mapper/system/SysConfigMapper.xml @@ -0,0 +1,113 @@ +<?xml version="1.0" encoding="UTF-8" ?> +<!DOCTYPE mapper + PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" + "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> +<mapper namespace="com.dc.system.mapper.SysConfigMapper"> + + <resultMap type="SysConfig" id="SysConfigResult"> + <id property="configId" column="config_id"/> + <result property="configName" column="config_name"/> + <result property="configKey" column="config_key"/> + <result property="configValue" column="config_value"/> + <result property="configType" column="config_type"/> + <result property="createBy" column="create_by"/> + <result property="createTime" column="create_time"/> + <result property="updateBy" column="update_by"/> + <result property="updateTime" column="update_time"/> + </resultMap> + + <sql id="selectConfigVo"> + select config_id, config_name, config_key, config_value, config_type, create_by, create_time, update_by, + update_time, remark + from sys_config + </sql> + + <!-- 查询条件 --> + <sql id="sqlwhereSearch"> + <where> + <if test="configId !=null"> + and config_id = #{configId} + </if> + <if test="configKey !=null and configKey != ''"> + and config_key = #{configKey} + </if> + </where> + </sql> + + <select id="selectConfig" parameterType="SysConfig" resultMap="SysConfigResult"> + <include refid="selectConfigVo"/> + <include refid="sqlwhereSearch"/> + </select> + + <select id="selectConfigList" parameterType="SysConfig" resultMap="SysConfigResult"> + <include refid="selectConfigVo"/> + <where> + <if test="configName != null and configName != ''"> + AND config_name like concat('%', #{configName}, '%') + </if> + <if test="configType != null and configType != ''"> + AND config_type = #{configType} + </if> + <if test="configKey != null and configKey != ''"> + AND config_key like concat('%', #{configKey}, '%') + </if> + <if test="params.beginTime != null and params.beginTime != ''"><!-- 开始时间检索 --> + and to_char(create_time,'yyyy-MM-dd') >= to_char(#{params.beginTime},'yyyy-MM-dd') + </if> + <if test="params.endTime != null and params.endTime != ''"><!-- 结束时间检索 --> + and to_char(create_time,'yyyy-MM-dd') <= to_char(#{params.endTime},'yyyy-MM-dd') + </if> + </where> + </select> + + <select id="checkConfigKeyUnique" parameterType="String" resultMap="SysConfigResult"> + <include refid="selectConfigVo"/> + where config_key = #{configKey} limit 1 + </select> + + <insert id="insertConfig" parameterType="SysConfig"> + insert into sys_config ( + <if test="configName != null and configName != '' ">config_name,</if> + <if test="configKey != null and configKey != '' ">config_key,</if> + <if test="configValue != null and configValue != '' ">config_value,</if> + <if test="configType != null and configType != '' ">config_type,</if> + <if test="createBy != null and createBy != ''">create_by,</if> + <if test="remark != null and remark != ''">remark,</if> + create_time + )values( + <if test="configName != null and configName != ''">#{configName},</if> + <if test="configKey != null and configKey != ''">#{configKey},</if> + <if test="configValue != null and configValue != ''">#{configValue},</if> + <if test="configType != null and configType != ''">#{configType},</if> + <if test="createBy != null and createBy != ''">#{createBy},</if> + <if test="remark != null and remark != ''">#{remark},</if> + current_timestamp + ) + </insert> + + <update id="updateConfig" parameterType="SysConfig"> + update sys_config + <set> + <if test="configName != null and configName != ''">config_name = #{configName},</if> + <if test="configKey != null and configKey != ''">config_key = #{configKey},</if> + <if test="configValue != null and configValue != ''">config_value = #{configValue},</if> + <if test="configType != null and configType != ''">config_type = #{configType},</if> + <if test="updateBy != null and updateBy != ''">update_by = #{updateBy},</if> + <if test="remark != null">remark = #{remark},</if> + update_time = current_timestamp + </set> + where config_id = #{configId} + </update> + + <delete id="deleteConfigById" parameterType="Long"> + delete from sys_config where config_id = #{configId} + </delete> + + <delete id="deleteConfigByIds" parameterType="Long"> + delete from sys_config where config_id in + <foreach item="configId" collection="array" open="(" separator="," close=")"> + #{configId} + </foreach> + </delete> + +</mapper> \ No newline at end of file diff --git a/dc-system/src/main/resources/mapper/system/SysDeptMapper.xml b/dc-system/src/main/resources/mapper/system/SysDeptMapper.xml new file mode 100644 index 0000000..d95d3ef --- /dev/null +++ b/dc-system/src/main/resources/mapper/system/SysDeptMapper.xml @@ -0,0 +1,161 @@ +<?xml version="1.0" encoding="UTF-8" ?> +<!DOCTYPE mapper + PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" + "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> +<mapper namespace="com.dc.system.mapper.SysDeptMapper"> + + <resultMap type="SysDept" id="SysDeptResult"> + <id property="deptId" column="dept_id"/> + <result property="parentId" column="parent_id"/> + <result property="ancestors" column="ancestors"/> + <result property="deptName" column="dept_name"/> + <result property="orderNum" column="order_num"/> + <result property="leader" column="leader"/> + <result property="phone" column="phone"/> + <result property="email" column="email"/> + <result property="status" column="status"/> + <result property="delFlag" column="del_flag"/> + <result property="parentName" column="parent_name"/> + <result property="createBy" column="create_by"/> + <result property="createTime" column="create_time"/> + <result property="updateBy" column="update_by"/> + <result property="updateTime" column="update_time"/> + </resultMap> + + <sql id="selectDeptVo"> + select d.dept_id, d.parent_id, d.ancestors, d.dept_name, d.order_num, d.leader, d.phone, d.email, d.status, + d.del_flag, d.create_by, d.create_time + from sys_dept d + </sql> + + <select id="selectDeptList" parameterType="SysDept" resultMap="SysDeptResult"> + <include refid="selectDeptVo"/> + where d.del_flag = '0' + <if test="deptId != null and deptId != 0"> + AND dept_id = #{deptId} + </if> + <if test="parentId != null and parentId != 0"> + AND parent_id = #{parentId} + </if> + <if test="deptName != null and deptName != ''"> + AND dept_name like concat('%', #{deptName}, '%') + </if> + <if test="status != null and status != ''"> + AND status = #{status} + </if> + <!-- 数据范围过滤 --> + ${params.dataScope} + order by d.parent_id, d.order_num + </select> + + <select id="selectDeptListByRoleId" resultType="Long"> + select d.dept_id + from sys_dept d + left join sys_role_dept rd on d.dept_id = rd.dept_id + where rd.role_id = #{roleId} + <if test="deptCheckStrictly"> + and d.dept_id not in (select d.parent_id from sys_dept d inner join sys_role_dept rd on d.dept_id = + rd.dept_id and rd.role_id = #{roleId}) + </if> + order by d.parent_id, d.order_num + </select> + + <select id="selectDeptById" parameterType="Long" resultMap="SysDeptResult"> + select d.dept_id, d.parent_id, d.ancestors, d.dept_name, d.order_num, d.leader, d.phone, d.email, d.status, + (select dept_name from sys_dept where dept_id = d.parent_id) parent_name + from sys_dept d + where d.dept_id = #{deptId} + </select> + + <select id="checkDeptExistUser" parameterType="Long" resultType="int"> + select count(1) from sys_user where dept_id = #{deptId} and del_flag = '0' + </select> + + <select id="hasChildByDeptId" parameterType="Long" resultType="int"> + select count(1) from sys_dept + where del_flag = '0' and parent_id = #{deptId} limit 1 + </select> + + <select id="selectChildrenDeptById" parameterType="Long" resultMap="SysDeptResult"> + select * from sys_dept where find_in_set(#{deptId}, ancestors) + </select> + + <select id="selectNormalChildrenDeptById" parameterType="Long" resultType="int"> + select count(*) from sys_dept where status = '0' and del_flag = '0' and find_in_set(#{deptId}, ancestors) + </select> + + <select id="checkDeptNameUnique" resultMap="SysDeptResult"> + <include refid="selectDeptVo"/> + where dept_name=#{deptName} and parent_id = #{parentId} and del_flag = '0' limit 1 + </select> + + <insert id="insertDept" parameterType="SysDept"> + insert into sys_dept( + <if test="deptId != null and deptId != 0">dept_id,</if> + <if test="parentId != null and parentId != 0">parent_id,</if> + <if test="deptName != null and deptName != ''">dept_name,</if> + <if test="ancestors != null and ancestors != ''">ancestors,</if> + <if test="orderNum != null">order_num,</if> + <if test="leader != null and leader != ''">leader,</if> + <if test="phone != null and phone != ''">phone,</if> + <if test="email != null and email != ''">email,</if> + <if test="status != null">status,</if> + <if test="createBy != null and createBy != ''">create_by,</if> + create_time + )values( + <if test="deptId != null and deptId != 0">#{deptId},</if> + <if test="parentId != null and parentId != 0">#{parentId},</if> + <if test="deptName != null and deptName != ''">#{deptName},</if> + <if test="ancestors != null and ancestors != ''">#{ancestors},</if> + <if test="orderNum != null">#{orderNum},</if> + <if test="leader != null and leader != ''">#{leader},</if> + <if test="phone != null and phone != ''">#{phone},</if> + <if test="email != null and email != ''">#{email},</if> + <if test="status != null">#{status},</if> + <if test="createBy != null and createBy != ''">#{createBy},</if> + current_timestamp + ) + </insert> + + <update id="updateDept" parameterType="SysDept"> + update sys_dept + <set> + <if test="parentId != null and parentId != 0">parent_id = #{parentId},</if> + <if test="deptName != null and deptName != ''">dept_name = #{deptName},</if> + <if test="ancestors != null and ancestors != ''">ancestors = #{ancestors},</if> + <if test="orderNum != null">order_num = #{orderNum},</if> + <if test="leader != null">leader = #{leader},</if> + <if test="phone != null">phone = #{phone},</if> + <if test="email != null">email = #{email},</if> + <if test="status != null and status != ''">status = #{status},</if> + <if test="updateBy != null and updateBy != ''">update_by = #{updateBy},</if> + update_time = current_timestamp + </set> + where dept_id = #{deptId} + </update> + + <update id="updateDeptChildren" parameterType="java.util.List"> + update sys_dept set ancestors = + <foreach collection="depts" item="item" index="index" + separator=" " open="case dept_id" close="end"> + when #{item.deptId} then #{item.ancestors} + </foreach> + where dept_id in + <foreach collection="depts" item="item" index="index" + separator="," open="(" close=")"> + #{item.deptId} + </foreach> + </update> + + <update id="updateDeptStatusNormal" parameterType="Long"> + update sys_dept set status = '0' where dept_id in + <foreach collection="array" item="deptId" open="(" separator="," close=")"> + #{deptId} + </foreach> + </update> + + <delete id="deleteDeptById" parameterType="Long"> + update sys_dept set del_flag = '2' where dept_id = #{deptId} + </delete> + +</mapper> \ No newline at end of file diff --git a/dc-system/src/main/resources/mapper/system/SysDictDataMapper.xml b/dc-system/src/main/resources/mapper/system/SysDictDataMapper.xml new file mode 100644 index 0000000..8f1676c --- /dev/null +++ b/dc-system/src/main/resources/mapper/system/SysDictDataMapper.xml @@ -0,0 +1,125 @@ +<?xml version="1.0" encoding="UTF-8" ?> +<!DOCTYPE mapper + PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" + "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> +<mapper namespace="com.dc.system.mapper.SysDictDataMapper"> + + <resultMap type="SysDictData" id="SysDictDataResult"> + <id property="dictCode" column="dict_code"/> + <result property="dictSort" column="dict_sort"/> + <result property="dictLabel" column="dict_label"/> + <result property="dictValue" column="dict_value"/> + <result property="dictType" column="dict_type"/> + <result property="cssClass" column="css_class"/> + <result property="listClass" column="list_class"/> + <result property="isDefault" column="is_default"/> + <result property="status" column="status"/> + <result property="createBy" column="create_by"/> + <result property="createTime" column="create_time"/> + <result property="updateBy" column="update_by"/> + <result property="updateTime" column="update_time"/> + </resultMap> + + <sql id="selectDictDataVo"> + select dict_code, dict_sort, dict_label, dict_value, dict_type, css_class, list_class, is_default, status, + create_by, create_time, remark + from sys_dict_data + </sql> + + <select id="selectDictDataList" parameterType="SysDictData" resultMap="SysDictDataResult"> + <include refid="selectDictDataVo"/> + <where> + <if test="dictType != null and dictType != ''"> + AND dict_type = #{dictType} + </if> + <if test="dictLabel != null and dictLabel != ''"> + AND dict_label like concat('%', #{dictLabel}, '%') + </if> + <if test="status != null and status != ''"> + AND status = #{status} + </if> + </where> + order by dict_sort asc + </select> + + <select id="selectDictDataByType" parameterType="SysDictData" resultMap="SysDictDataResult"> + <include refid="selectDictDataVo"/> + where status = '0' and dict_type = #{dictType} order by dict_sort asc + </select> + + <select id="selectDictLabel" resultType="String"> + select dict_label from sys_dict_data + where dict_type = #{dictType} and dict_value = #{dictValue} + </select> + + <select id="selectDictDataById" parameterType="Long" resultMap="SysDictDataResult"> + <include refid="selectDictDataVo"/> + where dict_code = #{dictCode} + </select> + + <select id="countDictDataByType" resultType="Integer"> + select count(1) from sys_dict_data where dict_type=#{dictType} + </select> + + <delete id="deleteDictDataById" parameterType="Long"> + delete from sys_dict_data where dict_code = #{dictCode} + </delete> + + <delete id="deleteDictDataByIds" parameterType="Long"> + delete from sys_dict_data where dict_code in + <foreach collection="array" item="dictCode" open="(" separator="," close=")"> + #{dictCode} + </foreach> + </delete> + + <update id="updateDictData" parameterType="SysDictData"> + update sys_dict_data + <set> + <if test="dictSort != null">dict_sort = #{dictSort},</if> + <if test="dictLabel != null and dictLabel != ''">dict_label = #{dictLabel},</if> + <if test="dictValue != null and dictValue != ''">dict_value = #{dictValue},</if> + <if test="dictType != null and dictType != ''">dict_type = #{dictType},</if> + <if test="cssClass != null">css_class = #{cssClass},</if> + <if test="listClass != null">list_class = #{listClass},</if> + <if test="isDefault != null and isDefault != ''">is_default = #{isDefault},</if> + <if test="status != null">status = #{status},</if> + <if test="remark != null">remark = #{remark},</if> + <if test="updateBy != null and updateBy != ''">update_by = #{updateBy},</if> + update_time = current_timestamp + </set> + where dict_code = #{dictCode} + </update> + + <update id="updateDictDataType" parameterType="String"> + update sys_dict_data set dict_type = #{newDictType} where dict_type = #{oldDictType} + </update> + + <insert id="insertDictData" parameterType="SysDictData"> + insert into sys_dict_data( + <if test="dictSort != null">dict_sort,</if> + <if test="dictLabel != null and dictLabel != ''">dict_label,</if> + <if test="dictValue != null and dictValue != ''">dict_value,</if> + <if test="dictType != null and dictType != ''">dict_type,</if> + <if test="cssClass != null and cssClass != ''">css_class,</if> + <if test="listClass != null and listClass != ''">list_class,</if> + <if test="isDefault != null and isDefault != ''">is_default,</if> + <if test="status != null">status,</if> + <if test="remark != null and remark != ''">remark,</if> + <if test="createBy != null and createBy != ''">create_by,</if> + create_time + )values( + <if test="dictSort != null">#{dictSort},</if> + <if test="dictLabel != null and dictLabel != ''">#{dictLabel},</if> + <if test="dictValue != null and dictValue != ''">#{dictValue},</if> + <if test="dictType != null and dictType != ''">#{dictType},</if> + <if test="cssClass != null and cssClass != ''">#{cssClass},</if> + <if test="listClass != null and listClass != ''">#{listClass},</if> + <if test="isDefault != null and isDefault != ''">#{isDefault},</if> + <if test="status != null">#{status},</if> + <if test="remark != null and remark != ''">#{remark},</if> + <if test="createBy != null and createBy != ''">#{createBy},</if> + current_timestamp + ) + </insert> + +</mapper> \ No newline at end of file diff --git a/dc-system/src/main/resources/mapper/system/SysDictTypeMapper.xml b/dc-system/src/main/resources/mapper/system/SysDictTypeMapper.xml new file mode 100644 index 0000000..dacd8eb --- /dev/null +++ b/dc-system/src/main/resources/mapper/system/SysDictTypeMapper.xml @@ -0,0 +1,105 @@ +<?xml version="1.0" encoding="UTF-8" ?> +<!DOCTYPE mapper + PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" + "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> +<mapper namespace="com.dc.system.mapper.SysDictTypeMapper"> + + <resultMap type="SysDictType" id="SysDictTypeResult"> + <id property="dictId" column="dict_id"/> + <result property="dictName" column="dict_name"/> + <result property="dictType" column="dict_type"/> + <result property="status" column="status"/> + <result property="createBy" column="create_by"/> + <result property="createTime" column="create_time"/> + <result property="updateBy" column="update_by"/> + <result property="updateTime" column="update_time"/> + </resultMap> + + <sql id="selectDictTypeVo"> + select dict_id, dict_name, dict_type, status, create_by, create_time, remark + from sys_dict_type + </sql> + + <select id="selectDictTypeList" parameterType="SysDictType" resultMap="SysDictTypeResult"> + <include refid="selectDictTypeVo"/> + <where> + <if test="dictName != null and dictName != ''"> + AND dict_name like concat('%', #{dictName}, '%') + </if> + <if test="status != null and status != ''"> + AND status = #{status} + </if> + <if test="dictType != null and dictType != ''"> + AND dict_type like concat('%', #{dictType}, '%') + </if> + <if test="params.beginTime != null and params.beginTime != ''"><!-- 开始时间检索 --> + and create_time::date >= to_date(#{params.beginTime},'yyyy-MM-dd') + </if> + <if test="params.endTime != null and params.endTime != ''"><!-- 结束时间检索 --> + and create_time::Date <= to_date(#{params.endTime},'yyyy-MM-dd') + </if> + </where> + </select> + + <select id="selectDictTypeAll" resultMap="SysDictTypeResult"> + <include refid="selectDictTypeVo"/> + </select> + + <select id="selectDictTypeById" parameterType="Long" resultMap="SysDictTypeResult"> + <include refid="selectDictTypeVo"/> + where dict_id = #{dictId} + </select> + + <select id="selectDictTypeByType" parameterType="String" resultMap="SysDictTypeResult"> + <include refid="selectDictTypeVo"/> + where dict_type = #{dictType} + </select> + + <select id="checkDictTypeUnique" parameterType="String" resultMap="SysDictTypeResult"> + <include refid="selectDictTypeVo"/> + where dict_type = #{dictType} limit 1 + </select> + + <delete id="deleteDictTypeById" parameterType="Long"> + delete from sys_dict_type where dict_id = #{dictId} + </delete> + + <delete id="deleteDictTypeByIds" parameterType="Long"> + delete from sys_dict_type where dict_id in + <foreach collection="array" item="dictId" open="(" separator="," close=")"> + #{dictId} + </foreach> + </delete> + + <update id="updateDictType" parameterType="SysDictType"> + update sys_dict_type + <set> + <if test="dictName != null and dictName != ''">dict_name = #{dictName},</if> + <if test="dictType != null and dictType != ''">dict_type = #{dictType},</if> + <if test="status != null">status = #{status},</if> + <if test="remark != null">remark = #{remark},</if> + <if test="updateBy != null and updateBy != ''">update_by = #{updateBy},</if> + update_time = current_timestamp + </set> + where dict_id = #{dictId} + </update> + + <insert id="insertDictType" parameterType="SysDictType"> + insert into sys_dict_type( + <if test="dictName != null and dictName != ''">dict_name,</if> + <if test="dictType != null and dictType != ''">dict_type,</if> + <if test="status != null">status,</if> + <if test="remark != null and remark != ''">remark,</if> + <if test="createBy != null and createBy != ''">create_by,</if> + create_time + )values( + <if test="dictName != null and dictName != ''">#{dictName},</if> + <if test="dictType != null and dictType != ''">#{dictType},</if> + <if test="status != null">#{status},</if> + <if test="remark != null and remark != ''">#{remark},</if> + <if test="createBy != null and createBy != ''">#{createBy},</if> + current_timestamp + ) + </insert> + +</mapper> \ No newline at end of file diff --git a/dc-system/src/main/resources/mapper/system/SysLogininforMapper.xml b/dc-system/src/main/resources/mapper/system/SysLogininforMapper.xml new file mode 100644 index 0000000..287033e --- /dev/null +++ b/dc-system/src/main/resources/mapper/system/SysLogininforMapper.xml @@ -0,0 +1,57 @@ +<?xml version="1.0" encoding="UTF-8" ?> +<!DOCTYPE mapper + PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" + "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> +<mapper namespace="com.dc.system.mapper.SysLogininforMapper"> + + <resultMap type="SysLogininfor" id="SysLogininforResult"> + <id property="infoId" column="info_id"/> + <result property="userName" column="user_name"/> + <result property="status" column="status"/> + <result property="ipaddr" column="ipaddr"/> + <result property="loginLocation" column="login_location"/> + <result property="browser" column="browser"/> + <result property="os" column="os"/> + <result property="msg" column="msg"/> + <result property="loginTime" column="login_time"/> + </resultMap> + + <insert id="insertLogininfor" parameterType="SysLogininfor"> + insert into sys_logininfor (user_name, status, ipaddr, login_location, browser, os, msg, login_time) + values (#{userName}, #{status}, #{ipaddr}, #{loginLocation}, #{browser}, #{os}, #{msg}, current_timestamp) + </insert> + + <select id="selectLogininforList" parameterType="SysLogininfor" resultMap="SysLogininforResult"> + select info_id, user_name, ipaddr, login_location, browser, os, status, msg, login_time from sys_logininfor + <where> + <if test="ipaddr != null and ipaddr != ''"> + AND ipaddr like concat('%', #{ipaddr}, '%') + </if> + <if test="status != null and status != ''"> + AND status = #{status} + </if> + <if test="userName != null and userName != ''"> + AND user_name like concat('%', #{userName}, '%') + </if> + <if test="params.beginTime != null and params.beginTime != ''"><!-- 开始时间检索 --> + and login_time::date >= to_date(#{params.beginTime},'yyyy-MM-dd') + </if> + <if test="params.endTime != null and params.endTime != ''"><!-- 结束时间检索 --> + and login_time::date <= to_date(#{params.endTime},'yyyy-MM-dd') + </if> + </where> + order by info_id desc + </select> + + <delete id="deleteLogininforByIds" parameterType="Long"> + delete from sys_logininfor where info_id in + <foreach collection="array" item="infoId" open="(" separator="," close=")"> + #{infoId} + </foreach> + </delete> + + <update id="cleanLogininfor"> + truncate table sys_logininfor + </update> + +</mapper> \ No newline at end of file diff --git a/dc-system/src/main/resources/mapper/system/SysMenuMapper.xml b/dc-system/src/main/resources/mapper/system/SysMenuMapper.xml new file mode 100644 index 0000000..86217f5 --- /dev/null +++ b/dc-system/src/main/resources/mapper/system/SysMenuMapper.xml @@ -0,0 +1,207 @@ +<?xml version="1.0" encoding="UTF-8" ?> +<!DOCTYPE mapper + PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" + "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> +<mapper namespace="com.dc.system.mapper.SysMenuMapper"> + + <resultMap type="SysMenu" id="SysMenuResult"> + <id property="menuId" column="menu_id"/> + <result property="menuName" column="menu_name"/> + <result property="parentName" column="parent_name"/> + <result property="parentId" column="parent_id"/> + <result property="orderNum" column="order_num"/> + <result property="path" column="path"/> + <result property="component" column="component"/> + <result property="query" column="query"/> + <result property="isFrame" column="is_frame"/> + <result property="isCache" column="is_cache"/> + <result property="menuType" column="menu_type"/> + <result property="visible" column="visible"/> + <result property="status" column="status"/> + <result property="perms" column="perms"/> + <result property="icon" column="icon"/> + <result property="createBy" column="create_by"/> + <result property="createTime" column="create_time"/> + <result property="updateTime" column="update_time"/> + <result property="updateBy" column="update_by"/> + <result property="remark" column="remark"/> + </resultMap> + + <sql id="selectMenuVo"> + select menu_id, menu_name, parent_id, order_num, path, component, query, is_frame, is_cache, menu_type, visible, + status, nullif(perms,'') as perms, icon, create_time + from sys_menu + </sql> + + <select id="selectMenuList" parameterType="SysMenu" resultMap="SysMenuResult"> + <include refid="selectMenuVo"/> + <where> + <if test="menuName != null and menuName != ''"> + AND menu_name like concat('%', #{menuName}, '%') + </if> + <if test="visible != null and visible != ''"> + AND visible = #{visible} + </if> + <if test="status != null and status != ''"> + AND status = #{status}::integer + </if> + </where> + order by parent_id, order_num + </select> + + <select id="selectMenuTreeAll" resultMap="SysMenuResult"> + select distinct m.menu_id, m.parent_id, m.menu_name, m.path, m.component, m.query, m.visible, m.status, + nullif(m.perms,'') as perms, m.is_frame, m.is_cache, m.menu_type, m.icon, m.order_num, m.create_time + from sys_menu m where m.menu_type in ('M', 'C') and m.status = 0 + order by m.parent_id, m.order_num + </select> + + <select id="selectMenuListByUserId" parameterType="SysMenu" resultMap="SysMenuResult"> + select distinct m.menu_id, m.parent_id, m.menu_name, m.path, m.component, m.query, m.visible, m.status, + nullif(m.perms,'') as perms, m.is_frame, m.is_cache, m.menu_type, m.icon, m.order_num, m.create_time + from sys_menu m + left join sys_role_menu rm on m.menu_id = rm.menu_id + left join sys_user_role ur on rm.role_id = ur.role_id + left join sys_role ro on ur.role_id = ro.role_id + where ur.user_id = #{params.userId} + <if test="menuName != null and menuName != ''"> + AND m.menu_name like concat('%', #{menuName}, '%') + </if> + <if test="visible != null and visible != ''"> + AND m.visible = #{visible} + </if> + <if test="status != null and status != ''"> + AND m.status = #{status}::integer + </if> + order by m.parent_id, m.order_num + </select> + + <select id="selectMenuTreeByUserId" parameterType="Long" resultMap="SysMenuResult"> + select distinct m.menu_id, m.parent_id, m.menu_name, m.path, m.component, m.query, m.visible, m.status, + nullif(m.perms,'') as perms, m.is_frame, m.is_cache, m.menu_type, m.icon, m.order_num, m.create_time + from sys_menu m + left join sys_role_menu rm on m.menu_id = rm.menu_id + left join sys_user_role ur on rm.role_id = ur.role_id + left join sys_role ro on ur.role_id = ro.role_id + left join sys_user u on ur.user_id = u.user_id + where u.user_id = #{userId} and m.menu_type in ('M', 'C') and m.status = '0' AND ro.status = '0' + order by m.parent_id, m.order_num + </select> + + <select id="selectMenuListByRoleId" resultType="Long"> + select m.menu_id + from sys_menu m + left join sys_role_menu rm on m.menu_id = rm.menu_id + where rm.role_id = #{roleId} + <if test="menuCheckStrictly"> + and m.menu_id not in (select m.parent_id from sys_menu m inner join sys_role_menu rm on m.menu_id = + rm.menu_id and rm.role_id = #{roleId}) + </if> + order by m.parent_id, m.order_num + </select> + + <select id="selectMenuPerms" resultType="String"> + select distinct m.perms + from sys_menu m + left join sys_role_menu rm on m.menu_id = rm.menu_id + left join sys_user_role ur on rm.role_id = ur.role_id + </select> + + <select id="selectMenuPermsByUserId" parameterType="Long" resultType="String"> + select distinct m.perms + from sys_menu m + left join sys_role_menu rm on m.menu_id = rm.menu_id + left join sys_user_role ur on rm.role_id = ur.role_id + left join sys_role r on r.role_id = ur.role_id + where m.status = '0' and r.status = '0' and ur.user_id = #{userId} + </select> + + <select id="selectMenuPermsByRoleId" parameterType="Long" resultType="String"> + select distinct m.perms + from sys_menu m + left join sys_role_menu rm on m.menu_id = rm.menu_id + where m.status = '0' and rm.role_id = #{roleId} + </select> + + <select id="selectMenuById" parameterType="Long" resultMap="SysMenuResult"> + <include refid="selectMenuVo"/> + where menu_id = #{menuId} + </select> + + <select id="hasChildByMenuId" resultType="Integer"> + select count(1) from sys_menu where parent_id = #{menuId} + </select> + + <select id="checkMenuNameUnique" parameterType="SysMenu" resultMap="SysMenuResult"> + <include refid="selectMenuVo"/> + where menu_name=#{menuName} and parent_id = #{parentId} limit 1 + </select> + + <update id="updateMenu" parameterType="SysMenu"> + update sys_menu + <set> + <if test="menuName != null and menuName != ''">menu_name = #{menuName},</if> + <if test="parentId != null">parent_id = #{parentId},</if> + <if test="orderNum != null">order_num = #{orderNum},</if> + <if test="path != null and path != ''">path = #{path},</if> + <if test="component != null">component = #{component},</if> + <if test="query != null">query = #{query},</if> + <if test="isFrame != null and isFrame != ''">is_frame = #{isFrame}::integer,</if> + <if test="isCache != null and isCache != ''">is_cache = #{isCache}::integer,</if> + <if test="menuType != null and menuType != ''">menu_type = #{menuType},</if> + <if test="visible != null">visible = #{visible},</if> + <if test="status != null">status = #{status}::integer,</if> + <if test="perms !=null">perms = #{perms},</if> + <if test="icon !=null and icon != ''">icon = #{icon},</if> + <if test="remark != null and remark != ''">remark = #{remark},</if> + <if test="updateBy != null and updateBy != ''">update_by = #{updateBy},</if> + update_time = current_timestamp + </set> + where menu_id = #{menuId} + </update> + + <insert id="insertMenu" parameterType="SysMenu"> + insert into sys_menu( + <if test="menuId != null and menuId != 0">menu_id,</if> + <if test="parentId != null and parentId != 0">parent_id,</if> + <if test="menuName != null and menuName != ''">menu_name,</if> + <if test="orderNum != null">order_num,</if> + <if test="path != null and path != ''">path,</if> + <if test="component != null and component != ''">component,</if> + <if test="query != null and query != ''">query,</if> + <if test="isFrame != null and isFrame != ''">is_frame,</if> + <if test="isCache != null and isCache != ''">is_cache,</if> + <if test="menuType != null and menuType != ''">menu_type,</if> + <if test="visible != null">visible,</if> + <if test="status != null">status,</if> + <if test="perms !=null and perms != ''">perms,</if> + <if test="icon != null and icon != ''">icon,</if> + <if test="remark != null and remark != ''">remark,</if> + <if test="createBy != null and createBy != ''">create_by,</if> + create_time + )values( + <if test="menuId != null and menuId != 0">#{menuId},</if> + <if test="parentId != null and parentId != 0">#{parentId},</if> + <if test="menuName != null and menuName != ''">#{menuName},</if> + <if test="orderNum != null">#{orderNum},</if> + <if test="path != null and path != ''">#{path},</if> + <if test="component != null and component != ''">#{component},</if> + <if test="query != null and query != ''">#{query},</if> + <if test="isFrame != null and isFrame != ''">#{isFrame}::integer,</if> + <if test="isCache != null and isCache != ''">#{isCache}::integer,</if> + <if test="menuType != null and menuType != ''">#{menuType},</if> + <if test="visible != null">#{visible},</if> + <if test="status != null">#{status}::integer,</if> + <if test="perms !=null and perms != ''">#{perms},</if> + <if test="icon != null and icon != ''">#{icon},</if> + <if test="remark != null and remark != ''">#{remark},</if> + <if test="createBy != null and createBy != ''">#{createBy},</if> + current_timestamp + ) + </insert> + + <delete id="deleteMenuById" parameterType="Long"> + delete from sys_menu where menu_id = #{menuId} + </delete> + +</mapper> \ No newline at end of file diff --git a/dc-system/src/main/resources/mapper/system/SysNoticeMapper.xml b/dc-system/src/main/resources/mapper/system/SysNoticeMapper.xml new file mode 100644 index 0000000..bb8ef4b --- /dev/null +++ b/dc-system/src/main/resources/mapper/system/SysNoticeMapper.xml @@ -0,0 +1,90 @@ +<?xml version="1.0" encoding="UTF-8" ?> +<!DOCTYPE mapper + PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" + "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> +<mapper namespace="com.dc.system.mapper.SysNoticeMapper"> + + <resultMap type="SysNotice" id="SysNoticeResult"> + <result property="noticeId" column="notice_id"/> + <result property="noticeTitle" column="notice_title"/> + <result property="noticeType" column="notice_type"/> + <result property="noticeContent" column="notice_content"/> + <result property="status" column="status"/> + <result property="createBy" column="create_by"/> + <result property="createTime" column="create_time"/> + <result property="updateBy" column="update_by"/> + <result property="updateTime" column="update_time"/> + <result property="remark" column="remark"/> + </resultMap> + + <sql id="selectNoticeVo"> + select notice_id, notice_title, notice_type, notice_content, status, create_by, create_time, update_by, + update_time, remark + from sys_notice + </sql> + + <select id="selectNoticeById" parameterType="Long" resultMap="SysNoticeResult"> + <include refid="selectNoticeVo"/> + where notice_id = #{noticeId} + </select> + + <select id="selectNoticeList" parameterType="SysNotice" resultMap="SysNoticeResult"> + <include refid="selectNoticeVo"/> + <where> + <if test="noticeTitle != null and noticeTitle != ''"> + AND notice_title like concat('%', #{noticeTitle}, '%') + </if> + <if test="noticeType != null and noticeType != ''"> + AND notice_type = #{noticeType} + </if> + <if test="createBy != null and createBy != ''"> + AND create_by like concat('%', #{createBy}, '%') + </if> + </where> + </select> + + <insert id="insertNotice" parameterType="SysNotice"> + insert into sys_notice ( + <if test="noticeTitle != null and noticeTitle != '' ">notice_title,</if> + <if test="noticeType != null and noticeType != '' ">notice_type,</if> + <if test="noticeContent != null and noticeContent != '' ">notice_content,</if> + <if test="status != null and status != '' ">status,</if> + <if test="remark != null and remark != ''">remark,</if> + <if test="createBy != null and createBy != ''">create_by,</if> + create_time + )values( + <if test="noticeTitle != null and noticeTitle != ''">#{noticeTitle},</if> + <if test="noticeType != null and noticeType != ''">#{noticeType},</if> + <if test="noticeContent != null and noticeContent != ''">#{noticeContent},</if> + <if test="status != null and status != ''">#{status},</if> + <if test="remark != null and remark != ''">#{remark},</if> + <if test="createBy != null and createBy != ''">#{createBy},</if> + current_timestamp + ) + </insert> + + <update id="updateNotice" parameterType="SysNotice"> + update sys_notice + <set> + <if test="noticeTitle != null and noticeTitle != ''">notice_title = #{noticeTitle},</if> + <if test="noticeType != null and noticeType != ''">notice_type = #{noticeType},</if> + <if test="noticeContent != null">notice_content = #{noticeContent},</if> + <if test="status != null and status != ''">status = #{status},</if> + <if test="updateBy != null and updateBy != ''">update_by = #{updateBy},</if> + update_time = current_timestamp + </set> + where notice_id = #{noticeId} + </update> + + <delete id="deleteNoticeById" parameterType="Long"> + delete from sys_notice where notice_id = #{noticeId} + </delete> + + <delete id="deleteNoticeByIds" parameterType="Long"> + delete from sys_notice where notice_id in + <foreach item="noticeId" collection="array" open="(" separator="," close=")"> + #{noticeId} + </foreach> + </delete> + +</mapper> diff --git a/dc-system/src/main/resources/mapper/system/SysOperLogMapper.xml b/dc-system/src/main/resources/mapper/system/SysOperLogMapper.xml new file mode 100644 index 0000000..b0ffbe6 --- /dev/null +++ b/dc-system/src/main/resources/mapper/system/SysOperLogMapper.xml @@ -0,0 +1,86 @@ +<?xml version="1.0" encoding="UTF-8" ?> +<!DOCTYPE mapper + PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" + "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> +<mapper namespace="com.dc.system.mapper.SysOperLogMapper"> + + <resultMap type="SysOperLog" id="SysOperLogResult"> + <id property="operId" column="oper_id"/> + <result property="title" column="title"/> + <result property="businessType" column="business_type"/> + <result property="method" column="method"/> + <result property="requestMethod" column="request_method"/> + <result property="operatorType" column="operator_type"/> + <result property="operName" column="oper_name"/> + <result property="deptName" column="dept_name"/> + <result property="operUrl" column="oper_url"/> + <result property="operIp" column="oper_ip"/> + <result property="operLocation" column="oper_location"/> + <result property="operParam" column="oper_param"/> + <result property="jsonResult" column="json_result"/> + <result property="status" column="status"/> + <result property="errorMsg" column="error_msg"/> + <result property="operTime" column="oper_time"/> + </resultMap> + + <sql id="selectOperLogVo"> + select oper_id, title, business_type, method, request_method, operator_type, oper_name, dept_name, oper_url, + oper_ip, oper_location, oper_param, json_result, status, error_msg, oper_time + from sys_oper_log + </sql> + + <insert id="insertOperlog" parameterType="SysOperLog"> + insert into sys_oper_log(title, business_type, method, request_method, operator_type, oper_name, dept_name, + oper_url, oper_ip, oper_location, oper_param, json_result, status, error_msg, oper_time) + values (#{title}, #{businessType}, #{method}, #{requestMethod}, #{operatorType}, #{operName}, #{deptName}, + #{operUrl}, #{operIp}, #{operLocation}, #{operParam}, #{jsonResult}, #{status}, #{errorMsg}, current_timestamp) + </insert> + + <select id="selectOperLogList" parameterType="SysOperLog" resultMap="SysOperLogResult"> + <include refid="selectOperLogVo"/> + <where> + <if test="title != null and title != ''"> + AND title like concat('%', #{title}, '%') + </if> + <if test="businessType != null"> + AND business_type = #{businessType} + </if> + <if test="businessTypes != null and businessTypes.length > 0"> + AND business_type in + <foreach collection="businessTypes" item="businessType" open="(" separator="," close=")"> + #{businessType} + </foreach> + </if> + <if test="status != null"> + AND status = #{status} + </if> + <if test="operName != null and operName != ''"> + AND oper_name like concat('%', #{operName}, '%') + </if> + <if test="params.beginTime != null and params.beginTime != ''"><!-- 开始时间检索 --> + and oper_time::date >= to_date(#{params.beginTime},'yyyy-MM-dd') + </if> + <if test="params.endTime != null and params.endTime != ''"><!-- 结束时间检索 --> + and oper_time::date <= to_date(#{params.endTime},'yyyy-MM-dd') + </if> + </where> + order by oper_id desc + </select> + + <delete id="deleteOperLogByIds" parameterType="Long"> + delete from sys_oper_log where oper_id in + <foreach collection="array" item="operId" open="(" separator="," close=")"> + #{operId} + </foreach> + </delete> + + <select id="selectOperLogById" parameterType="Long" resultMap="SysOperLogResult"> + <include refid="selectOperLogVo"/> + where oper_id = #{operId} + </select> + + <update id="cleanOperLog"> + truncate table sys_oper_log + </update> + +</mapper> \ No newline at end of file diff --git a/dc-system/src/main/resources/mapper/system/SysPostMapper.xml b/dc-system/src/main/resources/mapper/system/SysPostMapper.xml new file mode 100644 index 0000000..35956ea --- /dev/null +++ b/dc-system/src/main/resources/mapper/system/SysPostMapper.xml @@ -0,0 +1,122 @@ +<?xml version="1.0" encoding="UTF-8" ?> +<!DOCTYPE mapper + PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" + "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> +<mapper namespace="com.dc.system.mapper.SysPostMapper"> + + <resultMap type="SysPost" id="SysPostResult"> + <id property="postId" column="post_id"/> + <result property="postCode" column="post_code"/> + <result property="postName" column="post_name"/> + <result property="postSort" column="post_sort"/> + <result property="status" column="status"/> + <result property="createBy" column="create_by"/> + <result property="createTime" column="create_time"/> + <result property="updateBy" column="update_by"/> + <result property="updateTime" column="update_time"/> + <result property="remark" column="remark"/> + </resultMap> + + <sql id="selectPostVo"> + select post_id, post_code, post_name, post_sort, status, create_by, create_time, remark + from sys_post + </sql> + + <select id="selectPostList" parameterType="SysPost" resultMap="SysPostResult"> + <include refid="selectPostVo"/> + <where> + <if test="postCode != null and postCode != ''"> + AND post_code like concat('%', #{postCode}, '%') + </if> + <if test="status != null and status != ''"> + AND status = #{status} + </if> + <if test="postName != null and postName != ''"> + AND post_name like concat('%', #{postName}, '%') + </if> + </where> + </select> + + <select id="selectPostAll" resultMap="SysPostResult"> + <include refid="selectPostVo"/> + </select> + + <select id="selectPostById" parameterType="Long" resultMap="SysPostResult"> + <include refid="selectPostVo"/> + where post_id = #{postId} + </select> + + <select id="selectPostListByUserId" parameterType="Long" resultType="Long"> + select p.post_id + from sys_post p + left join sys_user_post up on up.post_id = p.post_id + left join sys_user u on u.user_id = up.user_id + where u.user_id = #{userId} + </select> + + <select id="selectPostsByUserName" parameterType="String" resultMap="SysPostResult"> + select p.post_id, p.post_name, p.post_code + from sys_post p + left join sys_user_post up on up.post_id = p.post_id + left join sys_user u on u.user_id = up.user_id + where u.user_name = #{userName} + </select> + + <select id="checkPostNameUnique" parameterType="String" resultMap="SysPostResult"> + <include refid="selectPostVo"/> + where post_name=#{postName} limit 1 + </select> + + <select id="checkPostCodeUnique" parameterType="String" resultMap="SysPostResult"> + <include refid="selectPostVo"/> + where post_code=#{postCode} limit 1 + </select> + + <update id="updatePost" parameterType="SysPost"> + update sys_post + <set> + <if test="postCode != null and postCode != ''">post_code = #{postCode},</if> + <if test="postName != null and postName != ''">post_name = #{postName},</if> + <if test="postSort != null and postSort != ''">post_sort = #{postSort},</if> + <if test="status != null and status != ''">status = #{status},</if> + <if test="remark != null">remark = #{remark},</if> + <if test="updateBy != null and updateBy != ''">update_by = #{updateBy},</if> + update_time = current_timestamp + </set> + where post_id = #{postId} + </update> + + <insert id="insertPost" parameterType="SysPost" useGeneratedKeys="true" keyProperty="postId"> + insert into sys_post( + <if test="postId != null and postId != 0">post_id,</if> + <if test="postCode != null and postCode != ''">post_code,</if> + <if test="postName != null and postName != ''">post_name,</if> + <if test="postSort != null and postSort != ''">post_sort,</if> + <if test="status != null and status != ''">status,</if> + <if test="remark != null and remark != ''">remark,</if> + <if test="createBy != null and createBy != ''">create_by,</if> + create_time + )values( + <if test="postId != null and postId != 0">#{postId},</if> + <if test="postCode != null and postCode != ''">#{postCode},</if> + <if test="postName != null and postName != ''">#{postName},</if> + <if test="postSort != null and postSort != ''">#{postSort},</if> + <if test="status != null and status != ''">#{status},</if> + <if test="remark != null and remark != ''">#{remark},</if> + <if test="createBy != null and createBy != ''">#{createBy},</if> + current_timestamp + ) + </insert> + + <delete id="deletePostById" parameterType="Long"> + delete from sys_post where post_id = #{postId} + </delete> + + <delete id="deletePostByIds" parameterType="Long"> + delete from sys_post where post_id in + <foreach collection="array" item="postId" open="(" separator="," close=")"> + #{postId} + </foreach> + </delete> + +</mapper> \ No newline at end of file diff --git a/dc-system/src/main/resources/mapper/system/SysRoleDeptMapper.xml b/dc-system/src/main/resources/mapper/system/SysRoleDeptMapper.xml new file mode 100644 index 0000000..b0dc35a --- /dev/null +++ b/dc-system/src/main/resources/mapper/system/SysRoleDeptMapper.xml @@ -0,0 +1,34 @@ +<?xml version="1.0" encoding="UTF-8" ?> +<!DOCTYPE mapper + PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" + "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> +<mapper namespace="com.dc.system.mapper.SysRoleDeptMapper"> + + <resultMap type="SysRoleDept" id="SysRoleDeptResult"> + <result property="roleId" column="role_id"/> + <result property="deptId" column="dept_id"/> + </resultMap> + + <delete id="deleteRoleDeptByRoleId" parameterType="Long"> + delete from sys_role_dept where role_id=#{roleId} + </delete> + + <select id="selectCountRoleDeptByDeptId" resultType="Integer"> + select count(1) from sys_role_dept where dept_id=#{deptId} + </select> + + <delete id="deleteRoleDept" parameterType="Long"> + delete from sys_role_dept where role_id in + <foreach collection="array" item="roleId" open="(" separator="," close=")"> + #{roleId} + </foreach> + </delete> + + <insert id="batchRoleDept"> + insert into sys_role_dept(role_id, dept_id) values + <foreach item="item" index="index" collection="list" separator=","> + (#{item.roleId},#{item.deptId}) + </foreach> + </insert> + +</mapper> \ No newline at end of file diff --git a/dc-system/src/main/resources/mapper/system/SysRoleMapper.xml b/dc-system/src/main/resources/mapper/system/SysRoleMapper.xml new file mode 100644 index 0000000..ab95da0 --- /dev/null +++ b/dc-system/src/main/resources/mapper/system/SysRoleMapper.xml @@ -0,0 +1,153 @@ +<?xml version="1.0" encoding="UTF-8" ?> +<!DOCTYPE mapper + PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" + "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> +<mapper namespace="com.dc.system.mapper.SysRoleMapper"> + + <resultMap type="SysRole" id="SysRoleResult"> + <id property="roleId" column="role_id"/> + <result property="roleName" column="role_name"/> + <result property="roleKey" column="role_key"/> + <result property="roleSort" column="role_sort"/> + <result property="dataScope" column="data_scope"/> + <result property="menuCheckStrictly" column="menu_check_strictly"/> + <result property="deptCheckStrictly" column="dept_check_strictly"/> + <result property="status" column="status"/> + <result property="delFlag" column="del_flag"/> + <result property="createBy" column="create_by"/> + <result property="createTime" column="create_time"/> + <result property="updateBy" column="update_by"/> + <result property="updateTime" column="update_time"/> + <result property="remark" column="remark"/> + </resultMap> + + <sql id="selectRoleVo"> + select distinct r.role_id, r.role_name, r.role_key, r.role_sort, r.data_scope, r.menu_check_strictly, + r.dept_check_strictly, + r.status, r.del_flag, r.create_time, r.remark + from sys_role r + left join sys_user_role ur on ur.role_id = r.role_id + left join sys_user u on u.user_id = ur.user_id + left join sys_dept d on u.dept_id = d.dept_id + </sql> + + <select id="selectRoleList" parameterType="SysRole" resultMap="SysRoleResult"> + <include refid="selectRoleVo"/> + where r.del_flag = '0' + <if test="roleId != null and roleId != 0"> + AND r.role_id = #{roleId} + </if> + <if test="roleName != null and roleName != ''"> + AND r.role_name like concat('%', #{roleName}, '%') + </if> + <if test="status != null and status != ''"> + AND r.status = #{status} + </if> + <if test="roleKey != null and roleKey != ''"> + AND r.role_key like concat('%', #{roleKey}, '%') + </if> + <if test="params.beginTime != null and params.beginTime != ''"><!-- 开始时间检索 --> + and r.create_time::date >= to_date(#{params.beginTime},'yyyy-MM-dd') + </if> + <if test="params.endTime != null and params.endTime != ''"><!-- 结束时间检索 --> + and r.create_time::date <= to_date(#{params.endTime},'yyyy-MM-dd') + </if> + <!-- 数据范围过滤 --> + ${params.dataScope} + order by r.role_sort + </select> + + <select id="selectRolePermissionByUserId" parameterType="Long" resultMap="SysRoleResult"> + <include refid="selectRoleVo"/> + WHERE r.del_flag = '0' and ur.user_id = #{userId} + </select> + + <select id="selectRoleAll" resultMap="SysRoleResult"> + <include refid="selectRoleVo"/> + </select> + + <select id="selectRoleListByUserId" parameterType="Long" resultType="Long"> + select r.role_id + from sys_role r + left join sys_user_role ur on ur.role_id = r.role_id + left join sys_user u on u.user_id = ur.user_id + where u.user_id = #{userId} + </select> + + <select id="selectRoleById" parameterType="Long" resultMap="SysRoleResult"> + <include refid="selectRoleVo"/> + where r.role_id = #{roleId} + </select> + + <select id="selectRolesByUserName" parameterType="String" resultMap="SysRoleResult"> + <include refid="selectRoleVo"/> + WHERE r.del_flag = '0' and u.user_name = #{userName} + </select> + + <select id="checkRoleNameUnique" parameterType="String" resultMap="SysRoleResult"> + <include refid="selectRoleVo"/> + where r.role_name=#{roleName} and r.del_flag = '0' limit 1 + </select> + + <select id="checkRoleKeyUnique" parameterType="String" resultMap="SysRoleResult"> + <include refid="selectRoleVo"/> + where r.role_key=#{roleKey} and r.del_flag = '0' limit 1 + </select> + + <insert id="insertRole" parameterType="SysRole" useGeneratedKeys="true" keyProperty="roleId"> + insert into sys_role( + <if test="roleId != null and roleId != 0">role_id,</if> + <if test="roleName != null and roleName != ''">role_name,</if> + <if test="roleKey != null and roleKey != ''">role_key,</if> + <if test="roleSort != null and roleSort != ''">role_sort,</if> + <if test="dataScope != null and dataScope != ''">data_scope,</if> + <if test="menuCheckStrictly != null">menu_check_strictly,</if> + <if test="deptCheckStrictly != null">dept_check_strictly,</if> + <if test="status != null and status != ''">status,</if> + <if test="remark != null and remark != ''">remark,</if> + <if test="createBy != null and createBy != ''">create_by,</if> + create_time + )values( + <if test="roleId != null and roleId != 0">#{roleId},</if> + <if test="roleName != null and roleName != ''">#{roleName},</if> + <if test="roleKey != null and roleKey != ''">#{roleKey},</if> + <if test="roleSort != null and roleSort != ''">#{roleSort},</if> + <if test="dataScope != null and dataScope != ''">#{dataScope},</if> + <if test="menuCheckStrictly != null">#{menuCheckStrictly},</if> + <if test="deptCheckStrictly != null">#{deptCheckStrictly},</if> + <if test="status != null and status != ''">#{status},</if> + <if test="remark != null and remark != ''">#{remark},</if> + <if test="createBy != null and createBy != ''">#{createBy},</if> + current_timestamp + ) + </insert> + + <update id="updateRole" parameterType="SysRole"> + update sys_role + <set> + <if test="roleName != null and roleName != ''">role_name = #{roleName},</if> + <if test="roleKey != null and roleKey != ''">role_key = #{roleKey},</if> + <if test="roleSort != null and roleSort != ''">role_sort = #{roleSort},</if> + <if test="dataScope != null and dataScope != ''">data_scope = #{dataScope},</if> + <if test="menuCheckStrictly != null">menu_check_strictly = #{menuCheckStrictly},</if> + <if test="deptCheckStrictly != null">dept_check_strictly = #{deptCheckStrictly},</if> + <if test="status != null and status != ''">status = #{status},</if> + <if test="remark != null">remark = #{remark},</if> + <if test="updateBy != null and updateBy != ''">update_by = #{updateBy},</if> + update_time = current_timestamp + </set> + where role_id = #{roleId} + </update> + + <delete id="deleteRoleById" parameterType="Long"> + update sys_role set del_flag = '2' where role_id = #{roleId} + </delete> + + <delete id="deleteRoleByIds" parameterType="Long"> + update sys_role set del_flag = '2' where role_id in + <foreach collection="array" item="roleId" open="(" separator="," close=")"> + #{roleId} + </foreach> + </delete> + +</mapper> \ No newline at end of file diff --git a/dc-system/src/main/resources/mapper/system/SysRoleMenuMapper.xml b/dc-system/src/main/resources/mapper/system/SysRoleMenuMapper.xml new file mode 100644 index 0000000..1f3b814 --- /dev/null +++ b/dc-system/src/main/resources/mapper/system/SysRoleMenuMapper.xml @@ -0,0 +1,34 @@ +<?xml version="1.0" encoding="UTF-8" ?> +<!DOCTYPE mapper + PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" + "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> +<mapper namespace="com.dc.system.mapper.SysRoleMenuMapper"> + + <resultMap type="SysRoleMenu" id="SysRoleMenuResult"> + <result property="roleId" column="role_id"/> + <result property="menuId" column="menu_id"/> + </resultMap> + + <select id="checkMenuExistRole" resultType="Integer"> + select count(1) from sys_role_menu where menu_id = #{menuId} + </select> + + <delete id="deleteRoleMenuByRoleId" parameterType="Long"> + delete from sys_role_menu where role_id=#{roleId} + </delete> + + <delete id="deleteRoleMenu" parameterType="Long"> + delete from sys_role_menu where role_id in + <foreach collection="array" item="roleId" open="(" separator="," close=")"> + #{roleId} + </foreach> + </delete> + + <insert id="batchRoleMenu"> + insert into sys_role_menu(role_id, menu_id) values + <foreach item="item" index="index" collection="list" separator=","> + (#{item.roleId},#{item.menuId}) + </foreach> + </insert> + +</mapper> \ No newline at end of file diff --git a/dc-system/src/main/resources/mapper/system/SysUserMapper.xml b/dc-system/src/main/resources/mapper/system/SysUserMapper.xml new file mode 100644 index 0000000..fd0d491 --- /dev/null +++ b/dc-system/src/main/resources/mapper/system/SysUserMapper.xml @@ -0,0 +1,226 @@ +<?xml version="1.0" encoding="UTF-8" ?> +<!DOCTYPE mapper + PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" + "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> +<mapper namespace="com.dc.system.mapper.SysUserMapper"> + + <resultMap type="SysUser" id="SysUserResult"> + <id property="userId" column="user_id"/> + <result property="deptId" column="dept_id"/> + <result property="userName" column="user_name"/> + <result property="nickName" column="nick_name"/> + <result property="email" column="email"/> + <result property="phonenumber" column="phonenumber"/> + <result property="sex" column="sex"/> + <result property="avatar" column="avatar"/> + <result property="password" column="password"/> + <result property="status" column="status"/> + <result property="delFlag" column="del_flag"/> + <result property="loginIp" column="login_ip"/> + <result property="loginDate" column="login_date"/> + <result property="createBy" column="create_by"/> + <result property="createTime" column="create_time"/> + <result property="updateBy" column="update_by"/> + <result property="updateTime" column="update_time"/> + <result property="remark" column="remark"/> + <association property="dept" column="dept_id" javaType="SysDept" resultMap="deptResult"/> + <collection property="roles" javaType="java.util.List" resultMap="RoleResult"/> + </resultMap> + + <resultMap id="deptResult" type="SysDept"> + <id property="deptId" column="dept_id"/> + <result property="parentId" column="parent_id"/> + <result property="deptName" column="dept_name"/> + <result property="ancestors" column="ancestors"/> + <result property="orderNum" column="order_num"/> + <result property="leader" column="leader"/> + <result property="status" column="dept_status"/> + </resultMap> + + <resultMap id="RoleResult" type="SysRole"> + <id property="roleId" column="role_id"/> + <result property="roleName" column="role_name"/> + <result property="roleKey" column="role_key"/> + <result property="roleSort" column="role_sort"/> + <result property="dataScope" column="data_scope"/> + <result property="status" column="role_status"/> + </resultMap> + + <sql id="selectUserVo"> + select u.user_id, u.dept_id, u.user_name, u.nick_name, u.email, u.avatar, u.phonenumber, u.password, u.sex, + u.status, u.del_flag, u.login_ip, u.login_date, u.create_by, u.create_time, u.remark, + d.dept_id, d.parent_id, d.ancestors, d.dept_name, d.order_num, d.leader, d.status as dept_status, + r.role_id, r.role_name, r.role_key, r.role_sort, r.data_scope, r.status as role_status + from sys_user u + left join sys_dept d on u.dept_id = d.dept_id + left join sys_user_role ur on u.user_id = ur.user_id + left join sys_role r on r.role_id = ur.role_id + </sql> + + <select id="selectUserList" parameterType="SysUser" resultMap="SysUserResult"> + select u.user_id, u.dept_id, u.nick_name, u.user_name, u.email, u.avatar, u.phonenumber, u.sex, u.status, + u.del_flag, u.login_ip, u.login_date, u.create_by, u.create_time, u.remark, d.dept_name, d.leader from sys_user + u + left join sys_dept d on u.dept_id = d.dept_id + where u.del_flag = '0' + <if test="userId != null and userId != 0"> + AND u.user_id = #{userId} + </if> + <if test="userName != null and userName != ''"> + AND u.user_name like concat('%', #{userName}, '%') + </if> + <if test="status != null and status != ''"> + AND u.status = #{status} + </if> + <if test="phonenumber != null and phonenumber != ''"> + AND u.phonenumber like concat('%', #{phonenumber}, '%') + </if> + <if test="params.beginTime != null and params.beginTime != ''"><!-- 开始时间检索 --> + AND to_char(u.create_time,'yyyy-MM-dd')::date >= to_date(#{params.beginTime},'yyyy-MM-dd') + </if> + <if test="params.endTime != null and params.endTime != ''"><!-- 结束时间检索 --> + AND to_char(u.create_time,'yyyy-MM-dd')::date <= to_date(#{params.endTime},'yyyy-MM-dd') + </if> + <if test="deptId != null and deptId != 0"> + AND (u.dept_id = #{deptId} OR u.dept_id IN ( SELECT t.dept_id FROM sys_dept t WHERE find_in_set(#{deptId}, + ancestors) )) + </if> + <!-- 数据范围过滤 --> + ${params.dataScope} + </select> + + <select id="selectAllocatedList" parameterType="SysUser" resultMap="SysUserResult"> + select distinct u.user_id, u.dept_id, u.user_name, u.nick_name, u.email, u.phonenumber, u.status, u.create_time + from sys_user u + left join sys_dept d on u.dept_id = d.dept_id + left join sys_user_role ur on u.user_id = ur.user_id + left join sys_role r on r.role_id = ur.role_id + where u.del_flag = '0' and r.role_id = #{roleId} + <if test="userName != null and userName != ''"> + AND u.user_name like concat('%', #{userName}, '%') + </if> + <if test="phonenumber != null and phonenumber != ''"> + AND u.phonenumber like concat('%', #{phonenumber}, '%') + </if> + <!-- 数据范围过滤 --> + ${params.dataScope} + </select> + + <select id="selectUnallocatedList" parameterType="SysUser" resultMap="SysUserResult"> + select distinct u.user_id, u.dept_id, u.user_name, u.nick_name, u.email, u.phonenumber, u.status, u.create_time + from sys_user u + left join sys_dept d on u.dept_id = d.dept_id + left join sys_user_role ur on u.user_id = ur.user_id + left join sys_role r on r.role_id = ur.role_id + where u.del_flag = '0' and (r.role_id != #{roleId} or r.role_id IS NULL) + and u.user_id not in (select u.user_id from sys_user u inner join sys_user_role ur on u.user_id = ur.user_id and + ur.role_id = #{roleId}) + <if test="userName != null and userName != ''"> + AND u.user_name like concat('%', #{userName}, '%') + </if> + <if test="phonenumber != null and phonenumber != ''"> + AND u.phonenumber like concat('%', #{phonenumber}, '%') + </if> + <!-- 数据范围过滤 --> + ${params.dataScope} + </select> + + <select id="selectUserByUserName" parameterType="String" resultMap="SysUserResult"> + <include refid="selectUserVo"/> + where u.user_name = #{userName} and u.del_flag = '0' + </select> + + <select id="selectUserById" parameterType="Long" resultMap="SysUserResult"> + <include refid="selectUserVo"/> + where u.user_id = #{userId} + </select> + + <select id="checkUserNameUnique" parameterType="String" resultMap="SysUserResult"> + select user_id, user_name from sys_user where user_name = #{userName} and del_flag = '0' limit 1 + </select> + + <select id="checkPhoneUnique" parameterType="String" resultMap="SysUserResult"> + select user_id, phonenumber from sys_user where phonenumber = #{phonenumber} and del_flag = '0' limit 1 + </select> + + <select id="checkEmailUnique" parameterType="String" resultMap="SysUserResult"> + select user_id, email from sys_user where email = #{email} and del_flag = '0' limit 1 + </select> + + <insert id="insertUser" parameterType="SysUser" useGeneratedKeys="true" keyProperty="userId"> + insert into sys_user( + <if test="userId != null and userId != 0">user_id,</if> + <if test="deptId != null and deptId != 0">dept_id,</if> + <if test="userName != null and userName != ''">user_name,</if> + <if test="nickName != null and nickName != ''">nick_name,</if> + <if test="email != null and email != ''">email,</if> + <if test="avatar != null and avatar != ''">avatar,</if> + <if test="phonenumber != null and phonenumber != ''">phonenumber,</if> + <if test="sex != null and sex != ''">sex,</if> + <if test="password != null and password != ''">password,</if> + <if test="status != null and status != ''">status,</if> + <if test="createBy != null and createBy != ''">create_by,</if> + <if test="remark != null and remark != ''">remark,</if> + create_time + )values( + <if test="userId != null and userId != ''">#{userId},</if> + <if test="deptId != null and deptId != ''">#{deptId},</if> + <if test="userName != null and userName != ''">#{userName},</if> + <if test="nickName != null and nickName != ''">#{nickName},</if> + <if test="email != null and email != ''">#{email},</if> + <if test="avatar != null and avatar != ''">#{avatar},</if> + <if test="phonenumber != null and phonenumber != ''">#{phonenumber},</if> + <if test="sex != null and sex != ''">#{sex},</if> + <if test="password != null and password != ''">#{password},</if> + <if test="status != null and status != ''">#{status},</if> + <if test="createBy != null and createBy != ''">#{createBy},</if> + <if test="remark != null and remark != ''">#{remark},</if> + current_timestamp + ) + </insert> + + <update id="updateUser" parameterType="SysUser"> + update sys_user + <set> + <if test="deptId != null and deptId != 0">dept_id = #{deptId},</if> + <if test="userName != null and userName != ''">user_name = #{userName},</if> + <if test="nickName != null and nickName != ''">nick_name = #{nickName},</if> + <if test="email != null ">email = #{email},</if> + <if test="phonenumber != null ">phonenumber = #{phonenumber},</if> + <if test="sex != null and sex != ''">sex = #{sex},</if> + <if test="avatar != null and avatar != ''">avatar = #{avatar},</if> + <if test="password != null and password != ''">password = #{password},</if> + <if test="status != null and status != ''">status = #{status},</if> + <if test="loginIp != null and loginIp != ''">login_ip = #{loginIp},</if> + <if test="loginDate != null">login_date = #{loginDate},</if> + <if test="updateBy != null and updateBy != ''">update_by = #{updateBy},</if> + <if test="remark != null">remark = #{remark},</if> + update_time = current_timestamp + </set> + where user_id = #{userId} + </update> + + <update id="updateUserStatus" parameterType="SysUser"> + update sys_user set status = #{status} where user_id = #{userId} + </update> + + <update id="updateUserAvatar" parameterType="SysUser"> + update sys_user set avatar = #{avatar} where user_name = #{userName} + </update> + + <update id="resetUserPwd" parameterType="SysUser"> + update sys_user set password = #{password} where user_name = #{userName} + </update> + + <delete id="deleteUserById" parameterType="Long"> + update sys_user set del_flag = '2' where user_id = #{userId} + </delete> + + <delete id="deleteUserByIds" parameterType="Long"> + update sys_user set del_flag = '2' where user_id in + <foreach collection="array" item="userId" open="(" separator="," close=")"> + #{userId} + </foreach> + </delete> + +</mapper> \ No newline at end of file diff --git a/dc-system/src/main/resources/mapper/system/SysUserPostMapper.xml b/dc-system/src/main/resources/mapper/system/SysUserPostMapper.xml new file mode 100644 index 0000000..540e662 --- /dev/null +++ b/dc-system/src/main/resources/mapper/system/SysUserPostMapper.xml @@ -0,0 +1,34 @@ +<?xml version="1.0" encoding="UTF-8" ?> +<!DOCTYPE mapper + PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" + "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> +<mapper namespace="com.dc.system.mapper.SysUserPostMapper"> + + <resultMap type="SysUserPost" id="SysUserPostResult"> + <result property="userId" column="user_id"/> + <result property="postId" column="post_id"/> + </resultMap> + + <delete id="deleteUserPostByUserId" parameterType="Long"> + delete from sys_user_post where user_id=#{userId} + </delete> + + <select id="countUserPostById" resultType="Integer"> + select count(1) from sys_user_post where post_id=#{postId} + </select> + + <delete id="deleteUserPost" parameterType="Long"> + delete from sys_user_post where user_id in + <foreach collection="array" item="userId" open="(" separator="," close=")"> + #{userId} + </foreach> + </delete> + + <insert id="batchUserPost"> + insert into sys_user_post(user_id, post_id) values + <foreach item="item" index="index" collection="list" separator=","> + (#{item.userId},#{item.postId}) + </foreach> + </insert> + +</mapper> \ No newline at end of file diff --git a/dc-system/src/main/resources/mapper/system/SysUserRoleMapper.xml b/dc-system/src/main/resources/mapper/system/SysUserRoleMapper.xml new file mode 100644 index 0000000..dcb8090 --- /dev/null +++ b/dc-system/src/main/resources/mapper/system/SysUserRoleMapper.xml @@ -0,0 +1,44 @@ +<?xml version="1.0" encoding="UTF-8" ?> +<!DOCTYPE mapper + PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" + "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> +<mapper namespace="com.dc.system.mapper.SysUserRoleMapper"> + + <resultMap type="SysUserRole" id="SysUserRoleResult"> + <result property="userId" column="user_id"/> + <result property="roleId" column="role_id"/> + </resultMap> + + <delete id="deleteUserRoleByUserId" parameterType="Long"> + delete from sys_user_role where user_id=#{userId} + </delete> + + <select id="countUserRoleByRoleId" resultType="Integer"> + select count(1) from sys_user_role where role_id=#{roleId} + </select> + + <delete id="deleteUserRole" parameterType="Long"> + delete from sys_user_role where user_id in + <foreach collection="array" item="userId" open="(" separator="," close=")"> + #{userId} + </foreach> + </delete> + + <insert id="batchUserRole"> + insert into sys_user_role(user_id, role_id) values + <foreach item="item" index="index" collection="list" separator=","> + (#{item.userId},#{item.roleId}) + </foreach> + </insert> + + <delete id="deleteUserRoleInfo" parameterType="SysUserRole"> + delete from sys_user_role where user_id=#{userId} and role_id=#{roleId} + </delete> + + <delete id="deleteUserRoleInfos"> + delete from sys_user_role where role_id=#{roleId} and user_id in + <foreach collection="userIds" item="userId" open="(" separator="," close=")"> + #{userId} + </foreach> + </delete> +</mapper> \ No newline at end of file diff --git a/dc.bat b/dc.bat new file mode 100644 index 0000000..322df07 --- /dev/null +++ b/dc.bat @@ -0,0 +1,67 @@ +@echo off + +rem jarƽ��Ŀ¼ +set AppName=dc-admin.jar + +rem JVM���� +set JVM_OPTS="-Dname=%AppName% -Duser.timezone=Asia/Shanghai -Xms512m -Xmx1024m -XX:MetaspaceSize=128m -XX:MaxMetaspaceSize=512m -XX:+HeapDumpOnOutOfMemoryError -XX:+PrintGCDateStamps -XX:+PrintGCDetails -XX:NewRatio=1 -XX:SurvivorRatio=30 -XX:+UseParallelGC -XX:+UseParallelOldGC" + + +ECHO. + ECHO. [1] ����%AppName% + ECHO. [2] �ر�%AppName% + ECHO. [3] ����%AppName% + ECHO. [4] ����״̬ %AppName% + ECHO. [5] �� �� +ECHO. + +ECHO.������ѡ����Ŀ�����: +set /p ID= + IF "%id%"=="1" GOTO start + IF "%id%"=="2" GOTO stop + IF "%id%"=="3" GOTO restart + IF "%id%"=="4" GOTO status + IF "%id%"=="5" EXIT +PAUSE +:start + for /f "usebackq tokens=1-2" %%a in (`jps -l ^| findstr %AppName%`) do ( + set pid=%%a + set image_name=%%b + ) + if defined pid ( + echo %%is running + PAUSE + ) + +start javaw %JVM_OPTS% -jar %AppName% + +echo starting���� +echo Start %AppName% success... +goto:eof + +rem ����stopͨ��jps�������pid���������� +:stop + for /f "usebackq tokens=1-2" %%a in (`jps -l ^| findstr %AppName%`) do ( + set pid=%%a + set image_name=%%b + ) + if not defined pid (echo process %AppName% does not exists) else ( + echo prepare to kill %image_name% + echo start kill %pid% ... + rem ���ݽ���ID��kill���� + taskkill /f /pid %pid% + ) +goto:eof +:restart + call :stop + call :start +goto:eof +:status + for /f "usebackq tokens=1-2" %%a in (`jps -l ^| findstr %AppName%`) do ( + set pid=%%a + set image_name=%%b + ) + if not defined pid (echo process %AppName% is dead ) else ( + echo %image_name% is running + ) +goto:eof diff --git a/dc.sh b/dc.sh new file mode 100644 index 0000000..3845bc8 --- /dev/null +++ b/dc.sh @@ -0,0 +1,86 @@ +#!/bin/sh +# ./dc.sh start 启动 stop 停止 restart 重启 status 状态 +AppName=dc-admin.jar + +# JVM参数 +JVM_OPTS="-Dname=$AppName -Duser.timezone=Asia/Shanghai -Xms512m -Xmx1024m -XX:MetaspaceSize=128m -XX:MaxMetaspaceSize=512m -XX:+HeapDumpOnOutOfMemoryError -XX:+PrintGCDateStamps -XX:+PrintGCDetails -XX:NewRatio=1 -XX:SurvivorRatio=30 -XX:+UseParallelGC -XX:+UseParallelOldGC" +APP_HOME=`pwd` +LOG_PATH=$APP_HOME/logs/$AppName.log + +if [ "$1" = "" ]; +then + echo -e "\033[0;31m 未输入操作名 \033[0m \033[0;34m {start|stop|restart|status} \033[0m" + exit 1 +fi + +if [ "$AppName" = "" ]; +then + echo -e "\033[0;31m 未输入应用名 \033[0m" + exit 1 +fi + +function start() +{ + PID=`ps -ef |grep java|grep $AppName|grep -v grep|awk '{print $2}'` + + if [ x"$PID" != x"" ]; then + echo "$AppName is running..." + else + nohup java $JVM_OPTS -jar $AppName > /dev/null 2>&1 & + echo "Start $AppName success..." + fi +} + +function stop() +{ + echo "Stop $AppName" + + PID="" + query(){ + PID=`ps -ef |grep java|grep $AppName|grep -v grep|awk '{print $2}'` + } + + query + if [ x"$PID" != x"" ]; then + kill -TERM $PID + echo "$AppName (pid:$PID) exiting..." + while [ x"$PID" != x"" ] + do + sleep 1 + query + done + echo "$AppName exited." + else + echo "$AppName already stopped." + fi +} + +function restart() +{ + stop + sleep 2 + start +} + +function status() +{ + PID=`ps -ef |grep java|grep $AppName|grep -v grep|wc -l` + if [ $PID != 0 ];then + echo "$AppName is running..." + else + echo "$AppName is not running..." + fi +} + +case $1 in + start) + start;; + stop) + stop;; + restart) + restart;; + status) + status;; + *) + +esac diff --git a/doc/开发文档说明.docx b/doc/开发文档说明.docx new file mode 100644 index 0000000000000000000000000000000000000000..9e4daef4d9be2e445419109a02eaf321cd4d537e GIT binary patch literal 428430 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	Rli)_iWGz7fMupr%QDEgRC> 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%0DfC-!Au^<Q0%m`XEL@1Ys{j@tA=_=Uom8^EHjQ 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 z∾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%0D$0i4SN));n7RdVpw~ze$@w6B*k7 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 literal 0 HcmV?d00001 diff --git a/logs/sys-error.2023-03-08.log b/logs/sys-error.2023-03-08.log new file mode 100644 index 0000000..e69de29 diff --git a/logs/sys-error.2023-03-09.log b/logs/sys-error.2023-03-09.log new file mode 100644 index 0000000..a3075e9 --- /dev/null +++ b/logs/sys-error.2023-03-09.log @@ -0,0 +1,110 @@ +13:07:27.243 [http-nio-8080-exec-77] ERROR c.w.f.w.e.GlobalExceptionHandler - [handleRuntimeException,70] - 请求地址'/login',发生未知异常. +com.dc.common.exception.user.CaptchaExpireException: 验证码已失效 + at com.dc.framework.web.service.SysLoginService.validateCaptcha(SysLoginService.java:120) + at com.dc.framework.web.service.SysLoginService.login(SysLoginService.java:69) + at com.dc.web.controller.system.SysLoginController.login(SysLoginController.java:49) + at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) + at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) + at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) + at java.lang.reflect.Method.invoke(Method.java:498) + at org.springframework.web.method.support.InvocableHandlerMethod.doInvoke(InvocableHandlerMethod.java:205) + at org.springframework.web.method.support.InvocableHandlerMethod.invokeForRequest(InvocableHandlerMethod.java:150) + at org.springframework.web.servlet.mvc.method.annotation.ServletInvocableHandlerMethod.invokeAndHandle(ServletInvocableHandlerMethod.java:117) + at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.invokeHandlerMethod(RequestMappingHandlerAdapter.java:895) + at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.handleInternal(RequestMappingHandlerAdapter.java:808) + at org.springframework.web.servlet.mvc.method.AbstractHandlerMethodAdapter.handle(AbstractHandlerMethodAdapter.java:87) + at org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:1067) + at org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:963) + at org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:1006) + at org.springframework.web.servlet.FrameworkServlet.doPost(FrameworkServlet.java:909) + at javax.servlet.http.HttpServlet.service(HttpServlet.java:681) + at org.springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.java:883) + at javax.servlet.http.HttpServlet.service(HttpServlet.java:764) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:227) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:53) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:111) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:111) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at com.alibaba.druid.support.http.WebStatFilter.doFilter(WebStatFilter.java:114) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at com.dc.common.filter.RepeatableFilter.doFilter(RepeatableFilter.java:39) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:327) + at org.springframework.security.web.access.intercept.FilterSecurityInterceptor.invoke(FilterSecurityInterceptor.java:115) + at org.springframework.security.web.access.intercept.FilterSecurityInterceptor.doFilter(FilterSecurityInterceptor.java:81) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.access.ExceptionTranslationFilter.doFilter(ExceptionTranslationFilter.java:121) + at org.springframework.security.web.access.ExceptionTranslationFilter.doFilter(ExceptionTranslationFilter.java:115) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.session.SessionManagementFilter.doFilter(SessionManagementFilter.java:126) + at org.springframework.security.web.session.SessionManagementFilter.doFilter(SessionManagementFilter.java:81) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.authentication.AnonymousAuthenticationFilter.doFilter(AnonymousAuthenticationFilter.java:105) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.servletapi.SecurityContextHolderAwareRequestFilter.doFilter(SecurityContextHolderAwareRequestFilter.java:149) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.savedrequest.RequestCacheAwareFilter.doFilter(RequestCacheAwareFilter.java:63) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at com.dc.framework.security.filter.JwtAuthenticationTokenFilter.doFilterInternal(JwtAuthenticationTokenFilter.java:43) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:111) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.authentication.logout.LogoutFilter.doFilter(LogoutFilter.java:103) + at org.springframework.security.web.authentication.logout.LogoutFilter.doFilter(LogoutFilter.java:89) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.web.filter.CorsFilter.doFilterInternal(CorsFilter.java:91) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.header.HeaderWriterFilter.doHeadersAfter(HeaderWriterFilter.java:90) + at org.springframework.security.web.header.HeaderWriterFilter.doFilterInternal(HeaderWriterFilter.java:75) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.context.SecurityContextPersistenceFilter.doFilter(SecurityContextPersistenceFilter.java:110) + at org.springframework.security.web.context.SecurityContextPersistenceFilter.doFilter(SecurityContextPersistenceFilter.java:80) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.context.request.async.WebAsyncManagerIntegrationFilter.doFilterInternal(WebAsyncManagerIntegrationFilter.java:55) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.FilterChainProxy.doFilterInternal(FilterChainProxy.java:211) + at org.springframework.security.web.FilterChainProxy.doFilter(FilterChainProxy.java:183) + at org.springframework.web.filter.DelegatingFilterProxy.invokeDelegate(DelegatingFilterProxy.java:354) + at org.springframework.web.filter.DelegatingFilterProxy.doFilter(DelegatingFilterProxy.java:267) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.RequestContextFilter.doFilterInternal(RequestContextFilter.java:100) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.FormContentFilter.doFilterInternal(FormContentFilter.java:93) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.CharacterEncodingFilter.doFilterInternal(CharacterEncodingFilter.java:201) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:197) + at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:97) + at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:541) + at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:135) + at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:92) + at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:78) + at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:360) + at org.apache.coyote.http11.Http11Processor.service(Http11Processor.java:399) + at org.apache.coyote.AbstractProcessorLight.process(AbstractProcessorLight.java:65) + at org.apache.coyote.AbstractProtocol$ConnectionHandler.process(AbstractProtocol.java:890) + at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1743) + at org.apache.tomcat.util.net.SocketProcessorBase.run(SocketProcessorBase.java:49) + at org.apache.tomcat.util.threads.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1191) + at org.apache.tomcat.util.threads.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:659) + at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61) + at java.lang.Thread.run(Thread.java:748) diff --git a/logs/sys-error.2023-07-06.log b/logs/sys-error.2023-07-06.log new file mode 100644 index 0000000..84fccff --- /dev/null +++ b/logs/sys-error.2023-07-06.log @@ -0,0 +1,54 @@ +08:56:19.287 [restartedMain] ERROR o.s.b.d.LoggingFailureAnalysisReporter - [report,40] - + +*************************** +APPLICATION FAILED TO START +*************************** + +Description: + +Field winConfig in com.dc.web.config.SwaggerConfig required a bean of type 'com.dc.common.config.WinConfig' that could not be found. + +The injection point has the following annotations: + - @org.springframework.beans.factory.annotation.Autowired(required=true) + + +Action: + +Consider defining a bean of type 'com.dc.common.config.WinConfig' in your configuration. + +08:57:10.070 [restartedMain] ERROR o.s.b.d.LoggingFailureAnalysisReporter - [report,40] - + +*************************** +APPLICATION FAILED TO START +*************************** + +Description: + +Field winConfig in com.dc.web.config.SwaggerConfig required a bean of type 'com.dc.common.config.WinConfig' that could not be found. + +The injection point has the following annotations: + - @org.springframework.beans.factory.annotation.Autowired(required=true) + + +Action: + +Consider defining a bean of type 'com.dc.common.config.WinConfig' in your configuration. + +08:59:34.921 [restartedMain] ERROR o.s.b.d.LoggingFailureAnalysisReporter - [report,40] - + +*************************** +APPLICATION FAILED TO START +*************************** + +Description: + +Field winConfig in com.dc.web.config.SwaggerConfig required a bean of type 'com.dc.common.config.WinConfig' that could not be found. + +The injection point has the following annotations: + - @org.springframework.beans.factory.annotation.Autowired(required=true) + + +Action: + +Consider defining a bean of type 'com.dc.common.config.WinConfig' in your configuration. + diff --git a/logs/sys-error.2023-07-19.log b/logs/sys-error.2023-07-19.log new file mode 100644 index 0000000..b5c8639 --- /dev/null +++ b/logs/sys-error.2023-07-19.log @@ -0,0 +1,221 @@ +13:48:51.759 [http-nio-8080-exec-13] ERROR c.w.f.w.e.GlobalExceptionHandler - [handleRuntimeException,82] - 请求地址'/login',发生未知异常. +com.dc.common.exception.user.CaptchaException: 验证码错误 + at com.dc.framework.web.service.SysLoginService.validateCaptcha(SysLoginService.java:143) + at com.dc.framework.web.service.SysLoginService.login(SysLoginService.java:74) + at com.dc.web.controller.system.SysLoginController.login(SysLoginController.java:49) + at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) + at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) + at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) + at java.lang.reflect.Method.invoke(Method.java:498) + at org.springframework.web.method.support.InvocableHandlerMethod.doInvoke(InvocableHandlerMethod.java:205) + at org.springframework.web.method.support.InvocableHandlerMethod.invokeForRequest(InvocableHandlerMethod.java:150) + at org.springframework.web.servlet.mvc.method.annotation.ServletInvocableHandlerMethod.invokeAndHandle(ServletInvocableHandlerMethod.java:117) + at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.invokeHandlerMethod(RequestMappingHandlerAdapter.java:895) + at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.handleInternal(RequestMappingHandlerAdapter.java:808) + at org.springframework.web.servlet.mvc.method.AbstractHandlerMethodAdapter.handle(AbstractHandlerMethodAdapter.java:87) + at org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:1067) + at org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:963) + at org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:1006) + at org.springframework.web.servlet.FrameworkServlet.doPost(FrameworkServlet.java:909) + at javax.servlet.http.HttpServlet.service(HttpServlet.java:681) + at org.springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.java:883) + at javax.servlet.http.HttpServlet.service(HttpServlet.java:764) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:227) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:53) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:111) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:111) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at com.alibaba.druid.support.http.WebStatFilter.doFilter(WebStatFilter.java:114) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at com.dc.common.filter.RepeatableFilter.doFilter(RepeatableFilter.java:39) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:327) + at org.springframework.security.web.access.intercept.FilterSecurityInterceptor.invoke(FilterSecurityInterceptor.java:115) + at org.springframework.security.web.access.intercept.FilterSecurityInterceptor.doFilter(FilterSecurityInterceptor.java:81) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.access.ExceptionTranslationFilter.doFilter(ExceptionTranslationFilter.java:121) + at org.springframework.security.web.access.ExceptionTranslationFilter.doFilter(ExceptionTranslationFilter.java:115) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.session.SessionManagementFilter.doFilter(SessionManagementFilter.java:126) + at org.springframework.security.web.session.SessionManagementFilter.doFilter(SessionManagementFilter.java:81) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.authentication.AnonymousAuthenticationFilter.doFilter(AnonymousAuthenticationFilter.java:105) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.servletapi.SecurityContextHolderAwareRequestFilter.doFilter(SecurityContextHolderAwareRequestFilter.java:149) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.savedrequest.RequestCacheAwareFilter.doFilter(RequestCacheAwareFilter.java:63) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at com.dc.framework.security.filter.JwtAuthenticationTokenFilter.doFilterInternal(JwtAuthenticationTokenFilter.java:43) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:111) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.authentication.logout.LogoutFilter.doFilter(LogoutFilter.java:103) + at org.springframework.security.web.authentication.logout.LogoutFilter.doFilter(LogoutFilter.java:89) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.web.filter.CorsFilter.doFilterInternal(CorsFilter.java:91) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.header.HeaderWriterFilter.doHeadersAfter(HeaderWriterFilter.java:90) + at org.springframework.security.web.header.HeaderWriterFilter.doFilterInternal(HeaderWriterFilter.java:75) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.context.SecurityContextPersistenceFilter.doFilter(SecurityContextPersistenceFilter.java:110) + at org.springframework.security.web.context.SecurityContextPersistenceFilter.doFilter(SecurityContextPersistenceFilter.java:80) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.context.request.async.WebAsyncManagerIntegrationFilter.doFilterInternal(WebAsyncManagerIntegrationFilter.java:55) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.FilterChainProxy.doFilterInternal(FilterChainProxy.java:211) + at org.springframework.security.web.FilterChainProxy.doFilter(FilterChainProxy.java:183) + at org.springframework.web.filter.DelegatingFilterProxy.invokeDelegate(DelegatingFilterProxy.java:354) + at org.springframework.web.filter.DelegatingFilterProxy.doFilter(DelegatingFilterProxy.java:267) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.RequestContextFilter.doFilterInternal(RequestContextFilter.java:100) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.FormContentFilter.doFilterInternal(FormContentFilter.java:93) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.CharacterEncodingFilter.doFilterInternal(CharacterEncodingFilter.java:201) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:197) + at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:97) + at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:541) + at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:135) + at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:92) + at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:78) + at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:360) + at org.apache.coyote.http11.Http11Processor.service(Http11Processor.java:399) + at org.apache.coyote.AbstractProcessorLight.process(AbstractProcessorLight.java:65) + at org.apache.coyote.AbstractProtocol$ConnectionHandler.process(AbstractProtocol.java:890) + at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1743) + at org.apache.tomcat.util.net.SocketProcessorBase.run(SocketProcessorBase.java:49) + at org.apache.tomcat.util.threads.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1191) + at org.apache.tomcat.util.threads.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:659) + at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61) + at java.lang.Thread.run(Thread.java:748) +14:04:46.006 [restartedMain] ERROR o.s.b.SpringApplication - [reportFailure,870] - Application run failed +java.lang.IllegalStateException: Failed to register @ServerEndpoint class: class com.dc.web.websocket.WebSocketServer + at org.springframework.web.socket.server.standard.ServerEndpointExporter.registerEndpoint(ServerEndpointExporter.java:159) + at org.springframework.web.socket.server.standard.ServerEndpointExporter.registerEndpoints(ServerEndpointExporter.java:134) + at org.springframework.web.socket.server.standard.ServerEndpointExporter.afterSingletonsInstantiated(ServerEndpointExporter.java:112) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.preInstantiateSingletons(DefaultListableBeanFactory.java:972) + at org.springframework.context.support.AbstractApplicationContext.finishBeanFactoryInitialization(AbstractApplicationContext.java:918) + at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:583) + at org.springframework.boot.web.servlet.context.ServletWebServerApplicationContext.refresh(ServletWebServerApplicationContext.java:145) + at org.springframework.boot.SpringApplication.refresh(SpringApplication.java:780) + at org.springframework.boot.SpringApplication.refreshContext(SpringApplication.java:453) + at org.springframework.boot.SpringApplication.run(SpringApplication.java:343) + at org.springframework.boot.SpringApplication.run(SpringApplication.java:1370) + at org.springframework.boot.SpringApplication.run(SpringApplication.java:1359) + at com.dc.web.DcApplication.main(WinApplication.java:21) + at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) + at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) + at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) + at java.lang.reflect.Method.invoke(Method.java:498) + at org.springframework.boot.devtools.restart.RestartLauncher.run(RestartLauncher.java:49) +Caused by: javax.websocket.DeploymentException: A parameter of type [class java.lang.String] was found on method[onOpen] of class [java.lang.reflect.Method] that did not have a @PathParam annotation + at org.apache.tomcat.websocket.pojo.PojoMethodMapping.getPathParams(PojoMethodMapping.java:347) + at org.apache.tomcat.websocket.pojo.PojoMethodMapping.<init>(PojoMethodMapping.java:221) + at org.apache.tomcat.websocket.server.WsServerContainer.addEndpoint(WsServerContainer.java:155) + at org.apache.tomcat.websocket.server.WsServerContainer.addEndpoint(WsServerContainer.java:279) + at org.apache.tomcat.websocket.server.WsServerContainer.addEndpoint(WsServerContainer.java:229) + at org.springframework.web.socket.server.standard.ServerEndpointExporter.registerEndpoint(ServerEndpointExporter.java:156) + ... 17 common frames omitted +14:05:07.532 [restartedMain] ERROR o.s.b.SpringApplication - [reportFailure,870] - Application run failed +java.lang.IllegalStateException: Failed to register @ServerEndpoint class: class com.dc.web.websocket.WebSocketServer + at org.springframework.web.socket.server.standard.ServerEndpointExporter.registerEndpoint(ServerEndpointExporter.java:159) + at org.springframework.web.socket.server.standard.ServerEndpointExporter.registerEndpoints(ServerEndpointExporter.java:134) + at org.springframework.web.socket.server.standard.ServerEndpointExporter.afterSingletonsInstantiated(ServerEndpointExporter.java:112) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.preInstantiateSingletons(DefaultListableBeanFactory.java:972) + at org.springframework.context.support.AbstractApplicationContext.finishBeanFactoryInitialization(AbstractApplicationContext.java:918) + at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:583) + at org.springframework.boot.web.servlet.context.ServletWebServerApplicationContext.refresh(ServletWebServerApplicationContext.java:145) + at org.springframework.boot.SpringApplication.refresh(SpringApplication.java:780) + at org.springframework.boot.SpringApplication.refreshContext(SpringApplication.java:453) + at org.springframework.boot.SpringApplication.run(SpringApplication.java:343) + at org.springframework.boot.SpringApplication.run(SpringApplication.java:1370) + at org.springframework.boot.SpringApplication.run(SpringApplication.java:1359) + at com.dc.web.DcApplication.main(WinApplication.java:21) + at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) + at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) + at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) + at java.lang.reflect.Method.invoke(Method.java:498) + at org.springframework.boot.devtools.restart.RestartLauncher.run(RestartLauncher.java:49) +Caused by: javax.websocket.DeploymentException: A parameter of type [class java.lang.String] was found on method[onOpen] of class [java.lang.reflect.Method] that did not have a @PathParam annotation + at org.apache.tomcat.websocket.pojo.PojoMethodMapping.getPathParams(PojoMethodMapping.java:347) + at org.apache.tomcat.websocket.pojo.PojoMethodMapping.<init>(PojoMethodMapping.java:221) + at org.apache.tomcat.websocket.server.WsServerContainer.addEndpoint(WsServerContainer.java:155) + at org.apache.tomcat.websocket.server.WsServerContainer.addEndpoint(WsServerContainer.java:279) + at org.apache.tomcat.websocket.server.WsServerContainer.addEndpoint(WsServerContainer.java:229) + at org.springframework.web.socket.server.standard.ServerEndpointExporter.registerEndpoint(ServerEndpointExporter.java:156) + ... 17 common frames omitted +14:05:56.966 [restartedMain] ERROR o.s.b.SpringApplication - [reportFailure,870] - Application run failed +java.lang.IllegalStateException: Failed to register @ServerEndpoint class: class com.dc.web.websocket.WebSocketServer + at org.springframework.web.socket.server.standard.ServerEndpointExporter.registerEndpoint(ServerEndpointExporter.java:159) + at org.springframework.web.socket.server.standard.ServerEndpointExporter.registerEndpoints(ServerEndpointExporter.java:134) + at org.springframework.web.socket.server.standard.ServerEndpointExporter.afterSingletonsInstantiated(ServerEndpointExporter.java:112) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.preInstantiateSingletons(DefaultListableBeanFactory.java:972) + at org.springframework.context.support.AbstractApplicationContext.finishBeanFactoryInitialization(AbstractApplicationContext.java:918) + at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:583) + at org.springframework.boot.web.servlet.context.ServletWebServerApplicationContext.refresh(ServletWebServerApplicationContext.java:145) + at org.springframework.boot.SpringApplication.refresh(SpringApplication.java:780) + at org.springframework.boot.SpringApplication.refreshContext(SpringApplication.java:453) + at org.springframework.boot.SpringApplication.run(SpringApplication.java:343) + at org.springframework.boot.SpringApplication.run(SpringApplication.java:1370) + at org.springframework.boot.SpringApplication.run(SpringApplication.java:1359) + at com.dc.web.DcApplication.main(WinApplication.java:21) + at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) + at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) + at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) + at java.lang.reflect.Method.invoke(Method.java:498) + at org.springframework.boot.devtools.restart.RestartLauncher.run(RestartLauncher.java:49) +Caused by: javax.websocket.DeploymentException: Multiple message parameters present on the method [onMessage] of class [com.dc.web.websocket.WebSocketServer] that was annotated with OnMessage + at org.apache.tomcat.websocket.pojo.PojoMethodMapping$MessageHandlerInfo.<init>(PojoMethodMapping.java:438) + at org.apache.tomcat.websocket.pojo.PojoMethodMapping.<init>(PojoMethodMapping.java:168) + at org.apache.tomcat.websocket.server.WsServerContainer.addEndpoint(WsServerContainer.java:155) + at org.apache.tomcat.websocket.server.WsServerContainer.addEndpoint(WsServerContainer.java:279) + at org.apache.tomcat.websocket.server.WsServerContainer.addEndpoint(WsServerContainer.java:229) + at org.springframework.web.socket.server.standard.ServerEndpointExporter.registerEndpoint(ServerEndpointExporter.java:156) + ... 17 common frames omitted +14:09:07.595 [restartedMain] ERROR o.s.b.SpringApplication - [reportFailure,870] - Application run failed +java.lang.IllegalStateException: Failed to register @ServerEndpoint class: class com.dc.web.websocket.WebSocketServer + at org.springframework.web.socket.server.standard.ServerEndpointExporter.registerEndpoint(ServerEndpointExporter.java:159) + at org.springframework.web.socket.server.standard.ServerEndpointExporter.registerEndpoints(ServerEndpointExporter.java:134) + at org.springframework.web.socket.server.standard.ServerEndpointExporter.afterSingletonsInstantiated(ServerEndpointExporter.java:112) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.preInstantiateSingletons(DefaultListableBeanFactory.java:972) + at org.springframework.context.support.AbstractApplicationContext.finishBeanFactoryInitialization(AbstractApplicationContext.java:918) + at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:583) + at org.springframework.boot.web.servlet.context.ServletWebServerApplicationContext.refresh(ServletWebServerApplicationContext.java:145) + at org.springframework.boot.SpringApplication.refresh(SpringApplication.java:780) + at org.springframework.boot.SpringApplication.refreshContext(SpringApplication.java:453) + at org.springframework.boot.SpringApplication.run(SpringApplication.java:343) + at org.springframework.boot.SpringApplication.run(SpringApplication.java:1370) + at org.springframework.boot.SpringApplication.run(SpringApplication.java:1359) + at com.dc.web.DcApplication.main(WinApplication.java:21) + at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) + at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) + at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) + at java.lang.reflect.Method.invoke(Method.java:498) + at org.springframework.boot.devtools.restart.RestartLauncher.run(RestartLauncher.java:49) +Caused by: javax.websocket.DeploymentException: The segment [${sessionId}] is not valid in the provided path [/websocket/${sessionId}] + at org.apache.tomcat.websocket.server.UriTemplate.<init>(UriTemplate.java:90) + at org.apache.tomcat.websocket.server.WsServerContainer.addEndpoint(WsServerContainer.java:162) + at org.apache.tomcat.websocket.server.WsServerContainer.addEndpoint(WsServerContainer.java:279) + at org.apache.tomcat.websocket.server.WsServerContainer.addEndpoint(WsServerContainer.java:229) + at org.springframework.web.socket.server.standard.ServerEndpointExporter.registerEndpoint(ServerEndpointExporter.java:156) + ... 17 common frames omitted diff --git a/logs/sys-error.2023-07-20.log b/logs/sys-error.2023-07-20.log new file mode 100644 index 0000000..5b7054f --- /dev/null +++ b/logs/sys-error.2023-07-20.log @@ -0,0 +1,202 @@ +11:38:31.037 [restartedMain] ERROR o.s.b.SpringApplication - [reportFailure,870] - Application run failed +org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'accessoryService': Unsatisfied dependency expressed through field 'baseMapper'; nested exception is org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'accessoryMapper' defined in file [D:\workspace\wenyin\win\win-system\target\classes\com\win\system\mapper\AccessoryMapper.class]: Unsatisfied dependency expressed through bean property 'sqlSessionFactory'; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'sqlSessionFactory' defined in class path resource [com/win/framework/config/DataSourceConfiguration.class]: Bean instantiation via factory method failed; nested exception is org.springframework.beans.BeanInstantiationException: Failed to instantiate [org.apache.ibatis.session.SqlSessionFactory]: Factory method 'sqlSessionFactory' threw exception; nested exception is java.io.IOException: Failed to parse mapping resource: 'file [D:\workspace\wenyin\win\win-system\target\classes\mapper\flowable\FlowDeployMapper.xml]' + at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor$AutowiredFieldElement.resolveFieldValue(AutowiredAnnotationBeanPostProcessor.java:659) + at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor$AutowiredFieldElement.inject(AutowiredAnnotationBeanPostProcessor.java:639) + at org.springframework.beans.factory.annotation.InjectionMetadata.inject(InjectionMetadata.java:119) + at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor.postProcessProperties(AutowiredAnnotationBeanPostProcessor.java:399) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.populateBean(AbstractAutowireCapableBeanFactory.java:1431) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:619) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:542) + at org.springframework.beans.factory.support.AbstractBeanFactory.lambda$doGetBean$0(AbstractBeanFactory.java:335) + at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:234) + at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:333) + at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:208) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.preInstantiateSingletons(DefaultListableBeanFactory.java:953) + at org.springframework.context.support.AbstractApplicationContext.finishBeanFactoryInitialization(AbstractApplicationContext.java:918) + at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:583) + at org.springframework.boot.web.servlet.context.ServletWebServerApplicationContext.refresh(ServletWebServerApplicationContext.java:145) + at org.springframework.boot.SpringApplication.refresh(SpringApplication.java:780) + at org.springframework.boot.SpringApplication.refreshContext(SpringApplication.java:453) + at org.springframework.boot.SpringApplication.run(SpringApplication.java:343) + at org.springframework.boot.SpringApplication.run(SpringApplication.java:1370) + at org.springframework.boot.SpringApplication.run(SpringApplication.java:1359) + at com.dc.web.DcApplication.main(WinApplication.java:25) + at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) + at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) + at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) + at java.lang.reflect.Method.invoke(Method.java:498) + at org.springframework.boot.devtools.restart.RestartLauncher.run(RestartLauncher.java:49) +Caused by: org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'accessoryMapper' defined in file [D:\workspace\wenyin\win\win-system\target\classes\com\win\system\mapper\AccessoryMapper.class]: Unsatisfied dependency expressed through bean property 'sqlSessionFactory'; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'sqlSessionFactory' defined in class path resource [com/win/framework/config/DataSourceConfiguration.class]: Bean instantiation via factory method failed; nested exception is org.springframework.beans.BeanInstantiationException: Failed to instantiate [org.apache.ibatis.session.SqlSessionFactory]: Factory method 'sqlSessionFactory' threw exception; nested exception is java.io.IOException: Failed to parse mapping resource: 'file [D:\workspace\wenyin\win\win-system\target\classes\mapper\flowable\FlowDeployMapper.xml]' + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.autowireByType(AbstractAutowireCapableBeanFactory.java:1534) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.populateBean(AbstractAutowireCapableBeanFactory.java:1417) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:619) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:542) + at org.springframework.beans.factory.support.AbstractBeanFactory.lambda$doGetBean$0(AbstractBeanFactory.java:335) + at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:234) + at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:333) + at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:208) + at org.springframework.beans.factory.config.DependencyDescriptor.resolveCandidate(DependencyDescriptor.java:276) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.doResolveDependency(DefaultListableBeanFactory.java:1389) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.resolveDependency(DefaultListableBeanFactory.java:1309) + at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor$AutowiredFieldElement.resolveFieldValue(AutowiredAnnotationBeanPostProcessor.java:656) + ... 25 common frames omitted +Caused by: org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'sqlSessionFactory' defined in class path resource [com/win/framework/config/DataSourceConfiguration.class]: Bean instantiation via factory method failed; nested exception is org.springframework.beans.BeanInstantiationException: Failed to instantiate [org.apache.ibatis.session.SqlSessionFactory]: Factory method 'sqlSessionFactory' threw exception; nested exception is java.io.IOException: Failed to parse mapping resource: 'file [D:\workspace\wenyin\win\win-system\target\classes\mapper\flowable\FlowDeployMapper.xml]' + at org.springframework.beans.factory.support.ConstructorResolver.instantiate(ConstructorResolver.java:658) + at org.springframework.beans.factory.support.ConstructorResolver.instantiateUsingFactoryMethod(ConstructorResolver.java:638) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.instantiateUsingFactoryMethod(AbstractAutowireCapableBeanFactory.java:1352) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBeanInstance(AbstractAutowireCapableBeanFactory.java:1195) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:582) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:542) + at org.springframework.beans.factory.support.AbstractBeanFactory.lambda$doGetBean$0(AbstractBeanFactory.java:335) + at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:234) + at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:333) + at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:208) + at org.springframework.beans.factory.config.DependencyDescriptor.resolveCandidate(DependencyDescriptor.java:276) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.doResolveDependency(DefaultListableBeanFactory.java:1389) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.resolveDependency(DefaultListableBeanFactory.java:1309) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.autowireByType(AbstractAutowireCapableBeanFactory.java:1519) + ... 36 common frames omitted +Caused by: org.springframework.beans.BeanInstantiationException: Failed to instantiate [org.apache.ibatis.session.SqlSessionFactory]: Factory method 'sqlSessionFactory' threw exception; nested exception is java.io.IOException: Failed to parse mapping resource: 'file [D:\workspace\wenyin\win\win-system\target\classes\mapper\flowable\FlowDeployMapper.xml]' + at org.springframework.beans.factory.support.SimpleInstantiationStrategy.instantiate(SimpleInstantiationStrategy.java:185) + at org.springframework.beans.factory.support.ConstructorResolver.instantiate(ConstructorResolver.java:653) + ... 49 common frames omitted +Caused by: java.io.IOException: Failed to parse mapping resource: 'file [D:\workspace\wenyin\win\win-system\target\classes\mapper\flowable\FlowDeployMapper.xml]' + at com.baomidou.mybatisplus.extension.spring.MybatisSqlSessionFactoryBean.buildSqlSessionFactory(MybatisSqlSessionFactoryBean.java:575) + at com.baomidou.mybatisplus.extension.spring.MybatisSqlSessionFactoryBean.afterPropertiesSet(MybatisSqlSessionFactoryBean.java:444) + at com.baomidou.mybatisplus.extension.spring.MybatisSqlSessionFactoryBean.getObject(MybatisSqlSessionFactoryBean.java:608) + at com.dc.framework.config.DataSourceConfiguration.sqlSessionFactory(DataSourceConfiguration.java:109) + at com.dc.framework.config.DataSourceConfiguration$$EnhancerBySpringCGLIB$$8afd51b2.CGLIB$sqlSessionFactory$0(<generated>) + at com.dc.framework.config.DataSourceConfiguration$$EnhancerBySpringCGLIB$$8afd51b2$$FastClassBySpringCGLIB$$7f2433b8.invoke(<generated>) + at org.springframework.cglib.proxy.MethodProxy.invokeSuper(MethodProxy.java:244) + at org.springframework.context.annotation.ConfigurationClassEnhancer$BeanMethodInterceptor.intercept(ConfigurationClassEnhancer.java:331) + at com.dc.framework.config.DataSourceConfiguration$$EnhancerBySpringCGLIB$$8afd51b2.sqlSessionFactory(<generated>) + at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) + at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) + at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) + at java.lang.reflect.Method.invoke(Method.java:498) + at org.springframework.beans.factory.support.SimpleInstantiationStrategy.instantiate(SimpleInstantiationStrategy.java:154) + ... 50 common frames omitted +Caused by: org.apache.ibatis.builder.BuilderException: Error parsing Mapper XML. The XML location is 'file [D:\workspace\wenyin\win\win-system\target\classes\mapper\flowable\FlowDeployMapper.xml]'. Cause: org.apache.ibatis.builder.BuilderException: Error resolving class. Cause: org.apache.ibatis.type.TypeException: Could not resolve type alias 'com.ruoyi.system.domain.FlowProcDefDto'. Cause: java.lang.ClassNotFoundException: Cannot find class: com.ruoyi.system.domain.FlowProcDefDto + at org.apache.ibatis.builder.xml.XMLMapperBuilder.configurationElement(XMLMapperBuilder.java:123) + at org.apache.ibatis.builder.xml.XMLMapperBuilder.parse(XMLMapperBuilder.java:95) + at com.baomidou.mybatisplus.extension.spring.MybatisSqlSessionFactoryBean.buildSqlSessionFactory(MybatisSqlSessionFactoryBean.java:573) + ... 63 common frames omitted +Caused by: org.apache.ibatis.builder.BuilderException: Error resolving class. Cause: org.apache.ibatis.type.TypeException: Could not resolve type alias 'com.ruoyi.system.domain.FlowProcDefDto'. Cause: java.lang.ClassNotFoundException: Cannot find class: com.ruoyi.system.domain.FlowProcDefDto + at org.apache.ibatis.builder.BaseBuilder.resolveClass(BaseBuilder.java:118) + at org.apache.ibatis.builder.xml.XMLStatementBuilder.parseStatementNode(XMLStatementBuilder.java:102) + at org.apache.ibatis.builder.xml.XMLMapperBuilder.buildStatementFromContext(XMLMapperBuilder.java:138) + at org.apache.ibatis.builder.xml.XMLMapperBuilder.buildStatementFromContext(XMLMapperBuilder.java:131) + at org.apache.ibatis.builder.xml.XMLMapperBuilder.configurationElement(XMLMapperBuilder.java:121) + ... 65 common frames omitted +Caused by: org.apache.ibatis.type.TypeException: Could not resolve type alias 'com.ruoyi.system.domain.FlowProcDefDto'. Cause: java.lang.ClassNotFoundException: Cannot find class: com.ruoyi.system.domain.FlowProcDefDto + at org.apache.ibatis.type.TypeAliasRegistry.resolveAlias(TypeAliasRegistry.java:120) + at org.apache.ibatis.builder.BaseBuilder.resolveAlias(BaseBuilder.java:149) + at org.apache.ibatis.builder.BaseBuilder.resolveClass(BaseBuilder.java:116) + ... 69 common frames omitted +Caused by: java.lang.ClassNotFoundException: Cannot find class: com.ruoyi.system.domain.FlowProcDefDto + at org.apache.ibatis.io.ClassLoaderWrapper.classForName(ClassLoaderWrapper.java:196) + at org.apache.ibatis.io.ClassLoaderWrapper.classForName(ClassLoaderWrapper.java:89) + at org.apache.ibatis.io.Resources.classForName(Resources.java:261) + at org.apache.ibatis.type.TypeAliasRegistry.resolveAlias(TypeAliasRegistry.java:116) + ... 71 common frames omitted +12:40:41.237 [restartedMain] ERROR o.s.b.SpringApplication - [reportFailure,870] - Application run failed +org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'accessoryService': Unsatisfied dependency expressed through field 'baseMapper'; nested exception is org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'accessoryMapper' defined in file [D:\workspace\wenyin\win\win-system\target\classes\com\win\system\mapper\AccessoryMapper.class]: Unsatisfied dependency expressed through bean property 'sqlSessionFactory'; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'sqlSessionFactory' defined in class path resource [com/win/framework/config/DataSourceConfiguration.class]: Bean instantiation via factory method failed; nested exception is org.springframework.beans.BeanInstantiationException: Failed to instantiate [org.apache.ibatis.session.SqlSessionFactory]: Factory method 'sqlSessionFactory' threw exception; nested exception is java.io.IOException: Failed to parse mapping resource: 'file [D:\workspace\wenyin\win\win-system\target\classes\mapper\flowable\FlowDeployMapper.xml]' + at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor$AutowiredFieldElement.resolveFieldValue(AutowiredAnnotationBeanPostProcessor.java:659) + at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor$AutowiredFieldElement.inject(AutowiredAnnotationBeanPostProcessor.java:639) + at org.springframework.beans.factory.annotation.InjectionMetadata.inject(InjectionMetadata.java:119) + at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor.postProcessProperties(AutowiredAnnotationBeanPostProcessor.java:399) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.populateBean(AbstractAutowireCapableBeanFactory.java:1431) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:619) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:542) + at org.springframework.beans.factory.support.AbstractBeanFactory.lambda$doGetBean$0(AbstractBeanFactory.java:335) + at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:234) + at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:333) + at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:208) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.preInstantiateSingletons(DefaultListableBeanFactory.java:953) + at org.springframework.context.support.AbstractApplicationContext.finishBeanFactoryInitialization(AbstractApplicationContext.java:918) + at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:583) + at org.springframework.boot.web.servlet.context.ServletWebServerApplicationContext.refresh(ServletWebServerApplicationContext.java:145) + at org.springframework.boot.SpringApplication.refresh(SpringApplication.java:780) + at org.springframework.boot.SpringApplication.refreshContext(SpringApplication.java:453) + at org.springframework.boot.SpringApplication.run(SpringApplication.java:343) + at org.springframework.boot.SpringApplication.run(SpringApplication.java:1370) + at org.springframework.boot.SpringApplication.run(SpringApplication.java:1359) + at com.dc.web.DcApplication.main(WinApplication.java:25) + at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) + at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) + at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) + at java.lang.reflect.Method.invoke(Method.java:498) + at org.springframework.boot.devtools.restart.RestartLauncher.run(RestartLauncher.java:49) +Caused by: org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'accessoryMapper' defined in file [D:\workspace\wenyin\win\win-system\target\classes\com\win\system\mapper\AccessoryMapper.class]: Unsatisfied dependency expressed through bean property 'sqlSessionFactory'; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'sqlSessionFactory' defined in class path resource [com/win/framework/config/DataSourceConfiguration.class]: Bean instantiation via factory method failed; nested exception is org.springframework.beans.BeanInstantiationException: Failed to instantiate [org.apache.ibatis.session.SqlSessionFactory]: Factory method 'sqlSessionFactory' threw exception; nested exception is java.io.IOException: Failed to parse mapping resource: 'file [D:\workspace\wenyin\win\win-system\target\classes\mapper\flowable\FlowDeployMapper.xml]' + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.autowireByType(AbstractAutowireCapableBeanFactory.java:1534) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.populateBean(AbstractAutowireCapableBeanFactory.java:1417) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:619) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:542) + at org.springframework.beans.factory.support.AbstractBeanFactory.lambda$doGetBean$0(AbstractBeanFactory.java:335) + at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:234) + at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:333) + at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:208) + at org.springframework.beans.factory.config.DependencyDescriptor.resolveCandidate(DependencyDescriptor.java:276) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.doResolveDependency(DefaultListableBeanFactory.java:1389) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.resolveDependency(DefaultListableBeanFactory.java:1309) + at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor$AutowiredFieldElement.resolveFieldValue(AutowiredAnnotationBeanPostProcessor.java:656) + ... 25 common frames omitted +Caused by: org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'sqlSessionFactory' defined in class path resource [com/win/framework/config/DataSourceConfiguration.class]: Bean instantiation via factory method failed; nested exception is org.springframework.beans.BeanInstantiationException: Failed to instantiate [org.apache.ibatis.session.SqlSessionFactory]: Factory method 'sqlSessionFactory' threw exception; nested exception is java.io.IOException: Failed to parse mapping resource: 'file [D:\workspace\wenyin\win\win-system\target\classes\mapper\flowable\FlowDeployMapper.xml]' + at org.springframework.beans.factory.support.ConstructorResolver.instantiate(ConstructorResolver.java:658) + at org.springframework.beans.factory.support.ConstructorResolver.instantiateUsingFactoryMethod(ConstructorResolver.java:638) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.instantiateUsingFactoryMethod(AbstractAutowireCapableBeanFactory.java:1352) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBeanInstance(AbstractAutowireCapableBeanFactory.java:1195) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:582) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:542) + at org.springframework.beans.factory.support.AbstractBeanFactory.lambda$doGetBean$0(AbstractBeanFactory.java:335) + at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:234) + at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:333) + at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:208) + at org.springframework.beans.factory.config.DependencyDescriptor.resolveCandidate(DependencyDescriptor.java:276) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.doResolveDependency(DefaultListableBeanFactory.java:1389) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.resolveDependency(DefaultListableBeanFactory.java:1309) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.autowireByType(AbstractAutowireCapableBeanFactory.java:1519) + ... 36 common frames omitted +Caused by: org.springframework.beans.BeanInstantiationException: Failed to instantiate [org.apache.ibatis.session.SqlSessionFactory]: Factory method 'sqlSessionFactory' threw exception; nested exception is java.io.IOException: Failed to parse mapping resource: 'file [D:\workspace\wenyin\win\win-system\target\classes\mapper\flowable\FlowDeployMapper.xml]' + at org.springframework.beans.factory.support.SimpleInstantiationStrategy.instantiate(SimpleInstantiationStrategy.java:185) + at org.springframework.beans.factory.support.ConstructorResolver.instantiate(ConstructorResolver.java:653) + ... 49 common frames omitted +Caused by: java.io.IOException: Failed to parse mapping resource: 'file [D:\workspace\wenyin\win\win-system\target\classes\mapper\flowable\FlowDeployMapper.xml]' + at com.baomidou.mybatisplus.extension.spring.MybatisSqlSessionFactoryBean.buildSqlSessionFactory(MybatisSqlSessionFactoryBean.java:575) + at com.baomidou.mybatisplus.extension.spring.MybatisSqlSessionFactoryBean.afterPropertiesSet(MybatisSqlSessionFactoryBean.java:444) + at com.baomidou.mybatisplus.extension.spring.MybatisSqlSessionFactoryBean.getObject(MybatisSqlSessionFactoryBean.java:608) + at com.dc.framework.config.DataSourceConfiguration.sqlSessionFactory(DataSourceConfiguration.java:109) + at com.dc.framework.config.DataSourceConfiguration$$EnhancerBySpringCGLIB$$4f894ea5.CGLIB$sqlSessionFactory$1(<generated>) + at com.dc.framework.config.DataSourceConfiguration$$EnhancerBySpringCGLIB$$4f894ea5$$FastClassBySpringCGLIB$$974217fd.invoke(<generated>) + at org.springframework.cglib.proxy.MethodProxy.invokeSuper(MethodProxy.java:244) + at org.springframework.context.annotation.ConfigurationClassEnhancer$BeanMethodInterceptor.intercept(ConfigurationClassEnhancer.java:331) + at com.dc.framework.config.DataSourceConfiguration$$EnhancerBySpringCGLIB$$4f894ea5.sqlSessionFactory(<generated>) + at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) + at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) + at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) + at java.lang.reflect.Method.invoke(Method.java:498) + at org.springframework.beans.factory.support.SimpleInstantiationStrategy.instantiate(SimpleInstantiationStrategy.java:154) + ... 50 common frames omitted +Caused by: org.apache.ibatis.builder.BuilderException: Error parsing Mapper XML. The XML location is 'file [D:\workspace\wenyin\win\win-system\target\classes\mapper\flowable\FlowDeployMapper.xml]'. Cause: org.apache.ibatis.builder.BuilderException: Error resolving class. Cause: org.apache.ibatis.type.TypeException: Could not resolve type alias 'com.ruoyi.system.domain.FlowProcDefDto'. Cause: java.lang.ClassNotFoundException: Cannot find class: com.ruoyi.system.domain.FlowProcDefDto + at org.apache.ibatis.builder.xml.XMLMapperBuilder.configurationElement(XMLMapperBuilder.java:123) + at org.apache.ibatis.builder.xml.XMLMapperBuilder.parse(XMLMapperBuilder.java:95) + at com.baomidou.mybatisplus.extension.spring.MybatisSqlSessionFactoryBean.buildSqlSessionFactory(MybatisSqlSessionFactoryBean.java:573) + ... 63 common frames omitted +Caused by: org.apache.ibatis.builder.BuilderException: Error resolving class. Cause: org.apache.ibatis.type.TypeException: Could not resolve type alias 'com.ruoyi.system.domain.FlowProcDefDto'. Cause: java.lang.ClassNotFoundException: Cannot find class: com.ruoyi.system.domain.FlowProcDefDto + at org.apache.ibatis.builder.BaseBuilder.resolveClass(BaseBuilder.java:118) + at org.apache.ibatis.builder.xml.XMLStatementBuilder.parseStatementNode(XMLStatementBuilder.java:102) + at org.apache.ibatis.builder.xml.XMLMapperBuilder.buildStatementFromContext(XMLMapperBuilder.java:138) + at org.apache.ibatis.builder.xml.XMLMapperBuilder.buildStatementFromContext(XMLMapperBuilder.java:131) + at org.apache.ibatis.builder.xml.XMLMapperBuilder.configurationElement(XMLMapperBuilder.java:121) + ... 65 common frames omitted +Caused by: org.apache.ibatis.type.TypeException: Could not resolve type alias 'com.ruoyi.system.domain.FlowProcDefDto'. Cause: java.lang.ClassNotFoundException: Cannot find class: com.ruoyi.system.domain.FlowProcDefDto + at org.apache.ibatis.type.TypeAliasRegistry.resolveAlias(TypeAliasRegistry.java:120) + at org.apache.ibatis.builder.BaseBuilder.resolveAlias(BaseBuilder.java:149) + at org.apache.ibatis.builder.BaseBuilder.resolveClass(BaseBuilder.java:116) + ... 69 common frames omitted +Caused by: java.lang.ClassNotFoundException: Cannot find class: com.ruoyi.system.domain.FlowProcDefDto + at org.apache.ibatis.io.ClassLoaderWrapper.classForName(ClassLoaderWrapper.java:196) + at org.apache.ibatis.io.ClassLoaderWrapper.classForName(ClassLoaderWrapper.java:89) + at org.apache.ibatis.io.Resources.classForName(Resources.java:261) + at org.apache.ibatis.type.TypeAliasRegistry.resolveAlias(TypeAliasRegistry.java:116) + ... 71 common frames omitted diff --git a/logs/sys-error.2023-07-24.log b/logs/sys-error.2023-07-24.log new file mode 100644 index 0000000..bcee397 --- /dev/null +++ b/logs/sys-error.2023-07-24.log @@ -0,0 +1,107 @@ +13:23:01.618 [http-nio-8080-exec-12] ERROR c.w.f.w.e.GlobalExceptionHandler - [handleRuntimeException,82] - 请求地址'/login',发生未知异常. +com.dc.common.exception.user.CaptchaException: 验证码错误 + at com.dc.framework.web.service.SysLoginService.validateCaptcha(SysLoginService.java:143) + at com.dc.framework.web.service.SysLoginService.login(SysLoginService.java:74) + at com.dc.web.controller.system.SysLoginController.login(SysLoginController.java:49) + at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) + at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) + at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) + at java.lang.reflect.Method.invoke(Method.java:498) + at org.springframework.web.method.support.InvocableHandlerMethod.doInvoke(InvocableHandlerMethod.java:205) + at org.springframework.web.method.support.InvocableHandlerMethod.invokeForRequest(InvocableHandlerMethod.java:150) + at org.springframework.web.servlet.mvc.method.annotation.ServletInvocableHandlerMethod.invokeAndHandle(ServletInvocableHandlerMethod.java:117) + at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.invokeHandlerMethod(RequestMappingHandlerAdapter.java:895) + at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.handleInternal(RequestMappingHandlerAdapter.java:808) + at org.springframework.web.servlet.mvc.method.AbstractHandlerMethodAdapter.handle(AbstractHandlerMethodAdapter.java:87) + at org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:1067) + at org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:963) + at org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:1006) + at org.springframework.web.servlet.FrameworkServlet.doPost(FrameworkServlet.java:909) + at javax.servlet.http.HttpServlet.service(HttpServlet.java:665) + at org.springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.java:883) + at javax.servlet.http.HttpServlet.service(HttpServlet.java:750) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:227) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:53) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:111) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:111) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at com.dc.common.filter.RepeatableFilter.doFilter(RepeatableFilter.java:39) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:327) + at org.springframework.security.web.access.intercept.FilterSecurityInterceptor.invoke(FilterSecurityInterceptor.java:115) + at org.springframework.security.web.access.intercept.FilterSecurityInterceptor.doFilter(FilterSecurityInterceptor.java:81) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.access.ExceptionTranslationFilter.doFilter(ExceptionTranslationFilter.java:121) + at org.springframework.security.web.access.ExceptionTranslationFilter.doFilter(ExceptionTranslationFilter.java:115) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.session.SessionManagementFilter.doFilter(SessionManagementFilter.java:126) + at org.springframework.security.web.session.SessionManagementFilter.doFilter(SessionManagementFilter.java:81) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.authentication.AnonymousAuthenticationFilter.doFilter(AnonymousAuthenticationFilter.java:105) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.servletapi.SecurityContextHolderAwareRequestFilter.doFilter(SecurityContextHolderAwareRequestFilter.java:149) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.savedrequest.RequestCacheAwareFilter.doFilter(RequestCacheAwareFilter.java:63) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at com.dc.framework.security.filter.JwtAuthenticationTokenFilter.doFilterInternal(JwtAuthenticationTokenFilter.java:43) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:111) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.authentication.logout.LogoutFilter.doFilter(LogoutFilter.java:103) + at org.springframework.security.web.authentication.logout.LogoutFilter.doFilter(LogoutFilter.java:89) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.web.filter.CorsFilter.doFilterInternal(CorsFilter.java:91) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.header.HeaderWriterFilter.doHeadersAfter(HeaderWriterFilter.java:90) + at org.springframework.security.web.header.HeaderWriterFilter.doFilterInternal(HeaderWriterFilter.java:75) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.context.SecurityContextPersistenceFilter.doFilter(SecurityContextPersistenceFilter.java:110) + at org.springframework.security.web.context.SecurityContextPersistenceFilter.doFilter(SecurityContextPersistenceFilter.java:80) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.context.request.async.WebAsyncManagerIntegrationFilter.doFilterInternal(WebAsyncManagerIntegrationFilter.java:55) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.FilterChainProxy.doFilterInternal(FilterChainProxy.java:211) + at org.springframework.security.web.FilterChainProxy.doFilter(FilterChainProxy.java:183) + at org.springframework.web.filter.DelegatingFilterProxy.invokeDelegate(DelegatingFilterProxy.java:354) + at org.springframework.web.filter.DelegatingFilterProxy.doFilter(DelegatingFilterProxy.java:267) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.RequestContextFilter.doFilterInternal(RequestContextFilter.java:100) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.FormContentFilter.doFilterInternal(FormContentFilter.java:93) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.CharacterEncodingFilter.doFilterInternal(CharacterEncodingFilter.java:201) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:197) + at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:97) + at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:541) + at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:135) + at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:92) + at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:78) + at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:360) + at org.apache.coyote.http11.Http11Processor.service(Http11Processor.java:399) + at org.apache.coyote.AbstractProcessorLight.process(AbstractProcessorLight.java:65) + at org.apache.coyote.AbstractProtocol$ConnectionHandler.process(AbstractProtocol.java:890) + at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1743) + at org.apache.tomcat.util.net.SocketProcessorBase.run(SocketProcessorBase.java:49) + at org.apache.tomcat.util.threads.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1191) + at org.apache.tomcat.util.threads.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:659) + at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61) + at java.lang.Thread.run(Thread.java:748) diff --git a/logs/sys-error.2023-07-28.log b/logs/sys-error.2023-07-28.log new file mode 100644 index 0000000..6e340e2 --- /dev/null +++ b/logs/sys-error.2023-07-28.log @@ -0,0 +1,7616 @@ +10:54:20.574 [restartedMain] ERROR o.f.c.e.i.i.CommandContext - [logException,125] - Error while closing command context +org.apache.ibatis.exceptions.PersistenceException: +### Error querying database. Cause: org.postgresql.util.PSQLException: 错误: 关系 "act_ge_property" 不存在 + 位置:20 +### The error may exist in org/flowable/common/db/mapping/entity/Property.xml +### The error may involve defaultParameterMap +### The error occurred while setting parameters +### SQL: select VALUE_ from ACT_GE_PROPERTY where NAME_ = 'schema.version' +### Cause: org.postgresql.util.PSQLException: 错误: 关系 "act_ge_property" 不存在 + 位置:20 + at org.apache.ibatis.exceptions.ExceptionFactory.wrapException(ExceptionFactory.java:30) + at org.apache.ibatis.session.defaults.DefaultSqlSession.selectList(DefaultSqlSession.java:153) + at org.apache.ibatis.session.defaults.DefaultSqlSession.selectList(DefaultSqlSession.java:145) + at org.apache.ibatis.session.defaults.DefaultSqlSession.selectList(DefaultSqlSession.java:140) + at org.apache.ibatis.session.defaults.DefaultSqlSession.selectOne(DefaultSqlSession.java:76) + at org.apache.ibatis.session.defaults.DefaultSqlSession.selectOne(DefaultSqlSession.java:70) + at org.flowable.engine.impl.db.ProcessDbSchemaManager.getDbVersion(ProcessDbSchemaManager.java:84) + at org.flowable.engine.impl.db.ProcessDbSchemaManager.schemaCheckVersion(ProcessDbSchemaManager.java:40) + at org.flowable.engine.impl.SchemaOperationsProcessEngineBuild.execute(SchemaOperationsProcessEngineBuild.java:51) + at org.flowable.engine.impl.SchemaOperationsProcessEngineBuild.execute(SchemaOperationsProcessEngineBuild.java:28) + at org.flowable.engine.impl.interceptor.CommandInvoker$1.run(CommandInvoker.java:67) + at org.flowable.engine.impl.interceptor.CommandInvoker.executeOperation(CommandInvoker.java:140) + at org.flowable.engine.impl.interceptor.CommandInvoker.executeOperations(CommandInvoker.java:114) + at org.flowable.engine.impl.interceptor.CommandInvoker.execute(CommandInvoker.java:72) + at org.flowable.engine.impl.interceptor.BpmnOverrideContextInterceptor.execute(BpmnOverrideContextInterceptor.java:26) + at org.flowable.common.engine.impl.interceptor.TransactionContextInterceptor.execute(TransactionContextInterceptor.java:53) + at org.flowable.common.engine.impl.interceptor.CommandContextInterceptor.execute(CommandContextInterceptor.java:105) + at org.flowable.common.spring.SpringTransactionInterceptor.lambda$execute$0(SpringTransactionInterceptor.java:57) + at org.springframework.transaction.support.TransactionTemplate.execute(TransactionTemplate.java:140) + at org.flowable.common.spring.SpringTransactionInterceptor.execute(SpringTransactionInterceptor.java:57) + at org.flowable.common.engine.impl.interceptor.LogInterceptor.execute(LogInterceptor.java:30) + at org.flowable.common.engine.impl.cfg.CommandExecutorImpl.execute(CommandExecutorImpl.java:56) + at org.flowable.engine.impl.ProcessEngineImpl.<init>(ProcessEngineImpl.java:83) + at org.flowable.engine.impl.cfg.ProcessEngineConfigurationImpl.buildProcessEngine(ProcessEngineConfigurationImpl.java:917) + at org.flowable.spring.SpringProcessEngineConfiguration.buildProcessEngine(SpringProcessEngineConfiguration.java:76) + at org.flowable.engine.spring.configurator.SpringProcessEngineConfigurator.initProcessEngine(SpringProcessEngineConfigurator.java:58) + at org.flowable.engine.spring.configurator.SpringProcessEngineConfigurator.configure(SpringProcessEngineConfigurator.java:47) + at org.flowable.common.engine.impl.AbstractEngineConfiguration.configuratorsAfterInit(AbstractEngineConfiguration.java:1109) + at org.flowable.app.engine.AppEngineConfiguration.init(AppEngineConfiguration.java:237) + at org.flowable.app.engine.AppEngineConfiguration.buildAppEngine(AppEngineConfiguration.java:193) + at org.flowable.app.spring.SpringAppEngineConfiguration.buildAppEngine(SpringAppEngineConfiguration.java:66) + at org.flowable.app.spring.AppEngineFactoryBean.getObject(AppEngineFactoryBean.java:58) + at org.flowable.app.spring.AppEngineFactoryBean.getObject(AppEngineFactoryBean.java:31) + at org.springframework.beans.factory.support.FactoryBeanRegistrySupport.doGetObjectFromFactoryBean(FactoryBeanRegistrySupport.java:169) + at org.springframework.beans.factory.support.FactoryBeanRegistrySupport.getObjectFromFactoryBean(FactoryBeanRegistrySupport.java:101) + at org.springframework.beans.factory.support.AbstractBeanFactory.getObjectForBeanInstance(AbstractBeanFactory.java:1884) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.getObjectForBeanInstance(AbstractAutowireCapableBeanFactory.java:1284) + at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:345) + at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:208) + at org.springframework.beans.factory.config.DependencyDescriptor.resolveCandidate(DependencyDescriptor.java:276) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.doResolveDependency(DefaultListableBeanFactory.java:1389) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.resolveDependency(DefaultListableBeanFactory.java:1309) + at org.springframework.beans.factory.support.ConstructorResolver.resolveAutowiredArgument(ConstructorResolver.java:887) + at org.springframework.beans.factory.support.ConstructorResolver.createArgumentArray(ConstructorResolver.java:791) + at org.springframework.beans.factory.support.ConstructorResolver.instantiateUsingFactoryMethod(ConstructorResolver.java:541) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.instantiateUsingFactoryMethod(AbstractAutowireCapableBeanFactory.java:1352) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBeanInstance(AbstractAutowireCapableBeanFactory.java:1195) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:582) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:542) + at org.springframework.beans.factory.support.AbstractBeanFactory.lambda$doGetBean$0(AbstractBeanFactory.java:335) + at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:234) + at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:333) + at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:208) + at org.springframework.beans.factory.config.DependencyDescriptor.resolveCandidate(DependencyDescriptor.java:276) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.doResolveDependency(DefaultListableBeanFactory.java:1389) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.resolveDependency(DefaultListableBeanFactory.java:1309) + at org.springframework.beans.factory.support.ConstructorResolver.resolveAutowiredArgument(ConstructorResolver.java:887) + at org.springframework.beans.factory.support.ConstructorResolver.createArgumentArray(ConstructorResolver.java:791) + at org.springframework.beans.factory.support.ConstructorResolver.instantiateUsingFactoryMethod(ConstructorResolver.java:541) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.instantiateUsingFactoryMethod(AbstractAutowireCapableBeanFactory.java:1352) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBeanInstance(AbstractAutowireCapableBeanFactory.java:1195) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:582) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:542) + at org.springframework.beans.factory.support.AbstractBeanFactory.lambda$doGetBean$0(AbstractBeanFactory.java:335) + at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:234) + at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:333) + at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:208) + at org.springframework.beans.factory.config.DependencyDescriptor.resolveCandidate(DependencyDescriptor.java:276) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.doResolveDependency(DefaultListableBeanFactory.java:1389) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.resolveDependency(DefaultListableBeanFactory.java:1309) + at org.springframework.context.annotation.CommonAnnotationBeanPostProcessor.autowireResource(CommonAnnotationBeanPostProcessor.java:544) + at org.springframework.context.annotation.CommonAnnotationBeanPostProcessor.getResource(CommonAnnotationBeanPostProcessor.java:520) + at org.springframework.context.annotation.CommonAnnotationBeanPostProcessor$ResourceElement.getResourceToInject(CommonAnnotationBeanPostProcessor.java:673) + at org.springframework.beans.factory.annotation.InjectionMetadata$InjectedElement.inject(InjectionMetadata.java:228) + at org.springframework.beans.factory.annotation.InjectionMetadata.inject(InjectionMetadata.java:119) + at org.springframework.context.annotation.CommonAnnotationBeanPostProcessor.postProcessProperties(CommonAnnotationBeanPostProcessor.java:329) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.populateBean(AbstractAutowireCapableBeanFactory.java:1431) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:619) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:542) + at org.springframework.beans.factory.support.AbstractBeanFactory.lambda$doGetBean$0(AbstractBeanFactory.java:335) + at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:234) + at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:333) + at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:208) + at org.springframework.beans.factory.config.DependencyDescriptor.resolveCandidate(DependencyDescriptor.java:276) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.doResolveDependency(DefaultListableBeanFactory.java:1389) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.resolveDependency(DefaultListableBeanFactory.java:1309) + at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor$AutowiredFieldElement.resolveFieldValue(AutowiredAnnotationBeanPostProcessor.java:656) + at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor$AutowiredFieldElement.inject(AutowiredAnnotationBeanPostProcessor.java:639) + at org.springframework.beans.factory.annotation.InjectionMetadata.inject(InjectionMetadata.java:119) + at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor.postProcessProperties(AutowiredAnnotationBeanPostProcessor.java:399) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.populateBean(AbstractAutowireCapableBeanFactory.java:1431) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:619) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:542) + at org.springframework.beans.factory.support.AbstractBeanFactory.lambda$doGetBean$0(AbstractBeanFactory.java:335) + at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:234) + at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:333) + at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:208) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.preInstantiateSingletons(DefaultListableBeanFactory.java:953) + at org.springframework.context.support.AbstractApplicationContext.finishBeanFactoryInitialization(AbstractApplicationContext.java:918) + at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:583) + at org.springframework.boot.web.servlet.context.ServletWebServerApplicationContext.refresh(ServletWebServerApplicationContext.java:145) + at org.springframework.boot.SpringApplication.refresh(SpringApplication.java:780) + at org.springframework.boot.SpringApplication.refreshContext(SpringApplication.java:453) + at org.springframework.boot.SpringApplication.run(SpringApplication.java:343) + at org.springframework.boot.SpringApplication.run(SpringApplication.java:1370) + at org.springframework.boot.SpringApplication.run(SpringApplication.java:1359) + at com.dc.web.DcApplication.main(DcApplication.java:25) + at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) + at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) + at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) + at java.lang.reflect.Method.invoke(Method.java:498) + at org.springframework.boot.devtools.restart.RestartLauncher.run(RestartLauncher.java:49) +Caused by: org.postgresql.util.PSQLException: 错误: 关系 "act_ge_property" 不存在 + 位置:20 + at org.postgresql.core.v3.QueryExecutorImpl.receiveErrorResponse(QueryExecutorImpl.java:2565) + at org.postgresql.core.v3.QueryExecutorImpl.processResults(QueryExecutorImpl.java:2297) + at org.postgresql.core.v3.QueryExecutorImpl.execute(QueryExecutorImpl.java:322) + at org.postgresql.jdbc.PgStatement.executeInternal(PgStatement.java:481) + at org.postgresql.jdbc.PgStatement.execute(PgStatement.java:401) + at org.postgresql.jdbc.PgPreparedStatement.executeWithFlags(PgPreparedStatement.java:164) + at org.postgresql.jdbc.PgPreparedStatement.execute(PgPreparedStatement.java:153) + at com.alibaba.druid.filter.FilterChainImpl.preparedStatement_execute(FilterChainImpl.java:3446) + at com.alibaba.druid.filter.FilterEventAdapter.preparedStatement_execute(FilterEventAdapter.java:434) + at com.alibaba.druid.filter.FilterChainImpl.preparedStatement_execute(FilterChainImpl.java:3444) + at com.alibaba.druid.proxy.jdbc.PreparedStatementProxyImpl.execute(PreparedStatementProxyImpl.java:152) + at com.alibaba.druid.pool.DruidPooledPreparedStatement.execute(DruidPooledPreparedStatement.java:483) + at org.apache.ibatis.executor.statement.PreparedStatementHandler.query(PreparedStatementHandler.java:64) + at org.apache.ibatis.executor.statement.RoutingStatementHandler.query(RoutingStatementHandler.java:79) + at org.apache.ibatis.executor.SimpleExecutor.doQuery(SimpleExecutor.java:63) + at org.apache.ibatis.executor.BaseExecutor.queryFromDatabase(BaseExecutor.java:325) + at org.apache.ibatis.executor.BaseExecutor.query(BaseExecutor.java:156) + at org.apache.ibatis.executor.CachingExecutor.query(CachingExecutor.java:109) + at org.apache.ibatis.executor.CachingExecutor.query(CachingExecutor.java:89) + at org.apache.ibatis.session.defaults.DefaultSqlSession.selectList(DefaultSqlSession.java:151) + ... 110 common frames omitted +10:54:20.806 [restartedMain] ERROR o.s.b.SpringApplication - [reportFailure,870] - Application run failed +org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'flowDefinitionController': Unsatisfied dependency expressed through field 'flowDefinitionService'; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'flowDefinitionService': Injection of resource dependencies failed; nested exception is org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'repositoryServiceBean' defined in class path resource [org/flowable/spring/boot/ProcessEngineServicesAutoConfiguration.class]: Unsatisfied dependency expressed through method 'repositoryServiceBean' parameter 0; nested exception is org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'processEngine' defined in class path resource [org/flowable/spring/boot/ProcessEngineServicesAutoConfiguration$AlreadyInitializedAppEngineConfiguration.class]: Unsatisfied dependency expressed through method 'processEngine' parameter 0; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'flowableAppEngine': FactoryBean threw exception on object creation; nested exception is org.apache.ibatis.exceptions.PersistenceException: +### Error querying database. Cause: org.postgresql.util.PSQLException: 错误: 关系 "act_ge_property" 不存在 + 位置:20 +### The error may exist in org/flowable/common/db/mapping/entity/Property.xml +### The error may involve defaultParameterMap +### The error occurred while setting parameters +### SQL: select VALUE_ from ACT_GE_PROPERTY where NAME_ = 'schema.version' +### Cause: org.postgresql.util.PSQLException: 错误: 关系 "act_ge_property" 不存在 + 位置:20 + at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor$AutowiredFieldElement.resolveFieldValue(AutowiredAnnotationBeanPostProcessor.java:659) + at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor$AutowiredFieldElement.inject(AutowiredAnnotationBeanPostProcessor.java:639) + at org.springframework.beans.factory.annotation.InjectionMetadata.inject(InjectionMetadata.java:119) + at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor.postProcessProperties(AutowiredAnnotationBeanPostProcessor.java:399) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.populateBean(AbstractAutowireCapableBeanFactory.java:1431) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:619) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:542) + at org.springframework.beans.factory.support.AbstractBeanFactory.lambda$doGetBean$0(AbstractBeanFactory.java:335) + at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:234) + at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:333) + at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:208) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.preInstantiateSingletons(DefaultListableBeanFactory.java:953) + at org.springframework.context.support.AbstractApplicationContext.finishBeanFactoryInitialization(AbstractApplicationContext.java:918) + at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:583) + at org.springframework.boot.web.servlet.context.ServletWebServerApplicationContext.refresh(ServletWebServerApplicationContext.java:145) + at org.springframework.boot.SpringApplication.refresh(SpringApplication.java:780) + at org.springframework.boot.SpringApplication.refreshContext(SpringApplication.java:453) + at org.springframework.boot.SpringApplication.run(SpringApplication.java:343) + at org.springframework.boot.SpringApplication.run(SpringApplication.java:1370) + at org.springframework.boot.SpringApplication.run(SpringApplication.java:1359) + at com.dc.web.DcApplication.main(DcApplication.java:25) + at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) + at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) + at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) + at java.lang.reflect.Method.invoke(Method.java:498) + at org.springframework.boot.devtools.restart.RestartLauncher.run(RestartLauncher.java:49) +Caused by: org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'flowDefinitionService': Injection of resource dependencies failed; nested exception is org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'repositoryServiceBean' defined in class path resource [org/flowable/spring/boot/ProcessEngineServicesAutoConfiguration.class]: Unsatisfied dependency expressed through method 'repositoryServiceBean' parameter 0; nested exception is org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'processEngine' defined in class path resource [org/flowable/spring/boot/ProcessEngineServicesAutoConfiguration$AlreadyInitializedAppEngineConfiguration.class]: Unsatisfied dependency expressed through method 'processEngine' parameter 0; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'flowableAppEngine': FactoryBean threw exception on object creation; nested exception is org.apache.ibatis.exceptions.PersistenceException: +### Error querying database. Cause: org.postgresql.util.PSQLException: 错误: 关系 "act_ge_property" 不存在 + 位置:20 +### The error may exist in org/flowable/common/db/mapping/entity/Property.xml +### The error may involve defaultParameterMap +### The error occurred while setting parameters +### SQL: select VALUE_ from ACT_GE_PROPERTY where NAME_ = 'schema.version' +### Cause: org.postgresql.util.PSQLException: 错误: 关系 "act_ge_property" 不存在 + 位置:20 + at org.springframework.context.annotation.CommonAnnotationBeanPostProcessor.postProcessProperties(CommonAnnotationBeanPostProcessor.java:332) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.populateBean(AbstractAutowireCapableBeanFactory.java:1431) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:619) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:542) + at org.springframework.beans.factory.support.AbstractBeanFactory.lambda$doGetBean$0(AbstractBeanFactory.java:335) + at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:234) + at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:333) + at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:208) + at org.springframework.beans.factory.config.DependencyDescriptor.resolveCandidate(DependencyDescriptor.java:276) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.doResolveDependency(DefaultListableBeanFactory.java:1389) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.resolveDependency(DefaultListableBeanFactory.java:1309) + at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor$AutowiredFieldElement.resolveFieldValue(AutowiredAnnotationBeanPostProcessor.java:656) + ... 25 common frames omitted +Caused by: org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'repositoryServiceBean' defined in class path resource [org/flowable/spring/boot/ProcessEngineServicesAutoConfiguration.class]: Unsatisfied dependency expressed through method 'repositoryServiceBean' parameter 0; nested exception is org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'processEngine' defined in class path resource [org/flowable/spring/boot/ProcessEngineServicesAutoConfiguration$AlreadyInitializedAppEngineConfiguration.class]: Unsatisfied dependency expressed through method 'processEngine' parameter 0; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'flowableAppEngine': FactoryBean threw exception on object creation; nested exception is org.apache.ibatis.exceptions.PersistenceException: +### Error querying database. Cause: org.postgresql.util.PSQLException: 错误: 关系 "act_ge_property" 不存在 + 位置:20 +### The error may exist in org/flowable/common/db/mapping/entity/Property.xml +### The error may involve defaultParameterMap +### The error occurred while setting parameters +### SQL: select VALUE_ from ACT_GE_PROPERTY where NAME_ = 'schema.version' +### Cause: org.postgresql.util.PSQLException: 错误: 关系 "act_ge_property" 不存在 + 位置:20 + at org.springframework.beans.factory.support.ConstructorResolver.createArgumentArray(ConstructorResolver.java:800) + at org.springframework.beans.factory.support.ConstructorResolver.instantiateUsingFactoryMethod(ConstructorResolver.java:541) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.instantiateUsingFactoryMethod(AbstractAutowireCapableBeanFactory.java:1352) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBeanInstance(AbstractAutowireCapableBeanFactory.java:1195) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:582) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:542) + at org.springframework.beans.factory.support.AbstractBeanFactory.lambda$doGetBean$0(AbstractBeanFactory.java:335) + at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:234) + at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:333) + at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:208) + at org.springframework.beans.factory.config.DependencyDescriptor.resolveCandidate(DependencyDescriptor.java:276) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.doResolveDependency(DefaultListableBeanFactory.java:1389) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.resolveDependency(DefaultListableBeanFactory.java:1309) + at org.springframework.context.annotation.CommonAnnotationBeanPostProcessor.autowireResource(CommonAnnotationBeanPostProcessor.java:544) + at org.springframework.context.annotation.CommonAnnotationBeanPostProcessor.getResource(CommonAnnotationBeanPostProcessor.java:520) + at org.springframework.context.annotation.CommonAnnotationBeanPostProcessor$ResourceElement.getResourceToInject(CommonAnnotationBeanPostProcessor.java:673) + at org.springframework.beans.factory.annotation.InjectionMetadata$InjectedElement.inject(InjectionMetadata.java:228) + at org.springframework.beans.factory.annotation.InjectionMetadata.inject(InjectionMetadata.java:119) + at org.springframework.context.annotation.CommonAnnotationBeanPostProcessor.postProcessProperties(CommonAnnotationBeanPostProcessor.java:329) + ... 36 common frames omitted +Caused by: org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'processEngine' defined in class path resource [org/flowable/spring/boot/ProcessEngineServicesAutoConfiguration$AlreadyInitializedAppEngineConfiguration.class]: Unsatisfied dependency expressed through method 'processEngine' parameter 0; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'flowableAppEngine': FactoryBean threw exception on object creation; nested exception is org.apache.ibatis.exceptions.PersistenceException: +### Error querying database. Cause: org.postgresql.util.PSQLException: 错误: 关系 "act_ge_property" 不存在 + 位置:20 +### The error may exist in org/flowable/common/db/mapping/entity/Property.xml +### The error may involve defaultParameterMap +### The error occurred while setting parameters +### SQL: select VALUE_ from ACT_GE_PROPERTY where NAME_ = 'schema.version' +### Cause: org.postgresql.util.PSQLException: 错误: 关系 "act_ge_property" 不存在 + 位置:20 + at org.springframework.beans.factory.support.ConstructorResolver.createArgumentArray(ConstructorResolver.java:800) + at org.springframework.beans.factory.support.ConstructorResolver.instantiateUsingFactoryMethod(ConstructorResolver.java:541) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.instantiateUsingFactoryMethod(AbstractAutowireCapableBeanFactory.java:1352) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBeanInstance(AbstractAutowireCapableBeanFactory.java:1195) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:582) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:542) + at org.springframework.beans.factory.support.AbstractBeanFactory.lambda$doGetBean$0(AbstractBeanFactory.java:335) + at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:234) + at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:333) + at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:208) + at org.springframework.beans.factory.config.DependencyDescriptor.resolveCandidate(DependencyDescriptor.java:276) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.doResolveDependency(DefaultListableBeanFactory.java:1389) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.resolveDependency(DefaultListableBeanFactory.java:1309) + at org.springframework.beans.factory.support.ConstructorResolver.resolveAutowiredArgument(ConstructorResolver.java:887) + at org.springframework.beans.factory.support.ConstructorResolver.createArgumentArray(ConstructorResolver.java:791) + ... 54 common frames omitted +Caused by: org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'flowableAppEngine': FactoryBean threw exception on object creation; nested exception is org.apache.ibatis.exceptions.PersistenceException: +### Error querying database. Cause: org.postgresql.util.PSQLException: 错误: 关系 "act_ge_property" 不存在 + 位置:20 +### The error may exist in org/flowable/common/db/mapping/entity/Property.xml +### The error may involve defaultParameterMap +### The error occurred while setting parameters +### SQL: select VALUE_ from ACT_GE_PROPERTY where NAME_ = 'schema.version' +### Cause: org.postgresql.util.PSQLException: 错误: 关系 "act_ge_property" 不存在 + 位置:20 + at org.springframework.beans.factory.support.FactoryBeanRegistrySupport.doGetObjectFromFactoryBean(FactoryBeanRegistrySupport.java:176) + at org.springframework.beans.factory.support.FactoryBeanRegistrySupport.getObjectFromFactoryBean(FactoryBeanRegistrySupport.java:101) + at org.springframework.beans.factory.support.AbstractBeanFactory.getObjectForBeanInstance(AbstractBeanFactory.java:1884) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.getObjectForBeanInstance(AbstractAutowireCapableBeanFactory.java:1284) + at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:345) + at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:208) + at org.springframework.beans.factory.config.DependencyDescriptor.resolveCandidate(DependencyDescriptor.java:276) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.doResolveDependency(DefaultListableBeanFactory.java:1389) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.resolveDependency(DefaultListableBeanFactory.java:1309) + at org.springframework.beans.factory.support.ConstructorResolver.resolveAutowiredArgument(ConstructorResolver.java:887) + at org.springframework.beans.factory.support.ConstructorResolver.createArgumentArray(ConstructorResolver.java:791) + ... 68 common frames omitted +Caused by: org.apache.ibatis.exceptions.PersistenceException: +### Error querying database. Cause: org.postgresql.util.PSQLException: 错误: 关系 "act_ge_property" 不存在 + 位置:20 +### The error may exist in org/flowable/common/db/mapping/entity/Property.xml +### The error may involve defaultParameterMap +### The error occurred while setting parameters +### SQL: select VALUE_ from ACT_GE_PROPERTY where NAME_ = 'schema.version' +### Cause: org.postgresql.util.PSQLException: 错误: 关系 "act_ge_property" 不存在 + 位置:20 + at org.apache.ibatis.exceptions.ExceptionFactory.wrapException(ExceptionFactory.java:30) + at org.apache.ibatis.session.defaults.DefaultSqlSession.selectList(DefaultSqlSession.java:153) + at org.apache.ibatis.session.defaults.DefaultSqlSession.selectList(DefaultSqlSession.java:145) + at org.apache.ibatis.session.defaults.DefaultSqlSession.selectList(DefaultSqlSession.java:140) + at org.apache.ibatis.session.defaults.DefaultSqlSession.selectOne(DefaultSqlSession.java:76) + at org.apache.ibatis.session.defaults.DefaultSqlSession.selectOne(DefaultSqlSession.java:70) + at org.flowable.engine.impl.db.ProcessDbSchemaManager.getDbVersion(ProcessDbSchemaManager.java:84) + at org.flowable.engine.impl.db.ProcessDbSchemaManager.schemaCheckVersion(ProcessDbSchemaManager.java:40) + at org.flowable.engine.impl.SchemaOperationsProcessEngineBuild.execute(SchemaOperationsProcessEngineBuild.java:51) + at org.flowable.engine.impl.SchemaOperationsProcessEngineBuild.execute(SchemaOperationsProcessEngineBuild.java:28) + at org.flowable.engine.impl.interceptor.CommandInvoker$1.run(CommandInvoker.java:67) + at org.flowable.engine.impl.interceptor.CommandInvoker.executeOperation(CommandInvoker.java:140) + at org.flowable.engine.impl.interceptor.CommandInvoker.executeOperations(CommandInvoker.java:114) + at org.flowable.engine.impl.interceptor.CommandInvoker.execute(CommandInvoker.java:72) + at org.flowable.engine.impl.interceptor.BpmnOverrideContextInterceptor.execute(BpmnOverrideContextInterceptor.java:26) + at org.flowable.common.engine.impl.interceptor.TransactionContextInterceptor.execute(TransactionContextInterceptor.java:53) + at org.flowable.common.engine.impl.interceptor.CommandContextInterceptor.execute(CommandContextInterceptor.java:105) + at org.flowable.common.spring.SpringTransactionInterceptor.lambda$execute$0(SpringTransactionInterceptor.java:57) + at org.springframework.transaction.support.TransactionTemplate.execute(TransactionTemplate.java:140) + at org.flowable.common.spring.SpringTransactionInterceptor.execute(SpringTransactionInterceptor.java:57) + at org.flowable.common.engine.impl.interceptor.LogInterceptor.execute(LogInterceptor.java:30) + at org.flowable.common.engine.impl.cfg.CommandExecutorImpl.execute(CommandExecutorImpl.java:56) + at org.flowable.engine.impl.ProcessEngineImpl.<init>(ProcessEngineImpl.java:83) + at org.flowable.engine.impl.cfg.ProcessEngineConfigurationImpl.buildProcessEngine(ProcessEngineConfigurationImpl.java:917) + at org.flowable.spring.SpringProcessEngineConfiguration.buildProcessEngine(SpringProcessEngineConfiguration.java:76) + at org.flowable.engine.spring.configurator.SpringProcessEngineConfigurator.initProcessEngine(SpringProcessEngineConfigurator.java:58) + at org.flowable.engine.spring.configurator.SpringProcessEngineConfigurator.configure(SpringProcessEngineConfigurator.java:47) + at org.flowable.common.engine.impl.AbstractEngineConfiguration.configuratorsAfterInit(AbstractEngineConfiguration.java:1109) + at org.flowable.app.engine.AppEngineConfiguration.init(AppEngineConfiguration.java:237) + at org.flowable.app.engine.AppEngineConfiguration.buildAppEngine(AppEngineConfiguration.java:193) + at org.flowable.app.spring.SpringAppEngineConfiguration.buildAppEngine(SpringAppEngineConfiguration.java:66) + at org.flowable.app.spring.AppEngineFactoryBean.getObject(AppEngineFactoryBean.java:58) + at org.flowable.app.spring.AppEngineFactoryBean.getObject(AppEngineFactoryBean.java:31) + at org.springframework.beans.factory.support.FactoryBeanRegistrySupport.doGetObjectFromFactoryBean(FactoryBeanRegistrySupport.java:169) + ... 78 common frames omitted +Caused by: org.postgresql.util.PSQLException: 错误: 关系 "act_ge_property" 不存在 + 位置:20 + at org.postgresql.core.v3.QueryExecutorImpl.receiveErrorResponse(QueryExecutorImpl.java:2565) + at org.postgresql.core.v3.QueryExecutorImpl.processResults(QueryExecutorImpl.java:2297) + at org.postgresql.core.v3.QueryExecutorImpl.execute(QueryExecutorImpl.java:322) + at org.postgresql.jdbc.PgStatement.executeInternal(PgStatement.java:481) + at org.postgresql.jdbc.PgStatement.execute(PgStatement.java:401) + at org.postgresql.jdbc.PgPreparedStatement.executeWithFlags(PgPreparedStatement.java:164) + at org.postgresql.jdbc.PgPreparedStatement.execute(PgPreparedStatement.java:153) + at com.alibaba.druid.filter.FilterChainImpl.preparedStatement_execute(FilterChainImpl.java:3446) + at com.alibaba.druid.filter.FilterEventAdapter.preparedStatement_execute(FilterEventAdapter.java:434) + at com.alibaba.druid.filter.FilterChainImpl.preparedStatement_execute(FilterChainImpl.java:3444) + at com.alibaba.druid.proxy.jdbc.PreparedStatementProxyImpl.execute(PreparedStatementProxyImpl.java:152) + at com.alibaba.druid.pool.DruidPooledPreparedStatement.execute(DruidPooledPreparedStatement.java:483) + at org.apache.ibatis.executor.statement.PreparedStatementHandler.query(PreparedStatementHandler.java:64) + at org.apache.ibatis.executor.statement.RoutingStatementHandler.query(RoutingStatementHandler.java:79) + at org.apache.ibatis.executor.SimpleExecutor.doQuery(SimpleExecutor.java:63) + at org.apache.ibatis.executor.BaseExecutor.queryFromDatabase(BaseExecutor.java:325) + at org.apache.ibatis.executor.BaseExecutor.query(BaseExecutor.java:156) + at org.apache.ibatis.executor.CachingExecutor.query(CachingExecutor.java:109) + at org.apache.ibatis.executor.CachingExecutor.query(CachingExecutor.java:89) + at org.apache.ibatis.session.defaults.DefaultSqlSession.selectList(DefaultSqlSession.java:151) + ... 110 common frames omitted +10:55:10.364 [restartedMain] ERROR o.f.c.e.i.i.CommandContext - [logException,125] - Error while closing command context +org.apache.ibatis.exceptions.PersistenceException: +### Error querying database. Cause: org.postgresql.util.PSQLException: 错误: 关系 "act_ge_property" 不存在 + 位置:20 +### The error may exist in org/flowable/common/db/mapping/entity/Property.xml +### The error may involve defaultParameterMap +### The error occurred while setting parameters +### SQL: select VALUE_ from ACT_GE_PROPERTY where NAME_ = 'schema.version' +### Cause: org.postgresql.util.PSQLException: 错误: 关系 "act_ge_property" 不存在 + 位置:20 + at org.apache.ibatis.exceptions.ExceptionFactory.wrapException(ExceptionFactory.java:30) + at org.apache.ibatis.session.defaults.DefaultSqlSession.selectList(DefaultSqlSession.java:153) + at org.apache.ibatis.session.defaults.DefaultSqlSession.selectList(DefaultSqlSession.java:145) + at org.apache.ibatis.session.defaults.DefaultSqlSession.selectList(DefaultSqlSession.java:140) + at org.apache.ibatis.session.defaults.DefaultSqlSession.selectOne(DefaultSqlSession.java:76) + at org.apache.ibatis.session.defaults.DefaultSqlSession.selectOne(DefaultSqlSession.java:70) + at org.flowable.engine.impl.db.ProcessDbSchemaManager.getDbVersion(ProcessDbSchemaManager.java:84) + at org.flowable.engine.impl.db.ProcessDbSchemaManager.schemaCheckVersion(ProcessDbSchemaManager.java:40) + at org.flowable.engine.impl.SchemaOperationsProcessEngineBuild.execute(SchemaOperationsProcessEngineBuild.java:51) + at org.flowable.engine.impl.SchemaOperationsProcessEngineBuild.execute(SchemaOperationsProcessEngineBuild.java:28) + at org.flowable.engine.impl.interceptor.CommandInvoker$1.run(CommandInvoker.java:67) + at org.flowable.engine.impl.interceptor.CommandInvoker.executeOperation(CommandInvoker.java:140) + at org.flowable.engine.impl.interceptor.CommandInvoker.executeOperations(CommandInvoker.java:114) + at org.flowable.engine.impl.interceptor.CommandInvoker.execute(CommandInvoker.java:72) + at org.flowable.engine.impl.interceptor.BpmnOverrideContextInterceptor.execute(BpmnOverrideContextInterceptor.java:26) + at org.flowable.common.engine.impl.interceptor.TransactionContextInterceptor.execute(TransactionContextInterceptor.java:53) + at org.flowable.common.engine.impl.interceptor.CommandContextInterceptor.execute(CommandContextInterceptor.java:105) + at org.flowable.common.spring.SpringTransactionInterceptor.lambda$execute$0(SpringTransactionInterceptor.java:57) + at org.springframework.transaction.support.TransactionTemplate.execute(TransactionTemplate.java:140) + at org.flowable.common.spring.SpringTransactionInterceptor.execute(SpringTransactionInterceptor.java:57) + at org.flowable.common.engine.impl.interceptor.LogInterceptor.execute(LogInterceptor.java:30) + at org.flowable.common.engine.impl.cfg.CommandExecutorImpl.execute(CommandExecutorImpl.java:56) + at org.flowable.engine.impl.ProcessEngineImpl.<init>(ProcessEngineImpl.java:83) + at org.flowable.engine.impl.cfg.ProcessEngineConfigurationImpl.buildProcessEngine(ProcessEngineConfigurationImpl.java:917) + at org.flowable.spring.SpringProcessEngineConfiguration.buildProcessEngine(SpringProcessEngineConfiguration.java:76) + at org.flowable.engine.spring.configurator.SpringProcessEngineConfigurator.initProcessEngine(SpringProcessEngineConfigurator.java:58) + at org.flowable.engine.spring.configurator.SpringProcessEngineConfigurator.configure(SpringProcessEngineConfigurator.java:47) + at org.flowable.common.engine.impl.AbstractEngineConfiguration.configuratorsAfterInit(AbstractEngineConfiguration.java:1109) + at org.flowable.app.engine.AppEngineConfiguration.init(AppEngineConfiguration.java:237) + at org.flowable.app.engine.AppEngineConfiguration.buildAppEngine(AppEngineConfiguration.java:193) + at org.flowable.app.spring.SpringAppEngineConfiguration.buildAppEngine(SpringAppEngineConfiguration.java:66) + at org.flowable.app.spring.AppEngineFactoryBean.getObject(AppEngineFactoryBean.java:58) + at org.flowable.app.spring.AppEngineFactoryBean.getObject(AppEngineFactoryBean.java:31) + at org.springframework.beans.factory.support.FactoryBeanRegistrySupport.doGetObjectFromFactoryBean(FactoryBeanRegistrySupport.java:169) + at org.springframework.beans.factory.support.FactoryBeanRegistrySupport.getObjectFromFactoryBean(FactoryBeanRegistrySupport.java:101) + at org.springframework.beans.factory.support.AbstractBeanFactory.getObjectForBeanInstance(AbstractBeanFactory.java:1884) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.getObjectForBeanInstance(AbstractAutowireCapableBeanFactory.java:1284) + at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:345) + at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:208) + at org.springframework.beans.factory.config.DependencyDescriptor.resolveCandidate(DependencyDescriptor.java:276) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.doResolveDependency(DefaultListableBeanFactory.java:1389) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.resolveDependency(DefaultListableBeanFactory.java:1309) + at org.springframework.beans.factory.support.ConstructorResolver.resolveAutowiredArgument(ConstructorResolver.java:887) + at org.springframework.beans.factory.support.ConstructorResolver.createArgumentArray(ConstructorResolver.java:791) + at org.springframework.beans.factory.support.ConstructorResolver.instantiateUsingFactoryMethod(ConstructorResolver.java:541) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.instantiateUsingFactoryMethod(AbstractAutowireCapableBeanFactory.java:1352) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBeanInstance(AbstractAutowireCapableBeanFactory.java:1195) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:582) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:542) + at org.springframework.beans.factory.support.AbstractBeanFactory.lambda$doGetBean$0(AbstractBeanFactory.java:335) + at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:234) + at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:333) + at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:208) + at org.springframework.beans.factory.config.DependencyDescriptor.resolveCandidate(DependencyDescriptor.java:276) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.doResolveDependency(DefaultListableBeanFactory.java:1389) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.resolveDependency(DefaultListableBeanFactory.java:1309) + at org.springframework.beans.factory.support.ConstructorResolver.resolveAutowiredArgument(ConstructorResolver.java:887) + at org.springframework.beans.factory.support.ConstructorResolver.createArgumentArray(ConstructorResolver.java:791) + at org.springframework.beans.factory.support.ConstructorResolver.instantiateUsingFactoryMethod(ConstructorResolver.java:541) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.instantiateUsingFactoryMethod(AbstractAutowireCapableBeanFactory.java:1352) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBeanInstance(AbstractAutowireCapableBeanFactory.java:1195) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:582) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:542) + at org.springframework.beans.factory.support.AbstractBeanFactory.lambda$doGetBean$0(AbstractBeanFactory.java:335) + at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:234) + at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:333) + at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:208) + at org.springframework.beans.factory.config.DependencyDescriptor.resolveCandidate(DependencyDescriptor.java:276) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.doResolveDependency(DefaultListableBeanFactory.java:1389) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.resolveDependency(DefaultListableBeanFactory.java:1309) + at org.springframework.context.annotation.CommonAnnotationBeanPostProcessor.autowireResource(CommonAnnotationBeanPostProcessor.java:544) + at org.springframework.context.annotation.CommonAnnotationBeanPostProcessor.getResource(CommonAnnotationBeanPostProcessor.java:520) + at org.springframework.context.annotation.CommonAnnotationBeanPostProcessor$ResourceElement.getResourceToInject(CommonAnnotationBeanPostProcessor.java:673) + at org.springframework.beans.factory.annotation.InjectionMetadata$InjectedElement.inject(InjectionMetadata.java:228) + at org.springframework.beans.factory.annotation.InjectionMetadata.inject(InjectionMetadata.java:119) + at org.springframework.context.annotation.CommonAnnotationBeanPostProcessor.postProcessProperties(CommonAnnotationBeanPostProcessor.java:329) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.populateBean(AbstractAutowireCapableBeanFactory.java:1431) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:619) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:542) + at org.springframework.beans.factory.support.AbstractBeanFactory.lambda$doGetBean$0(AbstractBeanFactory.java:335) + at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:234) + at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:333) + at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:208) + at org.springframework.beans.factory.config.DependencyDescriptor.resolveCandidate(DependencyDescriptor.java:276) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.doResolveDependency(DefaultListableBeanFactory.java:1389) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.resolveDependency(DefaultListableBeanFactory.java:1309) + at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor$AutowiredFieldElement.resolveFieldValue(AutowiredAnnotationBeanPostProcessor.java:656) + at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor$AutowiredFieldElement.inject(AutowiredAnnotationBeanPostProcessor.java:639) + at org.springframework.beans.factory.annotation.InjectionMetadata.inject(InjectionMetadata.java:119) + at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor.postProcessProperties(AutowiredAnnotationBeanPostProcessor.java:399) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.populateBean(AbstractAutowireCapableBeanFactory.java:1431) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:619) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:542) + at org.springframework.beans.factory.support.AbstractBeanFactory.lambda$doGetBean$0(AbstractBeanFactory.java:335) + at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:234) + at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:333) + at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:208) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.preInstantiateSingletons(DefaultListableBeanFactory.java:953) + at org.springframework.context.support.AbstractApplicationContext.finishBeanFactoryInitialization(AbstractApplicationContext.java:918) + at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:583) + at org.springframework.boot.web.servlet.context.ServletWebServerApplicationContext.refresh(ServletWebServerApplicationContext.java:145) + at org.springframework.boot.SpringApplication.refresh(SpringApplication.java:780) + at org.springframework.boot.SpringApplication.refreshContext(SpringApplication.java:453) + at org.springframework.boot.SpringApplication.run(SpringApplication.java:343) + at org.springframework.boot.SpringApplication.run(SpringApplication.java:1370) + at org.springframework.boot.SpringApplication.run(SpringApplication.java:1359) + at com.dc.web.DcApplication.main(DcApplication.java:25) + at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) + at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) + at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) + at java.lang.reflect.Method.invoke(Method.java:498) + at org.springframework.boot.devtools.restart.RestartLauncher.run(RestartLauncher.java:49) +Caused by: org.postgresql.util.PSQLException: 错误: 关系 "act_ge_property" 不存在 + 位置:20 + at org.postgresql.core.v3.QueryExecutorImpl.receiveErrorResponse(QueryExecutorImpl.java:2565) + at org.postgresql.core.v3.QueryExecutorImpl.processResults(QueryExecutorImpl.java:2297) + at org.postgresql.core.v3.QueryExecutorImpl.execute(QueryExecutorImpl.java:322) + at org.postgresql.jdbc.PgStatement.executeInternal(PgStatement.java:481) + at org.postgresql.jdbc.PgStatement.execute(PgStatement.java:401) + at org.postgresql.jdbc.PgPreparedStatement.executeWithFlags(PgPreparedStatement.java:164) + at org.postgresql.jdbc.PgPreparedStatement.execute(PgPreparedStatement.java:153) + at com.alibaba.druid.filter.FilterChainImpl.preparedStatement_execute(FilterChainImpl.java:3446) + at com.alibaba.druid.filter.FilterEventAdapter.preparedStatement_execute(FilterEventAdapter.java:434) + at com.alibaba.druid.filter.FilterChainImpl.preparedStatement_execute(FilterChainImpl.java:3444) + at com.alibaba.druid.proxy.jdbc.PreparedStatementProxyImpl.execute(PreparedStatementProxyImpl.java:152) + at com.alibaba.druid.pool.DruidPooledPreparedStatement.execute(DruidPooledPreparedStatement.java:483) + at org.apache.ibatis.executor.statement.PreparedStatementHandler.query(PreparedStatementHandler.java:64) + at org.apache.ibatis.executor.statement.RoutingStatementHandler.query(RoutingStatementHandler.java:79) + at org.apache.ibatis.executor.SimpleExecutor.doQuery(SimpleExecutor.java:63) + at org.apache.ibatis.executor.BaseExecutor.queryFromDatabase(BaseExecutor.java:325) + at org.apache.ibatis.executor.BaseExecutor.query(BaseExecutor.java:156) + at org.apache.ibatis.executor.CachingExecutor.query(CachingExecutor.java:109) + at org.apache.ibatis.executor.CachingExecutor.query(CachingExecutor.java:89) + at org.apache.ibatis.session.defaults.DefaultSqlSession.selectList(DefaultSqlSession.java:151) + ... 110 common frames omitted +10:55:10.575 [restartedMain] ERROR o.s.b.SpringApplication - [reportFailure,870] - Application run failed +org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'flowDefinitionController': Unsatisfied dependency expressed through field 'flowDefinitionService'; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'flowDefinitionService': Injection of resource dependencies failed; nested exception is org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'repositoryServiceBean' defined in class path resource [org/flowable/spring/boot/ProcessEngineServicesAutoConfiguration.class]: Unsatisfied dependency expressed through method 'repositoryServiceBean' parameter 0; nested exception is org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'processEngine' defined in class path resource [org/flowable/spring/boot/ProcessEngineServicesAutoConfiguration$AlreadyInitializedAppEngineConfiguration.class]: Unsatisfied dependency expressed through method 'processEngine' parameter 0; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'flowableAppEngine': FactoryBean threw exception on object creation; nested exception is org.apache.ibatis.exceptions.PersistenceException: +### Error querying database. Cause: org.postgresql.util.PSQLException: 错误: 关系 "act_ge_property" 不存在 + 位置:20 +### The error may exist in org/flowable/common/db/mapping/entity/Property.xml +### The error may involve defaultParameterMap +### The error occurred while setting parameters +### SQL: select VALUE_ from ACT_GE_PROPERTY where NAME_ = 'schema.version' +### Cause: org.postgresql.util.PSQLException: 错误: 关系 "act_ge_property" 不存在 + 位置:20 + at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor$AutowiredFieldElement.resolveFieldValue(AutowiredAnnotationBeanPostProcessor.java:659) + at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor$AutowiredFieldElement.inject(AutowiredAnnotationBeanPostProcessor.java:639) + at org.springframework.beans.factory.annotation.InjectionMetadata.inject(InjectionMetadata.java:119) + at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor.postProcessProperties(AutowiredAnnotationBeanPostProcessor.java:399) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.populateBean(AbstractAutowireCapableBeanFactory.java:1431) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:619) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:542) + at org.springframework.beans.factory.support.AbstractBeanFactory.lambda$doGetBean$0(AbstractBeanFactory.java:335) + at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:234) + at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:333) + at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:208) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.preInstantiateSingletons(DefaultListableBeanFactory.java:953) + at org.springframework.context.support.AbstractApplicationContext.finishBeanFactoryInitialization(AbstractApplicationContext.java:918) + at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:583) + at org.springframework.boot.web.servlet.context.ServletWebServerApplicationContext.refresh(ServletWebServerApplicationContext.java:145) + at org.springframework.boot.SpringApplication.refresh(SpringApplication.java:780) + at org.springframework.boot.SpringApplication.refreshContext(SpringApplication.java:453) + at org.springframework.boot.SpringApplication.run(SpringApplication.java:343) + at org.springframework.boot.SpringApplication.run(SpringApplication.java:1370) + at org.springframework.boot.SpringApplication.run(SpringApplication.java:1359) + at com.dc.web.DcApplication.main(DcApplication.java:25) + at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) + at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) + at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) + at java.lang.reflect.Method.invoke(Method.java:498) + at org.springframework.boot.devtools.restart.RestartLauncher.run(RestartLauncher.java:49) +Caused by: org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'flowDefinitionService': Injection of resource dependencies failed; nested exception is org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'repositoryServiceBean' defined in class path resource [org/flowable/spring/boot/ProcessEngineServicesAutoConfiguration.class]: Unsatisfied dependency expressed through method 'repositoryServiceBean' parameter 0; nested exception is org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'processEngine' defined in class path resource [org/flowable/spring/boot/ProcessEngineServicesAutoConfiguration$AlreadyInitializedAppEngineConfiguration.class]: Unsatisfied dependency expressed through method 'processEngine' parameter 0; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'flowableAppEngine': FactoryBean threw exception on object creation; nested exception is org.apache.ibatis.exceptions.PersistenceException: +### Error querying database. Cause: org.postgresql.util.PSQLException: 错误: 关系 "act_ge_property" 不存在 + 位置:20 +### The error may exist in org/flowable/common/db/mapping/entity/Property.xml +### The error may involve defaultParameterMap +### The error occurred while setting parameters +### SQL: select VALUE_ from ACT_GE_PROPERTY where NAME_ = 'schema.version' +### Cause: org.postgresql.util.PSQLException: 错误: 关系 "act_ge_property" 不存在 + 位置:20 + at org.springframework.context.annotation.CommonAnnotationBeanPostProcessor.postProcessProperties(CommonAnnotationBeanPostProcessor.java:332) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.populateBean(AbstractAutowireCapableBeanFactory.java:1431) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:619) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:542) + at org.springframework.beans.factory.support.AbstractBeanFactory.lambda$doGetBean$0(AbstractBeanFactory.java:335) + at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:234) + at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:333) + at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:208) + at org.springframework.beans.factory.config.DependencyDescriptor.resolveCandidate(DependencyDescriptor.java:276) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.doResolveDependency(DefaultListableBeanFactory.java:1389) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.resolveDependency(DefaultListableBeanFactory.java:1309) + at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor$AutowiredFieldElement.resolveFieldValue(AutowiredAnnotationBeanPostProcessor.java:656) + ... 25 common frames omitted +Caused by: org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'repositoryServiceBean' defined in class path resource [org/flowable/spring/boot/ProcessEngineServicesAutoConfiguration.class]: Unsatisfied dependency expressed through method 'repositoryServiceBean' parameter 0; nested exception is org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'processEngine' defined in class path resource [org/flowable/spring/boot/ProcessEngineServicesAutoConfiguration$AlreadyInitializedAppEngineConfiguration.class]: Unsatisfied dependency expressed through method 'processEngine' parameter 0; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'flowableAppEngine': FactoryBean threw exception on object creation; nested exception is org.apache.ibatis.exceptions.PersistenceException: +### Error querying database. Cause: org.postgresql.util.PSQLException: 错误: 关系 "act_ge_property" 不存在 + 位置:20 +### The error may exist in org/flowable/common/db/mapping/entity/Property.xml +### The error may involve defaultParameterMap +### The error occurred while setting parameters +### SQL: select VALUE_ from ACT_GE_PROPERTY where NAME_ = 'schema.version' +### Cause: org.postgresql.util.PSQLException: 错误: 关系 "act_ge_property" 不存在 + 位置:20 + at org.springframework.beans.factory.support.ConstructorResolver.createArgumentArray(ConstructorResolver.java:800) + at org.springframework.beans.factory.support.ConstructorResolver.instantiateUsingFactoryMethod(ConstructorResolver.java:541) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.instantiateUsingFactoryMethod(AbstractAutowireCapableBeanFactory.java:1352) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBeanInstance(AbstractAutowireCapableBeanFactory.java:1195) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:582) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:542) + at org.springframework.beans.factory.support.AbstractBeanFactory.lambda$doGetBean$0(AbstractBeanFactory.java:335) + at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:234) + at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:333) + at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:208) + at org.springframework.beans.factory.config.DependencyDescriptor.resolveCandidate(DependencyDescriptor.java:276) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.doResolveDependency(DefaultListableBeanFactory.java:1389) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.resolveDependency(DefaultListableBeanFactory.java:1309) + at org.springframework.context.annotation.CommonAnnotationBeanPostProcessor.autowireResource(CommonAnnotationBeanPostProcessor.java:544) + at org.springframework.context.annotation.CommonAnnotationBeanPostProcessor.getResource(CommonAnnotationBeanPostProcessor.java:520) + at org.springframework.context.annotation.CommonAnnotationBeanPostProcessor$ResourceElement.getResourceToInject(CommonAnnotationBeanPostProcessor.java:673) + at org.springframework.beans.factory.annotation.InjectionMetadata$InjectedElement.inject(InjectionMetadata.java:228) + at org.springframework.beans.factory.annotation.InjectionMetadata.inject(InjectionMetadata.java:119) + at org.springframework.context.annotation.CommonAnnotationBeanPostProcessor.postProcessProperties(CommonAnnotationBeanPostProcessor.java:329) + ... 36 common frames omitted +Caused by: org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'processEngine' defined in class path resource [org/flowable/spring/boot/ProcessEngineServicesAutoConfiguration$AlreadyInitializedAppEngineConfiguration.class]: Unsatisfied dependency expressed through method 'processEngine' parameter 0; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'flowableAppEngine': FactoryBean threw exception on object creation; nested exception is org.apache.ibatis.exceptions.PersistenceException: +### Error querying database. Cause: org.postgresql.util.PSQLException: 错误: 关系 "act_ge_property" 不存在 + 位置:20 +### The error may exist in org/flowable/common/db/mapping/entity/Property.xml +### The error may involve defaultParameterMap +### The error occurred while setting parameters +### SQL: select VALUE_ from ACT_GE_PROPERTY where NAME_ = 'schema.version' +### Cause: org.postgresql.util.PSQLException: 错误: 关系 "act_ge_property" 不存在 + 位置:20 + at org.springframework.beans.factory.support.ConstructorResolver.createArgumentArray(ConstructorResolver.java:800) + at org.springframework.beans.factory.support.ConstructorResolver.instantiateUsingFactoryMethod(ConstructorResolver.java:541) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.instantiateUsingFactoryMethod(AbstractAutowireCapableBeanFactory.java:1352) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBeanInstance(AbstractAutowireCapableBeanFactory.java:1195) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:582) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:542) + at org.springframework.beans.factory.support.AbstractBeanFactory.lambda$doGetBean$0(AbstractBeanFactory.java:335) + at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:234) + at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:333) + at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:208) + at org.springframework.beans.factory.config.DependencyDescriptor.resolveCandidate(DependencyDescriptor.java:276) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.doResolveDependency(DefaultListableBeanFactory.java:1389) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.resolveDependency(DefaultListableBeanFactory.java:1309) + at org.springframework.beans.factory.support.ConstructorResolver.resolveAutowiredArgument(ConstructorResolver.java:887) + at org.springframework.beans.factory.support.ConstructorResolver.createArgumentArray(ConstructorResolver.java:791) + ... 54 common frames omitted +Caused by: org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'flowableAppEngine': FactoryBean threw exception on object creation; nested exception is org.apache.ibatis.exceptions.PersistenceException: +### Error querying database. Cause: org.postgresql.util.PSQLException: 错误: 关系 "act_ge_property" 不存在 + 位置:20 +### The error may exist in org/flowable/common/db/mapping/entity/Property.xml +### The error may involve defaultParameterMap +### The error occurred while setting parameters +### SQL: select VALUE_ from ACT_GE_PROPERTY where NAME_ = 'schema.version' +### Cause: org.postgresql.util.PSQLException: 错误: 关系 "act_ge_property" 不存在 + 位置:20 + at org.springframework.beans.factory.support.FactoryBeanRegistrySupport.doGetObjectFromFactoryBean(FactoryBeanRegistrySupport.java:176) + at org.springframework.beans.factory.support.FactoryBeanRegistrySupport.getObjectFromFactoryBean(FactoryBeanRegistrySupport.java:101) + at org.springframework.beans.factory.support.AbstractBeanFactory.getObjectForBeanInstance(AbstractBeanFactory.java:1884) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.getObjectForBeanInstance(AbstractAutowireCapableBeanFactory.java:1284) + at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:345) + at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:208) + at org.springframework.beans.factory.config.DependencyDescriptor.resolveCandidate(DependencyDescriptor.java:276) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.doResolveDependency(DefaultListableBeanFactory.java:1389) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.resolveDependency(DefaultListableBeanFactory.java:1309) + at org.springframework.beans.factory.support.ConstructorResolver.resolveAutowiredArgument(ConstructorResolver.java:887) + at org.springframework.beans.factory.support.ConstructorResolver.createArgumentArray(ConstructorResolver.java:791) + ... 68 common frames omitted +Caused by: org.apache.ibatis.exceptions.PersistenceException: +### Error querying database. Cause: org.postgresql.util.PSQLException: 错误: 关系 "act_ge_property" 不存在 + 位置:20 +### The error may exist in org/flowable/common/db/mapping/entity/Property.xml +### The error may involve defaultParameterMap +### The error occurred while setting parameters +### SQL: select VALUE_ from ACT_GE_PROPERTY where NAME_ = 'schema.version' +### Cause: org.postgresql.util.PSQLException: 错误: 关系 "act_ge_property" 不存在 + 位置:20 + at org.apache.ibatis.exceptions.ExceptionFactory.wrapException(ExceptionFactory.java:30) + at org.apache.ibatis.session.defaults.DefaultSqlSession.selectList(DefaultSqlSession.java:153) + at org.apache.ibatis.session.defaults.DefaultSqlSession.selectList(DefaultSqlSession.java:145) + at org.apache.ibatis.session.defaults.DefaultSqlSession.selectList(DefaultSqlSession.java:140) + at org.apache.ibatis.session.defaults.DefaultSqlSession.selectOne(DefaultSqlSession.java:76) + at org.apache.ibatis.session.defaults.DefaultSqlSession.selectOne(DefaultSqlSession.java:70) + at org.flowable.engine.impl.db.ProcessDbSchemaManager.getDbVersion(ProcessDbSchemaManager.java:84) + at org.flowable.engine.impl.db.ProcessDbSchemaManager.schemaCheckVersion(ProcessDbSchemaManager.java:40) + at org.flowable.engine.impl.SchemaOperationsProcessEngineBuild.execute(SchemaOperationsProcessEngineBuild.java:51) + at org.flowable.engine.impl.SchemaOperationsProcessEngineBuild.execute(SchemaOperationsProcessEngineBuild.java:28) + at org.flowable.engine.impl.interceptor.CommandInvoker$1.run(CommandInvoker.java:67) + at org.flowable.engine.impl.interceptor.CommandInvoker.executeOperation(CommandInvoker.java:140) + at org.flowable.engine.impl.interceptor.CommandInvoker.executeOperations(CommandInvoker.java:114) + at org.flowable.engine.impl.interceptor.CommandInvoker.execute(CommandInvoker.java:72) + at org.flowable.engine.impl.interceptor.BpmnOverrideContextInterceptor.execute(BpmnOverrideContextInterceptor.java:26) + at org.flowable.common.engine.impl.interceptor.TransactionContextInterceptor.execute(TransactionContextInterceptor.java:53) + at org.flowable.common.engine.impl.interceptor.CommandContextInterceptor.execute(CommandContextInterceptor.java:105) + at org.flowable.common.spring.SpringTransactionInterceptor.lambda$execute$0(SpringTransactionInterceptor.java:57) + at org.springframework.transaction.support.TransactionTemplate.execute(TransactionTemplate.java:140) + at org.flowable.common.spring.SpringTransactionInterceptor.execute(SpringTransactionInterceptor.java:57) + at org.flowable.common.engine.impl.interceptor.LogInterceptor.execute(LogInterceptor.java:30) + at org.flowable.common.engine.impl.cfg.CommandExecutorImpl.execute(CommandExecutorImpl.java:56) + at org.flowable.engine.impl.ProcessEngineImpl.<init>(ProcessEngineImpl.java:83) + at org.flowable.engine.impl.cfg.ProcessEngineConfigurationImpl.buildProcessEngine(ProcessEngineConfigurationImpl.java:917) + at org.flowable.spring.SpringProcessEngineConfiguration.buildProcessEngine(SpringProcessEngineConfiguration.java:76) + at org.flowable.engine.spring.configurator.SpringProcessEngineConfigurator.initProcessEngine(SpringProcessEngineConfigurator.java:58) + at org.flowable.engine.spring.configurator.SpringProcessEngineConfigurator.configure(SpringProcessEngineConfigurator.java:47) + at org.flowable.common.engine.impl.AbstractEngineConfiguration.configuratorsAfterInit(AbstractEngineConfiguration.java:1109) + at org.flowable.app.engine.AppEngineConfiguration.init(AppEngineConfiguration.java:237) + at org.flowable.app.engine.AppEngineConfiguration.buildAppEngine(AppEngineConfiguration.java:193) + at org.flowable.app.spring.SpringAppEngineConfiguration.buildAppEngine(SpringAppEngineConfiguration.java:66) + at org.flowable.app.spring.AppEngineFactoryBean.getObject(AppEngineFactoryBean.java:58) + at org.flowable.app.spring.AppEngineFactoryBean.getObject(AppEngineFactoryBean.java:31) + at org.springframework.beans.factory.support.FactoryBeanRegistrySupport.doGetObjectFromFactoryBean(FactoryBeanRegistrySupport.java:169) + ... 78 common frames omitted +Caused by: org.postgresql.util.PSQLException: 错误: 关系 "act_ge_property" 不存在 + 位置:20 + at org.postgresql.core.v3.QueryExecutorImpl.receiveErrorResponse(QueryExecutorImpl.java:2565) + at org.postgresql.core.v3.QueryExecutorImpl.processResults(QueryExecutorImpl.java:2297) + at org.postgresql.core.v3.QueryExecutorImpl.execute(QueryExecutorImpl.java:322) + at org.postgresql.jdbc.PgStatement.executeInternal(PgStatement.java:481) + at org.postgresql.jdbc.PgStatement.execute(PgStatement.java:401) + at org.postgresql.jdbc.PgPreparedStatement.executeWithFlags(PgPreparedStatement.java:164) + at org.postgresql.jdbc.PgPreparedStatement.execute(PgPreparedStatement.java:153) + at com.alibaba.druid.filter.FilterChainImpl.preparedStatement_execute(FilterChainImpl.java:3446) + at com.alibaba.druid.filter.FilterEventAdapter.preparedStatement_execute(FilterEventAdapter.java:434) + at com.alibaba.druid.filter.FilterChainImpl.preparedStatement_execute(FilterChainImpl.java:3444) + at com.alibaba.druid.proxy.jdbc.PreparedStatementProxyImpl.execute(PreparedStatementProxyImpl.java:152) + at com.alibaba.druid.pool.DruidPooledPreparedStatement.execute(DruidPooledPreparedStatement.java:483) + at org.apache.ibatis.executor.statement.PreparedStatementHandler.query(PreparedStatementHandler.java:64) + at org.apache.ibatis.executor.statement.RoutingStatementHandler.query(RoutingStatementHandler.java:79) + at org.apache.ibatis.executor.SimpleExecutor.doQuery(SimpleExecutor.java:63) + at org.apache.ibatis.executor.BaseExecutor.queryFromDatabase(BaseExecutor.java:325) + at org.apache.ibatis.executor.BaseExecutor.query(BaseExecutor.java:156) + at org.apache.ibatis.executor.CachingExecutor.query(CachingExecutor.java:109) + at org.apache.ibatis.executor.CachingExecutor.query(CachingExecutor.java:89) + at org.apache.ibatis.session.defaults.DefaultSqlSession.selectList(DefaultSqlSession.java:151) + ... 110 common frames omitted +11:34:33.138 [restartedMain] ERROR o.s.b.w.e.t.TomcatStarter - [onStartup,61] - Error starting Tomcat context. Exception: org.springframework.beans.factory.UnsatisfiedDependencyException. Message: Error creating bean with name 'jwtAuthenticationTokenFilter': Unsatisfied dependency expressed through field 'tokenService'; nested exception is org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'tokenService': Unsatisfied dependency expressed through field 'redisCache'; nested exception is org.springframework.beans.factory.NoSuchBeanDefinitionException: No qualifying bean of type 'com.dc.common.core.redis.RedisCache' available: expected at least 1 bean which qualifies as autowire candidate. Dependency annotations: {@org.springframework.beans.factory.annotation.Autowired(required=true)} +11:34:33.371 [restartedMain] ERROR o.s.b.d.LoggingFailureAnalysisReporter - [report,40] - + +*************************** +APPLICATION FAILED TO START +*************************** + +Description: + +Field redisCache in com.dc.framework.web.service.TokenService required a bean of type 'com.dc.common.core.redis.RedisCache' that could not be found. + +The injection point has the following annotations: + - @org.springframework.beans.factory.annotation.Autowired(required=true) + + +Action: + +Consider defining a bean of type 'com.dc.common.core.redis.RedisCache' in your configuration. + +11:41:28.613 [restartedMain] ERROR o.s.b.SpringApplication - [reportFailure,870] - Application run failed +org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'accessoryService': Unsatisfied dependency expressed through field 'baseMapper'; nested exception is org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'accessoryMapper' defined in file [D:\workspace\wenyin\win\win-system\target\classes\com\win\system\mapper\AccessoryMapper.class]: Unsatisfied dependency expressed through bean property 'sqlSessionFactory'; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'sqlSessionFactory' defined in class path resource [com/win/framework/config/DataSourceConfiguration.class]: Bean instantiation via factory method failed; nested exception is org.springframework.beans.BeanInstantiationException: Failed to instantiate [org.apache.ibatis.session.SqlSessionFactory]: Factory method 'sqlSessionFactory' threw exception; nested exception is java.io.IOException: Failed to parse mapping resource: 'file [D:\workspace\wenyin\win\win-system\target\classes\mapper\system\SysDeployFormMapper.xml]' + at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor$AutowiredFieldElement.resolveFieldValue(AutowiredAnnotationBeanPostProcessor.java:659) + at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor$AutowiredFieldElement.inject(AutowiredAnnotationBeanPostProcessor.java:639) + at org.springframework.beans.factory.annotation.InjectionMetadata.inject(InjectionMetadata.java:119) + at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor.postProcessProperties(AutowiredAnnotationBeanPostProcessor.java:399) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.populateBean(AbstractAutowireCapableBeanFactory.java:1431) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:619) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:542) + at org.springframework.beans.factory.support.AbstractBeanFactory.lambda$doGetBean$0(AbstractBeanFactory.java:335) + at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:234) + at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:333) + at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:208) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.preInstantiateSingletons(DefaultListableBeanFactory.java:953) + at org.springframework.context.support.AbstractApplicationContext.finishBeanFactoryInitialization(AbstractApplicationContext.java:918) + at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:583) + at org.springframework.boot.web.servlet.context.ServletWebServerApplicationContext.refresh(ServletWebServerApplicationContext.java:145) + at org.springframework.boot.SpringApplication.refresh(SpringApplication.java:780) + at org.springframework.boot.SpringApplication.refreshContext(SpringApplication.java:453) + at org.springframework.boot.SpringApplication.run(SpringApplication.java:343) + at org.springframework.boot.SpringApplication.run(SpringApplication.java:1370) + at org.springframework.boot.SpringApplication.run(SpringApplication.java:1359) + at com.dc.web.DcApplication.main(DcApplication.java:20) + at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) + at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) + at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) + at java.lang.reflect.Method.invoke(Method.java:498) + at org.springframework.boot.devtools.restart.RestartLauncher.run(RestartLauncher.java:49) +Caused by: org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'accessoryMapper' defined in file [D:\workspace\wenyin\win\win-system\target\classes\com\win\system\mapper\AccessoryMapper.class]: Unsatisfied dependency expressed through bean property 'sqlSessionFactory'; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'sqlSessionFactory' defined in class path resource [com/win/framework/config/DataSourceConfiguration.class]: Bean instantiation via factory method failed; nested exception is org.springframework.beans.BeanInstantiationException: Failed to instantiate [org.apache.ibatis.session.SqlSessionFactory]: Factory method 'sqlSessionFactory' threw exception; nested exception is java.io.IOException: Failed to parse mapping resource: 'file [D:\workspace\wenyin\win\win-system\target\classes\mapper\system\SysDeployFormMapper.xml]' + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.autowireByType(AbstractAutowireCapableBeanFactory.java:1534) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.populateBean(AbstractAutowireCapableBeanFactory.java:1417) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:619) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:542) + at org.springframework.beans.factory.support.AbstractBeanFactory.lambda$doGetBean$0(AbstractBeanFactory.java:335) + at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:234) + at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:333) + at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:208) + at org.springframework.beans.factory.config.DependencyDescriptor.resolveCandidate(DependencyDescriptor.java:276) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.doResolveDependency(DefaultListableBeanFactory.java:1389) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.resolveDependency(DefaultListableBeanFactory.java:1309) + at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor$AutowiredFieldElement.resolveFieldValue(AutowiredAnnotationBeanPostProcessor.java:656) + ... 25 common frames omitted +Caused by: org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'sqlSessionFactory' defined in class path resource [com/win/framework/config/DataSourceConfiguration.class]: Bean instantiation via factory method failed; nested exception is org.springframework.beans.BeanInstantiationException: Failed to instantiate [org.apache.ibatis.session.SqlSessionFactory]: Factory method 'sqlSessionFactory' threw exception; nested exception is java.io.IOException: Failed to parse mapping resource: 'file [D:\workspace\wenyin\win\win-system\target\classes\mapper\system\SysDeployFormMapper.xml]' + at org.springframework.beans.factory.support.ConstructorResolver.instantiate(ConstructorResolver.java:658) + at org.springframework.beans.factory.support.ConstructorResolver.instantiateUsingFactoryMethod(ConstructorResolver.java:638) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.instantiateUsingFactoryMethod(AbstractAutowireCapableBeanFactory.java:1352) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBeanInstance(AbstractAutowireCapableBeanFactory.java:1195) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:582) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:542) + at org.springframework.beans.factory.support.AbstractBeanFactory.lambda$doGetBean$0(AbstractBeanFactory.java:335) + at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:234) + at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:333) + at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:208) + at org.springframework.beans.factory.config.DependencyDescriptor.resolveCandidate(DependencyDescriptor.java:276) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.doResolveDependency(DefaultListableBeanFactory.java:1389) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.resolveDependency(DefaultListableBeanFactory.java:1309) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.autowireByType(AbstractAutowireCapableBeanFactory.java:1519) + ... 36 common frames omitted +Caused by: org.springframework.beans.BeanInstantiationException: Failed to instantiate [org.apache.ibatis.session.SqlSessionFactory]: Factory method 'sqlSessionFactory' threw exception; nested exception is java.io.IOException: Failed to parse mapping resource: 'file [D:\workspace\wenyin\win\win-system\target\classes\mapper\system\SysDeployFormMapper.xml]' + at org.springframework.beans.factory.support.SimpleInstantiationStrategy.instantiate(SimpleInstantiationStrategy.java:185) + at org.springframework.beans.factory.support.ConstructorResolver.instantiate(ConstructorResolver.java:653) + ... 49 common frames omitted +Caused by: java.io.IOException: Failed to parse mapping resource: 'file [D:\workspace\wenyin\win\win-system\target\classes\mapper\system\SysDeployFormMapper.xml]' + at com.baomidou.mybatisplus.extension.spring.MybatisSqlSessionFactoryBean.buildSqlSessionFactory(MybatisSqlSessionFactoryBean.java:575) + at com.baomidou.mybatisplus.extension.spring.MybatisSqlSessionFactoryBean.afterPropertiesSet(MybatisSqlSessionFactoryBean.java:444) + at com.baomidou.mybatisplus.extension.spring.MybatisSqlSessionFactoryBean.getObject(MybatisSqlSessionFactoryBean.java:608) + at com.dc.framework.config.DataSourceConfiguration.sqlSessionFactory(DataSourceConfiguration.java:109) + at com.dc.framework.config.DataSourceConfiguration$$EnhancerBySpringCGLIB$$5459c6f7.CGLIB$sqlSessionFactory$1(<generated>) + at com.dc.framework.config.DataSourceConfiguration$$EnhancerBySpringCGLIB$$5459c6f7$$FastClassBySpringCGLIB$$a521d5ec.invoke(<generated>) + at org.springframework.cglib.proxy.MethodProxy.invokeSuper(MethodProxy.java:244) + at org.springframework.context.annotation.ConfigurationClassEnhancer$BeanMethodInterceptor.intercept(ConfigurationClassEnhancer.java:331) + at com.dc.framework.config.DataSourceConfiguration$$EnhancerBySpringCGLIB$$5459c6f7.sqlSessionFactory(<generated>) + at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) + at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) + at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) + at java.lang.reflect.Method.invoke(Method.java:498) + at org.springframework.beans.factory.support.SimpleInstantiationStrategy.instantiate(SimpleInstantiationStrategy.java:154) + ... 50 common frames omitted +Caused by: org.apache.ibatis.builder.BuilderException: Error parsing Mapper XML. The XML location is 'file [D:\workspace\wenyin\win\win-system\target\classes\mapper\system\SysDeployFormMapper.xml]'. Cause: org.apache.ibatis.builder.BuilderException: Error resolving class. Cause: org.apache.ibatis.type.TypeException: Could not resolve type alias 'SysDeployForm'. Cause: java.lang.ClassNotFoundException: Cannot find class: SysDeployForm + at org.apache.ibatis.builder.xml.XMLMapperBuilder.configurationElement(XMLMapperBuilder.java:123) + at org.apache.ibatis.builder.xml.XMLMapperBuilder.parse(XMLMapperBuilder.java:95) + at com.baomidou.mybatisplus.extension.spring.MybatisSqlSessionFactoryBean.buildSqlSessionFactory(MybatisSqlSessionFactoryBean.java:573) + ... 63 common frames omitted +Caused by: org.apache.ibatis.builder.BuilderException: Error resolving class. Cause: org.apache.ibatis.type.TypeException: Could not resolve type alias 'SysDeployForm'. Cause: java.lang.ClassNotFoundException: Cannot find class: SysDeployForm + at org.apache.ibatis.builder.BaseBuilder.resolveClass(BaseBuilder.java:118) + at org.apache.ibatis.builder.xml.XMLMapperBuilder.resultMapElement(XMLMapperBuilder.java:263) + at org.apache.ibatis.builder.xml.XMLMapperBuilder.resultMapElement(XMLMapperBuilder.java:254) + at org.apache.ibatis.builder.xml.XMLMapperBuilder.resultMapElements(XMLMapperBuilder.java:246) + at org.apache.ibatis.builder.xml.XMLMapperBuilder.configurationElement(XMLMapperBuilder.java:119) + ... 65 common frames omitted +Caused by: org.apache.ibatis.type.TypeException: Could not resolve type alias 'SysDeployForm'. Cause: java.lang.ClassNotFoundException: Cannot find class: SysDeployForm + at org.apache.ibatis.type.TypeAliasRegistry.resolveAlias(TypeAliasRegistry.java:120) + at org.apache.ibatis.builder.BaseBuilder.resolveAlias(BaseBuilder.java:149) + at org.apache.ibatis.builder.BaseBuilder.resolveClass(BaseBuilder.java:116) + ... 69 common frames omitted +Caused by: java.lang.ClassNotFoundException: Cannot find class: SysDeployForm + at org.apache.ibatis.io.ClassLoaderWrapper.classForName(ClassLoaderWrapper.java:196) + at org.apache.ibatis.io.ClassLoaderWrapper.classForName(ClassLoaderWrapper.java:89) + at org.apache.ibatis.io.Resources.classForName(Resources.java:261) + at org.apache.ibatis.type.TypeAliasRegistry.resolveAlias(TypeAliasRegistry.java:116) + ... 71 common frames omitted +11:42:25.241 [Druid-ConnectionPool-Create-159797312] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ruoyi?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state null +java.sql.SQLException: connect error, url jdbc:postgresql://localhost:5432/ruoyi?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, driverClass com.mysql.cj.jdbc.Driver + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1790) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +11:42:25.242 [Druid-ConnectionPool-Create-159797312] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ruoyi?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state null +java.sql.SQLException: connect error, url jdbc:postgresql://localhost:5432/ruoyi?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, driverClass com.mysql.cj.jdbc.Driver + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1790) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +11:42:25.746 [Druid-ConnectionPool-Create-159797312] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ruoyi?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state null +java.sql.SQLException: connect error, url jdbc:postgresql://localhost:5432/ruoyi?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, driverClass com.mysql.cj.jdbc.Driver + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1790) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +11:42:26.259 [Druid-ConnectionPool-Create-159797312] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ruoyi?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state null +java.sql.SQLException: connect error, url jdbc:postgresql://localhost:5432/ruoyi?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, driverClass com.mysql.cj.jdbc.Driver + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1790) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +11:42:26.771 [Druid-ConnectionPool-Create-159797312] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ruoyi?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state null +java.sql.SQLException: connect error, url jdbc:postgresql://localhost:5432/ruoyi?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, driverClass com.mysql.cj.jdbc.Driver + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1790) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +11:42:27.283 [Druid-ConnectionPool-Create-159797312] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ruoyi?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state null +java.sql.SQLException: connect error, url jdbc:postgresql://localhost:5432/ruoyi?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, driverClass com.mysql.cj.jdbc.Driver + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1790) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +11:42:27.797 [Druid-ConnectionPool-Create-159797312] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ruoyi?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state null +java.sql.SQLException: connect error, url jdbc:postgresql://localhost:5432/ruoyi?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, driverClass com.mysql.cj.jdbc.Driver + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1790) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +11:42:28.312 [Druid-ConnectionPool-Create-159797312] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ruoyi?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state null +java.sql.SQLException: connect error, url jdbc:postgresql://localhost:5432/ruoyi?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, driverClass com.mysql.cj.jdbc.Driver + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1790) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +11:42:28.823 [Druid-ConnectionPool-Create-159797312] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ruoyi?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state null +java.sql.SQLException: connect error, url jdbc:postgresql://localhost:5432/ruoyi?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, driverClass com.mysql.cj.jdbc.Driver + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1790) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +11:42:29.337 [Druid-ConnectionPool-Create-159797312] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ruoyi?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state null +java.sql.SQLException: connect error, url jdbc:postgresql://localhost:5432/ruoyi?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, driverClass com.mysql.cj.jdbc.Driver + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1790) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +11:42:29.850 [Druid-ConnectionPool-Create-159797312] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ruoyi?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state null +java.sql.SQLException: connect error, url jdbc:postgresql://localhost:5432/ruoyi?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, driverClass com.mysql.cj.jdbc.Driver + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1790) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +11:42:30.363 [Druid-ConnectionPool-Create-159797312] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ruoyi?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state null +java.sql.SQLException: connect error, url jdbc:postgresql://localhost:5432/ruoyi?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, driverClass com.mysql.cj.jdbc.Driver + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1790) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +11:42:30.865 [Druid-ConnectionPool-Create-159797312] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ruoyi?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state null +java.sql.SQLException: connect error, url jdbc:postgresql://localhost:5432/ruoyi?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, driverClass com.mysql.cj.jdbc.Driver + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1790) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +11:42:31.378 [Druid-ConnectionPool-Create-159797312] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ruoyi?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state null +java.sql.SQLException: connect error, url jdbc:postgresql://localhost:5432/ruoyi?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, driverClass com.mysql.cj.jdbc.Driver + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1790) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +11:42:31.893 [Druid-ConnectionPool-Create-159797312] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ruoyi?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state null +java.sql.SQLException: connect error, url jdbc:postgresql://localhost:5432/ruoyi?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, driverClass com.mysql.cj.jdbc.Driver + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1790) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +11:42:32.406 [Druid-ConnectionPool-Create-159797312] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ruoyi?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state null +java.sql.SQLException: connect error, url jdbc:postgresql://localhost:5432/ruoyi?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, driverClass com.mysql.cj.jdbc.Driver + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1790) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +11:42:32.907 [Druid-ConnectionPool-Create-159797312] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ruoyi?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state null +java.sql.SQLException: connect error, url jdbc:postgresql://localhost:5432/ruoyi?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, driverClass com.mysql.cj.jdbc.Driver + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1790) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +11:42:33.407 [Druid-ConnectionPool-Create-159797312] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ruoyi?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state null +java.sql.SQLException: connect error, url jdbc:postgresql://localhost:5432/ruoyi?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, driverClass com.mysql.cj.jdbc.Driver + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1790) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +11:42:33.918 [Druid-ConnectionPool-Create-159797312] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ruoyi?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state null +java.sql.SQLException: connect error, url jdbc:postgresql://localhost:5432/ruoyi?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, driverClass com.mysql.cj.jdbc.Driver + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1790) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +11:42:34.431 [Druid-ConnectionPool-Create-159797312] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ruoyi?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state null +java.sql.SQLException: connect error, url jdbc:postgresql://localhost:5432/ruoyi?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, driverClass com.mysql.cj.jdbc.Driver + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1790) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +11:42:34.944 [Druid-ConnectionPool-Create-159797312] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ruoyi?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state null +java.sql.SQLException: connect error, url jdbc:postgresql://localhost:5432/ruoyi?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, driverClass com.mysql.cj.jdbc.Driver + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1790) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +11:42:35.454 [Druid-ConnectionPool-Create-159797312] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ruoyi?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state null +java.sql.SQLException: connect error, url jdbc:postgresql://localhost:5432/ruoyi?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, driverClass com.mysql.cj.jdbc.Driver + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1790) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +11:42:35.970 [Druid-ConnectionPool-Create-159797312] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ruoyi?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state null +java.sql.SQLException: connect error, url jdbc:postgresql://localhost:5432/ruoyi?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, driverClass com.mysql.cj.jdbc.Driver + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1790) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +11:42:36.483 [Druid-ConnectionPool-Create-159797312] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ruoyi?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state null +java.sql.SQLException: connect error, url jdbc:postgresql://localhost:5432/ruoyi?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, driverClass com.mysql.cj.jdbc.Driver + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1790) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +11:42:36.997 [Druid-ConnectionPool-Create-159797312] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ruoyi?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state null +java.sql.SQLException: connect error, url jdbc:postgresql://localhost:5432/ruoyi?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, driverClass com.mysql.cj.jdbc.Driver + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1790) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +11:42:37.499 [Druid-ConnectionPool-Create-159797312] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ruoyi?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state null +java.sql.SQLException: connect error, url jdbc:postgresql://localhost:5432/ruoyi?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, driverClass com.mysql.cj.jdbc.Driver + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1790) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +11:42:47.142 [Druid-ConnectionPool-Create-11548541] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state null +java.sql.SQLException: connect error, url jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, driverClass com.mysql.cj.jdbc.Driver + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1790) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +11:42:47.143 [Druid-ConnectionPool-Create-11548541] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state null +java.sql.SQLException: connect error, url jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, driverClass com.mysql.cj.jdbc.Driver + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1790) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +11:42:47.658 [Druid-ConnectionPool-Create-11548541] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state null +java.sql.SQLException: connect error, url jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, driverClass com.mysql.cj.jdbc.Driver + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1790) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +11:42:48.160 [Druid-ConnectionPool-Create-11548541] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state null +java.sql.SQLException: connect error, url jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, driverClass com.mysql.cj.jdbc.Driver + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1790) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +11:42:48.672 [Druid-ConnectionPool-Create-11548541] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state null +java.sql.SQLException: connect error, url jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, driverClass com.mysql.cj.jdbc.Driver + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1790) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +11:42:49.185 [Druid-ConnectionPool-Create-11548541] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state null +java.sql.SQLException: connect error, url jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, driverClass com.mysql.cj.jdbc.Driver + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1790) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +11:42:49.685 [Druid-ConnectionPool-Create-11548541] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state null +java.sql.SQLException: connect error, url jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, driverClass com.mysql.cj.jdbc.Driver + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1790) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +11:42:50.200 [Druid-ConnectionPool-Create-11548541] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state null +java.sql.SQLException: connect error, url jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, driverClass com.mysql.cj.jdbc.Driver + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1790) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +11:42:50.714 [Druid-ConnectionPool-Create-11548541] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state null +java.sql.SQLException: connect error, url jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, driverClass com.mysql.cj.jdbc.Driver + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1790) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +11:42:51.228 [Druid-ConnectionPool-Create-11548541] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state null +java.sql.SQLException: connect error, url jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, driverClass com.mysql.cj.jdbc.Driver + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1790) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +11:42:51.743 [Druid-ConnectionPool-Create-11548541] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state null +java.sql.SQLException: connect error, url jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, driverClass com.mysql.cj.jdbc.Driver + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1790) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +11:42:52.256 [Druid-ConnectionPool-Create-11548541] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state null +java.sql.SQLException: connect error, url jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, driverClass com.mysql.cj.jdbc.Driver + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1790) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +11:42:52.757 [Druid-ConnectionPool-Create-11548541] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state null +java.sql.SQLException: connect error, url jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, driverClass com.mysql.cj.jdbc.Driver + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1790) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +11:42:53.272 [Druid-ConnectionPool-Create-11548541] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state null +java.sql.SQLException: connect error, url jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, driverClass com.mysql.cj.jdbc.Driver + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1790) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +11:42:53.786 [Druid-ConnectionPool-Create-11548541] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state null +java.sql.SQLException: connect error, url jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, driverClass com.mysql.cj.jdbc.Driver + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1790) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +11:42:54.300 [Druid-ConnectionPool-Create-11548541] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state null +java.sql.SQLException: connect error, url jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, driverClass com.mysql.cj.jdbc.Driver + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1790) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +11:42:54.814 [Druid-ConnectionPool-Create-11548541] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state null +java.sql.SQLException: connect error, url jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, driverClass com.mysql.cj.jdbc.Driver + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1790) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +11:42:55.327 [Druid-ConnectionPool-Create-11548541] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state null +java.sql.SQLException: connect error, url jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, driverClass com.mysql.cj.jdbc.Driver + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1790) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +11:42:55.827 [Druid-ConnectionPool-Create-11548541] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state null +java.sql.SQLException: connect error, url jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, driverClass com.mysql.cj.jdbc.Driver + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1790) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +11:42:56.327 [Druid-ConnectionPool-Create-11548541] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state null +java.sql.SQLException: connect error, url jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, driverClass com.mysql.cj.jdbc.Driver + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1790) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +11:42:56.834 [Druid-ConnectionPool-Create-11548541] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state null +java.sql.SQLException: connect error, url jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, driverClass com.mysql.cj.jdbc.Driver + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1790) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +11:42:57.347 [Druid-ConnectionPool-Create-11548541] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state null +java.sql.SQLException: connect error, url jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, driverClass com.mysql.cj.jdbc.Driver + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1790) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +11:42:57.859 [Druid-ConnectionPool-Create-11548541] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state null +java.sql.SQLException: connect error, url jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, driverClass com.mysql.cj.jdbc.Driver + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1790) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +11:42:58.374 [Druid-ConnectionPool-Create-11548541] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state null +java.sql.SQLException: connect error, url jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, driverClass com.mysql.cj.jdbc.Driver + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1790) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +11:42:58.886 [Druid-ConnectionPool-Create-11548541] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state null +java.sql.SQLException: connect error, url jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, driverClass com.mysql.cj.jdbc.Driver + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1790) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +11:42:59.400 [Druid-ConnectionPool-Create-11548541] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state null +java.sql.SQLException: connect error, url jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, driverClass com.mysql.cj.jdbc.Driver + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1790) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +11:42:59.914 [Druid-ConnectionPool-Create-11548541] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state null +java.sql.SQLException: connect error, url jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, driverClass com.mysql.cj.jdbc.Driver + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1790) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +11:43:00.429 [Druid-ConnectionPool-Create-11548541] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state null +java.sql.SQLException: connect error, url jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, driverClass com.mysql.cj.jdbc.Driver + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1790) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +11:43:00.943 [Druid-ConnectionPool-Create-11548541] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state null +java.sql.SQLException: connect error, url jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, driverClass com.mysql.cj.jdbc.Driver + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1790) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +11:43:01.454 [Druid-ConnectionPool-Create-11548541] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state null +java.sql.SQLException: connect error, url jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, driverClass com.mysql.cj.jdbc.Driver + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1790) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +11:43:01.969 [Druid-ConnectionPool-Create-11548541] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state null +java.sql.SQLException: connect error, url jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, driverClass com.mysql.cj.jdbc.Driver + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1790) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +11:43:02.482 [Druid-ConnectionPool-Create-11548541] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state null +java.sql.SQLException: connect error, url jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, driverClass com.mysql.cj.jdbc.Driver + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1790) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +11:43:02.983 [Druid-ConnectionPool-Create-11548541] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state null +java.sql.SQLException: connect error, url jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, driverClass com.mysql.cj.jdbc.Driver + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1790) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +11:43:03.494 [Druid-ConnectionPool-Create-11548541] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state null +java.sql.SQLException: connect error, url jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, driverClass com.mysql.cj.jdbc.Driver + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1790) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +11:43:09.619 [restartedMain] ERROR c.a.d.p.DruidDataSource - [init,971] - {dataSource-1} init error +java.sql.SQLException: org.postgresql.Driver + at com.alibaba.druid.util.JdbcUtils.createDriver(JdbcUtils.java:688) + at com.alibaba.druid.pool.DruidDataSource.resolveDriver(DruidDataSource.java:1259) + at com.alibaba.druid.pool.DruidDataSource.init(DruidDataSource.java:887) + at com.baomidou.dynamic.datasource.creator.DruidDataSourceCreator.createDataSource(DruidDataSourceCreator.java:95) + at com.baomidou.dynamic.datasource.creator.DefaultDataSourceCreator.createDataSource(DefaultDataSourceCreator.java:68) + at com.baomidou.dynamic.datasource.provider.AbstractDataSourceProvider.createDataSourceMap(AbstractDataSourceProvider.java:44) + at com.dc.framework.config.DataSourceConfiguration$1.loadDataSources(DataSourceConfiguration.java:72) + at com.baomidou.dynamic.datasource.DynamicRoutingDataSource.afterPropertiesSet(DynamicRoutingDataSource.java:227) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.invokeInitMethods(AbstractAutowireCapableBeanFactory.java:1863) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.initializeBean(AbstractAutowireCapableBeanFactory.java:1800) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:620) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:542) + at org.springframework.beans.factory.support.AbstractBeanFactory.lambda$doGetBean$0(AbstractBeanFactory.java:335) + at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:234) + at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:333) + at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:208) + at org.springframework.beans.factory.config.DependencyDescriptor.resolveCandidate(DependencyDescriptor.java:276) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.doResolveDependency(DefaultListableBeanFactory.java:1389) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.resolveDependency(DefaultListableBeanFactory.java:1309) + at org.springframework.beans.factory.support.ConstructorResolver.resolveAutowiredArgument(ConstructorResolver.java:887) + at org.springframework.beans.factory.support.ConstructorResolver.createArgumentArray(ConstructorResolver.java:791) + at org.springframework.beans.factory.support.ConstructorResolver.instantiateUsingFactoryMethod(ConstructorResolver.java:541) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.instantiateUsingFactoryMethod(AbstractAutowireCapableBeanFactory.java:1352) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBeanInstance(AbstractAutowireCapableBeanFactory.java:1195) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:582) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:542) + at org.springframework.beans.factory.support.AbstractBeanFactory.lambda$doGetBean$0(AbstractBeanFactory.java:335) + at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:234) + at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:333) + at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:208) + at org.springframework.beans.factory.config.DependencyDescriptor.resolveCandidate(DependencyDescriptor.java:276) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.doResolveDependency(DefaultListableBeanFactory.java:1389) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.resolveDependency(DefaultListableBeanFactory.java:1309) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.autowireByType(AbstractAutowireCapableBeanFactory.java:1519) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.populateBean(AbstractAutowireCapableBeanFactory.java:1417) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:619) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:542) + at org.springframework.beans.factory.support.AbstractBeanFactory.lambda$doGetBean$0(AbstractBeanFactory.java:335) + at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:234) + at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:333) + at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:208) + at org.springframework.beans.factory.config.DependencyDescriptor.resolveCandidate(DependencyDescriptor.java:276) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.doResolveDependency(DefaultListableBeanFactory.java:1389) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.resolveDependency(DefaultListableBeanFactory.java:1309) + at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor$AutowiredFieldElement.resolveFieldValue(AutowiredAnnotationBeanPostProcessor.java:656) + at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor$AutowiredFieldElement.inject(AutowiredAnnotationBeanPostProcessor.java:639) + at org.springframework.beans.factory.annotation.InjectionMetadata.inject(InjectionMetadata.java:119) + at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor.postProcessProperties(AutowiredAnnotationBeanPostProcessor.java:399) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.populateBean(AbstractAutowireCapableBeanFactory.java:1431) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:619) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:542) + at org.springframework.beans.factory.support.AbstractBeanFactory.lambda$doGetBean$0(AbstractBeanFactory.java:335) + at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:234) + at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:333) + at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:208) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.preInstantiateSingletons(DefaultListableBeanFactory.java:953) + at org.springframework.context.support.AbstractApplicationContext.finishBeanFactoryInitialization(AbstractApplicationContext.java:918) + at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:583) + at org.springframework.boot.web.servlet.context.ServletWebServerApplicationContext.refresh(ServletWebServerApplicationContext.java:145) + at org.springframework.boot.SpringApplication.refresh(SpringApplication.java:780) + at org.springframework.boot.SpringApplication.refreshContext(SpringApplication.java:453) + at org.springframework.boot.SpringApplication.run(SpringApplication.java:343) + at org.springframework.boot.SpringApplication.run(SpringApplication.java:1370) + at org.springframework.boot.SpringApplication.run(SpringApplication.java:1359) + at com.dc.web.DcApplication.main(DcApplication.java:20) + at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) + at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) + at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) + at java.lang.reflect.Method.invoke(Method.java:498) + at org.springframework.boot.devtools.restart.RestartLauncher.run(RestartLauncher.java:49) +Caused by: java.lang.ClassNotFoundException: org.postgresql.Driver + at java.net.URLClassLoader.findClass(URLClassLoader.java:382) + at java.lang.ClassLoader.loadClass(ClassLoader.java:418) + at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:355) + at java.lang.ClassLoader.loadClass(ClassLoader.java:351) + at java.lang.Class.forName0(Native Method) + at java.lang.Class.forName(Class.java:264) + at com.alibaba.druid.util.JdbcUtils.createDriver(JdbcUtils.java:686) + ... 69 common frames omitted +11:43:09.693 [restartedMain] ERROR o.s.b.SpringApplication - [reportFailure,870] - Application run failed +org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'accessoryService': Unsatisfied dependency expressed through field 'baseMapper'; nested exception is org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'accessoryMapper' defined in file [D:\workspace\wenyin\win\win-system\target\classes\com\win\system\mapper\AccessoryMapper.class]: Unsatisfied dependency expressed through bean property 'sqlSessionFactory'; nested exception is org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'sqlSessionFactory' defined in class path resource [com/win/framework/config/DataSourceConfiguration.class]: Unsatisfied dependency expressed through method 'sqlSessionFactory' parameter 0; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'dataSource' defined in class path resource [com/win/framework/config/DataSourceConfiguration.class]: Invocation of init method failed; nested exception is com.baomidou.dynamic.datasource.exception.ErrorCreateDataSourceException: druid create error + at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor$AutowiredFieldElement.resolveFieldValue(AutowiredAnnotationBeanPostProcessor.java:659) + at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor$AutowiredFieldElement.inject(AutowiredAnnotationBeanPostProcessor.java:639) + at org.springframework.beans.factory.annotation.InjectionMetadata.inject(InjectionMetadata.java:119) + at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor.postProcessProperties(AutowiredAnnotationBeanPostProcessor.java:399) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.populateBean(AbstractAutowireCapableBeanFactory.java:1431) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:619) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:542) + at org.springframework.beans.factory.support.AbstractBeanFactory.lambda$doGetBean$0(AbstractBeanFactory.java:335) + at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:234) + at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:333) + at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:208) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.preInstantiateSingletons(DefaultListableBeanFactory.java:953) + at org.springframework.context.support.AbstractApplicationContext.finishBeanFactoryInitialization(AbstractApplicationContext.java:918) + at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:583) + at org.springframework.boot.web.servlet.context.ServletWebServerApplicationContext.refresh(ServletWebServerApplicationContext.java:145) + at org.springframework.boot.SpringApplication.refresh(SpringApplication.java:780) + at org.springframework.boot.SpringApplication.refreshContext(SpringApplication.java:453) + at org.springframework.boot.SpringApplication.run(SpringApplication.java:343) + at org.springframework.boot.SpringApplication.run(SpringApplication.java:1370) + at org.springframework.boot.SpringApplication.run(SpringApplication.java:1359) + at com.dc.web.DcApplication.main(DcApplication.java:20) + at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) + at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) + at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) + at java.lang.reflect.Method.invoke(Method.java:498) + at org.springframework.boot.devtools.restart.RestartLauncher.run(RestartLauncher.java:49) +Caused by: org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'accessoryMapper' defined in file [D:\workspace\wenyin\win\win-system\target\classes\com\win\system\mapper\AccessoryMapper.class]: Unsatisfied dependency expressed through bean property 'sqlSessionFactory'; nested exception is org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'sqlSessionFactory' defined in class path resource [com/win/framework/config/DataSourceConfiguration.class]: Unsatisfied dependency expressed through method 'sqlSessionFactory' parameter 0; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'dataSource' defined in class path resource [com/win/framework/config/DataSourceConfiguration.class]: Invocation of init method failed; nested exception is com.baomidou.dynamic.datasource.exception.ErrorCreateDataSourceException: druid create error + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.autowireByType(AbstractAutowireCapableBeanFactory.java:1534) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.populateBean(AbstractAutowireCapableBeanFactory.java:1417) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:619) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:542) + at org.springframework.beans.factory.support.AbstractBeanFactory.lambda$doGetBean$0(AbstractBeanFactory.java:335) + at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:234) + at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:333) + at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:208) + at org.springframework.beans.factory.config.DependencyDescriptor.resolveCandidate(DependencyDescriptor.java:276) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.doResolveDependency(DefaultListableBeanFactory.java:1389) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.resolveDependency(DefaultListableBeanFactory.java:1309) + at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor$AutowiredFieldElement.resolveFieldValue(AutowiredAnnotationBeanPostProcessor.java:656) + ... 25 common frames omitted +Caused by: org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'sqlSessionFactory' defined in class path resource [com/win/framework/config/DataSourceConfiguration.class]: Unsatisfied dependency expressed through method 'sqlSessionFactory' parameter 0; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'dataSource' defined in class path resource [com/win/framework/config/DataSourceConfiguration.class]: Invocation of init method failed; nested exception is com.baomidou.dynamic.datasource.exception.ErrorCreateDataSourceException: druid create error + at org.springframework.beans.factory.support.ConstructorResolver.createArgumentArray(ConstructorResolver.java:800) + at org.springframework.beans.factory.support.ConstructorResolver.instantiateUsingFactoryMethod(ConstructorResolver.java:541) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.instantiateUsingFactoryMethod(AbstractAutowireCapableBeanFactory.java:1352) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBeanInstance(AbstractAutowireCapableBeanFactory.java:1195) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:582) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:542) + at org.springframework.beans.factory.support.AbstractBeanFactory.lambda$doGetBean$0(AbstractBeanFactory.java:335) + at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:234) + at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:333) + at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:208) + at org.springframework.beans.factory.config.DependencyDescriptor.resolveCandidate(DependencyDescriptor.java:276) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.doResolveDependency(DefaultListableBeanFactory.java:1389) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.resolveDependency(DefaultListableBeanFactory.java:1309) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.autowireByType(AbstractAutowireCapableBeanFactory.java:1519) + ... 36 common frames omitted +Caused by: org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'dataSource' defined in class path resource [com/win/framework/config/DataSourceConfiguration.class]: Invocation of init method failed; nested exception is com.baomidou.dynamic.datasource.exception.ErrorCreateDataSourceException: druid create error + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.initializeBean(AbstractAutowireCapableBeanFactory.java:1804) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:620) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:542) + at org.springframework.beans.factory.support.AbstractBeanFactory.lambda$doGetBean$0(AbstractBeanFactory.java:335) + at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:234) + at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:333) + at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:208) + at org.springframework.beans.factory.config.DependencyDescriptor.resolveCandidate(DependencyDescriptor.java:276) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.doResolveDependency(DefaultListableBeanFactory.java:1389) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.resolveDependency(DefaultListableBeanFactory.java:1309) + at org.springframework.beans.factory.support.ConstructorResolver.resolveAutowiredArgument(ConstructorResolver.java:887) + at org.springframework.beans.factory.support.ConstructorResolver.createArgumentArray(ConstructorResolver.java:791) + ... 49 common frames omitted +Caused by: com.baomidou.dynamic.datasource.exception.ErrorCreateDataSourceException: druid create error + at com.baomidou.dynamic.datasource.creator.DruidDataSourceCreator.createDataSource(DruidDataSourceCreator.java:97) + at com.baomidou.dynamic.datasource.creator.DefaultDataSourceCreator.createDataSource(DefaultDataSourceCreator.java:68) + at com.baomidou.dynamic.datasource.provider.AbstractDataSourceProvider.createDataSourceMap(AbstractDataSourceProvider.java:44) + at com.dc.framework.config.DataSourceConfiguration$1.loadDataSources(DataSourceConfiguration.java:72) + at com.baomidou.dynamic.datasource.DynamicRoutingDataSource.afterPropertiesSet(DynamicRoutingDataSource.java:227) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.invokeInitMethods(AbstractAutowireCapableBeanFactory.java:1863) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.initializeBean(AbstractAutowireCapableBeanFactory.java:1800) + ... 60 common frames omitted +Caused by: java.sql.SQLException: org.postgresql.Driver + at com.alibaba.druid.util.JdbcUtils.createDriver(JdbcUtils.java:688) + at com.alibaba.druid.pool.DruidDataSource.resolveDriver(DruidDataSource.java:1259) + at com.alibaba.druid.pool.DruidDataSource.init(DruidDataSource.java:887) + at com.baomidou.dynamic.datasource.creator.DruidDataSourceCreator.createDataSource(DruidDataSourceCreator.java:95) + ... 66 common frames omitted +Caused by: java.lang.ClassNotFoundException: org.postgresql.Driver + at java.net.URLClassLoader.findClass(URLClassLoader.java:382) + at java.lang.ClassLoader.loadClass(ClassLoader.java:418) + at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:355) + at java.lang.ClassLoader.loadClass(ClassLoader.java:351) + at java.lang.Class.forName0(Native Method) + at java.lang.Class.forName(Class.java:264) + at com.alibaba.druid.util.JdbcUtils.createDriver(JdbcUtils.java:686) + ... 69 common frames omitted +11:43:53.887 [schedule-pool-1] ERROR c.w.c.utils.Threads - [printException,93] - +### Error updating database. Cause: org.postgresql.util.PSQLException: 错误: 函数 sysdate() 不存在 + 建议:没有匹配指定名称和参数类型的函数. 您也许需要增加明确的类型转换. + 位置:146 +### The error may exist in file [D:\workspace\wenyin\win\win-system\target\classes\mapper\system\SysLogininforMapper.xml] +### The error may involve com.dc.system.mapper.SysLogininforMapper.insertLogininfor-Inline +### The error occurred while setting parameters +### SQL: insert into sys_logininfor (user_name, status, ipaddr, login_location, browser, os, msg, login_time) values (?, ?, ?, ?, ?, ?, ?, sysdate()) +### Cause: org.postgresql.util.PSQLException: 错误: 函数 sysdate() 不存在 + 建议:没有匹配指定名称和参数类型的函数. 您也许需要增加明确的类型转换. + 位置:146 +; bad SQL grammar []; nested exception is org.postgresql.util.PSQLException: 错误: 函数 sysdate() 不存在 + 建议:没有匹配指定名称和参数类型的函数. 您也许需要增加明确的类型转换. + 位置:146 +org.springframework.jdbc.BadSqlGrammarException: +### Error updating database. Cause: org.postgresql.util.PSQLException: 错误: 函数 sysdate() 不存在 + 建议:没有匹配指定名称和参数类型的函数. 您也许需要增加明确的类型转换. + 位置:146 +### The error may exist in file [D:\workspace\wenyin\win\win-system\target\classes\mapper\system\SysLogininforMapper.xml] +### The error may involve com.dc.system.mapper.SysLogininforMapper.insertLogininfor-Inline +### The error occurred while setting parameters +### SQL: insert into sys_logininfor (user_name, status, ipaddr, login_location, browser, os, msg, login_time) values (?, ?, ?, ?, ?, ?, ?, sysdate()) +### Cause: org.postgresql.util.PSQLException: 错误: 函数 sysdate() 不存在 + 建议:没有匹配指定名称和参数类型的函数. 您也许需要增加明确的类型转换. + 位置:146 +; bad SQL grammar []; nested exception is org.postgresql.util.PSQLException: 错误: 函数 sysdate() 不存在 + 建议:没有匹配指定名称和参数类型的函数. 您也许需要增加明确的类型转换. + 位置:146 + at org.springframework.jdbc.support.SQLStateSQLExceptionTranslator.doTranslate(SQLStateSQLExceptionTranslator.java:101) + at org.springframework.jdbc.support.AbstractFallbackSQLExceptionTranslator.translate(AbstractFallbackSQLExceptionTranslator.java:70) + at org.springframework.jdbc.support.AbstractFallbackSQLExceptionTranslator.translate(AbstractFallbackSQLExceptionTranslator.java:79) + at org.springframework.jdbc.support.AbstractFallbackSQLExceptionTranslator.translate(AbstractFallbackSQLExceptionTranslator.java:79) + at org.mybatis.spring.MyBatisExceptionTranslator.translateExceptionIfPossible(MyBatisExceptionTranslator.java:91) + at org.mybatis.spring.SqlSessionTemplate$SqlSessionInterceptor.invoke(SqlSessionTemplate.java:441) + at com.sun.proxy.$Proxy113.insert(Unknown Source) + at org.mybatis.spring.SqlSessionTemplate.insert(SqlSessionTemplate.java:272) + at com.baomidou.mybatisplus.core.override.MybatisMapperMethod.execute(MybatisMapperMethod.java:59) + at com.baomidou.mybatisplus.core.override.MybatisMapperProxy$PlainMethodInvoker.invoke(MybatisMapperProxy.java:148) + at com.baomidou.mybatisplus.core.override.MybatisMapperProxy.invoke(MybatisMapperProxy.java:89) + at com.sun.proxy.$Proxy130.insertLogininfor(Unknown Source) + at com.dc.system.service.SysLogininforService.insertLogininfor(SysLogininforService.java:29) + at com.dc.system.service.SysLogininforService$$FastClassBySpringCGLIB$$d103dfc6.invoke(<generated>) + at org.springframework.cglib.proxy.MethodProxy.invoke(MethodProxy.java:218) + at org.springframework.aop.framework.CglibAopProxy.invokeMethod(CglibAopProxy.java:386) + at org.springframework.aop.framework.CglibAopProxy.access$000(CglibAopProxy.java:85) + at org.springframework.aop.framework.CglibAopProxy$DynamicAdvisedInterceptor.intercept(CglibAopProxy.java:704) + at com.dc.system.service.SysLogininforService$$EnhancerBySpringCGLIB$$64c58e96.insertLogininfor(<generated>) + at com.dc.framework.manager.factory.AsyncFactory$1.run(AsyncFactory.java:79) + at java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:511) + at java.util.concurrent.FutureTask.run$$$capture(FutureTask.java:266) + at java.util.concurrent.FutureTask.run(FutureTask.java) + at java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.access$201(ScheduledThreadPoolExecutor.java:180) + at java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.run(ScheduledThreadPoolExecutor.java:293) + at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1149) + at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:624) + at java.lang.Thread.run(Thread.java:748) +Caused by: org.postgresql.util.PSQLException: 错误: 函数 sysdate() 不存在 + 建议:没有匹配指定名称和参数类型的函数. 您也许需要增加明确的类型转换. + 位置:146 + at org.postgresql.core.v3.QueryExecutorImpl.receiveErrorResponse(QueryExecutorImpl.java:2565) + at org.postgresql.core.v3.QueryExecutorImpl.processResults(QueryExecutorImpl.java:2297) + at org.postgresql.core.v3.QueryExecutorImpl.execute(QueryExecutorImpl.java:322) + at org.postgresql.jdbc.PgStatement.executeInternal(PgStatement.java:481) + at org.postgresql.jdbc.PgStatement.execute(PgStatement.java:401) + at org.postgresql.jdbc.PgPreparedStatement.executeWithFlags(PgPreparedStatement.java:164) + at org.postgresql.jdbc.PgPreparedStatement.execute(PgPreparedStatement.java:153) + at com.alibaba.druid.filter.FilterChainImpl.preparedStatement_execute(FilterChainImpl.java:3446) + at com.alibaba.druid.filter.FilterEventAdapter.preparedStatement_execute(FilterEventAdapter.java:434) + at com.alibaba.druid.filter.FilterChainImpl.preparedStatement_execute(FilterChainImpl.java:3444) + at com.alibaba.druid.proxy.jdbc.PreparedStatementProxyImpl.execute(PreparedStatementProxyImpl.java:152) + at com.alibaba.druid.pool.DruidPooledPreparedStatement.execute(DruidPooledPreparedStatement.java:483) + at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) + at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) + at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) + at java.lang.reflect.Method.invoke(Method.java:498) + at org.apache.ibatis.logging.jdbc.PreparedStatementLogger.invoke(PreparedStatementLogger.java:59) + at com.sun.proxy.$Proxy120.execute(Unknown Source) + at org.apache.ibatis.executor.statement.PreparedStatementHandler.update(PreparedStatementHandler.java:47) + at org.apache.ibatis.executor.statement.RoutingStatementHandler.update(RoutingStatementHandler.java:74) + at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) + at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) + at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) + at java.lang.reflect.Method.invoke(Method.java:498) + at org.apache.ibatis.plugin.Plugin.invoke(Plugin.java:64) + at com.sun.proxy.$Proxy118.update(Unknown Source) + at org.apache.ibatis.executor.SimpleExecutor.doUpdate(SimpleExecutor.java:50) + at org.apache.ibatis.executor.BaseExecutor.update(BaseExecutor.java:117) + at org.apache.ibatis.executor.CachingExecutor.update(CachingExecutor.java:76) + at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) + at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) + at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) + at java.lang.reflect.Method.invoke(Method.java:498) + at org.apache.ibatis.plugin.Invocation.proceed(Invocation.java:49) + at com.baomidou.mybatisplus.extension.plugins.MybatisPlusInterceptor.intercept(MybatisPlusInterceptor.java:106) + at org.apache.ibatis.plugin.Plugin.invoke(Plugin.java:62) + at com.sun.proxy.$Proxy117.update(Unknown Source) + at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) + at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) + at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) + at java.lang.reflect.Method.invoke(Method.java:498) + at org.apache.ibatis.plugin.Plugin.invoke(Plugin.java:64) + at com.sun.proxy.$Proxy117.update(Unknown Source) + at org.apache.ibatis.session.defaults.DefaultSqlSession.update(DefaultSqlSession.java:194) + at org.apache.ibatis.session.defaults.DefaultSqlSession.insert(DefaultSqlSession.java:181) + at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) + at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) + at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) + at java.lang.reflect.Method.invoke(Method.java:498) + at org.mybatis.spring.SqlSessionTemplate$SqlSessionInterceptor.invoke(SqlSessionTemplate.java:427) + ... 22 common frames omitted +11:43:53.887 [http-nio-8080-exec-5] ERROR c.w.f.w.e.GlobalExceptionHandler - [handleRuntimeException,82] - 请求地址'/login',发生未知异常. +org.springframework.jdbc.BadSqlGrammarException: +### Error updating database. Cause: org.postgresql.util.PSQLException: 错误: 函数 sysdate() 不存在 + 建议:没有匹配指定名称和参数类型的函数. 您也许需要增加明确的类型转换. + 位置:126 +### The error may exist in file [D:\workspace\wenyin\win\win-system\target\classes\mapper\system\SysUserMapper.xml] +### The error may involve com.dc.system.mapper.SysUserMapper.updateUser-Inline +### The error occurred while setting parameters +### SQL: update sys_user SET login_ip = ?, login_date = ?, update_time = sysdate() where user_id = ? +### Cause: org.postgresql.util.PSQLException: 错误: 函数 sysdate() 不存在 + 建议:没有匹配指定名称和参数类型的函数. 您也许需要增加明确的类型转换. + 位置:126 +; bad SQL grammar []; nested exception is org.postgresql.util.PSQLException: 错误: 函数 sysdate() 不存在 + 建议:没有匹配指定名称和参数类型的函数. 您也许需要增加明确的类型转换. + 位置:126 + at org.springframework.jdbc.support.SQLStateSQLExceptionTranslator.doTranslate(SQLStateSQLExceptionTranslator.java:101) + at org.springframework.jdbc.support.AbstractFallbackSQLExceptionTranslator.translate(AbstractFallbackSQLExceptionTranslator.java:70) + at org.springframework.jdbc.support.AbstractFallbackSQLExceptionTranslator.translate(AbstractFallbackSQLExceptionTranslator.java:79) + at org.springframework.jdbc.support.AbstractFallbackSQLExceptionTranslator.translate(AbstractFallbackSQLExceptionTranslator.java:79) + at org.mybatis.spring.MyBatisExceptionTranslator.translateExceptionIfPossible(MyBatisExceptionTranslator.java:91) + at org.mybatis.spring.SqlSessionTemplate$SqlSessionInterceptor.invoke(SqlSessionTemplate.java:441) + at com.sun.proxy.$Proxy113.update(Unknown Source) + at org.mybatis.spring.SqlSessionTemplate.update(SqlSessionTemplate.java:288) + at com.baomidou.mybatisplus.core.override.MybatisMapperMethod.execute(MybatisMapperMethod.java:64) + at com.baomidou.mybatisplus.core.override.MybatisMapperProxy$PlainMethodInvoker.invoke(MybatisMapperProxy.java:148) + at com.baomidou.mybatisplus.core.override.MybatisMapperProxy.invoke(MybatisMapperProxy.java:89) + at com.sun.proxy.$Proxy139.updateUser(Unknown Source) + at com.dc.system.service.SysUserService.updateUserProfile(SysUserService.java:322) + at com.dc.system.service.SysUserService$$FastClassBySpringCGLIB$$7f7e26b6.invoke(<generated>) + at org.springframework.cglib.proxy.MethodProxy.invoke(MethodProxy.java:218) + at org.springframework.aop.framework.CglibAopProxy$CglibMethodInvocation.invokeJoinpoint(CglibAopProxy.java:793) + at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:163) + at org.springframework.aop.framework.CglibAopProxy$CglibMethodInvocation.proceed(CglibAopProxy.java:763) + at org.springframework.aop.interceptor.ExposeInvocationInterceptor.invoke(ExposeInvocationInterceptor.java:97) + at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:186) + at org.springframework.aop.framework.CglibAopProxy$CglibMethodInvocation.proceed(CglibAopProxy.java:763) + at org.springframework.aop.framework.CglibAopProxy$DynamicAdvisedInterceptor.intercept(CglibAopProxy.java:708) + at com.dc.system.service.SysUserService$$EnhancerBySpringCGLIB$$592f4b68.updateUserProfile(<generated>) + at com.dc.framework.web.service.SysLoginService.recordLoginInfo(SysLoginService.java:158) + at com.dc.framework.web.service.SysLoginService.login(SysLoginService.java:104) + at com.dc.web.controller.system.SysLoginController.login(SysLoginController.java:49) + at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) + at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) + at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) + at java.lang.reflect.Method.invoke(Method.java:498) + at org.springframework.web.method.support.InvocableHandlerMethod.doInvoke(InvocableHandlerMethod.java:205) + at org.springframework.web.method.support.InvocableHandlerMethod.invokeForRequest(InvocableHandlerMethod.java:150) + at org.springframework.web.servlet.mvc.method.annotation.ServletInvocableHandlerMethod.invokeAndHandle(ServletInvocableHandlerMethod.java:117) + at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.invokeHandlerMethod(RequestMappingHandlerAdapter.java:895) + at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.handleInternal(RequestMappingHandlerAdapter.java:808) + at org.springframework.web.servlet.mvc.method.AbstractHandlerMethodAdapter.handle(AbstractHandlerMethodAdapter.java:87) + at org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:1067) + at org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:963) + at org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:1006) + at org.springframework.web.servlet.FrameworkServlet.doPost(FrameworkServlet.java:909) + at javax.servlet.http.HttpServlet.service(HttpServlet.java:681) + at org.springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.java:883) + at javax.servlet.http.HttpServlet.service(HttpServlet.java:764) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:227) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:53) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:111) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:111) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at com.dc.common.filter.RepeatableFilter.doFilter(RepeatableFilter.java:39) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:327) + at org.springframework.security.web.access.intercept.FilterSecurityInterceptor.invoke(FilterSecurityInterceptor.java:115) + at org.springframework.security.web.access.intercept.FilterSecurityInterceptor.doFilter(FilterSecurityInterceptor.java:81) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.access.ExceptionTranslationFilter.doFilter(ExceptionTranslationFilter.java:121) + at org.springframework.security.web.access.ExceptionTranslationFilter.doFilter(ExceptionTranslationFilter.java:115) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.session.SessionManagementFilter.doFilter(SessionManagementFilter.java:126) + at org.springframework.security.web.session.SessionManagementFilter.doFilter(SessionManagementFilter.java:81) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.authentication.AnonymousAuthenticationFilter.doFilter(AnonymousAuthenticationFilter.java:105) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.servletapi.SecurityContextHolderAwareRequestFilter.doFilter(SecurityContextHolderAwareRequestFilter.java:149) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.savedrequest.RequestCacheAwareFilter.doFilter(RequestCacheAwareFilter.java:63) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at com.dc.framework.security.filter.JwtAuthenticationTokenFilter.doFilterInternal(JwtAuthenticationTokenFilter.java:43) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:111) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.authentication.logout.LogoutFilter.doFilter(LogoutFilter.java:103) + at org.springframework.security.web.authentication.logout.LogoutFilter.doFilter(LogoutFilter.java:89) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.web.filter.CorsFilter.doFilterInternal(CorsFilter.java:91) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.header.HeaderWriterFilter.doHeadersAfter(HeaderWriterFilter.java:90) + at org.springframework.security.web.header.HeaderWriterFilter.doFilterInternal(HeaderWriterFilter.java:75) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.context.SecurityContextPersistenceFilter.doFilter(SecurityContextPersistenceFilter.java:110) + at org.springframework.security.web.context.SecurityContextPersistenceFilter.doFilter(SecurityContextPersistenceFilter.java:80) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.context.request.async.WebAsyncManagerIntegrationFilter.doFilterInternal(WebAsyncManagerIntegrationFilter.java:55) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.FilterChainProxy.doFilterInternal(FilterChainProxy.java:211) + at org.springframework.security.web.FilterChainProxy.doFilter(FilterChainProxy.java:183) + at org.springframework.web.filter.DelegatingFilterProxy.invokeDelegate(DelegatingFilterProxy.java:354) + at org.springframework.web.filter.DelegatingFilterProxy.doFilter(DelegatingFilterProxy.java:267) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.RequestContextFilter.doFilterInternal(RequestContextFilter.java:100) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.FormContentFilter.doFilterInternal(FormContentFilter.java:93) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.CharacterEncodingFilter.doFilterInternal(CharacterEncodingFilter.java:201) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:197) + at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:97) + at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:541) + at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:135) + at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:92) + at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:78) + at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:360) + at org.apache.coyote.http11.Http11Processor.service(Http11Processor.java:399) + at org.apache.coyote.AbstractProcessorLight.process(AbstractProcessorLight.java:65) + at org.apache.coyote.AbstractProtocol$ConnectionHandler.process(AbstractProtocol.java:890) + at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1743) + at org.apache.tomcat.util.net.SocketProcessorBase.run(SocketProcessorBase.java:49) + at org.apache.tomcat.util.threads.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1191) + at org.apache.tomcat.util.threads.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:659) + at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61) + at java.lang.Thread.run(Thread.java:748) +Caused by: org.postgresql.util.PSQLException: 错误: 函数 sysdate() 不存在 + 建议:没有匹配指定名称和参数类型的函数. 您也许需要增加明确的类型转换. + 位置:126 + at org.postgresql.core.v3.QueryExecutorImpl.receiveErrorResponse(QueryExecutorImpl.java:2565) + at org.postgresql.core.v3.QueryExecutorImpl.processResults(QueryExecutorImpl.java:2297) + at org.postgresql.core.v3.QueryExecutorImpl.execute(QueryExecutorImpl.java:322) + at org.postgresql.jdbc.PgStatement.executeInternal(PgStatement.java:481) + at org.postgresql.jdbc.PgStatement.execute(PgStatement.java:401) + at org.postgresql.jdbc.PgPreparedStatement.executeWithFlags(PgPreparedStatement.java:164) + at org.postgresql.jdbc.PgPreparedStatement.execute(PgPreparedStatement.java:153) + at com.alibaba.druid.filter.FilterChainImpl.preparedStatement_execute(FilterChainImpl.java:3446) + at com.alibaba.druid.filter.FilterEventAdapter.preparedStatement_execute(FilterEventAdapter.java:434) + at com.alibaba.druid.filter.FilterChainImpl.preparedStatement_execute(FilterChainImpl.java:3444) + at com.alibaba.druid.proxy.jdbc.PreparedStatementProxyImpl.execute(PreparedStatementProxyImpl.java:152) + at com.alibaba.druid.pool.DruidPooledPreparedStatement.execute(DruidPooledPreparedStatement.java:483) + at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) + at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) + at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) + at java.lang.reflect.Method.invoke(Method.java:498) + at org.apache.ibatis.logging.jdbc.PreparedStatementLogger.invoke(PreparedStatementLogger.java:59) + at com.sun.proxy.$Proxy120.execute(Unknown Source) + at org.apache.ibatis.executor.statement.PreparedStatementHandler.update(PreparedStatementHandler.java:47) + at org.apache.ibatis.executor.statement.RoutingStatementHandler.update(RoutingStatementHandler.java:74) + at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) + at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) + at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) + at java.lang.reflect.Method.invoke(Method.java:498) + at org.apache.ibatis.plugin.Plugin.invoke(Plugin.java:64) + at com.sun.proxy.$Proxy118.update(Unknown Source) + at org.apache.ibatis.executor.SimpleExecutor.doUpdate(SimpleExecutor.java:50) + at org.apache.ibatis.executor.BaseExecutor.update(BaseExecutor.java:117) + at org.apache.ibatis.executor.CachingExecutor.update(CachingExecutor.java:76) + at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) + at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) + at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) + at java.lang.reflect.Method.invoke(Method.java:498) + at org.apache.ibatis.plugin.Invocation.proceed(Invocation.java:49) + at com.baomidou.mybatisplus.extension.plugins.MybatisPlusInterceptor.intercept(MybatisPlusInterceptor.java:106) + at org.apache.ibatis.plugin.Plugin.invoke(Plugin.java:62) + at com.sun.proxy.$Proxy117.update(Unknown Source) + at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) + at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) + at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) + at java.lang.reflect.Method.invoke(Method.java:498) + at org.apache.ibatis.plugin.Plugin.invoke(Plugin.java:64) + at com.sun.proxy.$Proxy117.update(Unknown Source) + at org.apache.ibatis.session.defaults.DefaultSqlSession.update(DefaultSqlSession.java:194) + at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) + at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) + at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) + at java.lang.reflect.Method.invoke(Method.java:498) + at org.mybatis.spring.SqlSessionTemplate$SqlSessionInterceptor.invoke(SqlSessionTemplate.java:427) + ... 122 common frames omitted +11:45:40.006 [http-nio-8080-exec-8] ERROR c.w.f.w.e.GlobalExceptionHandler - [handleRuntimeException,82] - 请求地址'/monitor/online/list',发生未知异常. +java.lang.ClassCastException: com.alibaba.fastjson2.JSONObject cannot be cast to com.dc.common.core.domain.model.LoginUser + at com.dc.web.controller.monitor.SysUserOnlineController.list(SysUserOnlineController.java:44) + at com.dc.web.controller.monitor.SysUserOnlineController$$FastClassBySpringCGLIB$$13f4905a.invoke(<generated>) + at org.springframework.cglib.proxy.MethodProxy.invoke(MethodProxy.java:218) + at org.springframework.aop.framework.CglibAopProxy$CglibMethodInvocation.invokeJoinpoint(CglibAopProxy.java:793) + at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:163) + at org.springframework.aop.framework.CglibAopProxy$CglibMethodInvocation.proceed(CglibAopProxy.java:763) + at org.springframework.aop.interceptor.ExposeInvocationInterceptor.invoke(ExposeInvocationInterceptor.java:97) + at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:186) + at org.springframework.aop.framework.CglibAopProxy$CglibMethodInvocation.proceed(CglibAopProxy.java:763) + at org.springframework.aop.framework.CglibAopProxy$DynamicAdvisedInterceptor.intercept(CglibAopProxy.java:708) + at com.dc.web.controller.monitor.SysUserOnlineController$$EnhancerBySpringCGLIB$$e2ab7bcf.list(<generated>) + at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) + at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) + at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) + at java.lang.reflect.Method.invoke(Method.java:498) + at org.springframework.web.method.support.InvocableHandlerMethod.doInvoke(InvocableHandlerMethod.java:205) + at org.springframework.web.method.support.InvocableHandlerMethod.invokeForRequest(InvocableHandlerMethod.java:150) + at org.springframework.web.servlet.mvc.method.annotation.ServletInvocableHandlerMethod.invokeAndHandle(ServletInvocableHandlerMethod.java:117) + at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.invokeHandlerMethod(RequestMappingHandlerAdapter.java:895) + at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.handleInternal(RequestMappingHandlerAdapter.java:808) + at org.springframework.web.servlet.mvc.method.AbstractHandlerMethodAdapter.handle(AbstractHandlerMethodAdapter.java:87) + at org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:1067) + at org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:963) + at org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:1006) + at org.springframework.web.servlet.FrameworkServlet.doGet(FrameworkServlet.java:898) + at javax.servlet.http.HttpServlet.service(HttpServlet.java:655) + at org.springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.java:883) + at javax.servlet.http.HttpServlet.service(HttpServlet.java:764) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:227) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:53) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:111) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:111) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at com.dc.common.filter.RepeatableFilter.doFilter(RepeatableFilter.java:35) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:327) + at org.springframework.security.web.access.intercept.FilterSecurityInterceptor.invoke(FilterSecurityInterceptor.java:115) + at org.springframework.security.web.access.intercept.FilterSecurityInterceptor.doFilter(FilterSecurityInterceptor.java:81) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.access.ExceptionTranslationFilter.doFilter(ExceptionTranslationFilter.java:121) + at org.springframework.security.web.access.ExceptionTranslationFilter.doFilter(ExceptionTranslationFilter.java:115) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.session.SessionManagementFilter.doFilter(SessionManagementFilter.java:126) + at org.springframework.security.web.session.SessionManagementFilter.doFilter(SessionManagementFilter.java:81) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.authentication.AnonymousAuthenticationFilter.doFilter(AnonymousAuthenticationFilter.java:105) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.servletapi.SecurityContextHolderAwareRequestFilter.doFilter(SecurityContextHolderAwareRequestFilter.java:149) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.savedrequest.RequestCacheAwareFilter.doFilter(RequestCacheAwareFilter.java:63) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at com.dc.framework.security.filter.JwtAuthenticationTokenFilter.doFilterInternal(JwtAuthenticationTokenFilter.java:43) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:111) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.authentication.logout.LogoutFilter.doFilter(LogoutFilter.java:103) + at org.springframework.security.web.authentication.logout.LogoutFilter.doFilter(LogoutFilter.java:89) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.web.filter.CorsFilter.doFilterInternal(CorsFilter.java:91) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.header.HeaderWriterFilter.doHeadersAfter(HeaderWriterFilter.java:90) + at org.springframework.security.web.header.HeaderWriterFilter.doFilterInternal(HeaderWriterFilter.java:75) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.context.SecurityContextPersistenceFilter.doFilter(SecurityContextPersistenceFilter.java:110) + at org.springframework.security.web.context.SecurityContextPersistenceFilter.doFilter(SecurityContextPersistenceFilter.java:80) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.context.request.async.WebAsyncManagerIntegrationFilter.doFilterInternal(WebAsyncManagerIntegrationFilter.java:55) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.FilterChainProxy.doFilterInternal(FilterChainProxy.java:211) + at org.springframework.security.web.FilterChainProxy.doFilter(FilterChainProxy.java:183) + at org.springframework.web.filter.DelegatingFilterProxy.invokeDelegate(DelegatingFilterProxy.java:354) + at org.springframework.web.filter.DelegatingFilterProxy.doFilter(DelegatingFilterProxy.java:267) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.RequestContextFilter.doFilterInternal(RequestContextFilter.java:100) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.FormContentFilter.doFilterInternal(FormContentFilter.java:93) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.CharacterEncodingFilter.doFilterInternal(CharacterEncodingFilter.java:201) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at com.dc.common.filter.XssFilter.doFilter(XssFilter.java:47) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:197) + at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:97) + at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:541) + at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:135) + at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:92) + at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:78) + at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:360) + at org.apache.coyote.http11.Http11Processor.service(Http11Processor.java:399) + at org.apache.coyote.AbstractProcessorLight.process(AbstractProcessorLight.java:65) + at org.apache.coyote.AbstractProtocol$ConnectionHandler.process(AbstractProtocol.java:890) + at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1743) + at org.apache.tomcat.util.net.SocketProcessorBase.run(SocketProcessorBase.java:49) + at org.apache.tomcat.util.threads.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1191) + at org.apache.tomcat.util.threads.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:659) + at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61) + at java.lang.Thread.run(Thread.java:748) +13:35:15.005 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:35:15.005 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:35:15.512 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:35:16.018 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:35:16.525 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:35:17.031 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:35:17.537 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:35:18.045 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:35:18.552 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:35:19.060 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:35:19.567 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:35:20.074 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:35:20.580 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:35:21.086 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:35:21.591 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:35:22.098 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:35:22.605 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:35:23.111 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:35:23.617 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:35:24.125 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:35:24.630 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:35:25.136 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:35:25.643 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:35:26.150 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:35:26.656 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:35:27.161 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:35:27.666 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:35:28.172 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:35:28.677 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:35:29.182 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:35:29.690 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:35:30.197 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:35:30.703 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:35:31.211 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:35:31.717 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:35:32.226 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:35:32.731 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:35:33.238 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:35:33.743 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:35:34.248 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:35:34.755 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:35:35.263 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:35:35.767 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:35:36.269 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:35:36.778 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:35:37.281 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:35:37.790 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:35:38.298 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:35:38.806 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:35:39.312 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:35:39.819 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:35:40.326 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:35:40.835 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:35:41.338 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:35:41.844 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:35:42.352 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:35:42.859 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:35:43.366 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:35:43.872 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:35:44.379 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:35:44.883 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:35:45.385 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:35:45.892 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:35:46.396 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:35:46.898 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:35:47.401 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:35:47.907 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:35:48.414 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:35:48.919 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:35:49.426 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:35:49.933 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:35:50.439 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:35:50.945 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:35:51.451 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:35:51.958 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:35:52.461 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:35:52.968 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:35:53.474 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:35:53.981 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:35:54.486 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:35:54.992 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:35:55.498 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:35:56.003 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:35:56.509 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:35:57.010 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:35:57.517 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:35:58.020 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:35:58.526 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:35:59.032 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:35:59.538 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:36:00.044 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:36:00.550 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:36:01.051 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:36:01.554 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:36:02.058 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:36:02.559 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:36:03.065 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:36:03.570 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:36:04.074 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:36:04.577 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:36:05.078 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:36:05.580 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:36:06.086 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:36:06.592 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:36:07.098 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:36:07.603 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:36:08.109 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:36:08.615 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:36:09.121 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:36:09.628 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:36:10.133 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:36:10.638 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:36:11.145 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:36:11.651 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:36:12.157 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:36:12.663 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:36:13.169 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:36:13.674 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:36:14.181 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:36:14.686 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:36:15.192 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:36:15.696 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:36:16.202 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:36:16.708 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:36:17.214 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:36:17.718 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:36:18.224 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:36:18.730 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:36:19.236 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:36:19.743 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:36:20.248 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:36:20.755 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:36:21.257 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:36:21.763 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:36:22.268 [Druid-ConnectionPool-Create-970337372] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://localhost:5432/ccwin?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:303) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.ConnectException: Connection refused (Connection refused) + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +13:48:10.536 [restartedMain] ERROR o.s.b.SpringApplication - [reportFailure,870] - Application run failed +org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'sysConfigService': Invocation of init method failed; nested exception is org.springframework.data.redis.RedisConnectionFailureException: Unable to connect to Redis; nested exception is org.springframework.data.redis.connection.PoolException: Could not get a resource from the pool; nested exception is io.lettuce.core.RedisConnectionException: Unable to connect to 10.10.10.55:7000 + at org.springframework.beans.factory.annotation.InitDestroyAnnotationBeanPostProcessor.postProcessBeforeInitialization(InitDestroyAnnotationBeanPostProcessor.java:160) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.applyBeanPostProcessorsBeforeInitialization(AbstractAutowireCapableBeanFactory.java:440) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.initializeBean(AbstractAutowireCapableBeanFactory.java:1796) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:620) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:542) + at org.springframework.beans.factory.support.AbstractBeanFactory.lambda$doGetBean$0(AbstractBeanFactory.java:335) + at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:234) + at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:333) + at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:208) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.preInstantiateSingletons(DefaultListableBeanFactory.java:953) + at org.springframework.context.support.AbstractApplicationContext.finishBeanFactoryInitialization(AbstractApplicationContext.java:918) + at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:583) + at org.springframework.boot.web.servlet.context.ServletWebServerApplicationContext.refresh(ServletWebServerApplicationContext.java:145) + at org.springframework.boot.SpringApplication.refresh(SpringApplication.java:780) + at org.springframework.boot.SpringApplication.refreshContext(SpringApplication.java:453) + at org.springframework.boot.SpringApplication.run(SpringApplication.java:343) + at org.springframework.boot.SpringApplication.run(SpringApplication.java:1370) + at org.springframework.boot.SpringApplication.run(SpringApplication.java:1359) + at com.dc.web.DcApplication.main(DcApplication.java:20) + at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) + at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) + at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) + at java.lang.reflect.Method.invoke(Method.java:498) + at org.springframework.boot.devtools.restart.RestartLauncher.run(RestartLauncher.java:49) +Caused by: org.springframework.data.redis.RedisConnectionFailureException: Unable to connect to Redis; nested exception is org.springframework.data.redis.connection.PoolException: Could not get a resource from the pool; nested exception is io.lettuce.core.RedisConnectionException: Unable to connect to 10.10.10.55:7000 + at org.springframework.data.redis.connection.lettuce.LettuceConnectionFactory$ExceptionTranslatingConnectionProvider.translateException(LettuceConnectionFactory.java:1689) + at org.springframework.data.redis.connection.lettuce.LettuceConnectionFactory$ExceptionTranslatingConnectionProvider.getConnection(LettuceConnectionFactory.java:1597) + at org.springframework.data.redis.connection.lettuce.LettuceConnectionFactory$SharedConnection.getNativeConnection(LettuceConnectionFactory.java:1383) + at org.springframework.data.redis.connection.lettuce.LettuceConnectionFactory$SharedConnection.getConnection(LettuceConnectionFactory.java:1366) + at org.springframework.data.redis.connection.lettuce.LettuceConnectionFactory.getSharedConnection(LettuceConnectionFactory.java:1093) + at org.springframework.data.redis.connection.lettuce.LettuceConnectionFactory.getConnection(LettuceConnectionFactory.java:421) + at org.springframework.data.redis.core.RedisConnectionUtils.fetchConnection(RedisConnectionUtils.java:193) + at org.springframework.data.redis.core.RedisConnectionUtils.doGetConnection(RedisConnectionUtils.java:144) + at org.springframework.data.redis.core.RedisConnectionUtils.getConnection(RedisConnectionUtils.java:105) + at org.springframework.data.redis.core.RedisTemplate.execute(RedisTemplate.java:209) + at org.springframework.data.redis.core.RedisTemplate.execute(RedisTemplate.java:189) + at org.springframework.data.redis.core.AbstractOperations.execute(AbstractOperations.java:96) + at org.springframework.data.redis.core.DefaultValueOperations.set(DefaultValueOperations.java:236) + at com.dc.common.core.redis.RedisCache.setCacheObject(RedisCache.java:34) + at com.dc.system.service.SysConfigService.loadingConfigCache(SysConfigService.java:170) + at com.dc.system.service.SysConfigService.init(SysConfigService.java:39) + at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) + at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) + at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) + at java.lang.reflect.Method.invoke(Method.java:498) + at org.springframework.beans.factory.annotation.InitDestroyAnnotationBeanPostProcessor$LifecycleElement.invoke(InitDestroyAnnotationBeanPostProcessor.java:389) + at org.springframework.beans.factory.annotation.InitDestroyAnnotationBeanPostProcessor$LifecycleMetadata.invokeInitMethods(InitDestroyAnnotationBeanPostProcessor.java:333) + at org.springframework.beans.factory.annotation.InitDestroyAnnotationBeanPostProcessor.postProcessBeforeInitialization(InitDestroyAnnotationBeanPostProcessor.java:157) + ... 23 common frames omitted +Caused by: org.springframework.data.redis.connection.PoolException: Could not get a resource from the pool; nested exception is io.lettuce.core.RedisConnectionException: Unable to connect to 10.10.10.55:7000 + at org.springframework.data.redis.connection.lettuce.LettucePoolingConnectionProvider.getConnection(LettucePoolingConnectionProvider.java:109) + at org.springframework.data.redis.connection.lettuce.LettuceConnectionFactory$ExceptionTranslatingConnectionProvider.getConnection(LettuceConnectionFactory.java:1595) + ... 44 common frames omitted +Caused by: io.lettuce.core.RedisConnectionException: Unable to connect to 10.10.10.55:7000 + at io.lettuce.core.RedisConnectionException.create(RedisConnectionException.java:78) + at io.lettuce.core.RedisConnectionException.create(RedisConnectionException.java:56) + at io.lettuce.core.AbstractRedisClient.getConnection(AbstractRedisClient.java:330) + at io.lettuce.core.RedisClient.connect(RedisClient.java:216) + at org.springframework.data.redis.connection.lettuce.StandaloneConnectionProvider.lambda$getConnection$1(StandaloneConnectionProvider.java:115) + at java.util.Optional.orElseGet(Optional.java:267) + at org.springframework.data.redis.connection.lettuce.StandaloneConnectionProvider.getConnection(StandaloneConnectionProvider.java:115) + at org.springframework.data.redis.connection.lettuce.LettucePoolingConnectionProvider.lambda$null$0(LettucePoolingConnectionProvider.java:97) + at io.lettuce.core.support.ConnectionPoolSupport$RedisPooledObjectFactory.create(ConnectionPoolSupport.java:211) + at io.lettuce.core.support.ConnectionPoolSupport$RedisPooledObjectFactory.create(ConnectionPoolSupport.java:201) + at org.apache.commons.pool2.BasePooledObjectFactory.makeObject(BasePooledObjectFactory.java:58) + at org.apache.commons.pool2.impl.GenericObjectPool.create(GenericObjectPool.java:918) + at org.apache.commons.pool2.impl.GenericObjectPool.borrowObject(GenericObjectPool.java:431) + at org.apache.commons.pool2.impl.GenericObjectPool.borrowObject(GenericObjectPool.java:356) + at io.lettuce.core.support.ConnectionPoolSupport$1.borrowObject(ConnectionPoolSupport.java:122) + at io.lettuce.core.support.ConnectionPoolSupport$1.borrowObject(ConnectionPoolSupport.java:117) + at org.springframework.data.redis.connection.lettuce.LettucePoolingConnectionProvider.getConnection(LettucePoolingConnectionProvider.java:103) + ... 45 common frames omitted +Caused by: io.lettuce.core.RedisCommandExecutionException: NOAUTH HELLO must be called with the client already authenticated, otherwise the HELLO AUTH <user> <pass> option can be used to authenticate the client and select the RESP protocol version at the same time + at io.lettuce.core.internal.ExceptionFactory.createExecutionException(ExceptionFactory.java:147) + at io.lettuce.core.internal.ExceptionFactory.createExecutionException(ExceptionFactory.java:116) + at io.lettuce.core.protocol.AsyncCommand.completeResult(AsyncCommand.java:120) + at io.lettuce.core.protocol.AsyncCommand.complete(AsyncCommand.java:111) + at io.lettuce.core.protocol.CommandHandler.complete(CommandHandler.java:746) + at io.lettuce.core.protocol.CommandHandler.decode(CommandHandler.java:681) + at io.lettuce.core.protocol.CommandHandler.channelRead(CommandHandler.java:598) + at io.netty.channel.AbstractChannelHandlerContext.invokeChannelRead(AbstractChannelHandlerContext.java:379) + at io.netty.channel.AbstractChannelHandlerContext.invokeChannelRead(AbstractChannelHandlerContext.java:365) + at io.netty.channel.AbstractChannelHandlerContext.fireChannelRead(AbstractChannelHandlerContext.java:357) + at io.netty.channel.DefaultChannelPipeline$HeadContext.channelRead(DefaultChannelPipeline.java:1410) + at io.netty.channel.AbstractChannelHandlerContext.invokeChannelRead(AbstractChannelHandlerContext.java:379) + at io.netty.channel.AbstractChannelHandlerContext.invokeChannelRead(AbstractChannelHandlerContext.java:365) + at io.netty.channel.DefaultChannelPipeline.fireChannelRead(DefaultChannelPipeline.java:919) + at io.netty.channel.nio.AbstractNioByteChannel$NioByteUnsafe.read(AbstractNioByteChannel.java:166) + at io.netty.channel.nio.NioEventLoop.processSelectedKey(NioEventLoop.java:722) + at io.netty.channel.nio.NioEventLoop.processSelectedKeysOptimized(NioEventLoop.java:658) + at io.netty.channel.nio.NioEventLoop.processSelectedKeys(NioEventLoop.java:584) + at io.netty.channel.nio.NioEventLoop.run(NioEventLoop.java:496) + at io.netty.util.concurrent.SingleThreadEventExecutor$4.run(SingleThreadEventExecutor.java:995) + at io.netty.util.internal.ThreadExecutorMap$2.run(ThreadExecutorMap.java:74) + at io.netty.util.concurrent.FastThreadLocalRunnable.run(FastThreadLocalRunnable.java:30) + at java.lang.Thread.run(Thread.java:750) +14:01:36.721 [http-nio-9000-exec-6] ERROR c.w.f.w.e.GlobalExceptionHandler - [handleRuntimeException,82] - 请求地址'/getRouters',发生未知异常. +org.springframework.jdbc.BadSqlGrammarException: +### Error querying database. Cause: org.postgresql.util.PSQLException: ERROR: column m.query does not exist + 位置:75 +### The error may exist in file [/Users/longlongxiaogege/work/mengyin/code/lianmei/win/win-system/target/classes/mapper/system/SysMenuMapper.xml] +### The error may involve defaultParameterMap +### The error occurred while setting parameters +### SQL: select distinct m.menu_id, m.parent_id, m.menu_name, m.path, m.component, m.query, m.visible, m.status, nullif(m.perms,'') as perms, m.is_frame, m.is_cache, m.menu_type, m.icon, m.order_num, m.create_time from sys_menu m where m.menu_type in ('M', 'C') and m.status = 0 order by m.parent_id, m.order_num +### Cause: org.postgresql.util.PSQLException: ERROR: column m.query does not exist + 位置:75 +; bad SQL grammar []; nested exception is org.postgresql.util.PSQLException: ERROR: column m.query does not exist + 位置:75 + at org.springframework.jdbc.support.SQLStateSQLExceptionTranslator.doTranslate(SQLStateSQLExceptionTranslator.java:101) + at org.springframework.jdbc.support.AbstractFallbackSQLExceptionTranslator.translate(AbstractFallbackSQLExceptionTranslator.java:70) + at org.springframework.jdbc.support.AbstractFallbackSQLExceptionTranslator.translate(AbstractFallbackSQLExceptionTranslator.java:79) + at org.springframework.jdbc.support.AbstractFallbackSQLExceptionTranslator.translate(AbstractFallbackSQLExceptionTranslator.java:79) + at org.mybatis.spring.MyBatisExceptionTranslator.translateExceptionIfPossible(MyBatisExceptionTranslator.java:91) + at org.mybatis.spring.SqlSessionTemplate$SqlSessionInterceptor.invoke(SqlSessionTemplate.java:441) + at com.sun.proxy.$Proxy114.selectList(Unknown Source) + at org.mybatis.spring.SqlSessionTemplate.selectList(SqlSessionTemplate.java:224) + at com.baomidou.mybatisplus.core.override.MybatisMapperMethod.executeForMany(MybatisMapperMethod.java:166) + at com.baomidou.mybatisplus.core.override.MybatisMapperMethod.execute(MybatisMapperMethod.java:77) + at com.baomidou.mybatisplus.core.override.MybatisMapperProxy$PlainMethodInvoker.invoke(MybatisMapperProxy.java:148) + at com.baomidou.mybatisplus.core.override.MybatisMapperProxy.invoke(MybatisMapperProxy.java:89) + at com.sun.proxy.$Proxy146.selectMenuTreeAll(Unknown Source) + at com.dc.system.service.SysMenuService.selectMenuTreeByUserId(SysMenuService.java:112) + at com.dc.system.service.SysMenuService$$FastClassBySpringCGLIB$$ea5fcea2.invoke(<generated>) + at org.springframework.cglib.proxy.MethodProxy.invoke(MethodProxy.java:218) + at org.springframework.aop.framework.CglibAopProxy.invokeMethod(CglibAopProxy.java:386) + at org.springframework.aop.framework.CglibAopProxy.access$000(CglibAopProxy.java:85) + at org.springframework.aop.framework.CglibAopProxy$DynamicAdvisedInterceptor.intercept(CglibAopProxy.java:704) + at com.dc.system.service.SysMenuService$$EnhancerBySpringCGLIB$$64e9c81c.selectMenuTreeByUserId(<generated>) + at com.dc.web.controller.system.SysLoginController.getRouters(SysLoginController.java:84) + at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) + at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) + at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) + at java.lang.reflect.Method.invoke(Method.java:498) + at org.springframework.web.method.support.InvocableHandlerMethod.doInvoke(InvocableHandlerMethod.java:205) + at org.springframework.web.method.support.InvocableHandlerMethod.invokeForRequest(InvocableHandlerMethod.java:150) + at org.springframework.web.servlet.mvc.method.annotation.ServletInvocableHandlerMethod.invokeAndHandle(ServletInvocableHandlerMethod.java:117) + at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.invokeHandlerMethod(RequestMappingHandlerAdapter.java:895) + at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.handleInternal(RequestMappingHandlerAdapter.java:808) + at org.springframework.web.servlet.mvc.method.AbstractHandlerMethodAdapter.handle(AbstractHandlerMethodAdapter.java:87) + at org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:1067) + at org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:963) + at org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:1006) + at org.springframework.web.servlet.FrameworkServlet.doGet(FrameworkServlet.java:898) + at javax.servlet.http.HttpServlet.service(HttpServlet.java:655) + at org.springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.java:883) + at javax.servlet.http.HttpServlet.service(HttpServlet.java:764) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:227) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:53) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:111) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:111) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at com.dc.common.filter.RepeatableFilter.doFilter(RepeatableFilter.java:35) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:327) + at org.springframework.security.web.access.intercept.FilterSecurityInterceptor.invoke(FilterSecurityInterceptor.java:115) + at org.springframework.security.web.access.intercept.FilterSecurityInterceptor.doFilter(FilterSecurityInterceptor.java:81) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.access.ExceptionTranslationFilter.doFilter(ExceptionTranslationFilter.java:121) + at org.springframework.security.web.access.ExceptionTranslationFilter.doFilter(ExceptionTranslationFilter.java:115) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.session.SessionManagementFilter.doFilter(SessionManagementFilter.java:126) + at org.springframework.security.web.session.SessionManagementFilter.doFilter(SessionManagementFilter.java:81) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.authentication.AnonymousAuthenticationFilter.doFilter(AnonymousAuthenticationFilter.java:105) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.servletapi.SecurityContextHolderAwareRequestFilter.doFilter(SecurityContextHolderAwareRequestFilter.java:149) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.savedrequest.RequestCacheAwareFilter.doFilter(RequestCacheAwareFilter.java:63) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at com.dc.framework.security.filter.JwtAuthenticationTokenFilter.doFilterInternal(JwtAuthenticationTokenFilter.java:43) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:111) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.authentication.logout.LogoutFilter.doFilter(LogoutFilter.java:103) + at org.springframework.security.web.authentication.logout.LogoutFilter.doFilter(LogoutFilter.java:89) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.web.filter.CorsFilter.doFilterInternal(CorsFilter.java:91) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.header.HeaderWriterFilter.doHeadersAfter(HeaderWriterFilter.java:90) + at org.springframework.security.web.header.HeaderWriterFilter.doFilterInternal(HeaderWriterFilter.java:75) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.context.SecurityContextPersistenceFilter.doFilter(SecurityContextPersistenceFilter.java:110) + at org.springframework.security.web.context.SecurityContextPersistenceFilter.doFilter(SecurityContextPersistenceFilter.java:80) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.context.request.async.WebAsyncManagerIntegrationFilter.doFilterInternal(WebAsyncManagerIntegrationFilter.java:55) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.FilterChainProxy.doFilterInternal(FilterChainProxy.java:211) + at org.springframework.security.web.FilterChainProxy.doFilter(FilterChainProxy.java:183) + at org.springframework.web.filter.DelegatingFilterProxy.invokeDelegate(DelegatingFilterProxy.java:354) + at org.springframework.web.filter.DelegatingFilterProxy.doFilter(DelegatingFilterProxy.java:267) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.RequestContextFilter.doFilterInternal(RequestContextFilter.java:100) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.FormContentFilter.doFilterInternal(FormContentFilter.java:93) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.CharacterEncodingFilter.doFilterInternal(CharacterEncodingFilter.java:201) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:197) + at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:97) + at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:541) + at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:135) + at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:92) + at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:78) + at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:360) + at org.apache.coyote.http11.Http11Processor.service(Http11Processor.java:399) + at org.apache.coyote.AbstractProcessorLight.process(AbstractProcessorLight.java:65) + at org.apache.coyote.AbstractProtocol$ConnectionHandler.process(AbstractProtocol.java:890) + at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1743) + at org.apache.tomcat.util.net.SocketProcessorBase.run(SocketProcessorBase.java:49) + at org.apache.tomcat.util.threads.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1191) + at org.apache.tomcat.util.threads.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:659) + at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61) + at java.lang.Thread.run(Thread.java:750) +Caused by: org.postgresql.util.PSQLException: ERROR: column m.query does not exist + 位置:75 + at org.postgresql.core.v3.QueryExecutorImpl.receiveErrorResponse(QueryExecutorImpl.java:2565) + at org.postgresql.core.v3.QueryExecutorImpl.processResults(QueryExecutorImpl.java:2297) + at org.postgresql.core.v3.QueryExecutorImpl.execute(QueryExecutorImpl.java:322) + at org.postgresql.jdbc.PgStatement.executeInternal(PgStatement.java:481) + at org.postgresql.jdbc.PgStatement.execute(PgStatement.java:401) + at org.postgresql.jdbc.PgPreparedStatement.executeWithFlags(PgPreparedStatement.java:164) + at org.postgresql.jdbc.PgPreparedStatement.execute(PgPreparedStatement.java:153) + at com.alibaba.druid.filter.FilterChainImpl.preparedStatement_execute(FilterChainImpl.java:3446) + at com.alibaba.druid.filter.FilterEventAdapter.preparedStatement_execute(FilterEventAdapter.java:434) + at com.alibaba.druid.filter.FilterChainImpl.preparedStatement_execute(FilterChainImpl.java:3444) + at com.alibaba.druid.proxy.jdbc.PreparedStatementProxyImpl.execute(PreparedStatementProxyImpl.java:152) + at com.alibaba.druid.pool.DruidPooledPreparedStatement.execute(DruidPooledPreparedStatement.java:483) + at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) + at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) + at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) + at java.lang.reflect.Method.invoke(Method.java:498) + at org.apache.ibatis.logging.jdbc.PreparedStatementLogger.invoke(PreparedStatementLogger.java:59) + at com.sun.proxy.$Proxy121.execute(Unknown Source) + at org.apache.ibatis.executor.statement.PreparedStatementHandler.query(PreparedStatementHandler.java:64) + at org.apache.ibatis.executor.statement.RoutingStatementHandler.query(RoutingStatementHandler.java:79) + at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) + at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) + at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) + at java.lang.reflect.Method.invoke(Method.java:498) + at org.apache.ibatis.plugin.Plugin.invoke(Plugin.java:64) + at com.sun.proxy.$Proxy119.query(Unknown Source) + at org.apache.ibatis.executor.SimpleExecutor.doQuery(SimpleExecutor.java:63) + at org.apache.ibatis.executor.BaseExecutor.queryFromDatabase(BaseExecutor.java:325) + at org.apache.ibatis.executor.BaseExecutor.query(BaseExecutor.java:156) + at org.apache.ibatis.executor.CachingExecutor.query(CachingExecutor.java:109) + at com.baomidou.mybatisplus.extension.plugins.MybatisPlusInterceptor.intercept(MybatisPlusInterceptor.java:81) + at org.apache.ibatis.plugin.Plugin.invoke(Plugin.java:62) + at com.sun.proxy.$Proxy118.query(Unknown Source) + at com.github.pagehelper.PageInterceptor.intercept(PageInterceptor.java:151) + at org.apache.ibatis.plugin.Plugin.invoke(Plugin.java:62) + at com.sun.proxy.$Proxy118.query(Unknown Source) + at org.apache.ibatis.session.defaults.DefaultSqlSession.selectList(DefaultSqlSession.java:151) + at org.apache.ibatis.session.defaults.DefaultSqlSession.selectList(DefaultSqlSession.java:145) + at org.apache.ibatis.session.defaults.DefaultSqlSession.selectList(DefaultSqlSession.java:140) + at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) + at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) + at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) + at java.lang.reflect.Method.invoke(Method.java:498) + at org.mybatis.spring.SqlSessionTemplate$SqlSessionInterceptor.invoke(SqlSessionTemplate.java:427) + ... 117 common frames omitted +14:08:23.081 [http-nio-9000-exec-11] ERROR c.w.f.w.e.GlobalExceptionHandler - [handleRuntimeException,82] - 请求地址'/getRouters',发生未知异常. +org.springframework.jdbc.BadSqlGrammarException: +### Error querying database. Cause: org.postgresql.util.PSQLException: ERROR: column m.query does not exist + 位置:75 +### The error may exist in file [/Users/longlongxiaogege/work/mengyin/code/lianmei/win/win-system/target/classes/mapper/system/SysMenuMapper.xml] +### The error may involve defaultParameterMap +### The error occurred while setting parameters +### SQL: select distinct m.menu_id, m.parent_id, m.menu_name, m.path, m.component, m.query, m.visible, m.status, nullif(m.perms,'') as perms, m.is_frame, m.is_cache, m.menu_type, m.icon, m.order_num, m.create_time from sys_menu m where m.menu_type in ('M', 'C') and m.status = 0 order by m.parent_id, m.order_num +### Cause: org.postgresql.util.PSQLException: ERROR: column m.query does not exist + 位置:75 +; bad SQL grammar []; nested exception is org.postgresql.util.PSQLException: ERROR: column m.query does not exist + 位置:75 + at org.springframework.jdbc.support.SQLStateSQLExceptionTranslator.doTranslate(SQLStateSQLExceptionTranslator.java:101) + at org.springframework.jdbc.support.AbstractFallbackSQLExceptionTranslator.translate(AbstractFallbackSQLExceptionTranslator.java:70) + at org.springframework.jdbc.support.AbstractFallbackSQLExceptionTranslator.translate(AbstractFallbackSQLExceptionTranslator.java:79) + at org.springframework.jdbc.support.AbstractFallbackSQLExceptionTranslator.translate(AbstractFallbackSQLExceptionTranslator.java:79) + at org.mybatis.spring.MyBatisExceptionTranslator.translateExceptionIfPossible(MyBatisExceptionTranslator.java:91) + at org.mybatis.spring.SqlSessionTemplate$SqlSessionInterceptor.invoke(SqlSessionTemplate.java:441) + at com.sun.proxy.$Proxy114.selectList(Unknown Source) + at org.mybatis.spring.SqlSessionTemplate.selectList(SqlSessionTemplate.java:224) + at com.baomidou.mybatisplus.core.override.MybatisMapperMethod.executeForMany(MybatisMapperMethod.java:166) + at com.baomidou.mybatisplus.core.override.MybatisMapperMethod.execute(MybatisMapperMethod.java:77) + at com.baomidou.mybatisplus.core.override.MybatisMapperProxy$PlainMethodInvoker.invoke(MybatisMapperProxy.java:148) + at com.baomidou.mybatisplus.core.override.MybatisMapperProxy.invoke(MybatisMapperProxy.java:89) + at com.sun.proxy.$Proxy146.selectMenuTreeAll(Unknown Source) + at com.dc.system.service.SysMenuService.selectMenuTreeByUserId(SysMenuService.java:112) + at com.dc.system.service.SysMenuService$$FastClassBySpringCGLIB$$ea5fcea2.invoke(<generated>) + at org.springframework.cglib.proxy.MethodProxy.invoke(MethodProxy.java:218) + at org.springframework.aop.framework.CglibAopProxy.invokeMethod(CglibAopProxy.java:386) + at org.springframework.aop.framework.CglibAopProxy.access$000(CglibAopProxy.java:85) + at org.springframework.aop.framework.CglibAopProxy$DynamicAdvisedInterceptor.intercept(CglibAopProxy.java:704) + at com.dc.system.service.SysMenuService$$EnhancerBySpringCGLIB$$64e9c81c.selectMenuTreeByUserId(<generated>) + at com.dc.web.controller.system.SysLoginController.getRouters(SysLoginController.java:84) + at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) + at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) + at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) + at java.lang.reflect.Method.invoke(Method.java:498) + at org.springframework.web.method.support.InvocableHandlerMethod.doInvoke(InvocableHandlerMethod.java:205) + at org.springframework.web.method.support.InvocableHandlerMethod.invokeForRequest(InvocableHandlerMethod.java:150) + at org.springframework.web.servlet.mvc.method.annotation.ServletInvocableHandlerMethod.invokeAndHandle(ServletInvocableHandlerMethod.java:117) + at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.invokeHandlerMethod(RequestMappingHandlerAdapter.java:895) + at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.handleInternal(RequestMappingHandlerAdapter.java:808) + at org.springframework.web.servlet.mvc.method.AbstractHandlerMethodAdapter.handle(AbstractHandlerMethodAdapter.java:87) + at org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:1067) + at org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:963) + at org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:1006) + at org.springframework.web.servlet.FrameworkServlet.doGet(FrameworkServlet.java:898) + at javax.servlet.http.HttpServlet.service(HttpServlet.java:655) + at org.springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.java:883) + at javax.servlet.http.HttpServlet.service(HttpServlet.java:764) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:227) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:53) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:111) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:111) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at com.dc.common.filter.RepeatableFilter.doFilter(RepeatableFilter.java:35) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:327) + at org.springframework.security.web.access.intercept.FilterSecurityInterceptor.invoke(FilterSecurityInterceptor.java:115) + at org.springframework.security.web.access.intercept.FilterSecurityInterceptor.doFilter(FilterSecurityInterceptor.java:81) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.access.ExceptionTranslationFilter.doFilter(ExceptionTranslationFilter.java:121) + at org.springframework.security.web.access.ExceptionTranslationFilter.doFilter(ExceptionTranslationFilter.java:115) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.session.SessionManagementFilter.doFilter(SessionManagementFilter.java:126) + at org.springframework.security.web.session.SessionManagementFilter.doFilter(SessionManagementFilter.java:81) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.authentication.AnonymousAuthenticationFilter.doFilter(AnonymousAuthenticationFilter.java:105) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.servletapi.SecurityContextHolderAwareRequestFilter.doFilter(SecurityContextHolderAwareRequestFilter.java:149) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.savedrequest.RequestCacheAwareFilter.doFilter(RequestCacheAwareFilter.java:63) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at com.dc.framework.security.filter.JwtAuthenticationTokenFilter.doFilterInternal(JwtAuthenticationTokenFilter.java:43) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:111) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.authentication.logout.LogoutFilter.doFilter(LogoutFilter.java:103) + at org.springframework.security.web.authentication.logout.LogoutFilter.doFilter(LogoutFilter.java:89) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.web.filter.CorsFilter.doFilterInternal(CorsFilter.java:91) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.header.HeaderWriterFilter.doHeadersAfter(HeaderWriterFilter.java:90) + at org.springframework.security.web.header.HeaderWriterFilter.doFilterInternal(HeaderWriterFilter.java:75) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.context.SecurityContextPersistenceFilter.doFilter(SecurityContextPersistenceFilter.java:110) + at org.springframework.security.web.context.SecurityContextPersistenceFilter.doFilter(SecurityContextPersistenceFilter.java:80) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.context.request.async.WebAsyncManagerIntegrationFilter.doFilterInternal(WebAsyncManagerIntegrationFilter.java:55) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.FilterChainProxy.doFilterInternal(FilterChainProxy.java:211) + at org.springframework.security.web.FilterChainProxy.doFilter(FilterChainProxy.java:183) + at org.springframework.web.filter.DelegatingFilterProxy.invokeDelegate(DelegatingFilterProxy.java:354) + at org.springframework.web.filter.DelegatingFilterProxy.doFilter(DelegatingFilterProxy.java:267) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.RequestContextFilter.doFilterInternal(RequestContextFilter.java:100) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.FormContentFilter.doFilterInternal(FormContentFilter.java:93) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.CharacterEncodingFilter.doFilterInternal(CharacterEncodingFilter.java:201) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:197) + at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:97) + at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:541) + at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:135) + at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:92) + at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:78) + at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:360) + at org.apache.coyote.http11.Http11Processor.service(Http11Processor.java:399) + at org.apache.coyote.AbstractProcessorLight.process(AbstractProcessorLight.java:65) + at org.apache.coyote.AbstractProtocol$ConnectionHandler.process(AbstractProtocol.java:890) + at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1743) + at org.apache.tomcat.util.net.SocketProcessorBase.run(SocketProcessorBase.java:49) + at org.apache.tomcat.util.threads.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1191) + at org.apache.tomcat.util.threads.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:659) + at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61) + at java.lang.Thread.run(Thread.java:750) +Caused by: org.postgresql.util.PSQLException: ERROR: column m.query does not exist + 位置:75 + at org.postgresql.core.v3.QueryExecutorImpl.receiveErrorResponse(QueryExecutorImpl.java:2565) + at org.postgresql.core.v3.QueryExecutorImpl.processResults(QueryExecutorImpl.java:2297) + at org.postgresql.core.v3.QueryExecutorImpl.execute(QueryExecutorImpl.java:322) + at org.postgresql.jdbc.PgStatement.executeInternal(PgStatement.java:481) + at org.postgresql.jdbc.PgStatement.execute(PgStatement.java:401) + at org.postgresql.jdbc.PgPreparedStatement.executeWithFlags(PgPreparedStatement.java:164) + at org.postgresql.jdbc.PgPreparedStatement.execute(PgPreparedStatement.java:153) + at com.alibaba.druid.filter.FilterChainImpl.preparedStatement_execute(FilterChainImpl.java:3446) + at com.alibaba.druid.filter.FilterEventAdapter.preparedStatement_execute(FilterEventAdapter.java:434) + at com.alibaba.druid.filter.FilterChainImpl.preparedStatement_execute(FilterChainImpl.java:3444) + at com.alibaba.druid.proxy.jdbc.PreparedStatementProxyImpl.execute(PreparedStatementProxyImpl.java:152) + at com.alibaba.druid.pool.DruidPooledPreparedStatement.execute(DruidPooledPreparedStatement.java:483) + at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) + at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) + at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) + at java.lang.reflect.Method.invoke(Method.java:498) + at org.apache.ibatis.logging.jdbc.PreparedStatementLogger.invoke(PreparedStatementLogger.java:59) + at com.sun.proxy.$Proxy121.execute(Unknown Source) + at org.apache.ibatis.executor.statement.PreparedStatementHandler.query(PreparedStatementHandler.java:64) + at org.apache.ibatis.executor.statement.RoutingStatementHandler.query(RoutingStatementHandler.java:79) + at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) + at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) + at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) + at java.lang.reflect.Method.invoke(Method.java:498) + at org.apache.ibatis.plugin.Plugin.invoke(Plugin.java:64) + at com.sun.proxy.$Proxy119.query(Unknown Source) + at org.apache.ibatis.executor.SimpleExecutor.doQuery(SimpleExecutor.java:63) + at org.apache.ibatis.executor.BaseExecutor.queryFromDatabase(BaseExecutor.java:325) + at org.apache.ibatis.executor.BaseExecutor.query(BaseExecutor.java:156) + at org.apache.ibatis.executor.CachingExecutor.query(CachingExecutor.java:109) + at com.baomidou.mybatisplus.extension.plugins.MybatisPlusInterceptor.intercept(MybatisPlusInterceptor.java:81) + at org.apache.ibatis.plugin.Plugin.invoke(Plugin.java:62) + at com.sun.proxy.$Proxy118.query(Unknown Source) + at com.github.pagehelper.PageInterceptor.intercept(PageInterceptor.java:151) + at org.apache.ibatis.plugin.Plugin.invoke(Plugin.java:62) + at com.sun.proxy.$Proxy118.query(Unknown Source) + at org.apache.ibatis.session.defaults.DefaultSqlSession.selectList(DefaultSqlSession.java:151) + at org.apache.ibatis.session.defaults.DefaultSqlSession.selectList(DefaultSqlSession.java:145) + at org.apache.ibatis.session.defaults.DefaultSqlSession.selectList(DefaultSqlSession.java:140) + at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) + at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) + at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) + at java.lang.reflect.Method.invoke(Method.java:498) + at org.mybatis.spring.SqlSessionTemplate$SqlSessionInterceptor.invoke(SqlSessionTemplate.java:427) + ... 117 common frames omitted +14:19:01.583 [Druid-ConnectionPool-Create-70427675] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://10.10.10.56:5432/luenmeidb?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 3D000 +org.postgresql.util.PSQLException: FATAL: database "luenmeidb" does not exist + at org.postgresql.core.v3.QueryExecutorImpl.receiveErrorResponse(QueryExecutorImpl.java:2565) + at org.postgresql.core.v3.QueryExecutorImpl.readStartupMessages(QueryExecutorImpl.java:2677) + at org.postgresql.core.v3.QueryExecutorImpl.<init>(QueryExecutorImpl.java:147) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:273) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +14:19:01.627 [Druid-ConnectionPool-Create-70427675] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://10.10.10.56:5432/luenmeidb?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 3D000 +org.postgresql.util.PSQLException: FATAL: database "luenmeidb" does not exist + at org.postgresql.core.v3.QueryExecutorImpl.receiveErrorResponse(QueryExecutorImpl.java:2565) + at org.postgresql.core.v3.QueryExecutorImpl.readStartupMessages(QueryExecutorImpl.java:2677) + at org.postgresql.core.v3.QueryExecutorImpl.<init>(QueryExecutorImpl.java:147) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:273) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +14:19:02.206 [Druid-ConnectionPool-Create-70427675] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://10.10.10.56:5432/luenmeidb?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 3D000 +org.postgresql.util.PSQLException: FATAL: database "luenmeidb" does not exist + at org.postgresql.core.v3.QueryExecutorImpl.receiveErrorResponse(QueryExecutorImpl.java:2565) + at org.postgresql.core.v3.QueryExecutorImpl.readStartupMessages(QueryExecutorImpl.java:2677) + at org.postgresql.core.v3.QueryExecutorImpl.<init>(QueryExecutorImpl.java:147) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:273) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +14:19:02.778 [Druid-ConnectionPool-Create-70427675] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://10.10.10.56:5432/luenmeidb?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 3D000 +org.postgresql.util.PSQLException: FATAL: database "luenmeidb" does not exist + at org.postgresql.core.v3.QueryExecutorImpl.receiveErrorResponse(QueryExecutorImpl.java:2565) + at org.postgresql.core.v3.QueryExecutorImpl.readStartupMessages(QueryExecutorImpl.java:2677) + at org.postgresql.core.v3.QueryExecutorImpl.<init>(QueryExecutorImpl.java:147) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:273) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +14:19:03.353 [Druid-ConnectionPool-Create-70427675] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://10.10.10.56:5432/luenmeidb?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 3D000 +org.postgresql.util.PSQLException: FATAL: database "luenmeidb" does not exist + at org.postgresql.core.v3.QueryExecutorImpl.receiveErrorResponse(QueryExecutorImpl.java:2565) + at org.postgresql.core.v3.QueryExecutorImpl.readStartupMessages(QueryExecutorImpl.java:2677) + at org.postgresql.core.v3.QueryExecutorImpl.<init>(QueryExecutorImpl.java:147) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:273) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +14:19:03.934 [Druid-ConnectionPool-Create-70427675] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://10.10.10.56:5432/luenmeidb?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 3D000 +org.postgresql.util.PSQLException: FATAL: database "luenmeidb" does not exist + at org.postgresql.core.v3.QueryExecutorImpl.receiveErrorResponse(QueryExecutorImpl.java:2565) + at org.postgresql.core.v3.QueryExecutorImpl.readStartupMessages(QueryExecutorImpl.java:2677) + at org.postgresql.core.v3.QueryExecutorImpl.<init>(QueryExecutorImpl.java:147) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:273) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +14:19:04.504 [Druid-ConnectionPool-Create-70427675] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://10.10.10.56:5432/luenmeidb?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 3D000 +org.postgresql.util.PSQLException: FATAL: database "luenmeidb" does not exist + at org.postgresql.core.v3.QueryExecutorImpl.receiveErrorResponse(QueryExecutorImpl.java:2565) + at org.postgresql.core.v3.QueryExecutorImpl.readStartupMessages(QueryExecutorImpl.java:2677) + at org.postgresql.core.v3.QueryExecutorImpl.<init>(QueryExecutorImpl.java:147) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:273) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +14:19:05.076 [Druid-ConnectionPool-Create-70427675] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://10.10.10.56:5432/luenmeidb?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 3D000 +org.postgresql.util.PSQLException: FATAL: database "luenmeidb" does not exist + at org.postgresql.core.v3.QueryExecutorImpl.receiveErrorResponse(QueryExecutorImpl.java:2565) + at org.postgresql.core.v3.QueryExecutorImpl.readStartupMessages(QueryExecutorImpl.java:2677) + at org.postgresql.core.v3.QueryExecutorImpl.<init>(QueryExecutorImpl.java:147) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:273) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +14:19:05.647 [Druid-ConnectionPool-Create-70427675] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://10.10.10.56:5432/luenmeidb?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 3D000 +org.postgresql.util.PSQLException: FATAL: database "luenmeidb" does not exist + at org.postgresql.core.v3.QueryExecutorImpl.receiveErrorResponse(QueryExecutorImpl.java:2565) + at org.postgresql.core.v3.QueryExecutorImpl.readStartupMessages(QueryExecutorImpl.java:2677) + at org.postgresql.core.v3.QueryExecutorImpl.<init>(QueryExecutorImpl.java:147) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:273) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +14:19:06.195 [Druid-ConnectionPool-Create-70427675] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://10.10.10.56:5432/luenmeidb?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 3D000 +org.postgresql.util.PSQLException: FATAL: database "luenmeidb" does not exist + at org.postgresql.core.v3.QueryExecutorImpl.receiveErrorResponse(QueryExecutorImpl.java:2565) + at org.postgresql.core.v3.QueryExecutorImpl.readStartupMessages(QueryExecutorImpl.java:2677) + at org.postgresql.core.v3.QueryExecutorImpl.<init>(QueryExecutorImpl.java:147) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:273) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +14:19:06.767 [Druid-ConnectionPool-Create-70427675] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://10.10.10.56:5432/luenmeidb?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 3D000 +org.postgresql.util.PSQLException: FATAL: database "luenmeidb" does not exist + at org.postgresql.core.v3.QueryExecutorImpl.receiveErrorResponse(QueryExecutorImpl.java:2565) + at org.postgresql.core.v3.QueryExecutorImpl.readStartupMessages(QueryExecutorImpl.java:2677) + at org.postgresql.core.v3.QueryExecutorImpl.<init>(QueryExecutorImpl.java:147) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:273) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +14:19:07.365 [Druid-ConnectionPool-Create-70427675] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://10.10.10.56:5432/luenmeidb?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 3D000 +org.postgresql.util.PSQLException: FATAL: database "luenmeidb" does not exist + at org.postgresql.core.v3.QueryExecutorImpl.receiveErrorResponse(QueryExecutorImpl.java:2565) + at org.postgresql.core.v3.QueryExecutorImpl.readStartupMessages(QueryExecutorImpl.java:2677) + at org.postgresql.core.v3.QueryExecutorImpl.<init>(QueryExecutorImpl.java:147) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:273) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +14:19:07.941 [Druid-ConnectionPool-Create-70427675] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://10.10.10.56:5432/luenmeidb?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 3D000 +org.postgresql.util.PSQLException: FATAL: database "luenmeidb" does not exist + at org.postgresql.core.v3.QueryExecutorImpl.receiveErrorResponse(QueryExecutorImpl.java:2565) + at org.postgresql.core.v3.QueryExecutorImpl.readStartupMessages(QueryExecutorImpl.java:2677) + at org.postgresql.core.v3.QueryExecutorImpl.<init>(QueryExecutorImpl.java:147) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:273) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +14:19:08.509 [Druid-ConnectionPool-Create-70427675] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://10.10.10.56:5432/luenmeidb?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 3D000 +org.postgresql.util.PSQLException: FATAL: database "luenmeidb" does not exist + at org.postgresql.core.v3.QueryExecutorImpl.receiveErrorResponse(QueryExecutorImpl.java:2565) + at org.postgresql.core.v3.QueryExecutorImpl.readStartupMessages(QueryExecutorImpl.java:2677) + at org.postgresql.core.v3.QueryExecutorImpl.<init>(QueryExecutorImpl.java:147) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:273) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +14:19:09.062 [Druid-ConnectionPool-Create-70427675] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://10.10.10.56:5432/luenmeidb?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 3D000 +org.postgresql.util.PSQLException: FATAL: database "luenmeidb" does not exist + at org.postgresql.core.v3.QueryExecutorImpl.receiveErrorResponse(QueryExecutorImpl.java:2565) + at org.postgresql.core.v3.QueryExecutorImpl.readStartupMessages(QueryExecutorImpl.java:2677) + at org.postgresql.core.v3.QueryExecutorImpl.<init>(QueryExecutorImpl.java:147) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:273) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +14:19:09.612 [Druid-ConnectionPool-Create-70427675] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://10.10.10.56:5432/luenmeidb?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 3D000 +org.postgresql.util.PSQLException: FATAL: database "luenmeidb" does not exist + at org.postgresql.core.v3.QueryExecutorImpl.receiveErrorResponse(QueryExecutorImpl.java:2565) + at org.postgresql.core.v3.QueryExecutorImpl.readStartupMessages(QueryExecutorImpl.java:2677) + at org.postgresql.core.v3.QueryExecutorImpl.<init>(QueryExecutorImpl.java:147) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:273) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +14:19:10.162 [Druid-ConnectionPool-Create-70427675] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://10.10.10.56:5432/luenmeidb?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 3D000 +org.postgresql.util.PSQLException: FATAL: database "luenmeidb" does not exist + at org.postgresql.core.v3.QueryExecutorImpl.receiveErrorResponse(QueryExecutorImpl.java:2565) + at org.postgresql.core.v3.QueryExecutorImpl.readStartupMessages(QueryExecutorImpl.java:2677) + at org.postgresql.core.v3.QueryExecutorImpl.<init>(QueryExecutorImpl.java:147) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:273) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +14:19:10.722 [Druid-ConnectionPool-Create-70427675] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://10.10.10.56:5432/luenmeidb?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 3D000 +org.postgresql.util.PSQLException: FATAL: database "luenmeidb" does not exist + at org.postgresql.core.v3.QueryExecutorImpl.receiveErrorResponse(QueryExecutorImpl.java:2565) + at org.postgresql.core.v3.QueryExecutorImpl.readStartupMessages(QueryExecutorImpl.java:2677) + at org.postgresql.core.v3.QueryExecutorImpl.<init>(QueryExecutorImpl.java:147) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:273) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +14:19:11.295 [Druid-ConnectionPool-Create-70427675] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://10.10.10.56:5432/luenmeidb?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 3D000 +org.postgresql.util.PSQLException: FATAL: database "luenmeidb" does not exist + at org.postgresql.core.v3.QueryExecutorImpl.receiveErrorResponse(QueryExecutorImpl.java:2565) + at org.postgresql.core.v3.QueryExecutorImpl.readStartupMessages(QueryExecutorImpl.java:2677) + at org.postgresql.core.v3.QueryExecutorImpl.<init>(QueryExecutorImpl.java:147) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:273) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +14:19:11.858 [Druid-ConnectionPool-Create-70427675] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://10.10.10.56:5432/luenmeidb?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 3D000 +org.postgresql.util.PSQLException: FATAL: database "luenmeidb" does not exist + at org.postgresql.core.v3.QueryExecutorImpl.receiveErrorResponse(QueryExecutorImpl.java:2565) + at org.postgresql.core.v3.QueryExecutorImpl.readStartupMessages(QueryExecutorImpl.java:2677) + at org.postgresql.core.v3.QueryExecutorImpl.<init>(QueryExecutorImpl.java:147) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:273) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +14:19:12.418 [Druid-ConnectionPool-Create-70427675] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://10.10.10.56:5432/luenmeidb?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 3D000 +org.postgresql.util.PSQLException: FATAL: database "luenmeidb" does not exist + at org.postgresql.core.v3.QueryExecutorImpl.receiveErrorResponse(QueryExecutorImpl.java:2565) + at org.postgresql.core.v3.QueryExecutorImpl.readStartupMessages(QueryExecutorImpl.java:2677) + at org.postgresql.core.v3.QueryExecutorImpl.<init>(QueryExecutorImpl.java:147) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:273) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +14:19:12.976 [Druid-ConnectionPool-Create-70427675] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://10.10.10.56:5432/luenmeidb?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 3D000 +org.postgresql.util.PSQLException: FATAL: database "luenmeidb" does not exist + at org.postgresql.core.v3.QueryExecutorImpl.receiveErrorResponse(QueryExecutorImpl.java:2565) + at org.postgresql.core.v3.QueryExecutorImpl.readStartupMessages(QueryExecutorImpl.java:2677) + at org.postgresql.core.v3.QueryExecutorImpl.<init>(QueryExecutorImpl.java:147) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:273) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +14:19:13.529 [Druid-ConnectionPool-Create-70427675] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://10.10.10.56:5432/luenmeidb?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 3D000 +org.postgresql.util.PSQLException: FATAL: database "luenmeidb" does not exist + at org.postgresql.core.v3.QueryExecutorImpl.receiveErrorResponse(QueryExecutorImpl.java:2565) + at org.postgresql.core.v3.QueryExecutorImpl.readStartupMessages(QueryExecutorImpl.java:2677) + at org.postgresql.core.v3.QueryExecutorImpl.<init>(QueryExecutorImpl.java:147) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:273) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +14:19:14.093 [Druid-ConnectionPool-Create-70427675] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://10.10.10.56:5432/luenmeidb?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 3D000 +org.postgresql.util.PSQLException: FATAL: database "luenmeidb" does not exist + at org.postgresql.core.v3.QueryExecutorImpl.receiveErrorResponse(QueryExecutorImpl.java:2565) + at org.postgresql.core.v3.QueryExecutorImpl.readStartupMessages(QueryExecutorImpl.java:2677) + at org.postgresql.core.v3.QueryExecutorImpl.<init>(QueryExecutorImpl.java:147) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:273) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +14:19:14.656 [Druid-ConnectionPool-Create-70427675] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://10.10.10.56:5432/luenmeidb?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 3D000 +org.postgresql.util.PSQLException: FATAL: database "luenmeidb" does not exist + at org.postgresql.core.v3.QueryExecutorImpl.receiveErrorResponse(QueryExecutorImpl.java:2565) + at org.postgresql.core.v3.QueryExecutorImpl.readStartupMessages(QueryExecutorImpl.java:2677) + at org.postgresql.core.v3.QueryExecutorImpl.<init>(QueryExecutorImpl.java:147) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:273) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +14:19:15.217 [Druid-ConnectionPool-Create-70427675] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://10.10.10.56:5432/luenmeidb?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 3D000 +org.postgresql.util.PSQLException: FATAL: database "luenmeidb" does not exist + at org.postgresql.core.v3.QueryExecutorImpl.receiveErrorResponse(QueryExecutorImpl.java:2565) + at org.postgresql.core.v3.QueryExecutorImpl.readStartupMessages(QueryExecutorImpl.java:2677) + at org.postgresql.core.v3.QueryExecutorImpl.<init>(QueryExecutorImpl.java:147) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:273) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +14:19:15.839 [Druid-ConnectionPool-Create-70427675] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://10.10.10.56:5432/luenmeidb?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 3D000 +org.postgresql.util.PSQLException: FATAL: database "luenmeidb" does not exist + at org.postgresql.core.v3.QueryExecutorImpl.receiveErrorResponse(QueryExecutorImpl.java:2565) + at org.postgresql.core.v3.QueryExecutorImpl.readStartupMessages(QueryExecutorImpl.java:2677) + at org.postgresql.core.v3.QueryExecutorImpl.<init>(QueryExecutorImpl.java:147) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:273) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +14:19:16.393 [Druid-ConnectionPool-Create-70427675] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://10.10.10.56:5432/luenmeidb?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 3D000 +org.postgresql.util.PSQLException: FATAL: database "luenmeidb" does not exist + at org.postgresql.core.v3.QueryExecutorImpl.receiveErrorResponse(QueryExecutorImpl.java:2565) + at org.postgresql.core.v3.QueryExecutorImpl.readStartupMessages(QueryExecutorImpl.java:2677) + at org.postgresql.core.v3.QueryExecutorImpl.<init>(QueryExecutorImpl.java:147) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:273) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +14:19:16.964 [Druid-ConnectionPool-Create-70427675] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://10.10.10.56:5432/luenmeidb?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 3D000 +org.postgresql.util.PSQLException: FATAL: database "luenmeidb" does not exist + at org.postgresql.core.v3.QueryExecutorImpl.receiveErrorResponse(QueryExecutorImpl.java:2565) + at org.postgresql.core.v3.QueryExecutorImpl.readStartupMessages(QueryExecutorImpl.java:2677) + at org.postgresql.core.v3.QueryExecutorImpl.<init>(QueryExecutorImpl.java:147) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:273) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +14:19:17.530 [Druid-ConnectionPool-Create-70427675] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://10.10.10.56:5432/luenmeidb?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 3D000 +org.postgresql.util.PSQLException: FATAL: database "luenmeidb" does not exist + at org.postgresql.core.v3.QueryExecutorImpl.receiveErrorResponse(QueryExecutorImpl.java:2565) + at org.postgresql.core.v3.QueryExecutorImpl.readStartupMessages(QueryExecutorImpl.java:2677) + at org.postgresql.core.v3.QueryExecutorImpl.<init>(QueryExecutorImpl.java:147) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:273) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +14:19:18.107 [Druid-ConnectionPool-Create-70427675] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://10.10.10.56:5432/luenmeidb?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 3D000 +org.postgresql.util.PSQLException: FATAL: database "luenmeidb" does not exist + at org.postgresql.core.v3.QueryExecutorImpl.receiveErrorResponse(QueryExecutorImpl.java:2565) + at org.postgresql.core.v3.QueryExecutorImpl.readStartupMessages(QueryExecutorImpl.java:2677) + at org.postgresql.core.v3.QueryExecutorImpl.<init>(QueryExecutorImpl.java:147) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:273) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +14:19:18.688 [Druid-ConnectionPool-Create-70427675] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://10.10.10.56:5432/luenmeidb?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 3D000 +org.postgresql.util.PSQLException: FATAL: database "luenmeidb" does not exist + at org.postgresql.core.v3.QueryExecutorImpl.receiveErrorResponse(QueryExecutorImpl.java:2565) + at org.postgresql.core.v3.QueryExecutorImpl.readStartupMessages(QueryExecutorImpl.java:2677) + at org.postgresql.core.v3.QueryExecutorImpl.<init>(QueryExecutorImpl.java:147) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:273) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +14:19:19.240 [Druid-ConnectionPool-Create-70427675] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://10.10.10.56:5432/luenmeidb?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 3D000 +org.postgresql.util.PSQLException: FATAL: database "luenmeidb" does not exist + at org.postgresql.core.v3.QueryExecutorImpl.receiveErrorResponse(QueryExecutorImpl.java:2565) + at org.postgresql.core.v3.QueryExecutorImpl.readStartupMessages(QueryExecutorImpl.java:2677) + at org.postgresql.core.v3.QueryExecutorImpl.<init>(QueryExecutorImpl.java:147) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:273) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +14:19:19.823 [Druid-ConnectionPool-Create-70427675] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://10.10.10.56:5432/luenmeidb?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 3D000 +org.postgresql.util.PSQLException: FATAL: database "luenmeidb" does not exist + at org.postgresql.core.v3.QueryExecutorImpl.receiveErrorResponse(QueryExecutorImpl.java:2565) + at org.postgresql.core.v3.QueryExecutorImpl.readStartupMessages(QueryExecutorImpl.java:2677) + at org.postgresql.core.v3.QueryExecutorImpl.<init>(QueryExecutorImpl.java:147) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:273) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +14:19:20.375 [Druid-ConnectionPool-Create-70427675] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://10.10.10.56:5432/luenmeidb?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 3D000 +org.postgresql.util.PSQLException: FATAL: database "luenmeidb" does not exist + at org.postgresql.core.v3.QueryExecutorImpl.receiveErrorResponse(QueryExecutorImpl.java:2565) + at org.postgresql.core.v3.QueryExecutorImpl.readStartupMessages(QueryExecutorImpl.java:2677) + at org.postgresql.core.v3.QueryExecutorImpl.<init>(QueryExecutorImpl.java:147) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:273) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +14:19:20.949 [Druid-ConnectionPool-Create-70427675] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://10.10.10.56:5432/luenmeidb?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 3D000 +org.postgresql.util.PSQLException: FATAL: database "luenmeidb" does not exist + at org.postgresql.core.v3.QueryExecutorImpl.receiveErrorResponse(QueryExecutorImpl.java:2565) + at org.postgresql.core.v3.QueryExecutorImpl.readStartupMessages(QueryExecutorImpl.java:2677) + at org.postgresql.core.v3.QueryExecutorImpl.<init>(QueryExecutorImpl.java:147) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:273) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +14:19:21.559 [Druid-ConnectionPool-Create-70427675] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://10.10.10.56:5432/luenmeidb?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 3D000 +org.postgresql.util.PSQLException: FATAL: database "luenmeidb" does not exist + at org.postgresql.core.v3.QueryExecutorImpl.receiveErrorResponse(QueryExecutorImpl.java:2565) + at org.postgresql.core.v3.QueryExecutorImpl.readStartupMessages(QueryExecutorImpl.java:2677) + at org.postgresql.core.v3.QueryExecutorImpl.<init>(QueryExecutorImpl.java:147) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:273) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +14:19:22.106 [Druid-ConnectionPool-Create-70427675] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://10.10.10.56:5432/luenmeidb?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 3D000 +org.postgresql.util.PSQLException: FATAL: database "luenmeidb" does not exist + at org.postgresql.core.v3.QueryExecutorImpl.receiveErrorResponse(QueryExecutorImpl.java:2565) + at org.postgresql.core.v3.QueryExecutorImpl.readStartupMessages(QueryExecutorImpl.java:2677) + at org.postgresql.core.v3.QueryExecutorImpl.<init>(QueryExecutorImpl.java:147) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:273) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +14:19:22.650 [Druid-ConnectionPool-Create-70427675] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://10.10.10.56:5432/luenmeidb?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 3D000 +org.postgresql.util.PSQLException: FATAL: database "luenmeidb" does not exist + at org.postgresql.core.v3.QueryExecutorImpl.receiveErrorResponse(QueryExecutorImpl.java:2565) + at org.postgresql.core.v3.QueryExecutorImpl.readStartupMessages(QueryExecutorImpl.java:2677) + at org.postgresql.core.v3.QueryExecutorImpl.<init>(QueryExecutorImpl.java:147) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:273) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +14:19:23.202 [Druid-ConnectionPool-Create-70427675] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://10.10.10.56:5432/luenmeidb?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 3D000 +org.postgresql.util.PSQLException: FATAL: database "luenmeidb" does not exist + at org.postgresql.core.v3.QueryExecutorImpl.receiveErrorResponse(QueryExecutorImpl.java:2565) + at org.postgresql.core.v3.QueryExecutorImpl.readStartupMessages(QueryExecutorImpl.java:2677) + at org.postgresql.core.v3.QueryExecutorImpl.<init>(QueryExecutorImpl.java:147) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:273) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +14:19:23.748 [Druid-ConnectionPool-Create-70427675] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://10.10.10.56:5432/luenmeidb?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 3D000 +org.postgresql.util.PSQLException: FATAL: database "luenmeidb" does not exist + at org.postgresql.core.v3.QueryExecutorImpl.receiveErrorResponse(QueryExecutorImpl.java:2565) + at org.postgresql.core.v3.QueryExecutorImpl.readStartupMessages(QueryExecutorImpl.java:2677) + at org.postgresql.core.v3.QueryExecutorImpl.<init>(QueryExecutorImpl.java:147) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:273) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +14:19:24.325 [Druid-ConnectionPool-Create-70427675] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://10.10.10.56:5432/luenmeidb?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 3D000 +org.postgresql.util.PSQLException: FATAL: database "luenmeidb" does not exist + at org.postgresql.core.v3.QueryExecutorImpl.receiveErrorResponse(QueryExecutorImpl.java:2565) + at org.postgresql.core.v3.QueryExecutorImpl.readStartupMessages(QueryExecutorImpl.java:2677) + at org.postgresql.core.v3.QueryExecutorImpl.<init>(QueryExecutorImpl.java:147) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:273) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +14:19:25.136 [Druid-ConnectionPool-Create-70427675] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://10.10.10.56:5432/luenmeidb?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 3D000 +org.postgresql.util.PSQLException: FATAL: database "luenmeidb" does not exist + at org.postgresql.core.v3.QueryExecutorImpl.receiveErrorResponse(QueryExecutorImpl.java:2565) + at org.postgresql.core.v3.QueryExecutorImpl.readStartupMessages(QueryExecutorImpl.java:2677) + at org.postgresql.core.v3.QueryExecutorImpl.<init>(QueryExecutorImpl.java:147) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:273) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +14:19:25.723 [Druid-ConnectionPool-Create-70427675] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://10.10.10.56:5432/luenmeidb?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 3D000 +org.postgresql.util.PSQLException: FATAL: database "luenmeidb" does not exist + at org.postgresql.core.v3.QueryExecutorImpl.receiveErrorResponse(QueryExecutorImpl.java:2565) + at org.postgresql.core.v3.QueryExecutorImpl.readStartupMessages(QueryExecutorImpl.java:2677) + at org.postgresql.core.v3.QueryExecutorImpl.<init>(QueryExecutorImpl.java:147) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:273) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +14:19:26.279 [Druid-ConnectionPool-Create-70427675] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://10.10.10.56:5432/luenmeidb?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 3D000 +org.postgresql.util.PSQLException: FATAL: database "luenmeidb" does not exist + at org.postgresql.core.v3.QueryExecutorImpl.receiveErrorResponse(QueryExecutorImpl.java:2565) + at org.postgresql.core.v3.QueryExecutorImpl.readStartupMessages(QueryExecutorImpl.java:2677) + at org.postgresql.core.v3.QueryExecutorImpl.<init>(QueryExecutorImpl.java:147) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:273) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +14:19:26.833 [Druid-ConnectionPool-Create-70427675] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://10.10.10.56:5432/luenmeidb?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 3D000 +org.postgresql.util.PSQLException: FATAL: database "luenmeidb" does not exist + at org.postgresql.core.v3.QueryExecutorImpl.receiveErrorResponse(QueryExecutorImpl.java:2565) + at org.postgresql.core.v3.QueryExecutorImpl.readStartupMessages(QueryExecutorImpl.java:2677) + at org.postgresql.core.v3.QueryExecutorImpl.<init>(QueryExecutorImpl.java:147) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:273) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +14:19:27.400 [Druid-ConnectionPool-Create-70427675] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://10.10.10.56:5432/luenmeidb?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 3D000 +org.postgresql.util.PSQLException: FATAL: database "luenmeidb" does not exist + at org.postgresql.core.v3.QueryExecutorImpl.receiveErrorResponse(QueryExecutorImpl.java:2565) + at org.postgresql.core.v3.QueryExecutorImpl.readStartupMessages(QueryExecutorImpl.java:2677) + at org.postgresql.core.v3.QueryExecutorImpl.<init>(QueryExecutorImpl.java:147) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:273) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +14:19:27.982 [Druid-ConnectionPool-Create-70427675] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://10.10.10.56:5432/luenmeidb?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 3D000 +org.postgresql.util.PSQLException: FATAL: database "luenmeidb" does not exist + at org.postgresql.core.v3.QueryExecutorImpl.receiveErrorResponse(QueryExecutorImpl.java:2565) + at org.postgresql.core.v3.QueryExecutorImpl.readStartupMessages(QueryExecutorImpl.java:2677) + at org.postgresql.core.v3.QueryExecutorImpl.<init>(QueryExecutorImpl.java:147) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:273) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +14:19:28.556 [Druid-ConnectionPool-Create-70427675] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://10.10.10.56:5432/luenmeidb?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 3D000 +org.postgresql.util.PSQLException: FATAL: database "luenmeidb" does not exist + at org.postgresql.core.v3.QueryExecutorImpl.receiveErrorResponse(QueryExecutorImpl.java:2565) + at org.postgresql.core.v3.QueryExecutorImpl.readStartupMessages(QueryExecutorImpl.java:2677) + at org.postgresql.core.v3.QueryExecutorImpl.<init>(QueryExecutorImpl.java:147) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:273) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +14:19:29.148 [Druid-ConnectionPool-Create-70427675] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://10.10.10.56:5432/luenmeidb?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 3D000 +org.postgresql.util.PSQLException: FATAL: database "luenmeidb" does not exist + at org.postgresql.core.v3.QueryExecutorImpl.receiveErrorResponse(QueryExecutorImpl.java:2565) + at org.postgresql.core.v3.QueryExecutorImpl.readStartupMessages(QueryExecutorImpl.java:2677) + at org.postgresql.core.v3.QueryExecutorImpl.<init>(QueryExecutorImpl.java:147) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:273) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +14:19:29.722 [Druid-ConnectionPool-Create-70427675] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://10.10.10.56:5432/luenmeidb?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 3D000 +org.postgresql.util.PSQLException: FATAL: database "luenmeidb" does not exist + at org.postgresql.core.v3.QueryExecutorImpl.receiveErrorResponse(QueryExecutorImpl.java:2565) + at org.postgresql.core.v3.QueryExecutorImpl.readStartupMessages(QueryExecutorImpl.java:2677) + at org.postgresql.core.v3.QueryExecutorImpl.<init>(QueryExecutorImpl.java:147) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:273) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +14:19:30.300 [Druid-ConnectionPool-Create-70427675] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://10.10.10.56:5432/luenmeidb?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 3D000 +org.postgresql.util.PSQLException: FATAL: database "luenmeidb" does not exist + at org.postgresql.core.v3.QueryExecutorImpl.receiveErrorResponse(QueryExecutorImpl.java:2565) + at org.postgresql.core.v3.QueryExecutorImpl.readStartupMessages(QueryExecutorImpl.java:2677) + at org.postgresql.core.v3.QueryExecutorImpl.<init>(QueryExecutorImpl.java:147) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:273) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +14:19:30.884 [Druid-ConnectionPool-Create-70427675] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://10.10.10.56:5432/luenmeidb?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 3D000 +org.postgresql.util.PSQLException: FATAL: database "luenmeidb" does not exist + at org.postgresql.core.v3.QueryExecutorImpl.receiveErrorResponse(QueryExecutorImpl.java:2565) + at org.postgresql.core.v3.QueryExecutorImpl.readStartupMessages(QueryExecutorImpl.java:2677) + at org.postgresql.core.v3.QueryExecutorImpl.<init>(QueryExecutorImpl.java:147) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:273) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +14:19:31.459 [Druid-ConnectionPool-Create-70427675] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://10.10.10.56:5432/luenmeidb?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 3D000 +org.postgresql.util.PSQLException: FATAL: database "luenmeidb" does not exist + at org.postgresql.core.v3.QueryExecutorImpl.receiveErrorResponse(QueryExecutorImpl.java:2565) + at org.postgresql.core.v3.QueryExecutorImpl.readStartupMessages(QueryExecutorImpl.java:2677) + at org.postgresql.core.v3.QueryExecutorImpl.<init>(QueryExecutorImpl.java:147) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:273) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +14:19:32.039 [Druid-ConnectionPool-Create-70427675] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://10.10.10.56:5432/luenmeidb?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 3D000 +org.postgresql.util.PSQLException: FATAL: database "luenmeidb" does not exist + at org.postgresql.core.v3.QueryExecutorImpl.receiveErrorResponse(QueryExecutorImpl.java:2565) + at org.postgresql.core.v3.QueryExecutorImpl.readStartupMessages(QueryExecutorImpl.java:2677) + at org.postgresql.core.v3.QueryExecutorImpl.<init>(QueryExecutorImpl.java:147) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:273) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +14:19:32.609 [Druid-ConnectionPool-Create-70427675] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://10.10.10.56:5432/luenmeidb?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 3D000 +org.postgresql.util.PSQLException: FATAL: database "luenmeidb" does not exist + at org.postgresql.core.v3.QueryExecutorImpl.receiveErrorResponse(QueryExecutorImpl.java:2565) + at org.postgresql.core.v3.QueryExecutorImpl.readStartupMessages(QueryExecutorImpl.java:2677) + at org.postgresql.core.v3.QueryExecutorImpl.<init>(QueryExecutorImpl.java:147) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:273) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +14:19:33.178 [Druid-ConnectionPool-Create-70427675] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://10.10.10.56:5432/luenmeidb?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 3D000 +org.postgresql.util.PSQLException: FATAL: database "luenmeidb" does not exist + at org.postgresql.core.v3.QueryExecutorImpl.receiveErrorResponse(QueryExecutorImpl.java:2565) + at org.postgresql.core.v3.QueryExecutorImpl.readStartupMessages(QueryExecutorImpl.java:2677) + at org.postgresql.core.v3.QueryExecutorImpl.<init>(QueryExecutorImpl.java:147) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:273) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +14:19:45.672 [http-nio-9000-exec-2] ERROR c.w.f.w.e.GlobalExceptionHandler - [handleRuntimeException,82] - 请求地址'/getRouters',发生未知异常. +org.apache.ibatis.binding.BindingException: Invalid bound statement (not found): com.dc.system.mapper.SysMenuMapper.selectMenuTreeAll + at org.apache.ibatis.binding.MapperMethod$SqlCommand.<init>(MapperMethod.java:235) + at com.baomidou.mybatisplus.core.override.MybatisMapperMethod.<init>(MybatisMapperMethod.java:50) + at com.baomidou.mybatisplus.core.override.MybatisMapperProxy.lambda$cachedInvoker$0(MybatisMapperProxy.java:111) + at java.util.concurrent.ConcurrentHashMap.computeIfAbsent(ConcurrentHashMap.java:1660) + at com.baomidou.mybatisplus.core.toolkit.CollectionUtils.computeIfAbsent(CollectionUtils.java:115) + at com.baomidou.mybatisplus.core.override.MybatisMapperProxy.cachedInvoker(MybatisMapperProxy.java:98) + at com.baomidou.mybatisplus.core.override.MybatisMapperProxy.invoke(MybatisMapperProxy.java:89) + at com.sun.proxy.$Proxy146.selectMenuTreeAll(Unknown Source) + at com.dc.system.service.SysMenuService.selectMenuTreeByUserId(SysMenuService.java:112) + at com.dc.system.service.SysMenuService$$FastClassBySpringCGLIB$$ea5fcea2.invoke(<generated>) + at org.springframework.cglib.proxy.MethodProxy.invoke(MethodProxy.java:218) + at org.springframework.aop.framework.CglibAopProxy.invokeMethod(CglibAopProxy.java:386) + at org.springframework.aop.framework.CglibAopProxy.access$000(CglibAopProxy.java:85) + at org.springframework.aop.framework.CglibAopProxy$DynamicAdvisedInterceptor.intercept(CglibAopProxy.java:704) + at com.dc.system.service.SysMenuService$$EnhancerBySpringCGLIB$$5ee614bf.selectMenuTreeByUserId(<generated>) + at com.dc.web.controller.system.SysLoginController.getRouters(SysLoginController.java:84) + at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) + at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) + at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) + at java.lang.reflect.Method.invoke(Method.java:498) + at org.springframework.web.method.support.InvocableHandlerMethod.doInvoke(InvocableHandlerMethod.java:205) + at org.springframework.web.method.support.InvocableHandlerMethod.invokeForRequest(InvocableHandlerMethod.java:150) + at org.springframework.web.servlet.mvc.method.annotation.ServletInvocableHandlerMethod.invokeAndHandle(ServletInvocableHandlerMethod.java:117) + at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.invokeHandlerMethod(RequestMappingHandlerAdapter.java:895) + at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.handleInternal(RequestMappingHandlerAdapter.java:808) + at org.springframework.web.servlet.mvc.method.AbstractHandlerMethodAdapter.handle(AbstractHandlerMethodAdapter.java:87) + at org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:1067) + at org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:963) + at org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:1006) + at org.springframework.web.servlet.FrameworkServlet.doGet(FrameworkServlet.java:898) + at javax.servlet.http.HttpServlet.service(HttpServlet.java:655) + at org.springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.java:883) + at javax.servlet.http.HttpServlet.service(HttpServlet.java:764) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:227) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:53) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:111) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:111) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at com.dc.common.filter.RepeatableFilter.doFilter(RepeatableFilter.java:35) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:327) + at org.springframework.security.web.access.intercept.FilterSecurityInterceptor.invoke(FilterSecurityInterceptor.java:115) + at org.springframework.security.web.access.intercept.FilterSecurityInterceptor.doFilter(FilterSecurityInterceptor.java:81) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.access.ExceptionTranslationFilter.doFilter(ExceptionTranslationFilter.java:121) + at org.springframework.security.web.access.ExceptionTranslationFilter.doFilter(ExceptionTranslationFilter.java:115) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.session.SessionManagementFilter.doFilter(SessionManagementFilter.java:126) + at org.springframework.security.web.session.SessionManagementFilter.doFilter(SessionManagementFilter.java:81) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.authentication.AnonymousAuthenticationFilter.doFilter(AnonymousAuthenticationFilter.java:105) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.servletapi.SecurityContextHolderAwareRequestFilter.doFilter(SecurityContextHolderAwareRequestFilter.java:149) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.savedrequest.RequestCacheAwareFilter.doFilter(RequestCacheAwareFilter.java:63) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at com.dc.framework.security.filter.JwtAuthenticationTokenFilter.doFilterInternal(JwtAuthenticationTokenFilter.java:43) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:111) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.authentication.logout.LogoutFilter.doFilter(LogoutFilter.java:103) + at org.springframework.security.web.authentication.logout.LogoutFilter.doFilter(LogoutFilter.java:89) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.web.filter.CorsFilter.doFilterInternal(CorsFilter.java:91) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.header.HeaderWriterFilter.doHeadersAfter(HeaderWriterFilter.java:90) + at org.springframework.security.web.header.HeaderWriterFilter.doFilterInternal(HeaderWriterFilter.java:75) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.context.SecurityContextPersistenceFilter.doFilter(SecurityContextPersistenceFilter.java:110) + at org.springframework.security.web.context.SecurityContextPersistenceFilter.doFilter(SecurityContextPersistenceFilter.java:80) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.context.request.async.WebAsyncManagerIntegrationFilter.doFilterInternal(WebAsyncManagerIntegrationFilter.java:55) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.FilterChainProxy.doFilterInternal(FilterChainProxy.java:211) + at org.springframework.security.web.FilterChainProxy.doFilter(FilterChainProxy.java:183) + at org.springframework.web.filter.DelegatingFilterProxy.invokeDelegate(DelegatingFilterProxy.java:354) + at org.springframework.web.filter.DelegatingFilterProxy.doFilter(DelegatingFilterProxy.java:267) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.RequestContextFilter.doFilterInternal(RequestContextFilter.java:100) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.FormContentFilter.doFilterInternal(FormContentFilter.java:93) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.CharacterEncodingFilter.doFilterInternal(CharacterEncodingFilter.java:201) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:197) + at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:97) + at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:541) + at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:135) + at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:92) + at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:78) + at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:360) + at org.apache.coyote.http11.Http11Processor.service(Http11Processor.java:399) + at org.apache.coyote.AbstractProcessorLight.process(AbstractProcessorLight.java:65) + at org.apache.coyote.AbstractProtocol$ConnectionHandler.process(AbstractProtocol.java:890) + at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1743) + at org.apache.tomcat.util.net.SocketProcessorBase.run(SocketProcessorBase.java:49) + at org.apache.tomcat.util.threads.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1191) + at org.apache.tomcat.util.threads.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:659) + at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61) + at java.lang.Thread.run(Thread.java:750) +14:21:17.758 [http-nio-9000-exec-5] ERROR c.w.f.w.e.GlobalExceptionHandler - [handleRuntimeException,82] - 请求地址'/getRouters',发生未知异常. +org.apache.ibatis.binding.BindingException: Invalid bound statement (not found): com.dc.system.mapper.SysMenuMapper.selectMenuTreeAll + at org.apache.ibatis.binding.MapperMethod$SqlCommand.<init>(MapperMethod.java:235) + at com.baomidou.mybatisplus.core.override.MybatisMapperMethod.<init>(MybatisMapperMethod.java:50) + at com.baomidou.mybatisplus.core.override.MybatisMapperProxy.lambda$cachedInvoker$0(MybatisMapperProxy.java:111) + at java.util.concurrent.ConcurrentHashMap.computeIfAbsent(ConcurrentHashMap.java:1660) + at com.baomidou.mybatisplus.core.toolkit.CollectionUtils.computeIfAbsent(CollectionUtils.java:115) + at com.baomidou.mybatisplus.core.override.MybatisMapperProxy.cachedInvoker(MybatisMapperProxy.java:98) + at com.baomidou.mybatisplus.core.override.MybatisMapperProxy.invoke(MybatisMapperProxy.java:89) + at com.sun.proxy.$Proxy146.selectMenuTreeAll(Unknown Source) + at com.dc.system.service.SysMenuService.selectMenuTreeByUserId(SysMenuService.java:112) + at com.dc.system.service.SysMenuService$$FastClassBySpringCGLIB$$ea5fcea2.invoke(<generated>) + at org.springframework.cglib.proxy.MethodProxy.invoke(MethodProxy.java:218) + at org.springframework.aop.framework.CglibAopProxy.invokeMethod(CglibAopProxy.java:386) + at org.springframework.aop.framework.CglibAopProxy.access$000(CglibAopProxy.java:85) + at org.springframework.aop.framework.CglibAopProxy$DynamicAdvisedInterceptor.intercept(CglibAopProxy.java:704) + at com.dc.system.service.SysMenuService$$EnhancerBySpringCGLIB$$5ee614bf.selectMenuTreeByUserId(<generated>) + at com.dc.web.controller.system.SysLoginController.getRouters(SysLoginController.java:84) + at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) + at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) + at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) + at java.lang.reflect.Method.invoke(Method.java:498) + at org.springframework.web.method.support.InvocableHandlerMethod.doInvoke(InvocableHandlerMethod.java:205) + at org.springframework.web.method.support.InvocableHandlerMethod.invokeForRequest(InvocableHandlerMethod.java:150) + at org.springframework.web.servlet.mvc.method.annotation.ServletInvocableHandlerMethod.invokeAndHandle(ServletInvocableHandlerMethod.java:117) + at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.invokeHandlerMethod(RequestMappingHandlerAdapter.java:895) + at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.handleInternal(RequestMappingHandlerAdapter.java:808) + at org.springframework.web.servlet.mvc.method.AbstractHandlerMethodAdapter.handle(AbstractHandlerMethodAdapter.java:87) + at org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:1067) + at org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:963) + at org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:1006) + at org.springframework.web.servlet.FrameworkServlet.doGet(FrameworkServlet.java:898) + at javax.servlet.http.HttpServlet.service(HttpServlet.java:655) + at org.springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.java:883) + at javax.servlet.http.HttpServlet.service(HttpServlet.java:764) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:227) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:53) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:111) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:111) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at com.dc.common.filter.RepeatableFilter.doFilter(RepeatableFilter.java:35) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:327) + at org.springframework.security.web.access.intercept.FilterSecurityInterceptor.invoke(FilterSecurityInterceptor.java:115) + at org.springframework.security.web.access.intercept.FilterSecurityInterceptor.doFilter(FilterSecurityInterceptor.java:81) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.access.ExceptionTranslationFilter.doFilter(ExceptionTranslationFilter.java:121) + at org.springframework.security.web.access.ExceptionTranslationFilter.doFilter(ExceptionTranslationFilter.java:115) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.session.SessionManagementFilter.doFilter(SessionManagementFilter.java:126) + at org.springframework.security.web.session.SessionManagementFilter.doFilter(SessionManagementFilter.java:81) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.authentication.AnonymousAuthenticationFilter.doFilter(AnonymousAuthenticationFilter.java:105) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.servletapi.SecurityContextHolderAwareRequestFilter.doFilter(SecurityContextHolderAwareRequestFilter.java:149) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.savedrequest.RequestCacheAwareFilter.doFilter(RequestCacheAwareFilter.java:63) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at com.dc.framework.security.filter.JwtAuthenticationTokenFilter.doFilterInternal(JwtAuthenticationTokenFilter.java:43) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:111) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.authentication.logout.LogoutFilter.doFilter(LogoutFilter.java:103) + at org.springframework.security.web.authentication.logout.LogoutFilter.doFilter(LogoutFilter.java:89) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.web.filter.CorsFilter.doFilterInternal(CorsFilter.java:91) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.header.HeaderWriterFilter.doHeadersAfter(HeaderWriterFilter.java:90) + at org.springframework.security.web.header.HeaderWriterFilter.doFilterInternal(HeaderWriterFilter.java:75) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.context.SecurityContextPersistenceFilter.doFilter(SecurityContextPersistenceFilter.java:110) + at org.springframework.security.web.context.SecurityContextPersistenceFilter.doFilter(SecurityContextPersistenceFilter.java:80) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.context.request.async.WebAsyncManagerIntegrationFilter.doFilterInternal(WebAsyncManagerIntegrationFilter.java:55) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.FilterChainProxy.doFilterInternal(FilterChainProxy.java:211) + at org.springframework.security.web.FilterChainProxy.doFilter(FilterChainProxy.java:183) + at org.springframework.web.filter.DelegatingFilterProxy.invokeDelegate(DelegatingFilterProxy.java:354) + at org.springframework.web.filter.DelegatingFilterProxy.doFilter(DelegatingFilterProxy.java:267) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.RequestContextFilter.doFilterInternal(RequestContextFilter.java:100) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.FormContentFilter.doFilterInternal(FormContentFilter.java:93) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.CharacterEncodingFilter.doFilterInternal(CharacterEncodingFilter.java:201) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:197) + at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:97) + at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:541) + at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:135) + at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:92) + at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:78) + at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:360) + at org.apache.coyote.http11.Http11Processor.service(Http11Processor.java:399) + at org.apache.coyote.AbstractProcessorLight.process(AbstractProcessorLight.java:65) + at org.apache.coyote.AbstractProtocol$ConnectionHandler.process(AbstractProtocol.java:890) + at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1743) + at org.apache.tomcat.util.net.SocketProcessorBase.run(SocketProcessorBase.java:49) + at org.apache.tomcat.util.threads.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1191) + at org.apache.tomcat.util.threads.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:659) + at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61) + at java.lang.Thread.run(Thread.java:750) +15:30:19.834 [restartedMain] ERROR o.s.b.SpringApplication - [reportFailure,870] - Application run failed +org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'sysConfigService': Invocation of init method failed; nested exception is org.springframework.data.redis.RedisConnectionFailureException: Unable to connect to Redis; nested exception is org.springframework.data.redis.connection.PoolException: Could not get a resource from the pool; nested exception is io.lettuce.core.RedisConnectionException: Unable to connect to 10.10.10.55:7000 + at org.springframework.beans.factory.annotation.InitDestroyAnnotationBeanPostProcessor.postProcessBeforeInitialization(InitDestroyAnnotationBeanPostProcessor.java:160) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.applyBeanPostProcessorsBeforeInitialization(AbstractAutowireCapableBeanFactory.java:440) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.initializeBean(AbstractAutowireCapableBeanFactory.java:1796) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:620) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:542) + at org.springframework.beans.factory.support.AbstractBeanFactory.lambda$doGetBean$0(AbstractBeanFactory.java:335) + at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:234) + at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:333) + at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:208) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.preInstantiateSingletons(DefaultListableBeanFactory.java:953) + at org.springframework.context.support.AbstractApplicationContext.finishBeanFactoryInitialization(AbstractApplicationContext.java:918) + at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:583) + at org.springframework.boot.web.servlet.context.ServletWebServerApplicationContext.refresh(ServletWebServerApplicationContext.java:145) + at org.springframework.boot.SpringApplication.refresh(SpringApplication.java:780) + at org.springframework.boot.SpringApplication.refreshContext(SpringApplication.java:453) + at org.springframework.boot.SpringApplication.run(SpringApplication.java:343) + at org.springframework.boot.SpringApplication.run(SpringApplication.java:1370) + at org.springframework.boot.SpringApplication.run(SpringApplication.java:1359) + at com.dc.web.DcApplication.main(DcApplication.java:20) + at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) + at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) + at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) + at java.lang.reflect.Method.invoke(Method.java:498) + at org.springframework.boot.devtools.restart.RestartLauncher.run(RestartLauncher.java:49) +Caused by: org.springframework.data.redis.RedisConnectionFailureException: Unable to connect to Redis; nested exception is org.springframework.data.redis.connection.PoolException: Could not get a resource from the pool; nested exception is io.lettuce.core.RedisConnectionException: Unable to connect to 10.10.10.55:7000 + at org.springframework.data.redis.connection.lettuce.LettuceConnectionFactory$ExceptionTranslatingConnectionProvider.translateException(LettuceConnectionFactory.java:1689) + at org.springframework.data.redis.connection.lettuce.LettuceConnectionFactory$ExceptionTranslatingConnectionProvider.getConnection(LettuceConnectionFactory.java:1597) + at org.springframework.data.redis.connection.lettuce.LettuceConnectionFactory$SharedConnection.getNativeConnection(LettuceConnectionFactory.java:1383) + at org.springframework.data.redis.connection.lettuce.LettuceConnectionFactory$SharedConnection.getConnection(LettuceConnectionFactory.java:1366) + at org.springframework.data.redis.connection.lettuce.LettuceConnectionFactory.getSharedConnection(LettuceConnectionFactory.java:1093) + at org.springframework.data.redis.connection.lettuce.LettuceConnectionFactory.getConnection(LettuceConnectionFactory.java:421) + at org.springframework.data.redis.core.RedisConnectionUtils.fetchConnection(RedisConnectionUtils.java:193) + at org.springframework.data.redis.core.RedisConnectionUtils.doGetConnection(RedisConnectionUtils.java:144) + at org.springframework.data.redis.core.RedisConnectionUtils.getConnection(RedisConnectionUtils.java:105) + at org.springframework.data.redis.core.RedisTemplate.execute(RedisTemplate.java:209) + at org.springframework.data.redis.core.RedisTemplate.execute(RedisTemplate.java:189) + at org.springframework.data.redis.core.AbstractOperations.execute(AbstractOperations.java:96) + at org.springframework.data.redis.core.DefaultValueOperations.set(DefaultValueOperations.java:236) + at com.dc.common.core.redis.RedisCache.setCacheObject(RedisCache.java:34) + at com.dc.system.service.SysConfigService.loadingConfigCache(SysConfigService.java:170) + at com.dc.system.service.SysConfigService.init(SysConfigService.java:39) + at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) + at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) + at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) + at java.lang.reflect.Method.invoke(Method.java:498) + at org.springframework.beans.factory.annotation.InitDestroyAnnotationBeanPostProcessor$LifecycleElement.invoke(InitDestroyAnnotationBeanPostProcessor.java:389) + at org.springframework.beans.factory.annotation.InitDestroyAnnotationBeanPostProcessor$LifecycleMetadata.invokeInitMethods(InitDestroyAnnotationBeanPostProcessor.java:333) + at org.springframework.beans.factory.annotation.InitDestroyAnnotationBeanPostProcessor.postProcessBeforeInitialization(InitDestroyAnnotationBeanPostProcessor.java:157) + ... 23 common frames omitted +Caused by: org.springframework.data.redis.connection.PoolException: Could not get a resource from the pool; nested exception is io.lettuce.core.RedisConnectionException: Unable to connect to 10.10.10.55:7000 + at org.springframework.data.redis.connection.lettuce.LettucePoolingConnectionProvider.getConnection(LettucePoolingConnectionProvider.java:109) + at org.springframework.data.redis.connection.lettuce.LettuceConnectionFactory$ExceptionTranslatingConnectionProvider.getConnection(LettuceConnectionFactory.java:1595) + ... 44 common frames omitted +Caused by: io.lettuce.core.RedisConnectionException: Unable to connect to 10.10.10.55:7000 + at io.lettuce.core.RedisConnectionException.create(RedisConnectionException.java:78) + at io.lettuce.core.RedisConnectionException.create(RedisConnectionException.java:56) + at io.lettuce.core.AbstractRedisClient.getConnection(AbstractRedisClient.java:330) + at io.lettuce.core.RedisClient.connect(RedisClient.java:216) + at org.springframework.data.redis.connection.lettuce.StandaloneConnectionProvider.lambda$getConnection$1(StandaloneConnectionProvider.java:115) + at java.util.Optional.orElseGet(Optional.java:267) + at org.springframework.data.redis.connection.lettuce.StandaloneConnectionProvider.getConnection(StandaloneConnectionProvider.java:115) + at org.springframework.data.redis.connection.lettuce.LettucePoolingConnectionProvider.lambda$null$0(LettucePoolingConnectionProvider.java:97) + at io.lettuce.core.support.ConnectionPoolSupport$RedisPooledObjectFactory.create(ConnectionPoolSupport.java:211) + at io.lettuce.core.support.ConnectionPoolSupport$RedisPooledObjectFactory.create(ConnectionPoolSupport.java:201) + at org.apache.commons.pool2.BasePooledObjectFactory.makeObject(BasePooledObjectFactory.java:58) + at org.apache.commons.pool2.impl.GenericObjectPool.create(GenericObjectPool.java:918) + at org.apache.commons.pool2.impl.GenericObjectPool.borrowObject(GenericObjectPool.java:431) + at org.apache.commons.pool2.impl.GenericObjectPool.borrowObject(GenericObjectPool.java:356) + at io.lettuce.core.support.ConnectionPoolSupport$1.borrowObject(ConnectionPoolSupport.java:122) + at io.lettuce.core.support.ConnectionPoolSupport$1.borrowObject(ConnectionPoolSupport.java:117) + at org.springframework.data.redis.connection.lettuce.LettucePoolingConnectionProvider.getConnection(LettucePoolingConnectionProvider.java:103) + ... 45 common frames omitted +Caused by: io.lettuce.core.RedisCommandExecutionException: NOAUTH HELLO must be called with the client already authenticated, otherwise the HELLO AUTH <user> <pass> option can be used to authenticate the client and select the RESP protocol version at the same time + at io.lettuce.core.internal.ExceptionFactory.createExecutionException(ExceptionFactory.java:147) + at io.lettuce.core.internal.ExceptionFactory.createExecutionException(ExceptionFactory.java:116) + at io.lettuce.core.protocol.AsyncCommand.completeResult(AsyncCommand.java:120) + at io.lettuce.core.protocol.AsyncCommand.complete(AsyncCommand.java:111) + at io.lettuce.core.protocol.CommandHandler.complete(CommandHandler.java:746) + at io.lettuce.core.protocol.CommandHandler.decode(CommandHandler.java:681) + at io.lettuce.core.protocol.CommandHandler.channelRead(CommandHandler.java:598) + at io.netty.channel.AbstractChannelHandlerContext.invokeChannelRead(AbstractChannelHandlerContext.java:379) + at io.netty.channel.AbstractChannelHandlerContext.invokeChannelRead(AbstractChannelHandlerContext.java:365) + at io.netty.channel.AbstractChannelHandlerContext.fireChannelRead(AbstractChannelHandlerContext.java:357) + at io.netty.channel.DefaultChannelPipeline$HeadContext.channelRead(DefaultChannelPipeline.java:1410) + at io.netty.channel.AbstractChannelHandlerContext.invokeChannelRead(AbstractChannelHandlerContext.java:379) + at io.netty.channel.AbstractChannelHandlerContext.invokeChannelRead(AbstractChannelHandlerContext.java:365) + at io.netty.channel.DefaultChannelPipeline.fireChannelRead(DefaultChannelPipeline.java:919) + at io.netty.channel.nio.AbstractNioByteChannel$NioByteUnsafe.read(AbstractNioByteChannel.java:166) + at io.netty.channel.nio.NioEventLoop.processSelectedKey(NioEventLoop.java:722) + at io.netty.channel.nio.NioEventLoop.processSelectedKeysOptimized(NioEventLoop.java:658) + at io.netty.channel.nio.NioEventLoop.processSelectedKeys(NioEventLoop.java:584) + at io.netty.channel.nio.NioEventLoop.run(NioEventLoop.java:496) + at io.netty.util.concurrent.SingleThreadEventExecutor$4.run(SingleThreadEventExecutor.java:995) + at io.netty.util.internal.ThreadExecutorMap$2.run(ThreadExecutorMap.java:74) + at io.netty.util.concurrent.FastThreadLocalRunnable.run(FastThreadLocalRunnable.java:30) + at java.lang.Thread.run(Thread.java:750) +17:23:43.186 [restartedMain] ERROR o.s.b.d.LoggingFailureAnalysisReporter - [report,40] - + +*************************** +APPLICATION FAILED TO START +*************************** + +Description: + +Web server failed to start. Port 9000 was already in use. + +Action: + +Identify and stop the process that's listening on port 9000 or configure this application to listen on another port. + +09:50:33.078 [http-nio-9000-exec-6] ERROR c.d.f.w.e.GlobalExceptionHandler - [handleRuntimeException,82] - 请求地址'/captchaImage',发生未知异常. +java.lang.IllegalArgumentException: image == null! + at javax.imageio.ImageTypeSpecifier.createFromRenderedImage(ImageTypeSpecifier.java:925) + at javax.imageio.ImageIO.getWriter(ImageIO.java:1602) + at javax.imageio.ImageIO.write(ImageIO.java:1588) + at com.dc.web.controller.common.CaptchaController.getCode(CaptchaController.java:84) + at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) + at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) + at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) + at java.lang.reflect.Method.invoke(Method.java:498) + at org.springframework.web.method.support.InvocableHandlerMethod.doInvoke(InvocableHandlerMethod.java:205) + at org.springframework.web.method.support.InvocableHandlerMethod.invokeForRequest(InvocableHandlerMethod.java:150) + at org.springframework.web.servlet.mvc.method.annotation.ServletInvocableHandlerMethod.invokeAndHandle(ServletInvocableHandlerMethod.java:117) + at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.invokeHandlerMethod(RequestMappingHandlerAdapter.java:895) + at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.handleInternal(RequestMappingHandlerAdapter.java:808) + at org.springframework.web.servlet.mvc.method.AbstractHandlerMethodAdapter.handle(AbstractHandlerMethodAdapter.java:87) + at org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:1067) + at org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:963) + at org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:1006) + at org.springframework.web.servlet.FrameworkServlet.doGet(FrameworkServlet.java:898) + at javax.servlet.http.HttpServlet.service(HttpServlet.java:655) + at org.springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.java:883) + at javax.servlet.http.HttpServlet.service(HttpServlet.java:764) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:227) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:53) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:111) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:111) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at com.dc.common.filter.RepeatableFilter.doFilter(RepeatableFilter.java:35) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:327) + at org.springframework.security.web.access.intercept.FilterSecurityInterceptor.invoke(FilterSecurityInterceptor.java:115) + at org.springframework.security.web.access.intercept.FilterSecurityInterceptor.doFilter(FilterSecurityInterceptor.java:81) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.access.ExceptionTranslationFilter.doFilter(ExceptionTranslationFilter.java:121) + at org.springframework.security.web.access.ExceptionTranslationFilter.doFilter(ExceptionTranslationFilter.java:115) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.session.SessionManagementFilter.doFilter(SessionManagementFilter.java:126) + at org.springframework.security.web.session.SessionManagementFilter.doFilter(SessionManagementFilter.java:81) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.authentication.AnonymousAuthenticationFilter.doFilter(AnonymousAuthenticationFilter.java:105) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.servletapi.SecurityContextHolderAwareRequestFilter.doFilter(SecurityContextHolderAwareRequestFilter.java:149) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.savedrequest.RequestCacheAwareFilter.doFilter(RequestCacheAwareFilter.java:63) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at com.dc.framework.security.filter.JwtAuthenticationTokenFilter.doFilterInternal(JwtAuthenticationTokenFilter.java:43) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:111) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.authentication.logout.LogoutFilter.doFilter(LogoutFilter.java:103) + at org.springframework.security.web.authentication.logout.LogoutFilter.doFilter(LogoutFilter.java:89) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.web.filter.CorsFilter.doFilterInternal(CorsFilter.java:91) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.header.HeaderWriterFilter.doHeadersAfter(HeaderWriterFilter.java:90) + at org.springframework.security.web.header.HeaderWriterFilter.doFilterInternal(HeaderWriterFilter.java:75) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.context.SecurityContextPersistenceFilter.doFilter(SecurityContextPersistenceFilter.java:110) + at org.springframework.security.web.context.SecurityContextPersistenceFilter.doFilter(SecurityContextPersistenceFilter.java:80) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.context.request.async.WebAsyncManagerIntegrationFilter.doFilterInternal(WebAsyncManagerIntegrationFilter.java:55) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.FilterChainProxy.doFilterInternal(FilterChainProxy.java:211) + at org.springframework.security.web.FilterChainProxy.doFilter(FilterChainProxy.java:183) + at org.springframework.web.filter.DelegatingFilterProxy.invokeDelegate(DelegatingFilterProxy.java:354) + at org.springframework.web.filter.DelegatingFilterProxy.doFilter(DelegatingFilterProxy.java:267) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.RequestContextFilter.doFilterInternal(RequestContextFilter.java:100) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.FormContentFilter.doFilterInternal(FormContentFilter.java:93) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.CharacterEncodingFilter.doFilterInternal(CharacterEncodingFilter.java:201) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:197) + at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:97) + at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:541) + at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:135) + at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:92) + at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:78) + at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:360) + at org.apache.coyote.http11.Http11Processor.service(Http11Processor.java:399) + at org.apache.coyote.AbstractProcessorLight.process(AbstractProcessorLight.java:65) + at org.apache.coyote.AbstractProtocol$ConnectionHandler.process(AbstractProtocol.java:890) + at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1743) + at org.apache.tomcat.util.net.SocketProcessorBase.run(SocketProcessorBase.java:49) + at org.apache.tomcat.util.threads.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1191) + at org.apache.tomcat.util.threads.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:659) + at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61) + at java.lang.Thread.run(Thread.java:750) +09:50:37.028 [http-nio-9000-exec-7] ERROR c.d.f.w.e.GlobalExceptionHandler - [handleRuntimeException,82] - 请求地址'/captchaImage',发生未知异常. +java.lang.IllegalArgumentException: image == null! + at javax.imageio.ImageTypeSpecifier.createFromRenderedImage(ImageTypeSpecifier.java:925) + at javax.imageio.ImageIO.getWriter(ImageIO.java:1602) + at javax.imageio.ImageIO.write(ImageIO.java:1588) + at com.dc.web.controller.common.CaptchaController.getCode(CaptchaController.java:84) + at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) + at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) + at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) + at java.lang.reflect.Method.invoke(Method.java:498) + at org.springframework.web.method.support.InvocableHandlerMethod.doInvoke(InvocableHandlerMethod.java:205) + at org.springframework.web.method.support.InvocableHandlerMethod.invokeForRequest(InvocableHandlerMethod.java:150) + at org.springframework.web.servlet.mvc.method.annotation.ServletInvocableHandlerMethod.invokeAndHandle(ServletInvocableHandlerMethod.java:117) + at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.invokeHandlerMethod(RequestMappingHandlerAdapter.java:895) + at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.handleInternal(RequestMappingHandlerAdapter.java:808) + at org.springframework.web.servlet.mvc.method.AbstractHandlerMethodAdapter.handle(AbstractHandlerMethodAdapter.java:87) + at org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:1067) + at org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:963) + at org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:1006) + at org.springframework.web.servlet.FrameworkServlet.doGet(FrameworkServlet.java:898) + at javax.servlet.http.HttpServlet.service(HttpServlet.java:655) + at org.springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.java:883) + at javax.servlet.http.HttpServlet.service(HttpServlet.java:764) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:227) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:53) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:111) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:111) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at com.dc.common.filter.RepeatableFilter.doFilter(RepeatableFilter.java:35) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:327) + at org.springframework.security.web.access.intercept.FilterSecurityInterceptor.invoke(FilterSecurityInterceptor.java:115) + at org.springframework.security.web.access.intercept.FilterSecurityInterceptor.doFilter(FilterSecurityInterceptor.java:81) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.access.ExceptionTranslationFilter.doFilter(ExceptionTranslationFilter.java:121) + at org.springframework.security.web.access.ExceptionTranslationFilter.doFilter(ExceptionTranslationFilter.java:115) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.session.SessionManagementFilter.doFilter(SessionManagementFilter.java:126) + at org.springframework.security.web.session.SessionManagementFilter.doFilter(SessionManagementFilter.java:81) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.authentication.AnonymousAuthenticationFilter.doFilter(AnonymousAuthenticationFilter.java:105) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.servletapi.SecurityContextHolderAwareRequestFilter.doFilter(SecurityContextHolderAwareRequestFilter.java:149) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.savedrequest.RequestCacheAwareFilter.doFilter(RequestCacheAwareFilter.java:63) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at com.dc.framework.security.filter.JwtAuthenticationTokenFilter.doFilterInternal(JwtAuthenticationTokenFilter.java:43) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:111) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.authentication.logout.LogoutFilter.doFilter(LogoutFilter.java:103) + at org.springframework.security.web.authentication.logout.LogoutFilter.doFilter(LogoutFilter.java:89) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.web.filter.CorsFilter.doFilterInternal(CorsFilter.java:91) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.header.HeaderWriterFilter.doHeadersAfter(HeaderWriterFilter.java:90) + at org.springframework.security.web.header.HeaderWriterFilter.doFilterInternal(HeaderWriterFilter.java:75) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.context.SecurityContextPersistenceFilter.doFilter(SecurityContextPersistenceFilter.java:110) + at org.springframework.security.web.context.SecurityContextPersistenceFilter.doFilter(SecurityContextPersistenceFilter.java:80) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.context.request.async.WebAsyncManagerIntegrationFilter.doFilterInternal(WebAsyncManagerIntegrationFilter.java:55) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.FilterChainProxy.doFilterInternal(FilterChainProxy.java:211) + at org.springframework.security.web.FilterChainProxy.doFilter(FilterChainProxy.java:183) + at org.springframework.web.filter.DelegatingFilterProxy.invokeDelegate(DelegatingFilterProxy.java:354) + at org.springframework.web.filter.DelegatingFilterProxy.doFilter(DelegatingFilterProxy.java:267) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.RequestContextFilter.doFilterInternal(RequestContextFilter.java:100) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.FormContentFilter.doFilterInternal(FormContentFilter.java:93) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.CharacterEncodingFilter.doFilterInternal(CharacterEncodingFilter.java:201) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:197) + at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:97) + at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:541) + at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:135) + at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:92) + at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:78) + at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:360) + at org.apache.coyote.http11.Http11Processor.service(Http11Processor.java:399) + at org.apache.coyote.AbstractProcessorLight.process(AbstractProcessorLight.java:65) + at org.apache.coyote.AbstractProtocol$ConnectionHandler.process(AbstractProtocol.java:890) + at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1743) + at org.apache.tomcat.util.net.SocketProcessorBase.run(SocketProcessorBase.java:49) + at org.apache.tomcat.util.threads.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1191) + at org.apache.tomcat.util.threads.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:659) + at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61) + at java.lang.Thread.run(Thread.java:750) +09:50:59.977 [http-nio-9000-exec-8] ERROR c.d.f.w.e.GlobalExceptionHandler - [handleRuntimeException,82] - 请求地址'/captchaImage',发生未知异常. +java.lang.IllegalArgumentException: image == null! + at javax.imageio.ImageTypeSpecifier.createFromRenderedImage(ImageTypeSpecifier.java:925) + at javax.imageio.ImageIO.getWriter(ImageIO.java:1602) + at javax.imageio.ImageIO.write(ImageIO.java:1588) + at com.dc.web.controller.common.CaptchaController.getCode(CaptchaController.java:84) + at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) + at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) + at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) + at java.lang.reflect.Method.invoke(Method.java:498) + at org.springframework.web.method.support.InvocableHandlerMethod.doInvoke(InvocableHandlerMethod.java:205) + at org.springframework.web.method.support.InvocableHandlerMethod.invokeForRequest(InvocableHandlerMethod.java:150) + at org.springframework.web.servlet.mvc.method.annotation.ServletInvocableHandlerMethod.invokeAndHandle(ServletInvocableHandlerMethod.java:117) + at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.invokeHandlerMethod(RequestMappingHandlerAdapter.java:895) + at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.handleInternal(RequestMappingHandlerAdapter.java:808) + at org.springframework.web.servlet.mvc.method.AbstractHandlerMethodAdapter.handle(AbstractHandlerMethodAdapter.java:87) + at org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:1067) + at org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:963) + at org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:1006) + at org.springframework.web.servlet.FrameworkServlet.doGet(FrameworkServlet.java:898) + at javax.servlet.http.HttpServlet.service(HttpServlet.java:655) + at org.springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.java:883) + at javax.servlet.http.HttpServlet.service(HttpServlet.java:764) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:227) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:53) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:111) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:111) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at com.dc.common.filter.RepeatableFilter.doFilter(RepeatableFilter.java:35) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:327) + at org.springframework.security.web.access.intercept.FilterSecurityInterceptor.invoke(FilterSecurityInterceptor.java:115) + at org.springframework.security.web.access.intercept.FilterSecurityInterceptor.doFilter(FilterSecurityInterceptor.java:81) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.access.ExceptionTranslationFilter.doFilter(ExceptionTranslationFilter.java:121) + at org.springframework.security.web.access.ExceptionTranslationFilter.doFilter(ExceptionTranslationFilter.java:115) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.session.SessionManagementFilter.doFilter(SessionManagementFilter.java:126) + at org.springframework.security.web.session.SessionManagementFilter.doFilter(SessionManagementFilter.java:81) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.authentication.AnonymousAuthenticationFilter.doFilter(AnonymousAuthenticationFilter.java:105) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.servletapi.SecurityContextHolderAwareRequestFilter.doFilter(SecurityContextHolderAwareRequestFilter.java:149) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.savedrequest.RequestCacheAwareFilter.doFilter(RequestCacheAwareFilter.java:63) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at com.dc.framework.security.filter.JwtAuthenticationTokenFilter.doFilterInternal(JwtAuthenticationTokenFilter.java:43) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:111) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.authentication.logout.LogoutFilter.doFilter(LogoutFilter.java:103) + at org.springframework.security.web.authentication.logout.LogoutFilter.doFilter(LogoutFilter.java:89) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.web.filter.CorsFilter.doFilterInternal(CorsFilter.java:91) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.header.HeaderWriterFilter.doHeadersAfter(HeaderWriterFilter.java:90) + at org.springframework.security.web.header.HeaderWriterFilter.doFilterInternal(HeaderWriterFilter.java:75) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.context.SecurityContextPersistenceFilter.doFilter(SecurityContextPersistenceFilter.java:110) + at org.springframework.security.web.context.SecurityContextPersistenceFilter.doFilter(SecurityContextPersistenceFilter.java:80) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.context.request.async.WebAsyncManagerIntegrationFilter.doFilterInternal(WebAsyncManagerIntegrationFilter.java:55) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.FilterChainProxy.doFilterInternal(FilterChainProxy.java:211) + at org.springframework.security.web.FilterChainProxy.doFilter(FilterChainProxy.java:183) + at org.springframework.web.filter.DelegatingFilterProxy.invokeDelegate(DelegatingFilterProxy.java:354) + at org.springframework.web.filter.DelegatingFilterProxy.doFilter(DelegatingFilterProxy.java:267) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.RequestContextFilter.doFilterInternal(RequestContextFilter.java:100) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.FormContentFilter.doFilterInternal(FormContentFilter.java:93) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.CharacterEncodingFilter.doFilterInternal(CharacterEncodingFilter.java:201) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:197) + at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:97) + at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:541) + at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:135) + at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:92) + at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:78) + at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:360) + at org.apache.coyote.http11.Http11Processor.service(Http11Processor.java:399) + at org.apache.coyote.AbstractProcessorLight.process(AbstractProcessorLight.java:65) + at org.apache.coyote.AbstractProtocol$ConnectionHandler.process(AbstractProtocol.java:890) + at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1743) + at org.apache.tomcat.util.net.SocketProcessorBase.run(SocketProcessorBase.java:49) + at org.apache.tomcat.util.threads.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1191) + at org.apache.tomcat.util.threads.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:659) + at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61) + at java.lang.Thread.run(Thread.java:750) +09:51:10.024 [http-nio-9000-exec-9] ERROR c.d.f.w.e.GlobalExceptionHandler - [handleRuntimeException,82] - 请求地址'/captchaImage',发生未知异常. +java.lang.IllegalArgumentException: image == null! + at javax.imageio.ImageTypeSpecifier.createFromRenderedImage(ImageTypeSpecifier.java:925) + at javax.imageio.ImageIO.getWriter(ImageIO.java:1602) + at javax.imageio.ImageIO.write(ImageIO.java:1588) + at com.dc.web.controller.common.CaptchaController.getCode(CaptchaController.java:84) + at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) + at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) + at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) + at java.lang.reflect.Method.invoke(Method.java:498) + at org.springframework.web.method.support.InvocableHandlerMethod.doInvoke(InvocableHandlerMethod.java:205) + at org.springframework.web.method.support.InvocableHandlerMethod.invokeForRequest(InvocableHandlerMethod.java:150) + at org.springframework.web.servlet.mvc.method.annotation.ServletInvocableHandlerMethod.invokeAndHandle(ServletInvocableHandlerMethod.java:117) + at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.invokeHandlerMethod(RequestMappingHandlerAdapter.java:895) + at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.handleInternal(RequestMappingHandlerAdapter.java:808) + at org.springframework.web.servlet.mvc.method.AbstractHandlerMethodAdapter.handle(AbstractHandlerMethodAdapter.java:87) + at org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:1067) + at org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:963) + at org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:1006) + at org.springframework.web.servlet.FrameworkServlet.doGet(FrameworkServlet.java:898) + at javax.servlet.http.HttpServlet.service(HttpServlet.java:655) + at org.springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.java:883) + at javax.servlet.http.HttpServlet.service(HttpServlet.java:764) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:227) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:53) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:111) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:111) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at com.dc.common.filter.RepeatableFilter.doFilter(RepeatableFilter.java:35) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:327) + at org.springframework.security.web.access.intercept.FilterSecurityInterceptor.invoke(FilterSecurityInterceptor.java:115) + at org.springframework.security.web.access.intercept.FilterSecurityInterceptor.doFilter(FilterSecurityInterceptor.java:81) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.access.ExceptionTranslationFilter.doFilter(ExceptionTranslationFilter.java:121) + at org.springframework.security.web.access.ExceptionTranslationFilter.doFilter(ExceptionTranslationFilter.java:115) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.session.SessionManagementFilter.doFilter(SessionManagementFilter.java:126) + at org.springframework.security.web.session.SessionManagementFilter.doFilter(SessionManagementFilter.java:81) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.authentication.AnonymousAuthenticationFilter.doFilter(AnonymousAuthenticationFilter.java:105) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.servletapi.SecurityContextHolderAwareRequestFilter.doFilter(SecurityContextHolderAwareRequestFilter.java:149) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.savedrequest.RequestCacheAwareFilter.doFilter(RequestCacheAwareFilter.java:63) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at com.dc.framework.security.filter.JwtAuthenticationTokenFilter.doFilterInternal(JwtAuthenticationTokenFilter.java:43) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:111) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.authentication.logout.LogoutFilter.doFilter(LogoutFilter.java:103) + at org.springframework.security.web.authentication.logout.LogoutFilter.doFilter(LogoutFilter.java:89) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.web.filter.CorsFilter.doFilterInternal(CorsFilter.java:91) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.header.HeaderWriterFilter.doHeadersAfter(HeaderWriterFilter.java:90) + at org.springframework.security.web.header.HeaderWriterFilter.doFilterInternal(HeaderWriterFilter.java:75) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.context.SecurityContextPersistenceFilter.doFilter(SecurityContextPersistenceFilter.java:110) + at org.springframework.security.web.context.SecurityContextPersistenceFilter.doFilter(SecurityContextPersistenceFilter.java:80) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.context.request.async.WebAsyncManagerIntegrationFilter.doFilterInternal(WebAsyncManagerIntegrationFilter.java:55) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.FilterChainProxy.doFilterInternal(FilterChainProxy.java:211) + at org.springframework.security.web.FilterChainProxy.doFilter(FilterChainProxy.java:183) + at org.springframework.web.filter.DelegatingFilterProxy.invokeDelegate(DelegatingFilterProxy.java:354) + at org.springframework.web.filter.DelegatingFilterProxy.doFilter(DelegatingFilterProxy.java:267) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.RequestContextFilter.doFilterInternal(RequestContextFilter.java:100) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.FormContentFilter.doFilterInternal(FormContentFilter.java:93) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.CharacterEncodingFilter.doFilterInternal(CharacterEncodingFilter.java:201) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:197) + at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:97) + at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:541) + at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:135) + at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:92) + at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:78) + at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:360) + at org.apache.coyote.http11.Http11Processor.service(Http11Processor.java:399) + at org.apache.coyote.AbstractProcessorLight.process(AbstractProcessorLight.java:65) + at org.apache.coyote.AbstractProtocol$ConnectionHandler.process(AbstractProtocol.java:890) + at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1743) + at org.apache.tomcat.util.net.SocketProcessorBase.run(SocketProcessorBase.java:49) + at org.apache.tomcat.util.threads.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1191) + at org.apache.tomcat.util.threads.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:659) + at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61) + at java.lang.Thread.run(Thread.java:750) +09:51:10.101 [http-nio-9000-exec-10] ERROR c.d.f.w.e.GlobalExceptionHandler - [handleRuntimeException,82] - 请求地址'/captchaImage',发生未知异常. +java.lang.IllegalArgumentException: image == null! + at javax.imageio.ImageTypeSpecifier.createFromRenderedImage(ImageTypeSpecifier.java:925) + at javax.imageio.ImageIO.getWriter(ImageIO.java:1602) + at javax.imageio.ImageIO.write(ImageIO.java:1588) + at com.dc.web.controller.common.CaptchaController.getCode(CaptchaController.java:84) + at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) + at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) + at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) + at java.lang.reflect.Method.invoke(Method.java:498) + at org.springframework.web.method.support.InvocableHandlerMethod.doInvoke(InvocableHandlerMethod.java:205) + at org.springframework.web.method.support.InvocableHandlerMethod.invokeForRequest(InvocableHandlerMethod.java:150) + at org.springframework.web.servlet.mvc.method.annotation.ServletInvocableHandlerMethod.invokeAndHandle(ServletInvocableHandlerMethod.java:117) + at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.invokeHandlerMethod(RequestMappingHandlerAdapter.java:895) + at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.handleInternal(RequestMappingHandlerAdapter.java:808) + at org.springframework.web.servlet.mvc.method.AbstractHandlerMethodAdapter.handle(AbstractHandlerMethodAdapter.java:87) + at org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:1067) + at org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:963) + at org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:1006) + at org.springframework.web.servlet.FrameworkServlet.doGet(FrameworkServlet.java:898) + at javax.servlet.http.HttpServlet.service(HttpServlet.java:655) + at org.springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.java:883) + at javax.servlet.http.HttpServlet.service(HttpServlet.java:764) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:227) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:53) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:111) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:111) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at com.dc.common.filter.RepeatableFilter.doFilter(RepeatableFilter.java:35) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:327) + at org.springframework.security.web.access.intercept.FilterSecurityInterceptor.invoke(FilterSecurityInterceptor.java:115) + at org.springframework.security.web.access.intercept.FilterSecurityInterceptor.doFilter(FilterSecurityInterceptor.java:81) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.access.ExceptionTranslationFilter.doFilter(ExceptionTranslationFilter.java:121) + at org.springframework.security.web.access.ExceptionTranslationFilter.doFilter(ExceptionTranslationFilter.java:115) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.session.SessionManagementFilter.doFilter(SessionManagementFilter.java:126) + at org.springframework.security.web.session.SessionManagementFilter.doFilter(SessionManagementFilter.java:81) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.authentication.AnonymousAuthenticationFilter.doFilter(AnonymousAuthenticationFilter.java:105) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.servletapi.SecurityContextHolderAwareRequestFilter.doFilter(SecurityContextHolderAwareRequestFilter.java:149) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.savedrequest.RequestCacheAwareFilter.doFilter(RequestCacheAwareFilter.java:63) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at com.dc.framework.security.filter.JwtAuthenticationTokenFilter.doFilterInternal(JwtAuthenticationTokenFilter.java:43) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:111) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.authentication.logout.LogoutFilter.doFilter(LogoutFilter.java:103) + at org.springframework.security.web.authentication.logout.LogoutFilter.doFilter(LogoutFilter.java:89) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.web.filter.CorsFilter.doFilterInternal(CorsFilter.java:91) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.header.HeaderWriterFilter.doHeadersAfter(HeaderWriterFilter.java:90) + at org.springframework.security.web.header.HeaderWriterFilter.doFilterInternal(HeaderWriterFilter.java:75) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.context.SecurityContextPersistenceFilter.doFilter(SecurityContextPersistenceFilter.java:110) + at org.springframework.security.web.context.SecurityContextPersistenceFilter.doFilter(SecurityContextPersistenceFilter.java:80) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.context.request.async.WebAsyncManagerIntegrationFilter.doFilterInternal(WebAsyncManagerIntegrationFilter.java:55) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.FilterChainProxy.doFilterInternal(FilterChainProxy.java:211) + at org.springframework.security.web.FilterChainProxy.doFilter(FilterChainProxy.java:183) + at org.springframework.web.filter.DelegatingFilterProxy.invokeDelegate(DelegatingFilterProxy.java:354) + at org.springframework.web.filter.DelegatingFilterProxy.doFilter(DelegatingFilterProxy.java:267) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.RequestContextFilter.doFilterInternal(RequestContextFilter.java:100) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.FormContentFilter.doFilterInternal(FormContentFilter.java:93) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.CharacterEncodingFilter.doFilterInternal(CharacterEncodingFilter.java:201) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:197) + at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:97) + at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:541) + at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:135) + at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:92) + at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:78) + at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:360) + at org.apache.coyote.http11.Http11Processor.service(Http11Processor.java:399) + at org.apache.coyote.AbstractProcessorLight.process(AbstractProcessorLight.java:65) + at org.apache.coyote.AbstractProtocol$ConnectionHandler.process(AbstractProtocol.java:890) + at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1743) + at org.apache.tomcat.util.net.SocketProcessorBase.run(SocketProcessorBase.java:49) + at org.apache.tomcat.util.threads.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1191) + at org.apache.tomcat.util.threads.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:659) + at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61) + at java.lang.Thread.run(Thread.java:750) +09:53:25.655 [http-nio-9000-exec-12] ERROR c.d.f.w.e.GlobalExceptionHandler - [handleRuntimeException,82] - 请求地址'/captchaImage',发生未知异常. +java.lang.IllegalArgumentException: image == null! + at javax.imageio.ImageTypeSpecifier.createFromRenderedImage(ImageTypeSpecifier.java:925) + at javax.imageio.ImageIO.getWriter(ImageIO.java:1602) + at javax.imageio.ImageIO.write(ImageIO.java:1588) + at com.dc.web.controller.common.CaptchaController.getCode(CaptchaController.java:84) + at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) + at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) + at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) + at java.lang.reflect.Method.invoke(Method.java:498) + at org.springframework.web.method.support.InvocableHandlerMethod.doInvoke(InvocableHandlerMethod.java:205) + at org.springframework.web.method.support.InvocableHandlerMethod.invokeForRequest(InvocableHandlerMethod.java:150) + at org.springframework.web.servlet.mvc.method.annotation.ServletInvocableHandlerMethod.invokeAndHandle(ServletInvocableHandlerMethod.java:117) + at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.invokeHandlerMethod(RequestMappingHandlerAdapter.java:895) + at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.handleInternal(RequestMappingHandlerAdapter.java:808) + at org.springframework.web.servlet.mvc.method.AbstractHandlerMethodAdapter.handle(AbstractHandlerMethodAdapter.java:87) + at org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:1067) + at org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:963) + at org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:1006) + at org.springframework.web.servlet.FrameworkServlet.doGet(FrameworkServlet.java:898) + at javax.servlet.http.HttpServlet.service(HttpServlet.java:655) + at org.springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.java:883) + at javax.servlet.http.HttpServlet.service(HttpServlet.java:764) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:227) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:53) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:111) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:111) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at com.dc.common.filter.RepeatableFilter.doFilter(RepeatableFilter.java:35) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:327) + at org.springframework.security.web.access.intercept.FilterSecurityInterceptor.invoke(FilterSecurityInterceptor.java:115) + at org.springframework.security.web.access.intercept.FilterSecurityInterceptor.doFilter(FilterSecurityInterceptor.java:81) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.access.ExceptionTranslationFilter.doFilter(ExceptionTranslationFilter.java:121) + at org.springframework.security.web.access.ExceptionTranslationFilter.doFilter(ExceptionTranslationFilter.java:115) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.session.SessionManagementFilter.doFilter(SessionManagementFilter.java:126) + at org.springframework.security.web.session.SessionManagementFilter.doFilter(SessionManagementFilter.java:81) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.authentication.AnonymousAuthenticationFilter.doFilter(AnonymousAuthenticationFilter.java:105) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.servletapi.SecurityContextHolderAwareRequestFilter.doFilter(SecurityContextHolderAwareRequestFilter.java:149) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.savedrequest.RequestCacheAwareFilter.doFilter(RequestCacheAwareFilter.java:63) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at com.dc.framework.security.filter.JwtAuthenticationTokenFilter.doFilterInternal(JwtAuthenticationTokenFilter.java:43) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:111) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.authentication.logout.LogoutFilter.doFilter(LogoutFilter.java:103) + at org.springframework.security.web.authentication.logout.LogoutFilter.doFilter(LogoutFilter.java:89) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.web.filter.CorsFilter.doFilterInternal(CorsFilter.java:91) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.header.HeaderWriterFilter.doHeadersAfter(HeaderWriterFilter.java:90) + at org.springframework.security.web.header.HeaderWriterFilter.doFilterInternal(HeaderWriterFilter.java:75) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.context.SecurityContextPersistenceFilter.doFilter(SecurityContextPersistenceFilter.java:110) + at org.springframework.security.web.context.SecurityContextPersistenceFilter.doFilter(SecurityContextPersistenceFilter.java:80) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.context.request.async.WebAsyncManagerIntegrationFilter.doFilterInternal(WebAsyncManagerIntegrationFilter.java:55) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.FilterChainProxy.doFilterInternal(FilterChainProxy.java:211) + at org.springframework.security.web.FilterChainProxy.doFilter(FilterChainProxy.java:183) + at org.springframework.web.filter.DelegatingFilterProxy.invokeDelegate(DelegatingFilterProxy.java:354) + at org.springframework.web.filter.DelegatingFilterProxy.doFilter(DelegatingFilterProxy.java:267) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.RequestContextFilter.doFilterInternal(RequestContextFilter.java:100) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.FormContentFilter.doFilterInternal(FormContentFilter.java:93) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.CharacterEncodingFilter.doFilterInternal(CharacterEncodingFilter.java:201) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:197) + at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:97) + at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:541) + at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:135) + at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:92) + at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:78) + at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:360) + at org.apache.coyote.http11.Http11Processor.service(Http11Processor.java:399) + at org.apache.coyote.AbstractProcessorLight.process(AbstractProcessorLight.java:65) + at org.apache.coyote.AbstractProtocol$ConnectionHandler.process(AbstractProtocol.java:890) + at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1743) + at org.apache.tomcat.util.net.SocketProcessorBase.run(SocketProcessorBase.java:49) + at org.apache.tomcat.util.threads.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1191) + at org.apache.tomcat.util.threads.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:659) + at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61) + at java.lang.Thread.run(Thread.java:750) +11:09:16.676 [http-nio-9000-exec-2] ERROR c.d.f.w.e.GlobalExceptionHandler - [handleRuntimeException,82] - 请求地址'/captchaImage',发生未知异常. +java.lang.IllegalArgumentException: image == null! + at javax.imageio.ImageTypeSpecifier.createFromRenderedImage(ImageTypeSpecifier.java:925) + at javax.imageio.ImageIO.getWriter(ImageIO.java:1602) + at javax.imageio.ImageIO.write(ImageIO.java:1588) + at com.dc.web.controller.common.CaptchaController.getCode(CaptchaController.java:84) + at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) + at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) + at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) + at java.lang.reflect.Method.invoke(Method.java:498) + at org.springframework.web.method.support.InvocableHandlerMethod.doInvoke(InvocableHandlerMethod.java:205) + at org.springframework.web.method.support.InvocableHandlerMethod.invokeForRequest(InvocableHandlerMethod.java:150) + at org.springframework.web.servlet.mvc.method.annotation.ServletInvocableHandlerMethod.invokeAndHandle(ServletInvocableHandlerMethod.java:117) + at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.invokeHandlerMethod(RequestMappingHandlerAdapter.java:895) + at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.handleInternal(RequestMappingHandlerAdapter.java:808) + at org.springframework.web.servlet.mvc.method.AbstractHandlerMethodAdapter.handle(AbstractHandlerMethodAdapter.java:87) + at org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:1067) + at org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:963) + at org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:1006) + at org.springframework.web.servlet.FrameworkServlet.doGet(FrameworkServlet.java:898) + at javax.servlet.http.HttpServlet.service(HttpServlet.java:655) + at org.springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.java:883) + at javax.servlet.http.HttpServlet.service(HttpServlet.java:764) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:227) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:53) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:111) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:111) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at com.dc.common.filter.RepeatableFilter.doFilter(RepeatableFilter.java:35) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:327) + at org.springframework.security.web.access.intercept.FilterSecurityInterceptor.invoke(FilterSecurityInterceptor.java:115) + at org.springframework.security.web.access.intercept.FilterSecurityInterceptor.doFilter(FilterSecurityInterceptor.java:81) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.access.ExceptionTranslationFilter.doFilter(ExceptionTranslationFilter.java:121) + at org.springframework.security.web.access.ExceptionTranslationFilter.doFilter(ExceptionTranslationFilter.java:115) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.session.SessionManagementFilter.doFilter(SessionManagementFilter.java:126) + at org.springframework.security.web.session.SessionManagementFilter.doFilter(SessionManagementFilter.java:81) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.authentication.AnonymousAuthenticationFilter.doFilter(AnonymousAuthenticationFilter.java:105) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.servletapi.SecurityContextHolderAwareRequestFilter.doFilter(SecurityContextHolderAwareRequestFilter.java:149) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.savedrequest.RequestCacheAwareFilter.doFilter(RequestCacheAwareFilter.java:63) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at com.dc.framework.security.filter.JwtAuthenticationTokenFilter.doFilterInternal(JwtAuthenticationTokenFilter.java:43) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:111) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.authentication.logout.LogoutFilter.doFilter(LogoutFilter.java:103) + at org.springframework.security.web.authentication.logout.LogoutFilter.doFilter(LogoutFilter.java:89) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.web.filter.CorsFilter.doFilterInternal(CorsFilter.java:91) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.header.HeaderWriterFilter.doHeadersAfter(HeaderWriterFilter.java:90) + at org.springframework.security.web.header.HeaderWriterFilter.doFilterInternal(HeaderWriterFilter.java:75) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.context.SecurityContextPersistenceFilter.doFilter(SecurityContextPersistenceFilter.java:110) + at org.springframework.security.web.context.SecurityContextPersistenceFilter.doFilter(SecurityContextPersistenceFilter.java:80) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.context.request.async.WebAsyncManagerIntegrationFilter.doFilterInternal(WebAsyncManagerIntegrationFilter.java:55) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.FilterChainProxy.doFilterInternal(FilterChainProxy.java:211) + at org.springframework.security.web.FilterChainProxy.doFilter(FilterChainProxy.java:183) + at org.springframework.web.filter.DelegatingFilterProxy.invokeDelegate(DelegatingFilterProxy.java:354) + at org.springframework.web.filter.DelegatingFilterProxy.doFilter(DelegatingFilterProxy.java:267) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.RequestContextFilter.doFilterInternal(RequestContextFilter.java:100) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.FormContentFilter.doFilterInternal(FormContentFilter.java:93) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.CharacterEncodingFilter.doFilterInternal(CharacterEncodingFilter.java:201) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:197) + at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:97) + at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:541) + at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:135) + at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:92) + at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:78) + at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:360) + at org.apache.coyote.http11.Http11Processor.service(Http11Processor.java:399) + at org.apache.coyote.AbstractProcessorLight.process(AbstractProcessorLight.java:65) + at org.apache.coyote.AbstractProtocol$ConnectionHandler.process(AbstractProtocol.java:890) + at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1743) + at org.apache.tomcat.util.net.SocketProcessorBase.run(SocketProcessorBase.java:49) + at org.apache.tomcat.util.threads.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1191) + at org.apache.tomcat.util.threads.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:659) + at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61) + at java.lang.Thread.run(Thread.java:750) +11:18:02.866 [http-nio-9000-exec-1] ERROR c.d.f.w.e.GlobalExceptionHandler - [handleRuntimeException,82] - 请求地址'/captchaImage',发生未知异常. +java.lang.IllegalArgumentException: image == null! + at javax.imageio.ImageTypeSpecifier.createFromRenderedImage(ImageTypeSpecifier.java:925) + at javax.imageio.ImageIO.getWriter(ImageIO.java:1602) + at javax.imageio.ImageIO.write(ImageIO.java:1588) + at com.dc.web.controller.common.CaptchaController.getCode(CaptchaController.java:84) + at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) + at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) + at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) + at java.lang.reflect.Method.invoke(Method.java:498) + at org.springframework.web.method.support.InvocableHandlerMethod.doInvoke(InvocableHandlerMethod.java:205) + at org.springframework.web.method.support.InvocableHandlerMethod.invokeForRequest(InvocableHandlerMethod.java:150) + at org.springframework.web.servlet.mvc.method.annotation.ServletInvocableHandlerMethod.invokeAndHandle(ServletInvocableHandlerMethod.java:117) + at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.invokeHandlerMethod(RequestMappingHandlerAdapter.java:895) + at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.handleInternal(RequestMappingHandlerAdapter.java:808) + at org.springframework.web.servlet.mvc.method.AbstractHandlerMethodAdapter.handle(AbstractHandlerMethodAdapter.java:87) + at org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:1067) + at org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:963) + at org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:1006) + at org.springframework.web.servlet.FrameworkServlet.doGet(FrameworkServlet.java:898) + at javax.servlet.http.HttpServlet.service(HttpServlet.java:655) + at org.springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.java:883) + at javax.servlet.http.HttpServlet.service(HttpServlet.java:764) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:227) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:53) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:111) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:111) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at com.dc.common.filter.RepeatableFilter.doFilter(RepeatableFilter.java:35) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:327) + at org.springframework.security.web.access.intercept.FilterSecurityInterceptor.invoke(FilterSecurityInterceptor.java:115) + at org.springframework.security.web.access.intercept.FilterSecurityInterceptor.doFilter(FilterSecurityInterceptor.java:81) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.access.ExceptionTranslationFilter.doFilter(ExceptionTranslationFilter.java:121) + at org.springframework.security.web.access.ExceptionTranslationFilter.doFilter(ExceptionTranslationFilter.java:115) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.session.SessionManagementFilter.doFilter(SessionManagementFilter.java:126) + at org.springframework.security.web.session.SessionManagementFilter.doFilter(SessionManagementFilter.java:81) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.authentication.AnonymousAuthenticationFilter.doFilter(AnonymousAuthenticationFilter.java:105) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.servletapi.SecurityContextHolderAwareRequestFilter.doFilter(SecurityContextHolderAwareRequestFilter.java:149) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.savedrequest.RequestCacheAwareFilter.doFilter(RequestCacheAwareFilter.java:63) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at com.dc.framework.security.filter.JwtAuthenticationTokenFilter.doFilterInternal(JwtAuthenticationTokenFilter.java:43) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:111) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.authentication.logout.LogoutFilter.doFilter(LogoutFilter.java:103) + at org.springframework.security.web.authentication.logout.LogoutFilter.doFilter(LogoutFilter.java:89) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.web.filter.CorsFilter.doFilterInternal(CorsFilter.java:91) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.header.HeaderWriterFilter.doHeadersAfter(HeaderWriterFilter.java:90) + at org.springframework.security.web.header.HeaderWriterFilter.doFilterInternal(HeaderWriterFilter.java:75) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.context.SecurityContextPersistenceFilter.doFilter(SecurityContextPersistenceFilter.java:110) + at org.springframework.security.web.context.SecurityContextPersistenceFilter.doFilter(SecurityContextPersistenceFilter.java:80) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.context.request.async.WebAsyncManagerIntegrationFilter.doFilterInternal(WebAsyncManagerIntegrationFilter.java:55) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.FilterChainProxy.doFilterInternal(FilterChainProxy.java:211) + at org.springframework.security.web.FilterChainProxy.doFilter(FilterChainProxy.java:183) + at org.springframework.web.filter.DelegatingFilterProxy.invokeDelegate(DelegatingFilterProxy.java:354) + at org.springframework.web.filter.DelegatingFilterProxy.doFilter(DelegatingFilterProxy.java:267) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.RequestContextFilter.doFilterInternal(RequestContextFilter.java:100) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.FormContentFilter.doFilterInternal(FormContentFilter.java:93) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.CharacterEncodingFilter.doFilterInternal(CharacterEncodingFilter.java:201) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:197) + at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:97) + at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:541) + at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:135) + at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:92) + at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:78) + at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:360) + at org.apache.coyote.http11.Http11Processor.service(Http11Processor.java:399) + at org.apache.coyote.AbstractProcessorLight.process(AbstractProcessorLight.java:65) + at org.apache.coyote.AbstractProtocol$ConnectionHandler.process(AbstractProtocol.java:890) + at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1743) + at org.apache.tomcat.util.net.SocketProcessorBase.run(SocketProcessorBase.java:49) + at org.apache.tomcat.util.threads.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1191) + at org.apache.tomcat.util.threads.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:659) + at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61) + at java.lang.Thread.run(Thread.java:750) diff --git a/logs/sys-error.log b/logs/sys-error.log new file mode 100644 index 0000000..93bcfcc --- /dev/null +++ b/logs/sys-error.log @@ -0,0 +1,3588 @@ +09:41:03.220 [http-nio-9000-exec-11] ERROR c.d.f.w.e.GlobalExceptionHandler - [handleRuntimeException,82] - 请求地址'/captchaImage',发生未知异常. +org.springframework.dao.QueryTimeoutException: Redis command timed out; nested exception is io.lettuce.core.RedisCommandTimeoutException: Command timed out after 10 second(s) + at org.springframework.data.redis.connection.lettuce.LettuceExceptionConverter.convert(LettuceExceptionConverter.java:70) + at org.springframework.data.redis.connection.lettuce.LettuceExceptionConverter.convert(LettuceExceptionConverter.java:41) + at org.springframework.data.redis.PassThroughExceptionTranslationStrategy.translate(PassThroughExceptionTranslationStrategy.java:44) + at org.springframework.data.redis.FallbackExceptionTranslationStrategy.translate(FallbackExceptionTranslationStrategy.java:42) + at org.springframework.data.redis.connection.lettuce.LettuceConnection.convertLettuceAccessException(LettuceConnection.java:271) + at org.springframework.data.redis.connection.lettuce.LettuceConnection.await(LettuceConnection.java:1062) + at org.springframework.data.redis.connection.lettuce.LettuceConnection.lambda$doInvoke$4(LettuceConnection.java:919) + at org.springframework.data.redis.connection.lettuce.LettuceInvoker$Synchronizer.invoke(LettuceInvoker.java:665) + at org.springframework.data.redis.connection.lettuce.LettuceInvoker.just(LettuceInvoker.java:94) + at org.springframework.data.redis.connection.lettuce.LettuceStringCommands.get(LettuceStringCommands.java:55) + at org.springframework.data.redis.connection.DefaultedRedisConnection.get(DefaultedRedisConnection.java:267) + at org.springframework.data.redis.core.DefaultValueOperations$1.inRedis(DefaultValueOperations.java:57) + at org.springframework.data.redis.core.AbstractOperations$ValueDeserializingRedisCallback.doInRedis(AbstractOperations.java:60) + at org.springframework.data.redis.core.RedisTemplate.execute(RedisTemplate.java:222) + at org.springframework.data.redis.core.RedisTemplate.execute(RedisTemplate.java:189) + at org.springframework.data.redis.core.AbstractOperations.execute(AbstractOperations.java:96) + at org.springframework.data.redis.core.DefaultValueOperations.get(DefaultValueOperations.java:53) + at com.dc.common.core.redis.RedisCache.getCacheObject(RedisCache.java:106) + at com.dc.system.service.SysConfigService.selectConfigByKey(SysConfigService.java:63) + at com.dc.system.service.SysConfigService.selectCaptchaEnabled(SysConfigService.java:86) + at com.dc.system.service.SysConfigService$$FastClassBySpringCGLIB$$1060227c.invoke(<generated>) + at org.springframework.cglib.proxy.MethodProxy.invoke(MethodProxy.java:218) + at org.springframework.aop.framework.CglibAopProxy.invokeMethod(CglibAopProxy.java:386) + at org.springframework.aop.framework.CglibAopProxy.access$000(CglibAopProxy.java:85) + at org.springframework.aop.framework.CglibAopProxy$DynamicAdvisedInterceptor.intercept(CglibAopProxy.java:704) + at com.dc.system.service.SysConfigService$$EnhancerBySpringCGLIB$$f8b8b9c1.selectCaptchaEnabled(<generated>) + at com.dc.web.controller.common.CaptchaController.getCode(CaptchaController.java:50) + at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) + at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) + at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) + at java.lang.reflect.Method.invoke(Method.java:498) + at org.springframework.web.method.support.InvocableHandlerMethod.doInvoke(InvocableHandlerMethod.java:205) + at org.springframework.web.method.support.InvocableHandlerMethod.invokeForRequest(InvocableHandlerMethod.java:150) + at org.springframework.web.servlet.mvc.method.annotation.ServletInvocableHandlerMethod.invokeAndHandle(ServletInvocableHandlerMethod.java:117) + at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.invokeHandlerMethod(RequestMappingHandlerAdapter.java:895) + at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.handleInternal(RequestMappingHandlerAdapter.java:808) + at org.springframework.web.servlet.mvc.method.AbstractHandlerMethodAdapter.handle(AbstractHandlerMethodAdapter.java:87) + at org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:1067) + at org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:963) + at org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:1006) + at org.springframework.web.servlet.FrameworkServlet.doGet(FrameworkServlet.java:898) + at javax.servlet.http.HttpServlet.service(HttpServlet.java:655) + at org.springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.java:883) + at javax.servlet.http.HttpServlet.service(HttpServlet.java:764) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:227) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:53) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:111) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:111) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at com.dc.common.filter.RepeatableFilter.doFilter(RepeatableFilter.java:35) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:327) + at org.springframework.security.web.access.intercept.FilterSecurityInterceptor.invoke(FilterSecurityInterceptor.java:115) + at org.springframework.security.web.access.intercept.FilterSecurityInterceptor.doFilter(FilterSecurityInterceptor.java:81) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.access.ExceptionTranslationFilter.doFilter(ExceptionTranslationFilter.java:121) + at org.springframework.security.web.access.ExceptionTranslationFilter.doFilter(ExceptionTranslationFilter.java:115) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.session.SessionManagementFilter.doFilter(SessionManagementFilter.java:126) + at org.springframework.security.web.session.SessionManagementFilter.doFilter(SessionManagementFilter.java:81) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.authentication.AnonymousAuthenticationFilter.doFilter(AnonymousAuthenticationFilter.java:105) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.servletapi.SecurityContextHolderAwareRequestFilter.doFilter(SecurityContextHolderAwareRequestFilter.java:149) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.savedrequest.RequestCacheAwareFilter.doFilter(RequestCacheAwareFilter.java:63) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at com.dc.framework.security.filter.JwtAuthenticationTokenFilter.doFilterInternal(JwtAuthenticationTokenFilter.java:43) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:111) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.authentication.logout.LogoutFilter.doFilter(LogoutFilter.java:103) + at org.springframework.security.web.authentication.logout.LogoutFilter.doFilter(LogoutFilter.java:89) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.web.filter.CorsFilter.doFilterInternal(CorsFilter.java:91) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.header.HeaderWriterFilter.doHeadersAfter(HeaderWriterFilter.java:90) + at org.springframework.security.web.header.HeaderWriterFilter.doFilterInternal(HeaderWriterFilter.java:75) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.context.SecurityContextPersistenceFilter.doFilter(SecurityContextPersistenceFilter.java:110) + at org.springframework.security.web.context.SecurityContextPersistenceFilter.doFilter(SecurityContextPersistenceFilter.java:80) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.context.request.async.WebAsyncManagerIntegrationFilter.doFilterInternal(WebAsyncManagerIntegrationFilter.java:55) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.FilterChainProxy.doFilterInternal(FilterChainProxy.java:211) + at org.springframework.security.web.FilterChainProxy.doFilter(FilterChainProxy.java:183) + at org.springframework.web.filter.DelegatingFilterProxy.invokeDelegate(DelegatingFilterProxy.java:354) + at org.springframework.web.filter.DelegatingFilterProxy.doFilter(DelegatingFilterProxy.java:267) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.RequestContextFilter.doFilterInternal(RequestContextFilter.java:100) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.FormContentFilter.doFilterInternal(FormContentFilter.java:93) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.CharacterEncodingFilter.doFilterInternal(CharacterEncodingFilter.java:201) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:197) + at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:97) + at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:541) + at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:135) + at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:92) + at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:78) + at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:360) + at org.apache.coyote.http11.Http11Processor.service(Http11Processor.java:399) + at org.apache.coyote.AbstractProcessorLight.process(AbstractProcessorLight.java:65) + at org.apache.coyote.AbstractProtocol$ConnectionHandler.process(AbstractProtocol.java:890) + at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1743) + at org.apache.tomcat.util.net.SocketProcessorBase.run(SocketProcessorBase.java:49) + at org.apache.tomcat.util.threads.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1191) + at org.apache.tomcat.util.threads.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:659) + at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61) + at java.lang.Thread.run(Thread.java:750) +Caused by: io.lettuce.core.RedisCommandTimeoutException: Command timed out after 10 second(s) + at io.lettuce.core.internal.ExceptionFactory.createTimeoutException(ExceptionFactory.java:59) + at io.lettuce.core.internal.Futures.awaitOrCancel(Futures.java:246) + at io.lettuce.core.LettuceFutures.awaitOrCancel(LettuceFutures.java:74) + at org.springframework.data.redis.connection.lettuce.LettuceConnection.await(LettuceConnection.java:1060) + ... 123 common frames omitted +09:44:13.960 [Druid-ConnectionPool-Create-388032892] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://10.10.10.56:5432/dcdatabase?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: 尝试连线已失败。 + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:315) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.SocketTimeoutException: connect timed out + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +09:44:23.964 [Druid-ConnectionPool-Create-388032892] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://10.10.10.56:5432/dcdatabase?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: 尝试连线已失败。 + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:315) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.SocketTimeoutException: connect timed out + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +09:44:34.474 [Druid-ConnectionPool-Create-388032892] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://10.10.10.56:5432/dcdatabase?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: 尝试连线已失败。 + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:315) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.SocketTimeoutException: connect timed out + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +09:44:44.978 [Druid-ConnectionPool-Create-388032892] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://10.10.10.56:5432/dcdatabase?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: 尝试连线已失败。 + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:315) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.SocketTimeoutException: connect timed out + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +09:44:55.487 [Druid-ConnectionPool-Create-388032892] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://10.10.10.56:5432/dcdatabase?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: 尝试连线已失败。 + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:315) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.SocketTimeoutException: connect timed out + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +09:45:05.996 [Druid-ConnectionPool-Create-388032892] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://10.10.10.56:5432/dcdatabase?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: 尝试连线已失败。 + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:315) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.SocketTimeoutException: connect timed out + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +09:45:16.501 [Druid-ConnectionPool-Create-388032892] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://10.10.10.56:5432/dcdatabase?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: 尝试连线已失败。 + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:315) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.SocketTimeoutException: connect timed out + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +09:45:27.008 [Druid-ConnectionPool-Create-388032892] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://10.10.10.56:5432/dcdatabase?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: 尝试连线已失败。 + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:315) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.SocketTimeoutException: connect timed out + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +09:45:37.516 [Druid-ConnectionPool-Create-388032892] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://10.10.10.56:5432/dcdatabase?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: 尝试连线已失败。 + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:315) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.SocketTimeoutException: connect timed out + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +09:45:48.027 [Druid-ConnectionPool-Create-388032892] ERROR c.a.d.p.DruidDataSource - [run,2912] - create connection SQLException, url: jdbc:postgresql://10.10.10.56:5432/dcdatabase?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=Asia/Shanghai, errorCode 0, state 08001 +org.postgresql.util.PSQLException: 尝试连线已失败。 + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:315) + at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:51) + at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:225) + at org.postgresql.Driver.makeConnection(Driver.java:465) + at org.postgresql.Driver.connect(Driver.java:264) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:118) + at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:232) + at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:112) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1703) + at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1786) + at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2910) +Caused by: java.net.SocketTimeoutException: connect timed out + at java.net.PlainSocketImpl.socketConnect(Native Method) + at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) + at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) + at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) + at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) + at java.net.Socket.connect(Socket.java:607) + at org.postgresql.core.PGStream.createSocket(PGStream.java:231) + at org.postgresql.core.PGStream.<init>(PGStream.java:95) + at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98) + at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213) + ... 10 common frames omitted +10:28:23.593 [http-nio-9000-exec-26] ERROR c.d.f.w.e.GlobalExceptionHandler - [handleRuntimeException,82] - 请求地址'/tool/gen/db/list',发生未知异常. +org.springframework.jdbc.BadSqlGrammarException: +### Error querying database. Cause: org.postgresql.util.PSQLException: ERROR: column "table_comment" does not exist + 位置:44 +### The error may exist in file [/Users/longlongxiaogege/work/mengyin/code/lianmei/dc-master/dc-generator/target/classes/mapper/generator/GenTableMapper.xml] +### The error may involve com.dc.generator.mapper.GenTableMapper.selectDbTableList-Inline +### The error occurred while setting parameters +### Cause: org.postgresql.util.PSQLEx### SQL: select count(0) from ( select table_name, table_comment, create_time, update_time from information_schema.tables where table_schema = (select database()) AND table_name NOT LIKE 'qrtz_%' AND table_name NOT LIKE 'gen_%' AND table_name NOT IN (select table_name from gen_table) order by create_time desc ) tmp_count +ception: ERROR: column "table_comment" does not exist + 位置:44 +; bad SQL grammar []; nested exception is org.postgresql.util.PSQLException: ERROR: column "table_comment" does not exist + 位置:44 + at org.springframework.jdbc.support.SQLStateSQLExceptionTranslator.doTranslate(SQLStateSQLExceptionTranslator.java:101) + at org.springframework.jdbc.support.AbstractFallbackSQLExceptionTranslator.translate(AbstractFallbackSQLExceptionTranslator.java:70) + at org.springframework.jdbc.support.AbstractFallbackSQLExceptionTranslator.translate(AbstractFallbackSQLExceptionTranslator.java:79) + at org.springframework.jdbc.support.AbstractFallbackSQLExceptionTranslator.translate(AbstractFallbackSQLExceptionTranslator.java:79) + at org.mybatis.spring.MyBatisExceptionTranslator.translateExceptionIfPossible(MyBatisExceptionTranslator.java:91) + at org.mybatis.spring.SqlSessionTemplate$SqlSessionInterceptor.invoke(SqlSessionTemplate.java:441) + at com.sun.proxy.$Proxy114.selectList(Unknown Source) + at org.mybatis.spring.SqlSessionTemplate.selectList(SqlSessionTemplate.java:224) + at com.baomidou.mybatisplus.core.override.MybatisMapperMethod.executeForMany(MybatisMapperMethod.java:166) + at com.baomidou.mybatisplus.core.override.MybatisMapperMethod.execute(MybatisMapperMethod.java:77) + at com.baomidou.mybatisplus.core.override.MybatisMapperProxy$PlainMethodInvoker.invoke(MybatisMapperProxy.java:148) + at com.baomidou.mybatisplus.core.override.MybatisMapperProxy.invoke(MybatisMapperProxy.java:89) + at com.sun.proxy.$Proxy182.selectDbTableList(Unknown Source) + at com.dc.generator.service.GenTableService.selectDbTableList(GenTableService.java:86) + at com.dc.generator.service.GenTableService$$FastClassBySpringCGLIB$$641d1a1.invoke(<generated>) + at org.springframework.cglib.proxy.MethodProxy.invoke(MethodProxy.java:218) + at org.springframework.aop.framework.CglibAopProxy.invokeMethod(CglibAopProxy.java:386) + at org.springframework.aop.framework.CglibAopProxy.access$000(CglibAopProxy.java:85) + at org.springframework.aop.framework.CglibAopProxy$DynamicAdvisedInterceptor.intercept(CglibAopProxy.java:704) + at com.dc.generator.service.GenTableService$$EnhancerBySpringCGLIB$$b851a4e7.selectDbTableList(<generated>) + at com.dc.generator.controller.GenController.dataList(GenController.java:77) + at com.dc.generator.controller.GenController$$FastClassBySpringCGLIB$$a3bb93f7.invoke(<generated>) + at org.springframework.cglib.proxy.MethodProxy.invoke(MethodProxy.java:218) + at org.springframework.aop.framework.CglibAopProxy$CglibMethodInvocation.invokeJoinpoint(CglibAopProxy.java:793) + at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:163) + at org.springframework.aop.framework.CglibAopProxy$CglibMethodInvocation.proceed(CglibAopProxy.java:763) + at org.springframework.security.access.intercept.aopalliance.MethodSecurityInterceptor.invoke(MethodSecurityInterceptor.java:61) + at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:186) + at org.springframework.aop.framework.CglibAopProxy$CglibMethodInvocation.proceed(CglibAopProxy.java:763) + at org.springframework.aop.interceptor.ExposeInvocationInterceptor.invoke(ExposeInvocationInterceptor.java:97) + at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:186) + at org.springframework.aop.framework.CglibAopProxy$CglibMethodInvocation.proceed(CglibAopProxy.java:763) + at org.springframework.aop.framework.CglibAopProxy$DynamicAdvisedInterceptor.intercept(CglibAopProxy.java:708) + at com.dc.generator.controller.GenController$$EnhancerBySpringCGLIB$$731a3c38.dataList(<generated>) + at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) + at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) + at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) + at java.lang.reflect.Method.invoke(Method.java:498) + at org.springframework.web.method.support.InvocableHandlerMethod.doInvoke(InvocableHandlerMethod.java:205) + at org.springframework.web.method.support.InvocableHandlerMethod.invokeForRequest(InvocableHandlerMethod.java:150) + at org.springframework.web.servlet.mvc.method.annotation.ServletInvocableHandlerMethod.invokeAndHandle(ServletInvocableHandlerMethod.java:117) + at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.invokeHandlerMethod(RequestMappingHandlerAdapter.java:895) + at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.handleInternal(RequestMappingHandlerAdapter.java:808) + at org.springframework.web.servlet.mvc.method.AbstractHandlerMethodAdapter.handle(AbstractHandlerMethodAdapter.java:87) + at org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:1067) + at org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:963) + at org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:1006) + at org.springframework.web.servlet.FrameworkServlet.doGet(FrameworkServlet.java:898) + at javax.servlet.http.HttpServlet.service(HttpServlet.java:655) + at org.springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.java:883) + at javax.servlet.http.HttpServlet.service(HttpServlet.java:764) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:227) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:53) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:111) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:111) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at com.dc.common.filter.RepeatableFilter.doFilter(RepeatableFilter.java:35) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:327) + at org.springframework.security.web.access.intercept.FilterSecurityInterceptor.invoke(FilterSecurityInterceptor.java:115) + at org.springframework.security.web.access.intercept.FilterSecurityInterceptor.doFilter(FilterSecurityInterceptor.java:81) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.access.ExceptionTranslationFilter.doFilter(ExceptionTranslationFilter.java:121) + at org.springframework.security.web.access.ExceptionTranslationFilter.doFilter(ExceptionTranslationFilter.java:115) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.session.SessionManagementFilter.doFilter(SessionManagementFilter.java:126) + at org.springframework.security.web.session.SessionManagementFilter.doFilter(SessionManagementFilter.java:81) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.authentication.AnonymousAuthenticationFilter.doFilter(AnonymousAuthenticationFilter.java:105) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.servletapi.SecurityContextHolderAwareRequestFilter.doFilter(SecurityContextHolderAwareRequestFilter.java:149) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.savedrequest.RequestCacheAwareFilter.doFilter(RequestCacheAwareFilter.java:63) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at com.dc.framework.security.filter.JwtAuthenticationTokenFilter.doFilterInternal(JwtAuthenticationTokenFilter.java:43) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:111) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.authentication.logout.LogoutFilter.doFilter(LogoutFilter.java:103) + at org.springframework.security.web.authentication.logout.LogoutFilter.doFilter(LogoutFilter.java:89) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.web.filter.CorsFilter.doFilterInternal(CorsFilter.java:91) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.header.HeaderWriterFilter.doHeadersAfter(HeaderWriterFilter.java:90) + at org.springframework.security.web.header.HeaderWriterFilter.doFilterInternal(HeaderWriterFilter.java:75) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.context.SecurityContextPersistenceFilter.doFilter(SecurityContextPersistenceFilter.java:110) + at org.springframework.security.web.context.SecurityContextPersistenceFilter.doFilter(SecurityContextPersistenceFilter.java:80) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.context.request.async.WebAsyncManagerIntegrationFilter.doFilterInternal(WebAsyncManagerIntegrationFilter.java:55) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.FilterChainProxy.doFilterInternal(FilterChainProxy.java:211) + at org.springframework.security.web.FilterChainProxy.doFilter(FilterChainProxy.java:183) + at org.springframework.web.filter.DelegatingFilterProxy.invokeDelegate(DelegatingFilterProxy.java:354) + at org.springframework.web.filter.DelegatingFilterProxy.doFilter(DelegatingFilterProxy.java:267) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.RequestContextFilter.doFilterInternal(RequestContextFilter.java:100) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.FormContentFilter.doFilterInternal(FormContentFilter.java:93) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.CharacterEncodingFilter.doFilterInternal(CharacterEncodingFilter.java:201) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at com.dc.common.filter.XssFilter.doFilter(XssFilter.java:47) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:197) + at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:97) + at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:541) + at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:135) + at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:92) + at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:78) + at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:360) + at org.apache.coyote.http11.Http11Processor.service(Http11Processor.java:399) + at org.apache.coyote.AbstractProcessorLight.process(AbstractProcessorLight.java:65) + at org.apache.coyote.AbstractProtocol$ConnectionHandler.process(AbstractProtocol.java:890) + at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1743) + at org.apache.tomcat.util.net.SocketProcessorBase.run(SocketProcessorBase.java:49) + at org.apache.tomcat.util.threads.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1191) + at org.apache.tomcat.util.threads.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:659) + at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61) + at java.lang.Thread.run(Thread.java:750) +Caused by: org.postgresql.util.PSQLException: ERROR: column "table_comment" does not exist + 位置:44 + at org.postgresql.core.v3.QueryExecutorImpl.receiveErrorResponse(QueryExecutorImpl.java:2565) + at org.postgresql.core.v3.QueryExecutorImpl.processResults(QueryExecutorImpl.java:2297) + at org.postgresql.core.v3.QueryExecutorImpl.execute(QueryExecutorImpl.java:322) + at org.postgresql.jdbc.PgStatement.executeInternal(PgStatement.java:481) + at org.postgresql.jdbc.PgStatement.execute(PgStatement.java:401) + at org.postgresql.jdbc.PgPreparedStatement.executeWithFlags(PgPreparedStatement.java:164) + at org.postgresql.jdbc.PgPreparedStatement.execute(PgPreparedStatement.java:153) + at com.alibaba.druid.filter.FilterChainImpl.preparedStatement_execute(FilterChainImpl.java:3446) + at com.alibaba.druid.filter.FilterEventAdapter.preparedStatement_execute(FilterEventAdapter.java:434) + at com.alibaba.druid.filter.FilterChainImpl.preparedStatement_execute(FilterChainImpl.java:3444) + at com.alibaba.druid.proxy.jdbc.PreparedStatementProxyImpl.execute(PreparedStatementProxyImpl.java:152) + at com.alibaba.druid.pool.DruidPooledPreparedStatement.execute(DruidPooledPreparedStatement.java:483) + at org.apache.ibatis.executor.statement.PreparedStatementHandler.query(PreparedStatementHandler.java:64) + at org.apache.ibatis.executor.statement.RoutingStatementHandler.query(RoutingStatementHandler.java:79) + at sun.reflect.GeneratedMethodAccessor154.invoke(Unknown Source) + at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) + at java.lang.reflect.Method.invoke(Method.java:498) + at org.apache.ibatis.plugin.Plugin.invoke(Plugin.java:64) + at com.sun.proxy.$Proxy119.query(Unknown Source) + at org.apache.ibatis.executor.SimpleExecutor.doQuery(SimpleExecutor.java:63) + at org.apache.ibatis.executor.BaseExecutor.queryFromDatabase(BaseExecutor.java:325) + at org.apache.ibatis.executor.BaseExecutor.query(BaseExecutor.java:156) + at org.apache.ibatis.executor.CachingExecutor.query(CachingExecutor.java:109) + at com.baomidou.mybatisplus.extension.plugins.MybatisPlusInterceptor.intercept(MybatisPlusInterceptor.java:81) + at org.apache.ibatis.plugin.Plugin.invoke(Plugin.java:62) + at com.sun.proxy.$Proxy118.query(Unknown Source) + at com.github.pagehelper.util.ExecutorUtil.executeAutoCount(ExecutorUtil.java:169) + at com.github.pagehelper.PageInterceptor.count(PageInterceptor.java:197) + at com.github.pagehelper.PageInterceptor.intercept(PageInterceptor.java:140) + at org.apache.ibatis.plugin.Plugin.invoke(Plugin.java:62) + at com.sun.proxy.$Proxy118.query(Unknown Source) + at org.apache.ibatis.session.defaults.DefaultSqlSession.selectList(DefaultSqlSession.java:151) + at org.apache.ibatis.session.defaults.DefaultSqlSession.selectList(DefaultSqlSession.java:145) + at org.apache.ibatis.session.defaults.DefaultSqlSession.selectList(DefaultSqlSession.java:140) + at sun.reflect.GeneratedMethodAccessor151.invoke(Unknown Source) + at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) + at java.lang.reflect.Method.invoke(Method.java:498) + at org.mybatis.spring.SqlSessionTemplate$SqlSessionInterceptor.invoke(SqlSessionTemplate.java:427) + ... 133 common frames omitted +10:29:46.227 [http-nio-9000-exec-4] ERROR c.d.f.w.e.GlobalExceptionHandler - [handleRuntimeException,82] - 请求地址'/tool/gen/db/list',发生未知异常. +org.springframework.jdbc.BadSqlGrammarException: +### Error querying database. Cause: org.postgresql.util.PSQLException: ERROR: column "table_comment" does not exist + 位置:44 +### The error may exist in file [/Users/longlongxiaogege/work/mengyin/code/lianmei/dc-master/dc-generator/target/classes/mapper/generator/GenTableMapper.xml] +### The error may involve com.dc.generator.mapper.GenTableMapper.selectDbTableList-Inline +### The error occurred while setting parameters +### SQL: select count(0) from ( select table_name, table_comment, create_time, update_time from information_schema.tables where table_schema = (select database()) AND table_name NOT LIKE 'qrtz_%' AND table_name NOT LIKE 'gen_%' AND table_name NOT IN (select table_name from gen_table) order by create_time desc ) tmp_count +### Cause: org.postgresql.util.PSQLException: ERROR: column "table_comment" does not exist + 位置:44 +; bad SQL grammar []; nested exception is org.postgresql.util.PSQLException: ERROR: column "table_comment" does not exist + 位置:44 + at org.springframework.jdbc.support.SQLStateSQLExceptionTranslator.doTranslate(SQLStateSQLExceptionTranslator.java:101) + at org.springframework.jdbc.support.AbstractFallbackSQLExceptionTranslator.translate(AbstractFallbackSQLExceptionTranslator.java:70) + at org.springframework.jdbc.support.AbstractFallbackSQLExceptionTranslator.translate(AbstractFallbackSQLExceptionTranslator.java:79) + at org.springframework.jdbc.support.AbstractFallbackSQLExceptionTranslator.translate(AbstractFallbackSQLExceptionTranslator.java:79) + at org.mybatis.spring.MyBatisExceptionTranslator.translateExceptionIfPossible(MyBatisExceptionTranslator.java:91) + at org.mybatis.spring.SqlSessionTemplate$SqlSessionInterceptor.invoke(SqlSessionTemplate.java:441) + at com.sun.proxy.$Proxy114.selectList(Unknown Source) + at org.mybatis.spring.SqlSessionTemplate.selectList(SqlSessionTemplate.java:224) + at com.baomidou.mybatisplus.core.override.MybatisMapperMethod.executeForMany(MybatisMapperMethod.java:166) + at com.baomidou.mybatisplus.core.override.MybatisMapperMethod.execute(MybatisMapperMethod.java:77) + at com.baomidou.mybatisplus.core.override.MybatisMapperProxy$PlainMethodInvoker.invoke(MybatisMapperProxy.java:148) + at com.baomidou.mybatisplus.core.override.MybatisMapperProxy.invoke(MybatisMapperProxy.java:89) + at com.sun.proxy.$Proxy182.selectDbTableList(Unknown Source) + at com.dc.generator.service.GenTableService.selectDbTableList(GenTableService.java:86) + at com.dc.generator.service.GenTableService$$FastClassBySpringCGLIB$$641d1a1.invoke(<generated>) + at org.springframework.cglib.proxy.MethodProxy.invoke(MethodProxy.java:218) + at org.springframework.aop.framework.CglibAopProxy.invokeMethod(CglibAopProxy.java:386) + at org.springframework.aop.framework.CglibAopProxy.access$000(CglibAopProxy.java:85) + at org.springframework.aop.framework.CglibAopProxy$DynamicAdvisedInterceptor.intercept(CglibAopProxy.java:704) + at com.dc.generator.service.GenTableService$$EnhancerBySpringCGLIB$$5821132a.selectDbTableList(<generated>) + at com.dc.generator.controller.GenController.dataList(GenController.java:77) + at com.dc.generator.controller.GenController$$FastClassBySpringCGLIB$$a3bb93f7.invoke(<generated>) + at org.springframework.cglib.proxy.MethodProxy.invoke(MethodProxy.java:218) + at org.springframework.aop.framework.CglibAopProxy$CglibMethodInvocation.invokeJoinpoint(CglibAopProxy.java:793) + at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:163) + at org.springframework.aop.framework.CglibAopProxy$CglibMethodInvocation.proceed(CglibAopProxy.java:763) + at org.springframework.security.access.intercept.aopalliance.MethodSecurityInterceptor.invoke(MethodSecurityInterceptor.java:61) + at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:186) + at org.springframework.aop.framework.CglibAopProxy$CglibMethodInvocation.proceed(CglibAopProxy.java:763) + at org.springframework.aop.interceptor.ExposeInvocationInterceptor.invoke(ExposeInvocationInterceptor.java:97) + at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:186) + at org.springframework.aop.framework.CglibAopProxy$CglibMethodInvocation.proceed(CglibAopProxy.java:763) + at org.springframework.aop.framework.CglibAopProxy$DynamicAdvisedInterceptor.intercept(CglibAopProxy.java:708) + at com.dc.generator.controller.GenController$$EnhancerBySpringCGLIB$$3cb6e6e0.dataList(<generated>) + at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) + at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) + at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) + at java.lang.reflect.Method.invoke(Method.java:498) + at org.springframework.web.method.support.InvocableHandlerMethod.doInvoke(InvocableHandlerMethod.java:205) + at org.springframework.web.method.support.InvocableHandlerMethod.invokeForRequest(InvocableHandlerMethod.java:150) + at org.springframework.web.servlet.mvc.method.annotation.ServletInvocableHandlerMethod.invokeAndHandle(ServletInvocableHandlerMethod.java:117) + at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.invokeHandlerMethod(RequestMappingHandlerAdapter.java:895) + at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.handleInternal(RequestMappingHandlerAdapter.java:808) + at org.springframework.web.servlet.mvc.method.AbstractHandlerMethodAdapter.handle(AbstractHandlerMethodAdapter.java:87) + at org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:1067) + at org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:963) + at org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:1006) + at org.springframework.web.servlet.FrameworkServlet.doGet(FrameworkServlet.java:898) + at javax.servlet.http.HttpServlet.service(HttpServlet.java:655) + at org.springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.java:883) + at javax.servlet.http.HttpServlet.service(HttpServlet.java:764) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:227) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:53) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:111) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:111) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at com.dc.common.filter.RepeatableFilter.doFilter(RepeatableFilter.java:35) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:327) + at org.springframework.security.web.access.intercept.FilterSecurityInterceptor.invoke(FilterSecurityInterceptor.java:115) + at org.springframework.security.web.access.intercept.FilterSecurityInterceptor.doFilter(FilterSecurityInterceptor.java:81) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.access.ExceptionTranslationFilter.doFilter(ExceptionTranslationFilter.java:121) + at org.springframework.security.web.access.ExceptionTranslationFilter.doFilter(ExceptionTranslationFilter.java:115) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.session.SessionManagementFilter.doFilter(SessionManagementFilter.java:126) + at org.springframework.security.web.session.SessionManagementFilter.doFilter(SessionManagementFilter.java:81) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.authentication.AnonymousAuthenticationFilter.doFilter(AnonymousAuthenticationFilter.java:105) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.servletapi.SecurityContextHolderAwareRequestFilter.doFilter(SecurityContextHolderAwareRequestFilter.java:149) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.savedrequest.RequestCacheAwareFilter.doFilter(RequestCacheAwareFilter.java:63) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at com.dc.framework.security.filter.JwtAuthenticationTokenFilter.doFilterInternal(JwtAuthenticationTokenFilter.java:43) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:111) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.authentication.logout.LogoutFilter.doFilter(LogoutFilter.java:103) + at org.springframework.security.web.authentication.logout.LogoutFilter.doFilter(LogoutFilter.java:89) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.web.filter.CorsFilter.doFilterInternal(CorsFilter.java:91) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.header.HeaderWriterFilter.doHeadersAfter(HeaderWriterFilter.java:90) + at org.springframework.security.web.header.HeaderWriterFilter.doFilterInternal(HeaderWriterFilter.java:75) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.context.SecurityContextPersistenceFilter.doFilter(SecurityContextPersistenceFilter.java:110) + at org.springframework.security.web.context.SecurityContextPersistenceFilter.doFilter(SecurityContextPersistenceFilter.java:80) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.context.request.async.WebAsyncManagerIntegrationFilter.doFilterInternal(WebAsyncManagerIntegrationFilter.java:55) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.FilterChainProxy.doFilterInternal(FilterChainProxy.java:211) + at org.springframework.security.web.FilterChainProxy.doFilter(FilterChainProxy.java:183) + at org.springframework.web.filter.DelegatingFilterProxy.invokeDelegate(DelegatingFilterProxy.java:354) + at org.springframework.web.filter.DelegatingFilterProxy.doFilter(DelegatingFilterProxy.java:267) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.RequestContextFilter.doFilterInternal(RequestContextFilter.java:100) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.FormContentFilter.doFilterInternal(FormContentFilter.java:93) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.CharacterEncodingFilter.doFilterInternal(CharacterEncodingFilter.java:201) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at com.dc.common.filter.XssFilter.doFilter(XssFilter.java:47) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:197) + at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:97) + at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:541) + at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:135) + at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:92) + at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:78) + at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:360) + at org.apache.coyote.http11.Http11Processor.service(Http11Processor.java:399) + at org.apache.coyote.AbstractProcessorLight.process(AbstractProcessorLight.java:65) + at org.apache.coyote.AbstractProtocol$ConnectionHandler.process(AbstractProtocol.java:890) + at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1743) + at org.apache.tomcat.util.net.SocketProcessorBase.run(SocketProcessorBase.java:49) + at org.apache.tomcat.util.threads.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1191) + at org.apache.tomcat.util.threads.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:659) + at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61) + at java.lang.Thread.run(Thread.java:750) +Caused by: org.postgresql.util.PSQLException: ERROR: column "table_comment" does not exist + 位置:44 + at org.postgresql.core.v3.QueryExecutorImpl.receiveErrorResponse(QueryExecutorImpl.java:2565) + at org.postgresql.core.v3.QueryExecutorImpl.processResults(QueryExecutorImpl.java:2297) + at org.postgresql.core.v3.QueryExecutorImpl.execute(QueryExecutorImpl.java:322) + at org.postgresql.jdbc.PgStatement.executeInternal(PgStatement.java:481) + at org.postgresql.jdbc.PgStatement.execute(PgStatement.java:401) + at org.postgresql.jdbc.PgPreparedStatement.executeWithFlags(PgPreparedStatement.java:164) + at org.postgresql.jdbc.PgPreparedStatement.execute(PgPreparedStatement.java:153) + at com.alibaba.druid.filter.FilterChainImpl.preparedStatement_execute(FilterChainImpl.java:3446) + at com.alibaba.druid.filter.FilterEventAdapter.preparedStatement_execute(FilterEventAdapter.java:434) + at com.alibaba.druid.filter.FilterChainImpl.preparedStatement_execute(FilterChainImpl.java:3444) + at com.alibaba.druid.proxy.jdbc.PreparedStatementProxyImpl.execute(PreparedStatementProxyImpl.java:152) + at com.alibaba.druid.pool.DruidPooledPreparedStatement.execute(DruidPooledPreparedStatement.java:483) + at org.apache.ibatis.executor.statement.PreparedStatementHandler.query(PreparedStatementHandler.java:64) + at org.apache.ibatis.executor.statement.RoutingStatementHandler.query(RoutingStatementHandler.java:79) + at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) + at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) + at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) + at java.lang.reflect.Method.invoke(Method.java:498) + at org.apache.ibatis.plugin.Plugin.invoke(Plugin.java:64) + at com.sun.proxy.$Proxy119.query(Unknown Source) + at org.apache.ibatis.executor.SimpleExecutor.doQuery(SimpleExecutor.java:63) + at org.apache.ibatis.executor.BaseExecutor.queryFromDatabase(BaseExecutor.java:325) + at org.apache.ibatis.executor.BaseExecutor.query(BaseExecutor.java:156) + at org.apache.ibatis.executor.CachingExecutor.query(CachingExecutor.java:109) + at com.baomidou.mybatisplus.extension.plugins.MybatisPlusInterceptor.intercept(MybatisPlusInterceptor.java:81) + at org.apache.ibatis.plugin.Plugin.invoke(Plugin.java:62) + at com.sun.proxy.$Proxy118.query(Unknown Source) + at com.github.pagehelper.util.ExecutorUtil.executeAutoCount(ExecutorUtil.java:169) + at com.github.pagehelper.PageInterceptor.count(PageInterceptor.java:197) + at com.github.pagehelper.PageInterceptor.intercept(PageInterceptor.java:140) + at org.apache.ibatis.plugin.Plugin.invoke(Plugin.java:62) + at com.sun.proxy.$Proxy118.query(Unknown Source) + at org.apache.ibatis.session.defaults.DefaultSqlSession.selectList(DefaultSqlSession.java:151) + at org.apache.ibatis.session.defaults.DefaultSqlSession.selectList(DefaultSqlSession.java:145) + at org.apache.ibatis.session.defaults.DefaultSqlSession.selectList(DefaultSqlSession.java:140) + at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) + at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) + at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) + at java.lang.reflect.Method.invoke(Method.java:498) + at org.mybatis.spring.SqlSessionTemplate$SqlSessionInterceptor.invoke(SqlSessionTemplate.java:427) + ... 133 common frames omitted +10:05:09.742 [http-nio-9000-exec-16] ERROR c.d.f.w.e.GlobalExceptionHandler - [handleRuntimeException,82] - 请求地址'/tool/gen/db/list',发生未知异常. +org.springframework.jdbc.BadSqlGrammarException: +### Error querying database. Cause: org.postgresql.util.PSQLException: ERROR: column "table_comment" does not exist + 位置:44 +### The error may exist in file [/Users/longlongxiaogege/work/mengyin/code/lianmei/myself/backup/dc-backend/data-center/dc-generator/target/classes/mapper/generator/GenTableMapper.xml] +### The error may involve com.dc.generator.mapper.GenTableMapper.selectDbTableList-Inline +### The error occurred while setting parameters +### SQL: select count(0) from ( select table_name, table_comment, create_time, update_time from information_schema.tables where table_schema = (select database()) AND table_name NOT LIKE 'qrtz_%' AND table_name NOT LIKE 'gen_%' AND table_name NOT IN (select table_name from gen_table) order by create_time desc ) tmp_count +### Cause: org.postgresql.util.PSQLException: ERROR: column "table_comment" does not exist + 位置:44 +; bad SQL grammar []; nested exception is org.postgresql.util.PSQLException: ERROR: column "table_comment" does not exist + 位置:44 + at org.springframework.jdbc.support.SQLStateSQLExceptionTranslator.doTranslate(SQLStateSQLExceptionTranslator.java:101) + at org.springframework.jdbc.support.AbstractFallbackSQLExceptionTranslator.translate(AbstractFallbackSQLExceptionTranslator.java:70) + at org.springframework.jdbc.support.AbstractFallbackSQLExceptionTranslator.translate(AbstractFallbackSQLExceptionTranslator.java:79) + at org.springframework.jdbc.support.AbstractFallbackSQLExceptionTranslator.translate(AbstractFallbackSQLExceptionTranslator.java:79) + at org.mybatis.spring.MyBatisExceptionTranslator.translateExceptionIfPossible(MyBatisExceptionTranslator.java:91) + at org.mybatis.spring.SqlSessionTemplate$SqlSessionInterceptor.invoke(SqlSessionTemplate.java:441) + at jdk.proxy2/jdk.proxy2.$Proxy113.selectList(Unknown Source) + at org.mybatis.spring.SqlSessionTemplate.selectList(SqlSessionTemplate.java:224) + at com.baomidou.mybatisplus.core.override.MybatisMapperMethod.executeForMany(MybatisMapperMethod.java:166) + at com.baomidou.mybatisplus.core.override.MybatisMapperMethod.execute(MybatisMapperMethod.java:77) + at com.baomidou.mybatisplus.core.override.MybatisMapperProxy$PlainMethodInvoker.invoke(MybatisMapperProxy.java:148) + at com.baomidou.mybatisplus.core.override.MybatisMapperProxy.invoke(MybatisMapperProxy.java:89) + at jdk.proxy3/jdk.proxy3.$Proxy182.selectDbTableList(Unknown Source) + at com.dc.generator.service.GenTableService.selectDbTableList(GenTableService.java:86) + at com.dc.generator.service.GenTableService$$FastClassBySpringCGLIB$$641d1a1.invoke(<generated>) + at org.springframework.cglib.proxy.MethodProxy.invoke(MethodProxy.java:218) + at org.springframework.aop.framework.CglibAopProxy.invokeMethod(CglibAopProxy.java:386) + at org.springframework.aop.framework.CglibAopProxy.access$000(CglibAopProxy.java:85) + at org.springframework.aop.framework.CglibAopProxy$DynamicAdvisedInterceptor.intercept(CglibAopProxy.java:704) + at com.dc.generator.service.GenTableService$$EnhancerBySpringCGLIB$$57d8ac2e.selectDbTableList(<generated>) + at com.dc.generator.controller.GenController.dataList(GenController.java:77) + at com.dc.generator.controller.GenController$$FastClassBySpringCGLIB$$a3bb93f7.invoke(<generated>) + at org.springframework.cglib.proxy.MethodProxy.invoke(MethodProxy.java:218) + at org.springframework.aop.framework.CglibAopProxy$CglibMethodInvocation.invokeJoinpoint(CglibAopProxy.java:793) + at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:163) + at org.springframework.aop.framework.CglibAopProxy$CglibMethodInvocation.proceed(CglibAopProxy.java:763) + at org.springframework.security.access.intercept.aopalliance.MethodSecurityInterceptor.invoke(MethodSecurityInterceptor.java:61) + at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:186) + at org.springframework.aop.framework.CglibAopProxy$CglibMethodInvocation.proceed(CglibAopProxy.java:763) + at org.springframework.aop.interceptor.ExposeInvocationInterceptor.invoke(ExposeInvocationInterceptor.java:97) + at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:186) + at org.springframework.aop.framework.CglibAopProxy$CglibMethodInvocation.proceed(CglibAopProxy.java:763) + at org.springframework.aop.framework.CglibAopProxy$DynamicAdvisedInterceptor.intercept(CglibAopProxy.java:708) + at com.dc.generator.controller.GenController$$EnhancerBySpringCGLIB$$a461bfe2.dataList(<generated>) + at java.base/jdk.internal.reflect.DirectMethodHandleAccessor.invoke(DirectMethodHandleAccessor.java:104) + at java.base/java.lang.reflect.Method.invoke(Method.java:578) + at org.springframework.web.method.support.InvocableHandlerMethod.doInvoke(InvocableHandlerMethod.java:205) + at org.springframework.web.method.support.InvocableHandlerMethod.invokeForRequest(InvocableHandlerMethod.java:150) + at org.springframework.web.servlet.mvc.method.annotation.ServletInvocableHandlerMethod.invokeAndHandle(ServletInvocableHandlerMethod.java:117) + at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.invokeHandlerMethod(RequestMappingHandlerAdapter.java:895) + at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.handleInternal(RequestMappingHandlerAdapter.java:808) + at org.springframework.web.servlet.mvc.method.AbstractHandlerMethodAdapter.handle(AbstractHandlerMethodAdapter.java:87) + at org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:1067) + at org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:963) + at org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:1006) + at org.springframework.web.servlet.FrameworkServlet.doGet(FrameworkServlet.java:898) + at javax.servlet.http.HttpServlet.service(HttpServlet.java:655) + at org.springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.java:883) + at javax.servlet.http.HttpServlet.service(HttpServlet.java:764) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:227) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:53) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:111) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:111) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at com.dc.common.filter.RepeatableFilter.doFilter(RepeatableFilter.java:35) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:327) + at org.springframework.security.web.access.intercept.FilterSecurityInterceptor.invoke(FilterSecurityInterceptor.java:115) + at org.springframework.security.web.access.intercept.FilterSecurityInterceptor.doFilter(FilterSecurityInterceptor.java:81) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.access.ExceptionTranslationFilter.doFilter(ExceptionTranslationFilter.java:121) + at org.springframework.security.web.access.ExceptionTranslationFilter.doFilter(ExceptionTranslationFilter.java:115) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.session.SessionManagementFilter.doFilter(SessionManagementFilter.java:126) + at org.springframework.security.web.session.SessionManagementFilter.doFilter(SessionManagementFilter.java:81) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.authentication.AnonymousAuthenticationFilter.doFilter(AnonymousAuthenticationFilter.java:105) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.servletapi.SecurityContextHolderAwareRequestFilter.doFilter(SecurityContextHolderAwareRequestFilter.java:149) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.savedrequest.RequestCacheAwareFilter.doFilter(RequestCacheAwareFilter.java:63) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at com.dc.framework.security.filter.JwtAuthenticationTokenFilter.doFilterInternal(JwtAuthenticationTokenFilter.java:43) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:111) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.authentication.logout.LogoutFilter.doFilter(LogoutFilter.java:103) + at org.springframework.security.web.authentication.logout.LogoutFilter.doFilter(LogoutFilter.java:89) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.web.filter.CorsFilter.doFilterInternal(CorsFilter.java:91) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.header.HeaderWriterFilter.doHeadersAfter(HeaderWriterFilter.java:90) + at org.springframework.security.web.header.HeaderWriterFilter.doFilterInternal(HeaderWriterFilter.java:75) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.context.SecurityContextPersistenceFilter.doFilter(SecurityContextPersistenceFilter.java:110) + at org.springframework.security.web.context.SecurityContextPersistenceFilter.doFilter(SecurityContextPersistenceFilter.java:80) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.context.request.async.WebAsyncManagerIntegrationFilter.doFilterInternal(WebAsyncManagerIntegrationFilter.java:55) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.FilterChainProxy.doFilterInternal(FilterChainProxy.java:211) + at org.springframework.security.web.FilterChainProxy.doFilter(FilterChainProxy.java:183) + at org.springframework.web.filter.DelegatingFilterProxy.invokeDelegate(DelegatingFilterProxy.java:354) + at org.springframework.web.filter.DelegatingFilterProxy.doFilter(DelegatingFilterProxy.java:267) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.RequestContextFilter.doFilterInternal(RequestContextFilter.java:100) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.FormContentFilter.doFilterInternal(FormContentFilter.java:93) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.CharacterEncodingFilter.doFilterInternal(CharacterEncodingFilter.java:201) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at com.dc.common.filter.XssFilter.doFilter(XssFilter.java:47) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:197) + at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:97) + at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:541) + at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:135) + at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:92) + at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:78) + at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:360) + at org.apache.coyote.http11.Http11Processor.service(Http11Processor.java:399) + at org.apache.coyote.AbstractProcessorLight.process(AbstractProcessorLight.java:65) + at org.apache.coyote.AbstractProtocol$ConnectionHandler.process(AbstractProtocol.java:890) + at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1743) + at org.apache.tomcat.util.net.SocketProcessorBase.run(SocketProcessorBase.java:49) + at org.apache.tomcat.util.threads.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1191) + at org.apache.tomcat.util.threads.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:659) + at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61) + at java.base/java.lang.Thread.run(Thread.java:1589) +Caused by: org.postgresql.util.PSQLException: ERROR: column "table_comment" does not exist + 位置:44 + at org.postgresql.core.v3.QueryExecutorImpl.receiveErrorResponse(QueryExecutorImpl.java:2565) + at org.postgresql.core.v3.QueryExecutorImpl.processResults(QueryExecutorImpl.java:2297) + at org.postgresql.core.v3.QueryExecutorImpl.execute(QueryExecutorImpl.java:322) + at org.postgresql.jdbc.PgStatement.executeInternal(PgStatement.java:481) + at org.postgresql.jdbc.PgStatement.execute(PgStatement.java:401) + at org.postgresql.jdbc.PgPreparedStatement.executeWithFlags(PgPreparedStatement.java:164) + at org.postgresql.jdbc.PgPreparedStatement.execute(PgPreparedStatement.java:153) + at com.alibaba.druid.filter.FilterChainImpl.preparedStatement_execute(FilterChainImpl.java:3446) + at com.alibaba.druid.filter.FilterEventAdapter.preparedStatement_execute(FilterEventAdapter.java:434) + at com.alibaba.druid.filter.FilterChainImpl.preparedStatement_execute(FilterChainImpl.java:3444) + at com.alibaba.druid.proxy.jdbc.PreparedStatementProxyImpl.execute(PreparedStatementProxyImpl.java:152) + at com.alibaba.druid.pool.DruidPooledPreparedStatement.execute(DruidPooledPreparedStatement.java:483) + at org.apache.ibatis.executor.statement.PreparedStatementHandler.query(PreparedStatementHandler.java:64) + at org.apache.ibatis.executor.statement.RoutingStatementHandler.query(RoutingStatementHandler.java:79) + at java.base/jdk.internal.reflect.DirectMethodHandleAccessor.invoke(DirectMethodHandleAccessor.java:104) + at java.base/java.lang.reflect.Method.invoke(Method.java:578) + at org.apache.ibatis.plugin.Plugin.invoke(Plugin.java:64) + at jdk.proxy2/jdk.proxy2.$Proxy118.query(Unknown Source) + at org.apache.ibatis.executor.SimpleExecutor.doQuery(SimpleExecutor.java:63) + at org.apache.ibatis.executor.BaseExecutor.queryFromDatabase(BaseExecutor.java:325) + at org.apache.ibatis.executor.BaseExecutor.query(BaseExecutor.java:156) + at org.apache.ibatis.executor.CachingExecutor.query(CachingExecutor.java:109) + at com.baomidou.mybatisplus.extension.plugins.MybatisPlusInterceptor.intercept(MybatisPlusInterceptor.java:81) + at org.apache.ibatis.plugin.Plugin.invoke(Plugin.java:62) + at jdk.proxy2/jdk.proxy2.$Proxy117.query(Unknown Source) + at com.github.pagehelper.util.ExecutorUtil.executeAutoCount(ExecutorUtil.java:169) + at com.github.pagehelper.PageInterceptor.count(PageInterceptor.java:197) + at com.github.pagehelper.PageInterceptor.intercept(PageInterceptor.java:140) + at org.apache.ibatis.plugin.Plugin.invoke(Plugin.java:62) + at jdk.proxy2/jdk.proxy2.$Proxy117.query(Unknown Source) + at org.apache.ibatis.session.defaults.DefaultSqlSession.selectList(DefaultSqlSession.java:151) + at org.apache.ibatis.session.defaults.DefaultSqlSession.selectList(DefaultSqlSession.java:145) + at org.apache.ibatis.session.defaults.DefaultSqlSession.selectList(DefaultSqlSession.java:140) + at java.base/jdk.internal.reflect.DirectMethodHandleAccessor.invoke(DirectMethodHandleAccessor.java:104) + at java.base/java.lang.reflect.Method.invoke(Method.java:578) + at org.mybatis.spring.SqlSessionTemplate$SqlSessionInterceptor.invoke(SqlSessionTemplate.java:427) + ... 131 common frames omitted +10:21:13.542 [http-nio-9000-exec-19] ERROR c.d.f.w.e.GlobalExceptionHandler - [handleRuntimeException,82] - 请求地址'/tool/gen/db/list',发生未知异常. +org.springframework.jdbc.BadSqlGrammarException: +### Error querying database. Cause: org.postgresql.util.PSQLException: ERROR: column "table_comment" does not exist + 位置:44 +### The error may exist in file [/Users/longlongxiaogege/work/mengyin/code/lianmei/myself/backup/dc-backend/data-center/dc-generator/target/classes/mapper/generator/GenTableMapper.xml] +### The error may involve com.dc.generator.mapper.GenTableMapper.selectDbTableList-Inline +### The error occurred while setting parameters +### SQL: select count(0) from ( select table_name, table_comment, create_time, update_time from information_schema.tables where table_schema = (select database()) AND table_name NOT LIKE 'qrtz_%' AND table_name NOT LIKE 'gen_%' AND table_name NOT IN (select table_name from gen_table) order by create_time desc ) tmp_count +### Cause: org.postgresql.util.PSQLException: ERROR: column "table_comment" does not exist + 位置:44 +; bad SQL grammar []; nested exception is org.postgresql.util.PSQLException: ERROR: column "table_comment" does not exist + 位置:44 + at org.springframework.jdbc.support.SQLStateSQLExceptionTranslator.doTranslate(SQLStateSQLExceptionTranslator.java:101) + at org.springframework.jdbc.support.AbstractFallbackSQLExceptionTranslator.translate(AbstractFallbackSQLExceptionTranslator.java:70) + at org.springframework.jdbc.support.AbstractFallbackSQLExceptionTranslator.translate(AbstractFallbackSQLExceptionTranslator.java:79) + at org.springframework.jdbc.support.AbstractFallbackSQLExceptionTranslator.translate(AbstractFallbackSQLExceptionTranslator.java:79) + at org.mybatis.spring.MyBatisExceptionTranslator.translateExceptionIfPossible(MyBatisExceptionTranslator.java:91) + at org.mybatis.spring.SqlSessionTemplate$SqlSessionInterceptor.invoke(SqlSessionTemplate.java:441) + at jdk.proxy2/jdk.proxy2.$Proxy113.selectList(Unknown Source) + at org.mybatis.spring.SqlSessionTemplate.selectList(SqlSessionTemplate.java:224) + at com.baomidou.mybatisplus.core.override.MybatisMapperMethod.executeForMany(MybatisMapperMethod.java:166) + at com.baomidou.mybatisplus.core.override.MybatisMapperMethod.execute(MybatisMapperMethod.java:77) + at com.baomidou.mybatisplus.core.override.MybatisMapperProxy$PlainMethodInvoker.invoke(MybatisMapperProxy.java:148) + at com.baomidou.mybatisplus.core.override.MybatisMapperProxy.invoke(MybatisMapperProxy.java:89) + at jdk.proxy3/jdk.proxy3.$Proxy182.selectDbTableList(Unknown Source) + at com.dc.generator.service.GenTableService.selectDbTableList(GenTableService.java:86) + at com.dc.generator.service.GenTableService$$FastClassBySpringCGLIB$$641d1a1.invoke(<generated>) + at org.springframework.cglib.proxy.MethodProxy.invoke(MethodProxy.java:218) + at org.springframework.aop.framework.CglibAopProxy.invokeMethod(CglibAopProxy.java:386) + at org.springframework.aop.framework.CglibAopProxy.access$000(CglibAopProxy.java:85) + at org.springframework.aop.framework.CglibAopProxy$DynamicAdvisedInterceptor.intercept(CglibAopProxy.java:704) + at com.dc.generator.service.GenTableService$$EnhancerBySpringCGLIB$$34053fd6.selectDbTableList(<generated>) + at com.dc.generator.controller.GenController.dataList(GenController.java:77) + at com.dc.generator.controller.GenController$$FastClassBySpringCGLIB$$a3bb93f7.invoke(<generated>) + at org.springframework.cglib.proxy.MethodProxy.invoke(MethodProxy.java:218) + at org.springframework.aop.framework.CglibAopProxy$CglibMethodInvocation.invokeJoinpoint(CglibAopProxy.java:793) + at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:163) + at org.springframework.aop.framework.CglibAopProxy$CglibMethodInvocation.proceed(CglibAopProxy.java:763) + at org.springframework.security.access.intercept.aopalliance.MethodSecurityInterceptor.invoke(MethodSecurityInterceptor.java:61) + at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:186) + at org.springframework.aop.framework.CglibAopProxy$CglibMethodInvocation.proceed(CglibAopProxy.java:763) + at org.springframework.aop.interceptor.ExposeInvocationInterceptor.invoke(ExposeInvocationInterceptor.java:97) + at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:186) + at org.springframework.aop.framework.CglibAopProxy$CglibMethodInvocation.proceed(CglibAopProxy.java:763) + at org.springframework.aop.framework.CglibAopProxy$DynamicAdvisedInterceptor.intercept(CglibAopProxy.java:708) + at com.dc.generator.controller.GenController$$EnhancerBySpringCGLIB$$dcea08fc.dataList(<generated>) + at java.base/jdk.internal.reflect.DirectMethodHandleAccessor.invoke(DirectMethodHandleAccessor.java:104) + at java.base/java.lang.reflect.Method.invoke(Method.java:578) + at org.springframework.web.method.support.InvocableHandlerMethod.doInvoke(InvocableHandlerMethod.java:205) + at org.springframework.web.method.support.InvocableHandlerMethod.invokeForRequest(InvocableHandlerMethod.java:150) + at org.springframework.web.servlet.mvc.method.annotation.ServletInvocableHandlerMethod.invokeAndHandle(ServletInvocableHandlerMethod.java:117) + at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.invokeHandlerMethod(RequestMappingHandlerAdapter.java:895) + at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.handleInternal(RequestMappingHandlerAdapter.java:808) + at org.springframework.web.servlet.mvc.method.AbstractHandlerMethodAdapter.handle(AbstractHandlerMethodAdapter.java:87) + at org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:1067) + at org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:963) + at org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:1006) + at org.springframework.web.servlet.FrameworkServlet.doGet(FrameworkServlet.java:898) + at javax.servlet.http.HttpServlet.service(HttpServlet.java:655) + at org.springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.java:883) + at javax.servlet.http.HttpServlet.service(HttpServlet.java:764) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:227) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:53) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:111) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:111) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at com.dc.common.filter.RepeatableFilter.doFilter(RepeatableFilter.java:35) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:327) + at org.springframework.security.web.access.intercept.FilterSecurityInterceptor.invoke(FilterSecurityInterceptor.java:115) + at org.springframework.security.web.access.intercept.FilterSecurityInterceptor.doFilter(FilterSecurityInterceptor.java:81) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.access.ExceptionTranslationFilter.doFilter(ExceptionTranslationFilter.java:121) + at org.springframework.security.web.access.ExceptionTranslationFilter.doFilter(ExceptionTranslationFilter.java:115) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.session.SessionManagementFilter.doFilter(SessionManagementFilter.java:126) + at org.springframework.security.web.session.SessionManagementFilter.doFilter(SessionManagementFilter.java:81) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.authentication.AnonymousAuthenticationFilter.doFilter(AnonymousAuthenticationFilter.java:105) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.servletapi.SecurityContextHolderAwareRequestFilter.doFilter(SecurityContextHolderAwareRequestFilter.java:149) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.savedrequest.RequestCacheAwareFilter.doFilter(RequestCacheAwareFilter.java:63) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at com.dc.framework.security.filter.JwtAuthenticationTokenFilter.doFilterInternal(JwtAuthenticationTokenFilter.java:43) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:111) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.authentication.logout.LogoutFilter.doFilter(LogoutFilter.java:103) + at org.springframework.security.web.authentication.logout.LogoutFilter.doFilter(LogoutFilter.java:89) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.web.filter.CorsFilter.doFilterInternal(CorsFilter.java:91) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.header.HeaderWriterFilter.doHeadersAfter(HeaderWriterFilter.java:90) + at org.springframework.security.web.header.HeaderWriterFilter.doFilterInternal(HeaderWriterFilter.java:75) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.context.SecurityContextPersistenceFilter.doFilter(SecurityContextPersistenceFilter.java:110) + at org.springframework.security.web.context.SecurityContextPersistenceFilter.doFilter(SecurityContextPersistenceFilter.java:80) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.context.request.async.WebAsyncManagerIntegrationFilter.doFilterInternal(WebAsyncManagerIntegrationFilter.java:55) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.FilterChainProxy.doFilterInternal(FilterChainProxy.java:211) + at org.springframework.security.web.FilterChainProxy.doFilter(FilterChainProxy.java:183) + at org.springframework.web.filter.DelegatingFilterProxy.invokeDelegate(DelegatingFilterProxy.java:354) + at org.springframework.web.filter.DelegatingFilterProxy.doFilter(DelegatingFilterProxy.java:267) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.RequestContextFilter.doFilterInternal(RequestContextFilter.java:100) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.FormContentFilter.doFilterInternal(FormContentFilter.java:93) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.CharacterEncodingFilter.doFilterInternal(CharacterEncodingFilter.java:201) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at com.dc.common.filter.XssFilter.doFilter(XssFilter.java:47) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:197) + at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:97) + at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:541) + at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:135) + at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:92) + at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:78) + at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:360) + at org.apache.coyote.http11.Http11Processor.service(Http11Processor.java:399) + at org.apache.coyote.AbstractProcessorLight.process(AbstractProcessorLight.java:65) + at org.apache.coyote.AbstractProtocol$ConnectionHandler.process(AbstractProtocol.java:890) + at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1743) + at org.apache.tomcat.util.net.SocketProcessorBase.run(SocketProcessorBase.java:49) + at org.apache.tomcat.util.threads.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1191) + at org.apache.tomcat.util.threads.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:659) + at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61) + at java.base/java.lang.Thread.run(Thread.java:1589) +Caused by: org.postgresql.util.PSQLException: ERROR: column "table_comment" does not exist + 位置:44 + at org.postgresql.core.v3.QueryExecutorImpl.receiveErrorResponse(QueryExecutorImpl.java:2565) + at org.postgresql.core.v3.QueryExecutorImpl.processResults(QueryExecutorImpl.java:2297) + at org.postgresql.core.v3.QueryExecutorImpl.execute(QueryExecutorImpl.java:322) + at org.postgresql.jdbc.PgStatement.executeInternal(PgStatement.java:481) + at org.postgresql.jdbc.PgStatement.execute(PgStatement.java:401) + at org.postgresql.jdbc.PgPreparedStatement.executeWithFlags(PgPreparedStatement.java:164) + at org.postgresql.jdbc.PgPreparedStatement.execute(PgPreparedStatement.java:153) + at com.alibaba.druid.filter.FilterChainImpl.preparedStatement_execute(FilterChainImpl.java:3446) + at com.alibaba.druid.filter.FilterEventAdapter.preparedStatement_execute(FilterEventAdapter.java:434) + at com.alibaba.druid.filter.FilterChainImpl.preparedStatement_execute(FilterChainImpl.java:3444) + at com.alibaba.druid.proxy.jdbc.PreparedStatementProxyImpl.execute(PreparedStatementProxyImpl.java:152) + at com.alibaba.druid.pool.DruidPooledPreparedStatement.execute(DruidPooledPreparedStatement.java:483) + at org.apache.ibatis.executor.statement.PreparedStatementHandler.query(PreparedStatementHandler.java:64) + at org.apache.ibatis.executor.statement.RoutingStatementHandler.query(RoutingStatementHandler.java:79) + at java.base/jdk.internal.reflect.DirectMethodHandleAccessor.invoke(DirectMethodHandleAccessor.java:104) + at java.base/java.lang.reflect.Method.invoke(Method.java:578) + at org.apache.ibatis.plugin.Plugin.invoke(Plugin.java:64) + at jdk.proxy2/jdk.proxy2.$Proxy118.query(Unknown Source) + at org.apache.ibatis.executor.SimpleExecutor.doQuery(SimpleExecutor.java:63) + at org.apache.ibatis.executor.BaseExecutor.queryFromDatabase(BaseExecutor.java:325) + at org.apache.ibatis.executor.BaseExecutor.query(BaseExecutor.java:156) + at org.apache.ibatis.executor.CachingExecutor.query(CachingExecutor.java:109) + at com.baomidou.mybatisplus.extension.plugins.MybatisPlusInterceptor.intercept(MybatisPlusInterceptor.java:81) + at org.apache.ibatis.plugin.Plugin.invoke(Plugin.java:62) + at jdk.proxy2/jdk.proxy2.$Proxy117.query(Unknown Source) + at com.github.pagehelper.util.ExecutorUtil.executeAutoCount(ExecutorUtil.java:169) + at com.github.pagehelper.PageInterceptor.count(PageInterceptor.java:197) + at com.github.pagehelper.PageInterceptor.intercept(PageInterceptor.java:140) + at org.apache.ibatis.plugin.Plugin.invoke(Plugin.java:62) + at jdk.proxy2/jdk.proxy2.$Proxy117.query(Unknown Source) + at org.apache.ibatis.session.defaults.DefaultSqlSession.selectList(DefaultSqlSession.java:151) + at org.apache.ibatis.session.defaults.DefaultSqlSession.selectList(DefaultSqlSession.java:145) + at org.apache.ibatis.session.defaults.DefaultSqlSession.selectList(DefaultSqlSession.java:140) + at java.base/jdk.internal.reflect.DirectMethodHandleAccessor.invoke(DirectMethodHandleAccessor.java:104) + at java.base/java.lang.reflect.Method.invoke(Method.java:578) + at org.mybatis.spring.SqlSessionTemplate$SqlSessionInterceptor.invoke(SqlSessionTemplate.java:427) + ... 131 common frames omitted +10:53:59.560 [restartedMain] ERROR o.s.b.d.LoggingFailureAnalysisReporter - [report,40] - + +*************************** +APPLICATION FAILED TO START +*************************** + +Description: + +Failed to bind properties under 'mybatis-plus.configuration.log-impl' to java.lang.Class<org.apache.ibatis.logging.Log>: + + Property: mybatis-plus.configuration.log-impl + Value: org.apache.ibatis.logging.slf4j.slf4jimpl + Origin: class path resource [application-mybatis.yml] - 28:14 + Reason: failed to convert java.lang.String to java.lang.Class<org.apache.ibatis.logging.Log> (caused by java.lang.ClassNotFoundException: org.apache.ibatis.logging.slf4j.slf4jimpl) + +Action: + +Update your application's configuration + +10:55:03.561 [restartedMain] ERROR o.s.b.d.LoggingFailureAnalysisReporter - [report,40] - + +*************************** +APPLICATION FAILED TO START +*************************** + +Description: + +Failed to bind properties under 'mybatis-plus.configuration.log-impl' to java.lang.Class<org.apache.ibatis.logging.Log>: + + Property: mybatis-plus.configuration.log-impl + Value: org.apache.ibatis.logging.slf4j.slf4jimpl + Origin: class path resource [application-mybatis.yml] - 28:14 + Reason: failed to convert java.lang.String to java.lang.Class<org.apache.ibatis.logging.Log> (caused by java.lang.ClassNotFoundException: org.apache.ibatis.logging.slf4j.slf4jimpl) + +Action: + +Update your application's configuration + +10:58:47.718 [restartedMain] ERROR o.s.b.d.LoggingFailureAnalysisReporter - [report,40] - + +*************************** +APPLICATION FAILED TO START +*************************** + +Description: + +Failed to bind properties under 'mybatis-plus.configuration.log-impl' to java.lang.Class<org.apache.ibatis.logging.Log>: + + Property: mybatis-plus.configuration.log-impl + Value: org.apache.ibatis.logging.slf4j.slf4jimpl + Origin: class path resource [application-mybatis.yml] - 28:14 + Reason: failed to convert java.lang.String to java.lang.Class<org.apache.ibatis.logging.Log> (caused by java.lang.ClassNotFoundException: org.apache.ibatis.logging.slf4j.slf4jimpl) + +Action: + +Update your application's configuration + +11:02:48.497 [restartedMain] ERROR o.s.b.d.LoggingFailureAnalysisReporter - [report,40] - + +*************************** +APPLICATION FAILED TO START +*************************** + +Description: + +Failed to bind properties under 'mybatis-plus.configuration' to com.baomidou.mybatisplus.core.MybatisConfiguration: + + Property: mybatis-plus.configuration.log-impl + Value: org.apache.ibatis.logging.slf4j.Slf4jLoggerImpl + Origin: class path resource [application-mybatis.yml] - 28:14 + Reason: java.lang.NoSuchMethodException: org.apache.ibatis.logging.slf4j.Slf4jLoggerImpl.<init>(java.lang.String) + +Action: + +Update your application's configuration + +11:04:20.360 [restartedMain] ERROR o.s.b.SpringApplication - [reportFailure,870] - Application run failed +org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'sysConfigService': Invocation of init method failed; nested exception is org.apache.ibatis.binding.BindingException: Invalid bound statement (not found): com.dc.system.mapper.SysConfigMapper.selectConfigList + at org.springframework.beans.factory.annotation.InitDestroyAnnotationBeanPostProcessor.postProcessBeforeInitialization(InitDestroyAnnotationBeanPostProcessor.java:160) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.applyBeanPostProcessorsBeforeInitialization(AbstractAutowireCapableBeanFactory.java:440) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.initializeBean(AbstractAutowireCapableBeanFactory.java:1796) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:620) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:542) + at org.springframework.beans.factory.support.AbstractBeanFactory.lambda$doGetBean$0(AbstractBeanFactory.java:335) + at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:234) + at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:333) + at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:208) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.preInstantiateSingletons(DefaultListableBeanFactory.java:953) + at org.springframework.context.support.AbstractApplicationContext.finishBeanFactoryInitialization(AbstractApplicationContext.java:918) + at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:583) + at org.springframework.boot.web.servlet.context.ServletWebServerApplicationContext.refresh(ServletWebServerApplicationContext.java:145) + at org.springframework.boot.SpringApplication.refresh(SpringApplication.java:780) + at org.springframework.boot.SpringApplication.refreshContext(SpringApplication.java:453) + at org.springframework.boot.SpringApplication.run(SpringApplication.java:343) + at org.springframework.boot.SpringApplication.run(SpringApplication.java:1370) + at org.springframework.boot.SpringApplication.run(SpringApplication.java:1359) + at com.dc.web.DcApplication.main(DcApplication.java:20) + at java.base/jdk.internal.reflect.DirectMethodHandleAccessor.invoke(DirectMethodHandleAccessor.java:104) + at java.base/java.lang.reflect.Method.invoke(Method.java:578) + at org.springframework.boot.devtools.restart.RestartLauncher.run(RestartLauncher.java:49) +Caused by: org.apache.ibatis.binding.BindingException: Invalid bound statement (not found): com.dc.system.mapper.SysConfigMapper.selectConfigList + at org.apache.ibatis.binding.MapperMethod$SqlCommand.<init>(MapperMethod.java:235) + at com.baomidou.mybatisplus.core.override.MybatisMapperMethod.<init>(MybatisMapperMethod.java:50) + at com.baomidou.mybatisplus.core.override.MybatisMapperProxy.lambda$cachedInvoker$0(MybatisMapperProxy.java:111) + at java.base/java.util.concurrent.ConcurrentHashMap.computeIfAbsent(ConcurrentHashMap.java:1708) + at com.baomidou.mybatisplus.core.toolkit.CollectionUtils.computeIfAbsent(CollectionUtils.java:115) + at com.baomidou.mybatisplus.core.override.MybatisMapperProxy.cachedInvoker(MybatisMapperProxy.java:98) + at com.baomidou.mybatisplus.core.override.MybatisMapperProxy.invoke(MybatisMapperProxy.java:89) + at jdk.proxy3/jdk.proxy3.$Proxy112.selectConfigList(Unknown Source) + at com.dc.system.service.SysConfigService.loadingConfigCache(SysConfigService.java:167) + at com.dc.system.service.SysConfigService.init(SysConfigService.java:39) + at java.base/jdk.internal.reflect.DirectMethodHandleAccessor.invoke(DirectMethodHandleAccessor.java:104) + at java.base/java.lang.reflect.Method.invoke(Method.java:578) + at org.springframework.beans.factory.annotation.InitDestroyAnnotationBeanPostProcessor$LifecycleElement.invoke(InitDestroyAnnotationBeanPostProcessor.java:389) + at org.springframework.beans.factory.annotation.InitDestroyAnnotationBeanPostProcessor$LifecycleMetadata.invokeInitMethods(InitDestroyAnnotationBeanPostProcessor.java:333) + at org.springframework.beans.factory.annotation.InitDestroyAnnotationBeanPostProcessor.postProcessBeforeInitialization(InitDestroyAnnotationBeanPostProcessor.java:157) + ... 21 common frames omitted +11:05:36.409 [restartedMain] ERROR o.s.b.SpringApplication - [reportFailure,870] - Application run failed +org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'sysConfigService': Invocation of init method failed; nested exception is org.apache.ibatis.binding.BindingException: Invalid bound statement (not found): com.dc.system.mapper.SysConfigMapper.selectConfigList + at org.springframework.beans.factory.annotation.InitDestroyAnnotationBeanPostProcessor.postProcessBeforeInitialization(InitDestroyAnnotationBeanPostProcessor.java:160) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.applyBeanPostProcessorsBeforeInitialization(AbstractAutowireCapableBeanFactory.java:440) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.initializeBean(AbstractAutowireCapableBeanFactory.java:1796) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:620) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:542) + at org.springframework.beans.factory.support.AbstractBeanFactory.lambda$doGetBean$0(AbstractBeanFactory.java:335) + at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:234) + at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:333) + at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:208) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.preInstantiateSingletons(DefaultListableBeanFactory.java:953) + at org.springframework.context.support.AbstractApplicationContext.finishBeanFactoryInitialization(AbstractApplicationContext.java:918) + at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:583) + at org.springframework.boot.web.servlet.context.ServletWebServerApplicationContext.refresh(ServletWebServerApplicationContext.java:145) + at org.springframework.boot.SpringApplication.refresh(SpringApplication.java:780) + at org.springframework.boot.SpringApplication.refreshContext(SpringApplication.java:453) + at org.springframework.boot.SpringApplication.run(SpringApplication.java:343) + at org.springframework.boot.SpringApplication.run(SpringApplication.java:1370) + at org.springframework.boot.SpringApplication.run(SpringApplication.java:1359) + at com.dc.web.DcApplication.main(DcApplication.java:20) + at java.base/jdk.internal.reflect.DirectMethodHandleAccessor.invoke(DirectMethodHandleAccessor.java:104) + at java.base/java.lang.reflect.Method.invoke(Method.java:578) + at org.springframework.boot.devtools.restart.RestartLauncher.run(RestartLauncher.java:49) +Caused by: org.apache.ibatis.binding.BindingException: Invalid bound statement (not found): com.dc.system.mapper.SysConfigMapper.selectConfigList + at org.apache.ibatis.binding.MapperMethod$SqlCommand.<init>(MapperMethod.java:235) + at com.baomidou.mybatisplus.core.override.MybatisMapperMethod.<init>(MybatisMapperMethod.java:50) + at com.baomidou.mybatisplus.core.override.MybatisMapperProxy.lambda$cachedInvoker$0(MybatisMapperProxy.java:111) + at java.base/java.util.concurrent.ConcurrentHashMap.computeIfAbsent(ConcurrentHashMap.java:1708) + at com.baomidou.mybatisplus.core.toolkit.CollectionUtils.computeIfAbsent(CollectionUtils.java:115) + at com.baomidou.mybatisplus.core.override.MybatisMapperProxy.cachedInvoker(MybatisMapperProxy.java:98) + at com.baomidou.mybatisplus.core.override.MybatisMapperProxy.invoke(MybatisMapperProxy.java:89) + at jdk.proxy3/jdk.proxy3.$Proxy112.selectConfigList(Unknown Source) + at com.dc.system.service.SysConfigService.loadingConfigCache(SysConfigService.java:167) + at com.dc.system.service.SysConfigService.init(SysConfigService.java:39) + at java.base/jdk.internal.reflect.DirectMethodHandleAccessor.invoke(DirectMethodHandleAccessor.java:104) + at java.base/java.lang.reflect.Method.invoke(Method.java:578) + at org.springframework.beans.factory.annotation.InitDestroyAnnotationBeanPostProcessor$LifecycleElement.invoke(InitDestroyAnnotationBeanPostProcessor.java:389) + at org.springframework.beans.factory.annotation.InitDestroyAnnotationBeanPostProcessor$LifecycleMetadata.invokeInitMethods(InitDestroyAnnotationBeanPostProcessor.java:333) + at org.springframework.beans.factory.annotation.InitDestroyAnnotationBeanPostProcessor.postProcessBeforeInitialization(InitDestroyAnnotationBeanPostProcessor.java:157) + ... 21 common frames omitted +11:13:28.588 [restartedMain] ERROR o.s.b.SpringApplication - [reportFailure,870] - Application run failed +org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'sysConfigService': Invocation of init method failed; nested exception is org.apache.ibatis.binding.BindingException: Invalid bound statement (not found): com.dc.system.mapper.SysConfigMapper.selectConfigList + at org.springframework.beans.factory.annotation.InitDestroyAnnotationBeanPostProcessor.postProcessBeforeInitialization(InitDestroyAnnotationBeanPostProcessor.java:160) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.applyBeanPostProcessorsBeforeInitialization(AbstractAutowireCapableBeanFactory.java:440) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.initializeBean(AbstractAutowireCapableBeanFactory.java:1796) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:620) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:542) + at org.springframework.beans.factory.support.AbstractBeanFactory.lambda$doGetBean$0(AbstractBeanFactory.java:335) + at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:234) + at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:333) + at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:208) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.preInstantiateSingletons(DefaultListableBeanFactory.java:953) + at org.springframework.context.support.AbstractApplicationContext.finishBeanFactoryInitialization(AbstractApplicationContext.java:918) + at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:583) + at org.springframework.boot.web.servlet.context.ServletWebServerApplicationContext.refresh(ServletWebServerApplicationContext.java:145) + at org.springframework.boot.SpringApplication.refresh(SpringApplication.java:780) + at org.springframework.boot.SpringApplication.refreshContext(SpringApplication.java:453) + at org.springframework.boot.SpringApplication.run(SpringApplication.java:343) + at org.springframework.boot.SpringApplication.run(SpringApplication.java:1370) + at org.springframework.boot.SpringApplication.run(SpringApplication.java:1359) + at com.dc.web.DcApplication.main(DcApplication.java:20) + at java.base/jdk.internal.reflect.DirectMethodHandleAccessor.invoke(DirectMethodHandleAccessor.java:104) + at java.base/java.lang.reflect.Method.invoke(Method.java:578) + at org.springframework.boot.devtools.restart.RestartLauncher.run(RestartLauncher.java:49) +Caused by: org.apache.ibatis.binding.BindingException: Invalid bound statement (not found): com.dc.system.mapper.SysConfigMapper.selectConfigList + at org.apache.ibatis.binding.MapperMethod$SqlCommand.<init>(MapperMethod.java:235) + at com.baomidou.mybatisplus.core.override.MybatisMapperMethod.<init>(MybatisMapperMethod.java:50) + at com.baomidou.mybatisplus.core.override.MybatisMapperProxy.lambda$cachedInvoker$0(MybatisMapperProxy.java:111) + at java.base/java.util.concurrent.ConcurrentHashMap.computeIfAbsent(ConcurrentHashMap.java:1708) + at com.baomidou.mybatisplus.core.toolkit.CollectionUtils.computeIfAbsent(CollectionUtils.java:115) + at com.baomidou.mybatisplus.core.override.MybatisMapperProxy.cachedInvoker(MybatisMapperProxy.java:98) + at com.baomidou.mybatisplus.core.override.MybatisMapperProxy.invoke(MybatisMapperProxy.java:89) + at jdk.proxy3/jdk.proxy3.$Proxy112.selectConfigList(Unknown Source) + at com.dc.system.service.SysConfigService.loadingConfigCache(SysConfigService.java:167) + at com.dc.system.service.SysConfigService.init(SysConfigService.java:39) + at java.base/jdk.internal.reflect.DirectMethodHandleAccessor.invoke(DirectMethodHandleAccessor.java:104) + at java.base/java.lang.reflect.Method.invoke(Method.java:578) + at org.springframework.beans.factory.annotation.InitDestroyAnnotationBeanPostProcessor$LifecycleElement.invoke(InitDestroyAnnotationBeanPostProcessor.java:389) + at org.springframework.beans.factory.annotation.InitDestroyAnnotationBeanPostProcessor$LifecycleMetadata.invokeInitMethods(InitDestroyAnnotationBeanPostProcessor.java:333) + at org.springframework.beans.factory.annotation.InitDestroyAnnotationBeanPostProcessor.postProcessBeforeInitialization(InitDestroyAnnotationBeanPostProcessor.java:157) + ... 21 common frames omitted +11:16:12.755 [http-nio-9000-exec-6] ERROR c.d.f.w.e.GlobalExceptionHandler - [handleRuntimeException,82] - 请求地址'/tool/gen/list',发生未知异常. +org.apache.ibatis.binding.BindingException: Invalid bound statement (not found): com.dc.generator.mapper.GenTableMapper.selectGenTableList + at org.apache.ibatis.binding.MapperMethod$SqlCommand.<init>(MapperMethod.java:235) + at com.baomidou.mybatisplus.core.override.MybatisMapperMethod.<init>(MybatisMapperMethod.java:50) + at com.baomidou.mybatisplus.core.override.MybatisMapperProxy.lambda$cachedInvoker$0(MybatisMapperProxy.java:111) + at java.base/java.util.concurrent.ConcurrentHashMap.computeIfAbsent(ConcurrentHashMap.java:1708) + at com.baomidou.mybatisplus.core.toolkit.CollectionUtils.computeIfAbsent(CollectionUtils.java:115) + at com.baomidou.mybatisplus.core.override.MybatisMapperProxy.cachedInvoker(MybatisMapperProxy.java:98) + at com.baomidou.mybatisplus.core.override.MybatisMapperProxy.invoke(MybatisMapperProxy.java:89) + at jdk.proxy3/jdk.proxy3.$Proxy182.selectGenTableList(Unknown Source) + at com.dc.generator.service.GenTableService.selectGenTableList(GenTableService.java:75) + at com.dc.generator.service.GenTableService$$FastClassBySpringCGLIB$$641d1a1.invoke(<generated>) + at org.springframework.cglib.proxy.MethodProxy.invoke(MethodProxy.java:218) + at org.springframework.aop.framework.CglibAopProxy.invokeMethod(CglibAopProxy.java:386) + at org.springframework.aop.framework.CglibAopProxy.access$000(CglibAopProxy.java:85) + at org.springframework.aop.framework.CglibAopProxy$DynamicAdvisedInterceptor.intercept(CglibAopProxy.java:704) + at com.dc.generator.service.GenTableService$$EnhancerBySpringCGLIB$$a46ccbd2.selectGenTableList(<generated>) + at com.dc.generator.controller.GenController.genList(GenController.java:48) + at com.dc.generator.controller.GenController$$FastClassBySpringCGLIB$$a3bb93f7.invoke(<generated>) + at org.springframework.cglib.proxy.MethodProxy.invoke(MethodProxy.java:218) + at org.springframework.aop.framework.CglibAopProxy$CglibMethodInvocation.invokeJoinpoint(CglibAopProxy.java:793) + at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:163) + at org.springframework.aop.framework.CglibAopProxy$CglibMethodInvocation.proceed(CglibAopProxy.java:763) + at org.springframework.security.access.intercept.aopalliance.MethodSecurityInterceptor.invoke(MethodSecurityInterceptor.java:61) + at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:186) + at org.springframework.aop.framework.CglibAopProxy$CglibMethodInvocation.proceed(CglibAopProxy.java:763) + at org.springframework.aop.interceptor.ExposeInvocationInterceptor.invoke(ExposeInvocationInterceptor.java:97) + at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:186) + at org.springframework.aop.framework.CglibAopProxy$CglibMethodInvocation.proceed(CglibAopProxy.java:763) + at org.springframework.aop.framework.CglibAopProxy$DynamicAdvisedInterceptor.intercept(CglibAopProxy.java:708) + at com.dc.generator.controller.GenController$$EnhancerBySpringCGLIB$$b823cbb9.genList(<generated>) + at java.base/jdk.internal.reflect.DirectMethodHandleAccessor.invoke(DirectMethodHandleAccessor.java:104) + at java.base/java.lang.reflect.Method.invoke(Method.java:578) + at org.springframework.web.method.support.InvocableHandlerMethod.doInvoke(InvocableHandlerMethod.java:205) + at org.springframework.web.method.support.InvocableHandlerMethod.invokeForRequest(InvocableHandlerMethod.java:150) + at org.springframework.web.servlet.mvc.method.annotation.ServletInvocableHandlerMethod.invokeAndHandle(ServletInvocableHandlerMethod.java:117) + at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.invokeHandlerMethod(RequestMappingHandlerAdapter.java:895) + at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.handleInternal(RequestMappingHandlerAdapter.java:808) + at org.springframework.web.servlet.mvc.method.AbstractHandlerMethodAdapter.handle(AbstractHandlerMethodAdapter.java:87) + at org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:1067) + at org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:963) + at org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:1006) + at org.springframework.web.servlet.FrameworkServlet.doGet(FrameworkServlet.java:898) + at javax.servlet.http.HttpServlet.service(HttpServlet.java:655) + at org.springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.java:883) + at javax.servlet.http.HttpServlet.service(HttpServlet.java:764) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:227) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:53) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:111) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:111) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at com.dc.common.filter.RepeatableFilter.doFilter(RepeatableFilter.java:35) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:327) + at org.springframework.security.web.access.intercept.FilterSecurityInterceptor.invoke(FilterSecurityInterceptor.java:115) + at org.springframework.security.web.access.intercept.FilterSecurityInterceptor.doFilter(FilterSecurityInterceptor.java:81) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.access.ExceptionTranslationFilter.doFilter(ExceptionTranslationFilter.java:121) + at org.springframework.security.web.access.ExceptionTranslationFilter.doFilter(ExceptionTranslationFilter.java:115) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.session.SessionManagementFilter.doFilter(SessionManagementFilter.java:126) + at org.springframework.security.web.session.SessionManagementFilter.doFilter(SessionManagementFilter.java:81) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.authentication.AnonymousAuthenticationFilter.doFilter(AnonymousAuthenticationFilter.java:105) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.servletapi.SecurityContextHolderAwareRequestFilter.doFilter(SecurityContextHolderAwareRequestFilter.java:149) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.savedrequest.RequestCacheAwareFilter.doFilter(RequestCacheAwareFilter.java:63) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at com.dc.framework.security.filter.JwtAuthenticationTokenFilter.doFilterInternal(JwtAuthenticationTokenFilter.java:43) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:111) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.authentication.logout.LogoutFilter.doFilter(LogoutFilter.java:103) + at org.springframework.security.web.authentication.logout.LogoutFilter.doFilter(LogoutFilter.java:89) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.web.filter.CorsFilter.doFilterInternal(CorsFilter.java:91) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.header.HeaderWriterFilter.doHeadersAfter(HeaderWriterFilter.java:90) + at org.springframework.security.web.header.HeaderWriterFilter.doFilterInternal(HeaderWriterFilter.java:75) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.context.SecurityContextPersistenceFilter.doFilter(SecurityContextPersistenceFilter.java:110) + at org.springframework.security.web.context.SecurityContextPersistenceFilter.doFilter(SecurityContextPersistenceFilter.java:80) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.context.request.async.WebAsyncManagerIntegrationFilter.doFilterInternal(WebAsyncManagerIntegrationFilter.java:55) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.FilterChainProxy.doFilterInternal(FilterChainProxy.java:211) + at org.springframework.security.web.FilterChainProxy.doFilter(FilterChainProxy.java:183) + at org.springframework.web.filter.DelegatingFilterProxy.invokeDelegate(DelegatingFilterProxy.java:354) + at org.springframework.web.filter.DelegatingFilterProxy.doFilter(DelegatingFilterProxy.java:267) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.RequestContextFilter.doFilterInternal(RequestContextFilter.java:100) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.FormContentFilter.doFilterInternal(FormContentFilter.java:93) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.CharacterEncodingFilter.doFilterInternal(CharacterEncodingFilter.java:201) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at com.dc.common.filter.XssFilter.doFilter(XssFilter.java:47) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:197) + at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:97) + at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:541) + at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:135) + at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:92) + at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:78) + at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:360) + at org.apache.coyote.http11.Http11Processor.service(Http11Processor.java:399) + at org.apache.coyote.AbstractProcessorLight.process(AbstractProcessorLight.java:65) + at org.apache.coyote.AbstractProtocol$ConnectionHandler.process(AbstractProtocol.java:890) + at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1743) + at org.apache.tomcat.util.net.SocketProcessorBase.run(SocketProcessorBase.java:49) + at org.apache.tomcat.util.threads.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1191) + at org.apache.tomcat.util.threads.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:659) + at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61) + at java.base/java.lang.Thread.run(Thread.java:1589) +11:17:51.488 [http-nio-9000-exec-37] ERROR c.d.f.w.e.GlobalExceptionHandler - [handleRuntimeException,82] - 请求地址'/tool/gen/list',发生未知异常. +org.apache.ibatis.binding.BindingException: Invalid bound statement (not found): com.dc.generator.mapper.GenTableMapper.selectGenTableList + at org.apache.ibatis.binding.MapperMethod$SqlCommand.<init>(MapperMethod.java:235) + at com.baomidou.mybatisplus.core.override.MybatisMapperMethod.<init>(MybatisMapperMethod.java:50) + at com.baomidou.mybatisplus.core.override.MybatisMapperProxy.lambda$cachedInvoker$0(MybatisMapperProxy.java:111) + at java.base/java.util.concurrent.ConcurrentHashMap.computeIfAbsent(ConcurrentHashMap.java:1708) + at com.baomidou.mybatisplus.core.toolkit.CollectionUtils.computeIfAbsent(CollectionUtils.java:115) + at com.baomidou.mybatisplus.core.override.MybatisMapperProxy.cachedInvoker(MybatisMapperProxy.java:98) + at com.baomidou.mybatisplus.core.override.MybatisMapperProxy.invoke(MybatisMapperProxy.java:89) + at jdk.proxy3/jdk.proxy3.$Proxy182.selectGenTableList(Unknown Source) + at com.dc.generator.service.GenTableService.selectGenTableList(GenTableService.java:75) + at com.dc.generator.service.GenTableService$$FastClassBySpringCGLIB$$641d1a1.invoke(<generated>) + at org.springframework.cglib.proxy.MethodProxy.invoke(MethodProxy.java:218) + at org.springframework.aop.framework.CglibAopProxy.invokeMethod(CglibAopProxy.java:386) + at org.springframework.aop.framework.CglibAopProxy.access$000(CglibAopProxy.java:85) + at org.springframework.aop.framework.CglibAopProxy$DynamicAdvisedInterceptor.intercept(CglibAopProxy.java:704) + at com.dc.generator.service.GenTableService$$EnhancerBySpringCGLIB$$a46ccbd2.selectGenTableList(<generated>) + at com.dc.generator.controller.GenController.genList(GenController.java:48) + at com.dc.generator.controller.GenController$$FastClassBySpringCGLIB$$a3bb93f7.invoke(<generated>) + at org.springframework.cglib.proxy.MethodProxy.invoke(MethodProxy.java:218) + at org.springframework.aop.framework.CglibAopProxy$CglibMethodInvocation.invokeJoinpoint(CglibAopProxy.java:793) + at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:163) + at org.springframework.aop.framework.CglibAopProxy$CglibMethodInvocation.proceed(CglibAopProxy.java:763) + at org.springframework.security.access.intercept.aopalliance.MethodSecurityInterceptor.invoke(MethodSecurityInterceptor.java:61) + at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:186) + at org.springframework.aop.framework.CglibAopProxy$CglibMethodInvocation.proceed(CglibAopProxy.java:763) + at org.springframework.aop.interceptor.ExposeInvocationInterceptor.invoke(ExposeInvocationInterceptor.java:97) + at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:186) + at org.springframework.aop.framework.CglibAopProxy$CglibMethodInvocation.proceed(CglibAopProxy.java:763) + at org.springframework.aop.framework.CglibAopProxy$DynamicAdvisedInterceptor.intercept(CglibAopProxy.java:708) + at com.dc.generator.controller.GenController$$EnhancerBySpringCGLIB$$b823cbb9.genList(<generated>) + at java.base/jdk.internal.reflect.DirectMethodHandleAccessor.invoke(DirectMethodHandleAccessor.java:104) + at java.base/java.lang.reflect.Method.invoke(Method.java:578) + at org.springframework.web.method.support.InvocableHandlerMethod.doInvoke(InvocableHandlerMethod.java:205) + at org.springframework.web.method.support.InvocableHandlerMethod.invokeForRequest(InvocableHandlerMethod.java:150) + at org.springframework.web.servlet.mvc.method.annotation.ServletInvocableHandlerMethod.invokeAndHandle(ServletInvocableHandlerMethod.java:117) + at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.invokeHandlerMethod(RequestMappingHandlerAdapter.java:895) + at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.handleInternal(RequestMappingHandlerAdapter.java:808) + at org.springframework.web.servlet.mvc.method.AbstractHandlerMethodAdapter.handle(AbstractHandlerMethodAdapter.java:87) + at org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:1067) + at org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:963) + at org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:1006) + at org.springframework.web.servlet.FrameworkServlet.doGet(FrameworkServlet.java:898) + at javax.servlet.http.HttpServlet.service(HttpServlet.java:655) + at org.springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.java:883) + at javax.servlet.http.HttpServlet.service(HttpServlet.java:764) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:227) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:53) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:111) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:111) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at com.dc.common.filter.RepeatableFilter.doFilter(RepeatableFilter.java:35) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:327) + at org.springframework.security.web.access.intercept.FilterSecurityInterceptor.invoke(FilterSecurityInterceptor.java:115) + at org.springframework.security.web.access.intercept.FilterSecurityInterceptor.doFilter(FilterSecurityInterceptor.java:81) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.access.ExceptionTranslationFilter.doFilter(ExceptionTranslationFilter.java:121) + at org.springframework.security.web.access.ExceptionTranslationFilter.doFilter(ExceptionTranslationFilter.java:115) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.session.SessionManagementFilter.doFilter(SessionManagementFilter.java:126) + at org.springframework.security.web.session.SessionManagementFilter.doFilter(SessionManagementFilter.java:81) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.authentication.AnonymousAuthenticationFilter.doFilter(AnonymousAuthenticationFilter.java:105) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.servletapi.SecurityContextHolderAwareRequestFilter.doFilter(SecurityContextHolderAwareRequestFilter.java:149) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.savedrequest.RequestCacheAwareFilter.doFilter(RequestCacheAwareFilter.java:63) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at com.dc.framework.security.filter.JwtAuthenticationTokenFilter.doFilterInternal(JwtAuthenticationTokenFilter.java:43) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:111) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.authentication.logout.LogoutFilter.doFilter(LogoutFilter.java:103) + at org.springframework.security.web.authentication.logout.LogoutFilter.doFilter(LogoutFilter.java:89) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.web.filter.CorsFilter.doFilterInternal(CorsFilter.java:91) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.header.HeaderWriterFilter.doHeadersAfter(HeaderWriterFilter.java:90) + at org.springframework.security.web.header.HeaderWriterFilter.doFilterInternal(HeaderWriterFilter.java:75) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.context.SecurityContextPersistenceFilter.doFilter(SecurityContextPersistenceFilter.java:110) + at org.springframework.security.web.context.SecurityContextPersistenceFilter.doFilter(SecurityContextPersistenceFilter.java:80) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.context.request.async.WebAsyncManagerIntegrationFilter.doFilterInternal(WebAsyncManagerIntegrationFilter.java:55) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.FilterChainProxy.doFilterInternal(FilterChainProxy.java:211) + at org.springframework.security.web.FilterChainProxy.doFilter(FilterChainProxy.java:183) + at org.springframework.web.filter.DelegatingFilterProxy.invokeDelegate(DelegatingFilterProxy.java:354) + at org.springframework.web.filter.DelegatingFilterProxy.doFilter(DelegatingFilterProxy.java:267) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.RequestContextFilter.doFilterInternal(RequestContextFilter.java:100) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.FormContentFilter.doFilterInternal(FormContentFilter.java:93) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.CharacterEncodingFilter.doFilterInternal(CharacterEncodingFilter.java:201) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at com.dc.common.filter.XssFilter.doFilter(XssFilter.java:47) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:197) + at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:97) + at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:541) + at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:135) + at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:92) + at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:78) + at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:360) + at org.apache.coyote.http11.Http11Processor.service(Http11Processor.java:399) + at org.apache.coyote.AbstractProcessorLight.process(AbstractProcessorLight.java:65) + at org.apache.coyote.AbstractProtocol$ConnectionHandler.process(AbstractProtocol.java:890) + at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1743) + at org.apache.tomcat.util.net.SocketProcessorBase.run(SocketProcessorBase.java:49) + at org.apache.tomcat.util.threads.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1191) + at org.apache.tomcat.util.threads.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:659) + at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61) + at java.base/java.lang.Thread.run(Thread.java:1589) +11:22:41.034 [restartedMain] ERROR o.s.b.SpringApplication - [reportFailure,870] - Application run failed +org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'accessoryService': Unsatisfied dependency expressed through field 'baseMapper'; nested exception is org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'accessoryMapper' defined in file [/Users/longlongxiaogege/work/mengyin/code/lianmei/myself/backup/dc-backend/data-center/dc-system/target/classes/com/dc/system/mapper/AccessoryMapper.class]: Unsatisfied dependency expressed through bean property 'sqlSessionFactory'; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'sqlSessionFactory' defined in class path resource [com/dc/framework/config/DataSourceConfiguration.class]: Bean instantiation via factory method failed; nested exception is org.springframework.beans.BeanInstantiationException: Failed to instantiate [org.apache.ibatis.session.SqlSessionFactory]: Factory method 'sqlSessionFactory' threw exception; nested exception is java.io.IOException: Failed to parse mapping resource: 'file [/Users/longlongxiaogege/work/mengyin/code/lianmei/myself/backup/dc-backend/data-center/dc-generator/target/classes/mapper/generator/GenTableMapper.xml]' + at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor$AutowiredFieldElement.resolveFieldValue(AutowiredAnnotationBeanPostProcessor.java:659) + at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor$AutowiredFieldElement.inject(AutowiredAnnotationBeanPostProcessor.java:639) + at org.springframework.beans.factory.annotation.InjectionMetadata.inject(InjectionMetadata.java:119) + at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor.postProcessProperties(AutowiredAnnotationBeanPostProcessor.java:399) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.populateBean(AbstractAutowireCapableBeanFactory.java:1431) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:619) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:542) + at org.springframework.beans.factory.support.AbstractBeanFactory.lambda$doGetBean$0(AbstractBeanFactory.java:335) + at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:234) + at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:333) + at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:208) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.preInstantiateSingletons(DefaultListableBeanFactory.java:953) + at org.springframework.context.support.AbstractApplicationContext.finishBeanFactoryInitialization(AbstractApplicationContext.java:918) + at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:583) + at org.springframework.boot.web.servlet.context.ServletWebServerApplicationContext.refresh(ServletWebServerApplicationContext.java:145) + at org.springframework.boot.SpringApplication.refresh(SpringApplication.java:780) + at org.springframework.boot.SpringApplication.refreshContext(SpringApplication.java:453) + at org.springframework.boot.SpringApplication.run(SpringApplication.java:343) + at org.springframework.boot.SpringApplication.run(SpringApplication.java:1370) + at org.springframework.boot.SpringApplication.run(SpringApplication.java:1359) + at com.dc.web.DcApplication.main(DcApplication.java:20) + at java.base/jdk.internal.reflect.DirectMethodHandleAccessor.invoke(DirectMethodHandleAccessor.java:104) + at java.base/java.lang.reflect.Method.invoke(Method.java:578) + at org.springframework.boot.devtools.restart.RestartLauncher.run(RestartLauncher.java:49) +Caused by: org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'accessoryMapper' defined in file [/Users/longlongxiaogege/work/mengyin/code/lianmei/myself/backup/dc-backend/data-center/dc-system/target/classes/com/dc/system/mapper/AccessoryMapper.class]: Unsatisfied dependency expressed through bean property 'sqlSessionFactory'; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'sqlSessionFactory' defined in class path resource [com/dc/framework/config/DataSourceConfiguration.class]: Bean instantiation via factory method failed; nested exception is org.springframework.beans.BeanInstantiationException: Failed to instantiate [org.apache.ibatis.session.SqlSessionFactory]: Factory method 'sqlSessionFactory' threw exception; nested exception is java.io.IOException: Failed to parse mapping resource: 'file [/Users/longlongxiaogege/work/mengyin/code/lianmei/myself/backup/dc-backend/data-center/dc-generator/target/classes/mapper/generator/GenTableMapper.xml]' + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.autowireByType(AbstractAutowireCapableBeanFactory.java:1534) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.populateBean(AbstractAutowireCapableBeanFactory.java:1417) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:619) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:542) + at org.springframework.beans.factory.support.AbstractBeanFactory.lambda$doGetBean$0(AbstractBeanFactory.java:335) + at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:234) + at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:333) + at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:208) + at org.springframework.beans.factory.config.DependencyDescriptor.resolveCandidate(DependencyDescriptor.java:276) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.doResolveDependency(DefaultListableBeanFactory.java:1389) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.resolveDependency(DefaultListableBeanFactory.java:1309) + at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor$AutowiredFieldElement.resolveFieldValue(AutowiredAnnotationBeanPostProcessor.java:656) + ... 23 common frames omitted +Caused by: org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'sqlSessionFactory' defined in class path resource [com/dc/framework/config/DataSourceConfiguration.class]: Bean instantiation via factory method failed; nested exception is org.springframework.beans.BeanInstantiationException: Failed to instantiate [org.apache.ibatis.session.SqlSessionFactory]: Factory method 'sqlSessionFactory' threw exception; nested exception is java.io.IOException: Failed to parse mapping resource: 'file [/Users/longlongxiaogege/work/mengyin/code/lianmei/myself/backup/dc-backend/data-center/dc-generator/target/classes/mapper/generator/GenTableMapper.xml]' + at org.springframework.beans.factory.support.ConstructorResolver.instantiate(ConstructorResolver.java:658) + at org.springframework.beans.factory.support.ConstructorResolver.instantiateUsingFactoryMethod(ConstructorResolver.java:638) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.instantiateUsingFactoryMethod(AbstractAutowireCapableBeanFactory.java:1352) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBeanInstance(AbstractAutowireCapableBeanFactory.java:1195) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:582) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:542) + at org.springframework.beans.factory.support.AbstractBeanFactory.lambda$doGetBean$0(AbstractBeanFactory.java:335) + at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:234) + at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:333) + at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:208) + at org.springframework.beans.factory.config.DependencyDescriptor.resolveCandidate(DependencyDescriptor.java:276) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.doResolveDependency(DefaultListableBeanFactory.java:1389) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.resolveDependency(DefaultListableBeanFactory.java:1309) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.autowireByType(AbstractAutowireCapableBeanFactory.java:1519) + ... 34 common frames omitted +Caused by: org.springframework.beans.BeanInstantiationException: Failed to instantiate [org.apache.ibatis.session.SqlSessionFactory]: Factory method 'sqlSessionFactory' threw exception; nested exception is java.io.IOException: Failed to parse mapping resource: 'file [/Users/longlongxiaogege/work/mengyin/code/lianmei/myself/backup/dc-backend/data-center/dc-generator/target/classes/mapper/generator/GenTableMapper.xml]' + at org.springframework.beans.factory.support.SimpleInstantiationStrategy.instantiate(SimpleInstantiationStrategy.java:185) + at org.springframework.beans.factory.support.ConstructorResolver.instantiate(ConstructorResolver.java:653) + ... 47 common frames omitted +Caused by: java.io.IOException: Failed to parse mapping resource: 'file [/Users/longlongxiaogege/work/mengyin/code/lianmei/myself/backup/dc-backend/data-center/dc-generator/target/classes/mapper/generator/GenTableMapper.xml]' + at com.baomidou.mybatisplus.extension.spring.MybatisSqlSessionFactoryBean.buildSqlSessionFactory(MybatisSqlSessionFactoryBean.java:575) + at com.baomidou.mybatisplus.extension.spring.MybatisSqlSessionFactoryBean.afterPropertiesSet(MybatisSqlSessionFactoryBean.java:444) + at com.baomidou.mybatisplus.extension.spring.MybatisSqlSessionFactoryBean.getObject(MybatisSqlSessionFactoryBean.java:608) + at com.dc.framework.config.DataSourceConfiguration.sqlSessionFactory(DataSourceConfiguration.java:109) + at com.dc.framework.config.DataSourceConfiguration$$EnhancerBySpringCGLIB$$f69724ad.CGLIB$sqlSessionFactory$1(<generated>) + at com.dc.framework.config.DataSourceConfiguration$$EnhancerBySpringCGLIB$$f69724ad$$FastClassBySpringCGLIB$$3926ce55.invoke(<generated>) + at org.springframework.cglib.proxy.MethodProxy.invokeSuper(MethodProxy.java:244) + at org.springframework.context.annotation.ConfigurationClassEnhancer$BeanMethodInterceptor.intercept(ConfigurationClassEnhancer.java:331) + at com.dc.framework.config.DataSourceConfiguration$$EnhancerBySpringCGLIB$$f69724ad.sqlSessionFactory(<generated>) + at java.base/jdk.internal.reflect.DirectMethodHandleAccessor.invoke(DirectMethodHandleAccessor.java:104) + at java.base/java.lang.reflect.Method.invoke(Method.java:578) + at org.springframework.beans.factory.support.SimpleInstantiationStrategy.instantiate(SimpleInstantiationStrategy.java:154) + ... 48 common frames omitted +Caused by: org.apache.ibatis.builder.BuilderException: Error creating document instance. Cause: org.xml.sax.SAXParseException; lineNumber: 4; columnNumber: 55; 前言中不允许有内容。 + at org.apache.ibatis.parsing.XPathParser.createDocument(XPathParser.java:263) + at org.apache.ibatis.parsing.XPathParser.<init>(XPathParser.java:127) + at org.apache.ibatis.builder.xml.XMLMapperBuilder.<init>(XMLMapperBuilder.java:81) + at com.baomidou.mybatisplus.extension.spring.MybatisSqlSessionFactoryBean.buildSqlSessionFactory(MybatisSqlSessionFactoryBean.java:572) + ... 59 common frames omitted +Caused by: org.xml.sax.SAXParseException: 前言中不允许有内容。 + at java.xml/com.sun.org.apache.xerces.internal.util.ErrorHandlerWrapper.createSAXParseException(ErrorHandlerWrapper.java:204) + at java.xml/com.sun.org.apache.xerces.internal.util.ErrorHandlerWrapper.fatalError(ErrorHandlerWrapper.java:178) + at java.xml/com.sun.org.apache.xerces.internal.impl.XMLErrorReporter.reportError(XMLErrorReporter.java:400) + at java.xml/com.sun.org.apache.xerces.internal.impl.XMLErrorReporter.reportError(XMLErrorReporter.java:327) + at java.xml/com.sun.org.apache.xerces.internal.impl.XMLScanner.reportFatalError(XMLScanner.java:1465) + at java.xml/com.sun.org.apache.xerces.internal.impl.XMLDocumentScannerImpl$PrologDriver.next(XMLDocumentScannerImpl.java:978) + at java.xml/com.sun.org.apache.xerces.internal.impl.XMLDocumentScannerImpl.next(XMLDocumentScannerImpl.java:605) + at java.xml/com.sun.org.apache.xerces.internal.impl.XMLDocumentFragmentScannerImpl.scanDocument(XMLDocumentFragmentScannerImpl.java:542) + at java.xml/com.sun.org.apache.xerces.internal.parsers.XML11Configuration.parse(XML11Configuration.java:889) + at java.xml/com.sun.org.apache.xerces.internal.parsers.XML11Configuration.parse(XML11Configuration.java:825) + at java.xml/com.sun.org.apache.xerces.internal.parsers.XMLParser.parse(XMLParser.java:141) + at java.xml/com.sun.org.apache.xerces.internal.parsers.DOMParser.parse(DOMParser.java:247) + at java.xml/com.sun.org.apache.xerces.internal.jaxp.DocumentBuilderImpl.parse(DocumentBuilderImpl.java:342) + at org.apache.ibatis.parsing.XPathParser.createDocument(XPathParser.java:261) + ... 62 common frames omitted +11:22:44.068 [restartedMain] ERROR o.s.b.SpringApplication - [reportFailure,870] - Application run failed +org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'accessoryService': Unsatisfied dependency expressed through field 'baseMapper'; nested exception is org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'accessoryMapper' defined in file [/Users/longlongxiaogege/work/mengyin/code/lianmei/myself/backup/dc-backend/data-center/dc-system/target/classes/com/dc/system/mapper/AccessoryMapper.class]: Unsatisfied dependency expressed through bean property 'sqlSessionFactory'; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'sqlSessionFactory' defined in class path resource [com/dc/framework/config/DataSourceConfiguration.class]: Bean instantiation via factory method failed; nested exception is org.springframework.beans.BeanInstantiationException: Failed to instantiate [org.apache.ibatis.session.SqlSessionFactory]: Factory method 'sqlSessionFactory' threw exception; nested exception is java.io.IOException: Failed to parse mapping resource: 'file [/Users/longlongxiaogege/work/mengyin/code/lianmei/myself/backup/dc-backend/data-center/dc-generator/target/classes/mapper/generator/GenTableMapper.xml]' + at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor$AutowiredFieldElement.resolveFieldValue(AutowiredAnnotationBeanPostProcessor.java:659) + at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor$AutowiredFieldElement.inject(AutowiredAnnotationBeanPostProcessor.java:639) + at org.springframework.beans.factory.annotation.InjectionMetadata.inject(InjectionMetadata.java:119) + at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor.postProcessProperties(AutowiredAnnotationBeanPostProcessor.java:399) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.populateBean(AbstractAutowireCapableBeanFactory.java:1431) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:619) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:542) + at org.springframework.beans.factory.support.AbstractBeanFactory.lambda$doGetBean$0(AbstractBeanFactory.java:335) + at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:234) + at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:333) + at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:208) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.preInstantiateSingletons(DefaultListableBeanFactory.java:953) + at org.springframework.context.support.AbstractApplicationContext.finishBeanFactoryInitialization(AbstractApplicationContext.java:918) + at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:583) + at org.springframework.boot.web.servlet.context.ServletWebServerApplicationContext.refresh(ServletWebServerApplicationContext.java:145) + at org.springframework.boot.SpringApplication.refresh(SpringApplication.java:780) + at org.springframework.boot.SpringApplication.refreshContext(SpringApplication.java:453) + at org.springframework.boot.SpringApplication.run(SpringApplication.java:343) + at org.springframework.boot.SpringApplication.run(SpringApplication.java:1370) + at org.springframework.boot.SpringApplication.run(SpringApplication.java:1359) + at com.dc.web.DcApplication.main(DcApplication.java:20) + at java.base/jdk.internal.reflect.DirectMethodHandleAccessor.invoke(DirectMethodHandleAccessor.java:104) + at java.base/java.lang.reflect.Method.invoke(Method.java:578) + at org.springframework.boot.devtools.restart.RestartLauncher.run(RestartLauncher.java:49) +Caused by: org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'accessoryMapper' defined in file [/Users/longlongxiaogege/work/mengyin/code/lianmei/myself/backup/dc-backend/data-center/dc-system/target/classes/com/dc/system/mapper/AccessoryMapper.class]: Unsatisfied dependency expressed through bean property 'sqlSessionFactory'; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'sqlSessionFactory' defined in class path resource [com/dc/framework/config/DataSourceConfiguration.class]: Bean instantiation via factory method failed; nested exception is org.springframework.beans.BeanInstantiationException: Failed to instantiate [org.apache.ibatis.session.SqlSessionFactory]: Factory method 'sqlSessionFactory' threw exception; nested exception is java.io.IOException: Failed to parse mapping resource: 'file [/Users/longlongxiaogege/work/mengyin/code/lianmei/myself/backup/dc-backend/data-center/dc-generator/target/classes/mapper/generator/GenTableMapper.xml]' + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.autowireByType(AbstractAutowireCapableBeanFactory.java:1534) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.populateBean(AbstractAutowireCapableBeanFactory.java:1417) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:619) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:542) + at org.springframework.beans.factory.support.AbstractBeanFactory.lambda$doGetBean$0(AbstractBeanFactory.java:335) + at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:234) + at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:333) + at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:208) + at org.springframework.beans.factory.config.DependencyDescriptor.resolveCandidate(DependencyDescriptor.java:276) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.doResolveDependency(DefaultListableBeanFactory.java:1389) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.resolveDependency(DefaultListableBeanFactory.java:1309) + at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor$AutowiredFieldElement.resolveFieldValue(AutowiredAnnotationBeanPostProcessor.java:656) + ... 23 common frames omitted +Caused by: org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'sqlSessionFactory' defined in class path resource [com/dc/framework/config/DataSourceConfiguration.class]: Bean instantiation via factory method failed; nested exception is org.springframework.beans.BeanInstantiationException: Failed to instantiate [org.apache.ibatis.session.SqlSessionFactory]: Factory method 'sqlSessionFactory' threw exception; nested exception is java.io.IOException: Failed to parse mapping resource: 'file [/Users/longlongxiaogege/work/mengyin/code/lianmei/myself/backup/dc-backend/data-center/dc-generator/target/classes/mapper/generator/GenTableMapper.xml]' + at org.springframework.beans.factory.support.ConstructorResolver.instantiate(ConstructorResolver.java:658) + at org.springframework.beans.factory.support.ConstructorResolver.instantiateUsingFactoryMethod(ConstructorResolver.java:638) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.instantiateUsingFactoryMethod(AbstractAutowireCapableBeanFactory.java:1352) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBeanInstance(AbstractAutowireCapableBeanFactory.java:1195) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:582) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:542) + at org.springframework.beans.factory.support.AbstractBeanFactory.lambda$doGetBean$0(AbstractBeanFactory.java:335) + at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:234) + at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:333) + at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:208) + at org.springframework.beans.factory.config.DependencyDescriptor.resolveCandidate(DependencyDescriptor.java:276) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.doResolveDependency(DefaultListableBeanFactory.java:1389) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.resolveDependency(DefaultListableBeanFactory.java:1309) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.autowireByType(AbstractAutowireCapableBeanFactory.java:1519) + ... 34 common frames omitted +Caused by: org.springframework.beans.BeanInstantiationException: Failed to instantiate [org.apache.ibatis.session.SqlSessionFactory]: Factory method 'sqlSessionFactory' threw exception; nested exception is java.io.IOException: Failed to parse mapping resource: 'file [/Users/longlongxiaogege/work/mengyin/code/lianmei/myself/backup/dc-backend/data-center/dc-generator/target/classes/mapper/generator/GenTableMapper.xml]' + at org.springframework.beans.factory.support.SimpleInstantiationStrategy.instantiate(SimpleInstantiationStrategy.java:185) + at org.springframework.beans.factory.support.ConstructorResolver.instantiate(ConstructorResolver.java:653) + ... 47 common frames omitted +Caused by: java.io.IOException: Failed to parse mapping resource: 'file [/Users/longlongxiaogege/work/mengyin/code/lianmei/myself/backup/dc-backend/data-center/dc-generator/target/classes/mapper/generator/GenTableMapper.xml]' + at com.baomidou.mybatisplus.extension.spring.MybatisSqlSessionFactoryBean.buildSqlSessionFactory(MybatisSqlSessionFactoryBean.java:575) + at com.baomidou.mybatisplus.extension.spring.MybatisSqlSessionFactoryBean.afterPropertiesSet(MybatisSqlSessionFactoryBean.java:444) + at com.baomidou.mybatisplus.extension.spring.MybatisSqlSessionFactoryBean.getObject(MybatisSqlSessionFactoryBean.java:608) + at com.dc.framework.config.DataSourceConfiguration.sqlSessionFactory(DataSourceConfiguration.java:109) + at com.dc.framework.config.DataSourceConfiguration$$EnhancerBySpringCGLIB$$f69724ad.CGLIB$sqlSessionFactory$1(<generated>) + at com.dc.framework.config.DataSourceConfiguration$$EnhancerBySpringCGLIB$$f69724ad$$FastClassBySpringCGLIB$$3926ce55.invoke(<generated>) + at org.springframework.cglib.proxy.MethodProxy.invokeSuper(MethodProxy.java:244) + at org.springframework.context.annotation.ConfigurationClassEnhancer$BeanMethodInterceptor.intercept(ConfigurationClassEnhancer.java:331) + at com.dc.framework.config.DataSourceConfiguration$$EnhancerBySpringCGLIB$$f69724ad.sqlSessionFactory(<generated>) + at java.base/jdk.internal.reflect.DirectMethodHandleAccessor.invoke(DirectMethodHandleAccessor.java:104) + at java.base/java.lang.reflect.Method.invoke(Method.java:578) + at org.springframework.beans.factory.support.SimpleInstantiationStrategy.instantiate(SimpleInstantiationStrategy.java:154) + ... 48 common frames omitted +Caused by: org.apache.ibatis.builder.BuilderException: Error creating document instance. Cause: org.xml.sax.SAXParseException; lineNumber: 4; columnNumber: 55; 前言中不允许有内容。 + at org.apache.ibatis.parsing.XPathParser.createDocument(XPathParser.java:263) + at org.apache.ibatis.parsing.XPathParser.<init>(XPathParser.java:127) + at org.apache.ibatis.builder.xml.XMLMapperBuilder.<init>(XMLMapperBuilder.java:81) + at com.baomidou.mybatisplus.extension.spring.MybatisSqlSessionFactoryBean.buildSqlSessionFactory(MybatisSqlSessionFactoryBean.java:572) + ... 59 common frames omitted +Caused by: org.xml.sax.SAXParseException: 前言中不允许有内容。 + at java.xml/com.sun.org.apache.xerces.internal.util.ErrorHandlerWrapper.createSAXParseException(ErrorHandlerWrapper.java:204) + at java.xml/com.sun.org.apache.xerces.internal.util.ErrorHandlerWrapper.fatalError(ErrorHandlerWrapper.java:178) + at java.xml/com.sun.org.apache.xerces.internal.impl.XMLErrorReporter.reportError(XMLErrorReporter.java:400) + at java.xml/com.sun.org.apache.xerces.internal.impl.XMLErrorReporter.reportError(XMLErrorReporter.java:327) + at java.xml/com.sun.org.apache.xerces.internal.impl.XMLScanner.reportFatalError(XMLScanner.java:1465) + at java.xml/com.sun.org.apache.xerces.internal.impl.XMLDocumentScannerImpl$PrologDriver.next(XMLDocumentScannerImpl.java:978) + at java.xml/com.sun.org.apache.xerces.internal.impl.XMLDocumentScannerImpl.next(XMLDocumentScannerImpl.java:605) + at java.xml/com.sun.org.apache.xerces.internal.impl.XMLDocumentFragmentScannerImpl.scanDocument(XMLDocumentFragmentScannerImpl.java:542) + at java.xml/com.sun.org.apache.xerces.internal.parsers.XML11Configuration.parse(XML11Configuration.java:889) + at java.xml/com.sun.org.apache.xerces.internal.parsers.XML11Configuration.parse(XML11Configuration.java:825) + at java.xml/com.sun.org.apache.xerces.internal.parsers.XMLParser.parse(XMLParser.java:141) + at java.xml/com.sun.org.apache.xerces.internal.parsers.DOMParser.parse(DOMParser.java:247) + at java.xml/com.sun.org.apache.xerces.internal.jaxp.DocumentBuilderImpl.parse(DocumentBuilderImpl.java:342) + at org.apache.ibatis.parsing.XPathParser.createDocument(XPathParser.java:261) + ... 62 common frames omitted +11:22:47.988 [restartedMain] ERROR o.s.b.SpringApplication - [reportFailure,870] - Application run failed +org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'accessoryService': Unsatisfied dependency expressed through field 'baseMapper'; nested exception is org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'accessoryMapper' defined in file [/Users/longlongxiaogege/work/mengyin/code/lianmei/myself/backup/dc-backend/data-center/dc-system/target/classes/com/dc/system/mapper/AccessoryMapper.class]: Unsatisfied dependency expressed through bean property 'sqlSessionFactory'; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'sqlSessionFactory' defined in class path resource [com/dc/framework/config/DataSourceConfiguration.class]: Bean instantiation via factory method failed; nested exception is org.springframework.beans.BeanInstantiationException: Failed to instantiate [org.apache.ibatis.session.SqlSessionFactory]: Factory method 'sqlSessionFactory' threw exception; nested exception is java.io.IOException: Failed to parse mapping resource: 'file [/Users/longlongxiaogege/work/mengyin/code/lianmei/myself/backup/dc-backend/data-center/dc-generator/target/classes/mapper/generator/GenTableMapper.xml]' + at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor$AutowiredFieldElement.resolveFieldValue(AutowiredAnnotationBeanPostProcessor.java:659) + at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor$AutowiredFieldElement.inject(AutowiredAnnotationBeanPostProcessor.java:639) + at org.springframework.beans.factory.annotation.InjectionMetadata.inject(InjectionMetadata.java:119) + at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor.postProcessProperties(AutowiredAnnotationBeanPostProcessor.java:399) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.populateBean(AbstractAutowireCapableBeanFactory.java:1431) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:619) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:542) + at org.springframework.beans.factory.support.AbstractBeanFactory.lambda$doGetBean$0(AbstractBeanFactory.java:335) + at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:234) + at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:333) + at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:208) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.preInstantiateSingletons(DefaultListableBeanFactory.java:953) + at org.springframework.context.support.AbstractApplicationContext.finishBeanFactoryInitialization(AbstractApplicationContext.java:918) + at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:583) + at org.springframework.boot.web.servlet.context.ServletWebServerApplicationContext.refresh(ServletWebServerApplicationContext.java:145) + at org.springframework.boot.SpringApplication.refresh(SpringApplication.java:780) + at org.springframework.boot.SpringApplication.refreshContext(SpringApplication.java:453) + at org.springframework.boot.SpringApplication.run(SpringApplication.java:343) + at org.springframework.boot.SpringApplication.run(SpringApplication.java:1370) + at org.springframework.boot.SpringApplication.run(SpringApplication.java:1359) + at com.dc.web.DcApplication.main(DcApplication.java:20) + at java.base/jdk.internal.reflect.DirectMethodHandleAccessor.invoke(DirectMethodHandleAccessor.java:104) + at java.base/java.lang.reflect.Method.invoke(Method.java:578) + at org.springframework.boot.devtools.restart.RestartLauncher.run(RestartLauncher.java:49) +Caused by: org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'accessoryMapper' defined in file [/Users/longlongxiaogege/work/mengyin/code/lianmei/myself/backup/dc-backend/data-center/dc-system/target/classes/com/dc/system/mapper/AccessoryMapper.class]: Unsatisfied dependency expressed through bean property 'sqlSessionFactory'; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'sqlSessionFactory' defined in class path resource [com/dc/framework/config/DataSourceConfiguration.class]: Bean instantiation via factory method failed; nested exception is org.springframework.beans.BeanInstantiationException: Failed to instantiate [org.apache.ibatis.session.SqlSessionFactory]: Factory method 'sqlSessionFactory' threw exception; nested exception is java.io.IOException: Failed to parse mapping resource: 'file [/Users/longlongxiaogege/work/mengyin/code/lianmei/myself/backup/dc-backend/data-center/dc-generator/target/classes/mapper/generator/GenTableMapper.xml]' + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.autowireByType(AbstractAutowireCapableBeanFactory.java:1534) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.populateBean(AbstractAutowireCapableBeanFactory.java:1417) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:619) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:542) + at org.springframework.beans.factory.support.AbstractBeanFactory.lambda$doGetBean$0(AbstractBeanFactory.java:335) + at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:234) + at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:333) + at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:208) + at org.springframework.beans.factory.config.DependencyDescriptor.resolveCandidate(DependencyDescriptor.java:276) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.doResolveDependency(DefaultListableBeanFactory.java:1389) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.resolveDependency(DefaultListableBeanFactory.java:1309) + at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor$AutowiredFieldElement.resolveFieldValue(AutowiredAnnotationBeanPostProcessor.java:656) + ... 23 common frames omitted +Caused by: org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'sqlSessionFactory' defined in class path resource [com/dc/framework/config/DataSourceConfiguration.class]: Bean instantiation via factory method failed; nested exception is org.springframework.beans.BeanInstantiationException: Failed to instantiate [org.apache.ibatis.session.SqlSessionFactory]: Factory method 'sqlSessionFactory' threw exception; nested exception is java.io.IOException: Failed to parse mapping resource: 'file [/Users/longlongxiaogege/work/mengyin/code/lianmei/myself/backup/dc-backend/data-center/dc-generator/target/classes/mapper/generator/GenTableMapper.xml]' + at org.springframework.beans.factory.support.ConstructorResolver.instantiate(ConstructorResolver.java:658) + at org.springframework.beans.factory.support.ConstructorResolver.instantiateUsingFactoryMethod(ConstructorResolver.java:638) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.instantiateUsingFactoryMethod(AbstractAutowireCapableBeanFactory.java:1352) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBeanInstance(AbstractAutowireCapableBeanFactory.java:1195) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:582) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:542) + at org.springframework.beans.factory.support.AbstractBeanFactory.lambda$doGetBean$0(AbstractBeanFactory.java:335) + at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:234) + at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:333) + at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:208) + at org.springframework.beans.factory.config.DependencyDescriptor.resolveCandidate(DependencyDescriptor.java:276) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.doResolveDependency(DefaultListableBeanFactory.java:1389) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.resolveDependency(DefaultListableBeanFactory.java:1309) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.autowireByType(AbstractAutowireCapableBeanFactory.java:1519) + ... 34 common frames omitted +Caused by: org.springframework.beans.BeanInstantiationException: Failed to instantiate [org.apache.ibatis.session.SqlSessionFactory]: Factory method 'sqlSessionFactory' threw exception; nested exception is java.io.IOException: Failed to parse mapping resource: 'file [/Users/longlongxiaogege/work/mengyin/code/lianmei/myself/backup/dc-backend/data-center/dc-generator/target/classes/mapper/generator/GenTableMapper.xml]' + at org.springframework.beans.factory.support.SimpleInstantiationStrategy.instantiate(SimpleInstantiationStrategy.java:185) + at org.springframework.beans.factory.support.ConstructorResolver.instantiate(ConstructorResolver.java:653) + ... 47 common frames omitted +Caused by: java.io.IOException: Failed to parse mapping resource: 'file [/Users/longlongxiaogege/work/mengyin/code/lianmei/myself/backup/dc-backend/data-center/dc-generator/target/classes/mapper/generator/GenTableMapper.xml]' + at com.baomidou.mybatisplus.extension.spring.MybatisSqlSessionFactoryBean.buildSqlSessionFactory(MybatisSqlSessionFactoryBean.java:575) + at com.baomidou.mybatisplus.extension.spring.MybatisSqlSessionFactoryBean.afterPropertiesSet(MybatisSqlSessionFactoryBean.java:444) + at com.baomidou.mybatisplus.extension.spring.MybatisSqlSessionFactoryBean.getObject(MybatisSqlSessionFactoryBean.java:608) + at com.dc.framework.config.DataSourceConfiguration.sqlSessionFactory(DataSourceConfiguration.java:109) + at com.dc.framework.config.DataSourceConfiguration$$EnhancerBySpringCGLIB$$4d99d59d.CGLIB$sqlSessionFactory$1(<generated>) + at com.dc.framework.config.DataSourceConfiguration$$EnhancerBySpringCGLIB$$4d99d59d$$FastClassBySpringCGLIB$$70bd98ee.invoke(<generated>) + at org.springframework.cglib.proxy.MethodProxy.invokeSuper(MethodProxy.java:244) + at org.springframework.context.annotation.ConfigurationClassEnhancer$BeanMethodInterceptor.intercept(ConfigurationClassEnhancer.java:331) + at com.dc.framework.config.DataSourceConfiguration$$EnhancerBySpringCGLIB$$4d99d59d.sqlSessionFactory(<generated>) + at java.base/jdk.internal.reflect.DirectMethodHandleAccessor.invoke(DirectMethodHandleAccessor.java:104) + at java.base/java.lang.reflect.Method.invoke(Method.java:578) + at org.springframework.beans.factory.support.SimpleInstantiationStrategy.instantiate(SimpleInstantiationStrategy.java:154) + ... 48 common frames omitted +Caused by: org.apache.ibatis.builder.BuilderException: Error creating document instance. Cause: org.xml.sax.SAXParseException; lineNumber: 4; columnNumber: 55; 前言中不允许有内容。 + at org.apache.ibatis.parsing.XPathParser.createDocument(XPathParser.java:263) + at org.apache.ibatis.parsing.XPathParser.<init>(XPathParser.java:127) + at org.apache.ibatis.builder.xml.XMLMapperBuilder.<init>(XMLMapperBuilder.java:81) + at com.baomidou.mybatisplus.extension.spring.MybatisSqlSessionFactoryBean.buildSqlSessionFactory(MybatisSqlSessionFactoryBean.java:572) + ... 59 common frames omitted +Caused by: org.xml.sax.SAXParseException: 前言中不允许有内容。 + at java.xml/com.sun.org.apache.xerces.internal.util.ErrorHandlerWrapper.createSAXParseException(ErrorHandlerWrapper.java:204) + at java.xml/com.sun.org.apache.xerces.internal.util.ErrorHandlerWrapper.fatalError(ErrorHandlerWrapper.java:178) + at java.xml/com.sun.org.apache.xerces.internal.impl.XMLErrorReporter.reportError(XMLErrorReporter.java:400) + at java.xml/com.sun.org.apache.xerces.internal.impl.XMLErrorReporter.reportError(XMLErrorReporter.java:327) + at java.xml/com.sun.org.apache.xerces.internal.impl.XMLScanner.reportFatalError(XMLScanner.java:1465) + at java.xml/com.sun.org.apache.xerces.internal.impl.XMLDocumentScannerImpl$PrologDriver.next(XMLDocumentScannerImpl.java:978) + at java.xml/com.sun.org.apache.xerces.internal.impl.XMLDocumentScannerImpl.next(XMLDocumentScannerImpl.java:605) + at java.xml/com.sun.org.apache.xerces.internal.impl.XMLDocumentFragmentScannerImpl.scanDocument(XMLDocumentFragmentScannerImpl.java:542) + at java.xml/com.sun.org.apache.xerces.internal.parsers.XML11Configuration.parse(XML11Configuration.java:889) + at java.xml/com.sun.org.apache.xerces.internal.parsers.XML11Configuration.parse(XML11Configuration.java:825) + at java.xml/com.sun.org.apache.xerces.internal.parsers.XMLParser.parse(XMLParser.java:141) + at java.xml/com.sun.org.apache.xerces.internal.parsers.DOMParser.parse(DOMParser.java:247) + at java.xml/com.sun.org.apache.xerces.internal.jaxp.DocumentBuilderImpl.parse(DocumentBuilderImpl.java:342) + at org.apache.ibatis.parsing.XPathParser.createDocument(XPathParser.java:261) + ... 62 common frames omitted +11:23:48.535 [restartedMain] ERROR o.s.b.SpringApplication - [reportFailure,870] - Application run failed +org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'accessoryService': Unsatisfied dependency expressed through field 'baseMapper'; nested exception is org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'accessoryMapper' defined in file [/Users/longlongxiaogege/work/mengyin/code/lianmei/myself/backup/dc-backend/data-center/dc-system/target/classes/com/dc/system/mapper/AccessoryMapper.class]: Unsatisfied dependency expressed through bean property 'sqlSessionFactory'; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'sqlSessionFactory' defined in class path resource [com/dc/framework/config/DataSourceConfiguration.class]: Bean instantiation via factory method failed; nested exception is org.springframework.beans.BeanInstantiationException: Failed to instantiate [org.apache.ibatis.session.SqlSessionFactory]: Factory method 'sqlSessionFactory' threw exception; nested exception is java.io.IOException: Failed to parse mapping resource: 'file [/Users/longlongxiaogege/work/mengyin/code/lianmei/myself/backup/dc-backend/data-center/dc-generator/target/classes/mapper/generator/GenTableMapper.xml]' + at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor$AutowiredFieldElement.resolveFieldValue(AutowiredAnnotationBeanPostProcessor.java:659) + at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor$AutowiredFieldElement.inject(AutowiredAnnotationBeanPostProcessor.java:639) + at org.springframework.beans.factory.annotation.InjectionMetadata.inject(InjectionMetadata.java:119) + at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor.postProcessProperties(AutowiredAnnotationBeanPostProcessor.java:399) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.populateBean(AbstractAutowireCapableBeanFactory.java:1431) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:619) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:542) + at org.springframework.beans.factory.support.AbstractBeanFactory.lambda$doGetBean$0(AbstractBeanFactory.java:335) + at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:234) + at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:333) + at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:208) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.preInstantiateSingletons(DefaultListableBeanFactory.java:953) + at org.springframework.context.support.AbstractApplicationContext.finishBeanFactoryInitialization(AbstractApplicationContext.java:918) + at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:583) + at org.springframework.boot.web.servlet.context.ServletWebServerApplicationContext.refresh(ServletWebServerApplicationContext.java:145) + at org.springframework.boot.SpringApplication.refresh(SpringApplication.java:780) + at org.springframework.boot.SpringApplication.refreshContext(SpringApplication.java:453) + at org.springframework.boot.SpringApplication.run(SpringApplication.java:343) + at org.springframework.boot.SpringApplication.run(SpringApplication.java:1370) + at org.springframework.boot.SpringApplication.run(SpringApplication.java:1359) + at com.dc.web.DcApplication.main(DcApplication.java:20) + at java.base/jdk.internal.reflect.DirectMethodHandleAccessor.invoke(DirectMethodHandleAccessor.java:104) + at java.base/java.lang.reflect.Method.invoke(Method.java:578) + at org.springframework.boot.devtools.restart.RestartLauncher.run(RestartLauncher.java:49) +Caused by: org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'accessoryMapper' defined in file [/Users/longlongxiaogege/work/mengyin/code/lianmei/myself/backup/dc-backend/data-center/dc-system/target/classes/com/dc/system/mapper/AccessoryMapper.class]: Unsatisfied dependency expressed through bean property 'sqlSessionFactory'; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'sqlSessionFactory' defined in class path resource [com/dc/framework/config/DataSourceConfiguration.class]: Bean instantiation via factory method failed; nested exception is org.springframework.beans.BeanInstantiationException: Failed to instantiate [org.apache.ibatis.session.SqlSessionFactory]: Factory method 'sqlSessionFactory' threw exception; nested exception is java.io.IOException: Failed to parse mapping resource: 'file [/Users/longlongxiaogege/work/mengyin/code/lianmei/myself/backup/dc-backend/data-center/dc-generator/target/classes/mapper/generator/GenTableMapper.xml]' + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.autowireByType(AbstractAutowireCapableBeanFactory.java:1534) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.populateBean(AbstractAutowireCapableBeanFactory.java:1417) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:619) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:542) + at org.springframework.beans.factory.support.AbstractBeanFactory.lambda$doGetBean$0(AbstractBeanFactory.java:335) + at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:234) + at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:333) + at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:208) + at org.springframework.beans.factory.config.DependencyDescriptor.resolveCandidate(DependencyDescriptor.java:276) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.doResolveDependency(DefaultListableBeanFactory.java:1389) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.resolveDependency(DefaultListableBeanFactory.java:1309) + at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor$AutowiredFieldElement.resolveFieldValue(AutowiredAnnotationBeanPostProcessor.java:656) + ... 23 common frames omitted +Caused by: org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'sqlSessionFactory' defined in class path resource [com/dc/framework/config/DataSourceConfiguration.class]: Bean instantiation via factory method failed; nested exception is org.springframework.beans.BeanInstantiationException: Failed to instantiate [org.apache.ibatis.session.SqlSessionFactory]: Factory method 'sqlSessionFactory' threw exception; nested exception is java.io.IOException: Failed to parse mapping resource: 'file [/Users/longlongxiaogege/work/mengyin/code/lianmei/myself/backup/dc-backend/data-center/dc-generator/target/classes/mapper/generator/GenTableMapper.xml]' + at org.springframework.beans.factory.support.ConstructorResolver.instantiate(ConstructorResolver.java:658) + at org.springframework.beans.factory.support.ConstructorResolver.instantiateUsingFactoryMethod(ConstructorResolver.java:638) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.instantiateUsingFactoryMethod(AbstractAutowireCapableBeanFactory.java:1352) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBeanInstance(AbstractAutowireCapableBeanFactory.java:1195) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:582) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:542) + at org.springframework.beans.factory.support.AbstractBeanFactory.lambda$doGetBean$0(AbstractBeanFactory.java:335) + at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:234) + at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:333) + at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:208) + at org.springframework.beans.factory.config.DependencyDescriptor.resolveCandidate(DependencyDescriptor.java:276) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.doResolveDependency(DefaultListableBeanFactory.java:1389) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.resolveDependency(DefaultListableBeanFactory.java:1309) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.autowireByType(AbstractAutowireCapableBeanFactory.java:1519) + ... 34 common frames omitted +Caused by: org.springframework.beans.BeanInstantiationException: Failed to instantiate [org.apache.ibatis.session.SqlSessionFactory]: Factory method 'sqlSessionFactory' threw exception; nested exception is java.io.IOException: Failed to parse mapping resource: 'file [/Users/longlongxiaogege/work/mengyin/code/lianmei/myself/backup/dc-backend/data-center/dc-generator/target/classes/mapper/generator/GenTableMapper.xml]' + at org.springframework.beans.factory.support.SimpleInstantiationStrategy.instantiate(SimpleInstantiationStrategy.java:185) + at org.springframework.beans.factory.support.ConstructorResolver.instantiate(ConstructorResolver.java:653) + ... 47 common frames omitted +Caused by: java.io.IOException: Failed to parse mapping resource: 'file [/Users/longlongxiaogege/work/mengyin/code/lianmei/myself/backup/dc-backend/data-center/dc-generator/target/classes/mapper/generator/GenTableMapper.xml]' + at com.baomidou.mybatisplus.extension.spring.MybatisSqlSessionFactoryBean.buildSqlSessionFactory(MybatisSqlSessionFactoryBean.java:575) + at com.baomidou.mybatisplus.extension.spring.MybatisSqlSessionFactoryBean.afterPropertiesSet(MybatisSqlSessionFactoryBean.java:444) + at com.baomidou.mybatisplus.extension.spring.MybatisSqlSessionFactoryBean.getObject(MybatisSqlSessionFactoryBean.java:608) + at com.dc.framework.config.DataSourceConfiguration.sqlSessionFactory(DataSourceConfiguration.java:109) + at com.dc.framework.config.DataSourceConfiguration$$EnhancerBySpringCGLIB$$f79246f7.CGLIB$sqlSessionFactory$1(<generated>) + at com.dc.framework.config.DataSourceConfiguration$$EnhancerBySpringCGLIB$$f79246f7$$FastClassBySpringCGLIB$$6dc784bf.invoke(<generated>) + at org.springframework.cglib.proxy.MethodProxy.invokeSuper(MethodProxy.java:244) + at org.springframework.context.annotation.ConfigurationClassEnhancer$BeanMethodInterceptor.intercept(ConfigurationClassEnhancer.java:331) + at com.dc.framework.config.DataSourceConfiguration$$EnhancerBySpringCGLIB$$f79246f7.sqlSessionFactory(<generated>) + at java.base/jdk.internal.reflect.DirectMethodHandleAccessor.invoke(DirectMethodHandleAccessor.java:104) + at java.base/java.lang.reflect.Method.invoke(Method.java:578) + at org.springframework.beans.factory.support.SimpleInstantiationStrategy.instantiate(SimpleInstantiationStrategy.java:154) + ... 48 common frames omitted +Caused by: org.apache.ibatis.builder.BuilderException: Error creating document instance. Cause: org.xml.sax.SAXParseException; lineNumber: 4; columnNumber: 55; 前言中不允许有内容。 + at org.apache.ibatis.parsing.XPathParser.createDocument(XPathParser.java:263) + at org.apache.ibatis.parsing.XPathParser.<init>(XPathParser.java:127) + at org.apache.ibatis.builder.xml.XMLMapperBuilder.<init>(XMLMapperBuilder.java:81) + at com.baomidou.mybatisplus.extension.spring.MybatisSqlSessionFactoryBean.buildSqlSessionFactory(MybatisSqlSessionFactoryBean.java:572) + ... 59 common frames omitted +Caused by: org.xml.sax.SAXParseException: 前言中不允许有内容。 + at java.xml/com.sun.org.apache.xerces.internal.util.ErrorHandlerWrapper.createSAXParseException(ErrorHandlerWrapper.java:204) + at java.xml/com.sun.org.apache.xerces.internal.util.ErrorHandlerWrapper.fatalError(ErrorHandlerWrapper.java:178) + at java.xml/com.sun.org.apache.xerces.internal.impl.XMLErrorReporter.reportError(XMLErrorReporter.java:400) + at java.xml/com.sun.org.apache.xerces.internal.impl.XMLErrorReporter.reportError(XMLErrorReporter.java:327) + at java.xml/com.sun.org.apache.xerces.internal.impl.XMLScanner.reportFatalError(XMLScanner.java:1465) + at java.xml/com.sun.org.apache.xerces.internal.impl.XMLDocumentScannerImpl$PrologDriver.next(XMLDocumentScannerImpl.java:978) + at java.xml/com.sun.org.apache.xerces.internal.impl.XMLDocumentScannerImpl.next(XMLDocumentScannerImpl.java:605) + at java.xml/com.sun.org.apache.xerces.internal.impl.XMLDocumentFragmentScannerImpl.scanDocument(XMLDocumentFragmentScannerImpl.java:542) + at java.xml/com.sun.org.apache.xerces.internal.parsers.XML11Configuration.parse(XML11Configuration.java:889) + at java.xml/com.sun.org.apache.xerces.internal.parsers.XML11Configuration.parse(XML11Configuration.java:825) + at java.xml/com.sun.org.apache.xerces.internal.parsers.XMLParser.parse(XMLParser.java:141) + at java.xml/com.sun.org.apache.xerces.internal.parsers.DOMParser.parse(DOMParser.java:247) + at java.xml/com.sun.org.apache.xerces.internal.jaxp.DocumentBuilderImpl.parse(DocumentBuilderImpl.java:342) + at org.apache.ibatis.parsing.XPathParser.createDocument(XPathParser.java:261) + ... 62 common frames omitted +12:02:02.003 [restartedMain] ERROR o.s.b.SpringApplication - [reportFailure,870] - Application run failed +org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'accessoryService': Unsatisfied dependency expressed through field 'baseMapper'; nested exception is org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'accessoryMapper' defined in file [/Users/longlongxiaogege/work/mengyin/code/lianmei/myself/backup/dc-backend/data-center/dc-system/target/classes/com/dc/system/mapper/AccessoryMapper.class]: Unsatisfied dependency expressed through bean property 'sqlSessionFactory'; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'sqlSessionFactory' defined in class path resource [com/dc/framework/config/DataSourceConfiguration.class]: Bean instantiation via factory method failed; nested exception is org.springframework.beans.BeanInstantiationException: Failed to instantiate [org.apache.ibatis.session.SqlSessionFactory]: Factory method 'sqlSessionFactory' threw exception; nested exception is java.io.IOException: Failed to parse mapping resource: 'file [/Users/longlongxiaogege/work/mengyin/code/lianmei/myself/backup/dc-backend/data-center/dc-system/target/classes/mapper/system/DcCodeRuleTestMapper.xml]' + at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor$AutowiredFieldElement.resolveFieldValue(AutowiredAnnotationBeanPostProcessor.java:659) + at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor$AutowiredFieldElement.inject(AutowiredAnnotationBeanPostProcessor.java:639) + at org.springframework.beans.factory.annotation.InjectionMetadata.inject(InjectionMetadata.java:119) + at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor.postProcessProperties(AutowiredAnnotationBeanPostProcessor.java:399) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.populateBean(AbstractAutowireCapableBeanFactory.java:1431) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:619) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:542) + at org.springframework.beans.factory.support.AbstractBeanFactory.lambda$doGetBean$0(AbstractBeanFactory.java:335) + at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:234) + at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:333) + at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:208) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.preInstantiateSingletons(DefaultListableBeanFactory.java:953) + at org.springframework.context.support.AbstractApplicationContext.finishBeanFactoryInitialization(AbstractApplicationContext.java:918) + at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:583) + at org.springframework.boot.web.servlet.context.ServletWebServerApplicationContext.refresh(ServletWebServerApplicationContext.java:145) + at org.springframework.boot.SpringApplication.refresh(SpringApplication.java:780) + at org.springframework.boot.SpringApplication.refreshContext(SpringApplication.java:453) + at org.springframework.boot.SpringApplication.run(SpringApplication.java:343) + at org.springframework.boot.SpringApplication.run(SpringApplication.java:1370) + at org.springframework.boot.SpringApplication.run(SpringApplication.java:1359) + at com.dc.web.DcApplication.main(DcApplication.java:20) + at java.base/jdk.internal.reflect.DirectMethodHandleAccessor.invoke(DirectMethodHandleAccessor.java:104) + at java.base/java.lang.reflect.Method.invoke(Method.java:578) + at org.springframework.boot.devtools.restart.RestartLauncher.run(RestartLauncher.java:49) +Caused by: org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'accessoryMapper' defined in file [/Users/longlongxiaogege/work/mengyin/code/lianmei/myself/backup/dc-backend/data-center/dc-system/target/classes/com/dc/system/mapper/AccessoryMapper.class]: Unsatisfied dependency expressed through bean property 'sqlSessionFactory'; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'sqlSessionFactory' defined in class path resource [com/dc/framework/config/DataSourceConfiguration.class]: Bean instantiation via factory method failed; nested exception is org.springframework.beans.BeanInstantiationException: Failed to instantiate [org.apache.ibatis.session.SqlSessionFactory]: Factory method 'sqlSessionFactory' threw exception; nested exception is java.io.IOException: Failed to parse mapping resource: 'file [/Users/longlongxiaogege/work/mengyin/code/lianmei/myself/backup/dc-backend/data-center/dc-system/target/classes/mapper/system/DcCodeRuleTestMapper.xml]' + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.autowireByType(AbstractAutowireCapableBeanFactory.java:1534) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.populateBean(AbstractAutowireCapableBeanFactory.java:1417) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:619) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:542) + at org.springframework.beans.factory.support.AbstractBeanFactory.lambda$doGetBean$0(AbstractBeanFactory.java:335) + at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:234) + at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:333) + at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:208) + at org.springframework.beans.factory.config.DependencyDescriptor.resolveCandidate(DependencyDescriptor.java:276) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.doResolveDependency(DefaultListableBeanFactory.java:1389) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.resolveDependency(DefaultListableBeanFactory.java:1309) + at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor$AutowiredFieldElement.resolveFieldValue(AutowiredAnnotationBeanPostProcessor.java:656) + ... 23 common frames omitted +Caused by: org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'sqlSessionFactory' defined in class path resource [com/dc/framework/config/DataSourceConfiguration.class]: Bean instantiation via factory method failed; nested exception is org.springframework.beans.BeanInstantiationException: Failed to instantiate [org.apache.ibatis.session.SqlSessionFactory]: Factory method 'sqlSessionFactory' threw exception; nested exception is java.io.IOException: Failed to parse mapping resource: 'file [/Users/longlongxiaogege/work/mengyin/code/lianmei/myself/backup/dc-backend/data-center/dc-system/target/classes/mapper/system/DcCodeRuleTestMapper.xml]' + at org.springframework.beans.factory.support.ConstructorResolver.instantiate(ConstructorResolver.java:658) + at org.springframework.beans.factory.support.ConstructorResolver.instantiateUsingFactoryMethod(ConstructorResolver.java:638) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.instantiateUsingFactoryMethod(AbstractAutowireCapableBeanFactory.java:1352) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBeanInstance(AbstractAutowireCapableBeanFactory.java:1195) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:582) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:542) + at org.springframework.beans.factory.support.AbstractBeanFactory.lambda$doGetBean$0(AbstractBeanFactory.java:335) + at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:234) + at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:333) + at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:208) + at org.springframework.beans.factory.config.DependencyDescriptor.resolveCandidate(DependencyDescriptor.java:276) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.doResolveDependency(DefaultListableBeanFactory.java:1389) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.resolveDependency(DefaultListableBeanFactory.java:1309) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.autowireByType(AbstractAutowireCapableBeanFactory.java:1519) + ... 34 common frames omitted +Caused by: org.springframework.beans.BeanInstantiationException: Failed to instantiate [org.apache.ibatis.session.SqlSessionFactory]: Factory method 'sqlSessionFactory' threw exception; nested exception is java.io.IOException: Failed to parse mapping resource: 'file [/Users/longlongxiaogege/work/mengyin/code/lianmei/myself/backup/dc-backend/data-center/dc-system/target/classes/mapper/system/DcCodeRuleTestMapper.xml]' + at org.springframework.beans.factory.support.SimpleInstantiationStrategy.instantiate(SimpleInstantiationStrategy.java:185) + at org.springframework.beans.factory.support.ConstructorResolver.instantiate(ConstructorResolver.java:653) + ... 47 common frames omitted +Caused by: java.io.IOException: Failed to parse mapping resource: 'file [/Users/longlongxiaogege/work/mengyin/code/lianmei/myself/backup/dc-backend/data-center/dc-system/target/classes/mapper/system/DcCodeRuleTestMapper.xml]' + at com.baomidou.mybatisplus.extension.spring.MybatisSqlSessionFactoryBean.buildSqlSessionFactory(MybatisSqlSessionFactoryBean.java:575) + at com.baomidou.mybatisplus.extension.spring.MybatisSqlSessionFactoryBean.afterPropertiesSet(MybatisSqlSessionFactoryBean.java:444) + at com.baomidou.mybatisplus.extension.spring.MybatisSqlSessionFactoryBean.getObject(MybatisSqlSessionFactoryBean.java:608) + at com.dc.framework.config.DataSourceConfiguration.sqlSessionFactory(DataSourceConfiguration.java:109) + at com.dc.framework.config.DataSourceConfiguration$$EnhancerBySpringCGLIB$$4d99d59d.CGLIB$sqlSessionFactory$1(<generated>) + at com.dc.framework.config.DataSourceConfiguration$$EnhancerBySpringCGLIB$$4d99d59d$$FastClassBySpringCGLIB$$70bd98ee.invoke(<generated>) + at org.springframework.cglib.proxy.MethodProxy.invokeSuper(MethodProxy.java:244) + at org.springframework.context.annotation.ConfigurationClassEnhancer$BeanMethodInterceptor.intercept(ConfigurationClassEnhancer.java:331) + at com.dc.framework.config.DataSourceConfiguration$$EnhancerBySpringCGLIB$$4d99d59d.sqlSessionFactory(<generated>) + at java.base/jdk.internal.reflect.DirectMethodHandleAccessor.invoke(DirectMethodHandleAccessor.java:104) + at java.base/java.lang.reflect.Method.invoke(Method.java:578) + at org.springframework.beans.factory.support.SimpleInstantiationStrategy.instantiate(SimpleInstantiationStrategy.java:154) + ... 48 common frames omitted +Caused by: org.apache.ibatis.builder.BuilderException: Error parsing Mapper XML. The XML location is 'file [/Users/longlongxiaogege/work/mengyin/code/lianmei/myself/backup/dc-backend/data-center/dc-system/target/classes/mapper/system/DcCodeRuleTestMapper.xml]'. Cause: org.apache.ibatis.builder.BuilderException: Error resolving class. Cause: org.apache.ibatis.type.TypeException: Could not resolve type alias 'DcCodeRuleTest'. Cause: java.lang.ClassNotFoundException: Cannot find class: DcCodeRuleTest + at org.apache.ibatis.builder.xml.XMLMapperBuilder.configurationElement(XMLMapperBuilder.java:123) + at org.apache.ibatis.builder.xml.XMLMapperBuilder.parse(XMLMapperBuilder.java:95) + at com.baomidou.mybatisplus.extension.spring.MybatisSqlSessionFactoryBean.buildSqlSessionFactory(MybatisSqlSessionFactoryBean.java:573) + ... 59 common frames omitted +Caused by: org.apache.ibatis.builder.BuilderException: Error resolving class. Cause: org.apache.ibatis.type.TypeException: Could not resolve type alias 'DcCodeRuleTest'. Cause: java.lang.ClassNotFoundException: Cannot find class: DcCodeRuleTest + at org.apache.ibatis.builder.BaseBuilder.resolveClass(BaseBuilder.java:118) + at org.apache.ibatis.builder.xml.XMLMapperBuilder.resultMapElement(XMLMapperBuilder.java:263) + at org.apache.ibatis.builder.xml.XMLMapperBuilder.resultMapElement(XMLMapperBuilder.java:254) + at org.apache.ibatis.builder.xml.XMLMapperBuilder.resultMapElements(XMLMapperBuilder.java:246) + at org.apache.ibatis.builder.xml.XMLMapperBuilder.configurationElement(XMLMapperBuilder.java:119) + ... 61 common frames omitted +Caused by: org.apache.ibatis.type.TypeException: Could not resolve type alias 'DcCodeRuleTest'. Cause: java.lang.ClassNotFoundException: Cannot find class: DcCodeRuleTest + at org.apache.ibatis.type.TypeAliasRegistry.resolveAlias(TypeAliasRegistry.java:120) + at org.apache.ibatis.builder.BaseBuilder.resolveAlias(BaseBuilder.java:149) + at org.apache.ibatis.builder.BaseBuilder.resolveClass(BaseBuilder.java:116) + ... 65 common frames omitted +Caused by: java.lang.ClassNotFoundException: Cannot find class: DcCodeRuleTest + at org.apache.ibatis.io.ClassLoaderWrapper.classForName(ClassLoaderWrapper.java:196) + at org.apache.ibatis.io.ClassLoaderWrapper.classForName(ClassLoaderWrapper.java:89) + at org.apache.ibatis.io.Resources.classForName(Resources.java:261) + at org.apache.ibatis.type.TypeAliasRegistry.resolveAlias(TypeAliasRegistry.java:116) + ... 67 common frames omitted +12:07:02.435 [restartedMain] ERROR o.s.b.SpringApplication - [reportFailure,870] - Application run failed +org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'accessoryService': Unsatisfied dependency expressed through field 'baseMapper'; nested exception is org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'accessoryMapper' defined in file [/Users/longlongxiaogege/work/mengyin/code/lianmei/myself/backup/dc-backend/data-center/dc-system/target/classes/com/dc/system/mapper/AccessoryMapper.class]: Unsatisfied dependency expressed through bean property 'sqlSessionFactory'; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'sqlSessionFactory' defined in class path resource [com/dc/framework/config/DataSourceConfiguration.class]: Bean instantiation via factory method failed; nested exception is org.springframework.beans.BeanInstantiationException: Failed to instantiate [org.apache.ibatis.session.SqlSessionFactory]: Factory method 'sqlSessionFactory' threw exception; nested exception is java.io.IOException: Failed to parse mapping resource: 'file [/Users/longlongxiaogege/work/mengyin/code/lianmei/myself/backup/dc-backend/data-center/dc-system/target/classes/mapper/system/DcCodeRuleTestMapper.xml]' + at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor$AutowiredFieldElement.resolveFieldValue(AutowiredAnnotationBeanPostProcessor.java:659) + at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor$AutowiredFieldElement.inject(AutowiredAnnotationBeanPostProcessor.java:639) + at org.springframework.beans.factory.annotation.InjectionMetadata.inject(InjectionMetadata.java:119) + at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor.postProcessProperties(AutowiredAnnotationBeanPostProcessor.java:399) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.populateBean(AbstractAutowireCapableBeanFactory.java:1431) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:619) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:542) + at org.springframework.beans.factory.support.AbstractBeanFactory.lambda$doGetBean$0(AbstractBeanFactory.java:335) + at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:234) + at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:333) + at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:208) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.preInstantiateSingletons(DefaultListableBeanFactory.java:953) + at org.springframework.context.support.AbstractApplicationContext.finishBeanFactoryInitialization(AbstractApplicationContext.java:918) + at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:583) + at org.springframework.boot.web.servlet.context.ServletWebServerApplicationContext.refresh(ServletWebServerApplicationContext.java:145) + at org.springframework.boot.SpringApplication.refresh(SpringApplication.java:780) + at org.springframework.boot.SpringApplication.refreshContext(SpringApplication.java:453) + at org.springframework.boot.SpringApplication.run(SpringApplication.java:343) + at org.springframework.boot.SpringApplication.run(SpringApplication.java:1370) + at org.springframework.boot.SpringApplication.run(SpringApplication.java:1359) + at com.dc.web.DcApplication.main(DcApplication.java:20) + at java.base/jdk.internal.reflect.DirectMethodHandleAccessor.invoke(DirectMethodHandleAccessor.java:104) + at java.base/java.lang.reflect.Method.invoke(Method.java:578) + at org.springframework.boot.devtools.restart.RestartLauncher.run(RestartLauncher.java:49) +Caused by: org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'accessoryMapper' defined in file [/Users/longlongxiaogege/work/mengyin/code/lianmei/myself/backup/dc-backend/data-center/dc-system/target/classes/com/dc/system/mapper/AccessoryMapper.class]: Unsatisfied dependency expressed through bean property 'sqlSessionFactory'; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'sqlSessionFactory' defined in class path resource [com/dc/framework/config/DataSourceConfiguration.class]: Bean instantiation via factory method failed; nested exception is org.springframework.beans.BeanInstantiationException: Failed to instantiate [org.apache.ibatis.session.SqlSessionFactory]: Factory method 'sqlSessionFactory' threw exception; nested exception is java.io.IOException: Failed to parse mapping resource: 'file [/Users/longlongxiaogege/work/mengyin/code/lianmei/myself/backup/dc-backend/data-center/dc-system/target/classes/mapper/system/DcCodeRuleTestMapper.xml]' + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.autowireByType(AbstractAutowireCapableBeanFactory.java:1534) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.populateBean(AbstractAutowireCapableBeanFactory.java:1417) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:619) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:542) + at org.springframework.beans.factory.support.AbstractBeanFactory.lambda$doGetBean$0(AbstractBeanFactory.java:335) + at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:234) + at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:333) + at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:208) + at org.springframework.beans.factory.config.DependencyDescriptor.resolveCandidate(DependencyDescriptor.java:276) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.doResolveDependency(DefaultListableBeanFactory.java:1389) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.resolveDependency(DefaultListableBeanFactory.java:1309) + at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor$AutowiredFieldElement.resolveFieldValue(AutowiredAnnotationBeanPostProcessor.java:656) + ... 23 common frames omitted +Caused by: org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'sqlSessionFactory' defined in class path resource [com/dc/framework/config/DataSourceConfiguration.class]: Bean instantiation via factory method failed; nested exception is org.springframework.beans.BeanInstantiationException: Failed to instantiate [org.apache.ibatis.session.SqlSessionFactory]: Factory method 'sqlSessionFactory' threw exception; nested exception is java.io.IOException: Failed to parse mapping resource: 'file [/Users/longlongxiaogege/work/mengyin/code/lianmei/myself/backup/dc-backend/data-center/dc-system/target/classes/mapper/system/DcCodeRuleTestMapper.xml]' + at org.springframework.beans.factory.support.ConstructorResolver.instantiate(ConstructorResolver.java:658) + at org.springframework.beans.factory.support.ConstructorResolver.instantiateUsingFactoryMethod(ConstructorResolver.java:638) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.instantiateUsingFactoryMethod(AbstractAutowireCapableBeanFactory.java:1352) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBeanInstance(AbstractAutowireCapableBeanFactory.java:1195) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:582) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:542) + at org.springframework.beans.factory.support.AbstractBeanFactory.lambda$doGetBean$0(AbstractBeanFactory.java:335) + at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:234) + at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:333) + at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:208) + at org.springframework.beans.factory.config.DependencyDescriptor.resolveCandidate(DependencyDescriptor.java:276) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.doResolveDependency(DefaultListableBeanFactory.java:1389) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.resolveDependency(DefaultListableBeanFactory.java:1309) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.autowireByType(AbstractAutowireCapableBeanFactory.java:1519) + ... 34 common frames omitted +Caused by: org.springframework.beans.BeanInstantiationException: Failed to instantiate [org.apache.ibatis.session.SqlSessionFactory]: Factory method 'sqlSessionFactory' threw exception; nested exception is java.io.IOException: Failed to parse mapping resource: 'file [/Users/longlongxiaogege/work/mengyin/code/lianmei/myself/backup/dc-backend/data-center/dc-system/target/classes/mapper/system/DcCodeRuleTestMapper.xml]' + at org.springframework.beans.factory.support.SimpleInstantiationStrategy.instantiate(SimpleInstantiationStrategy.java:185) + at org.springframework.beans.factory.support.ConstructorResolver.instantiate(ConstructorResolver.java:653) + ... 47 common frames omitted +Caused by: java.io.IOException: Failed to parse mapping resource: 'file [/Users/longlongxiaogege/work/mengyin/code/lianmei/myself/backup/dc-backend/data-center/dc-system/target/classes/mapper/system/DcCodeRuleTestMapper.xml]' + at com.baomidou.mybatisplus.extension.spring.MybatisSqlSessionFactoryBean.buildSqlSessionFactory(MybatisSqlSessionFactoryBean.java:575) + at com.baomidou.mybatisplus.extension.spring.MybatisSqlSessionFactoryBean.afterPropertiesSet(MybatisSqlSessionFactoryBean.java:444) + at com.baomidou.mybatisplus.extension.spring.MybatisSqlSessionFactoryBean.getObject(MybatisSqlSessionFactoryBean.java:608) + at com.dc.framework.config.DataSourceConfiguration.sqlSessionFactory(DataSourceConfiguration.java:109) + at com.dc.framework.config.DataSourceConfiguration$$EnhancerBySpringCGLIB$$4d99d59d.CGLIB$sqlSessionFactory$1(<generated>) + at com.dc.framework.config.DataSourceConfiguration$$EnhancerBySpringCGLIB$$4d99d59d$$FastClassBySpringCGLIB$$70bd98ee.invoke(<generated>) + at org.springframework.cglib.proxy.MethodProxy.invokeSuper(MethodProxy.java:244) + at org.springframework.context.annotation.ConfigurationClassEnhancer$BeanMethodInterceptor.intercept(ConfigurationClassEnhancer.java:331) + at com.dc.framework.config.DataSourceConfiguration$$EnhancerBySpringCGLIB$$4d99d59d.sqlSessionFactory(<generated>) + at java.base/jdk.internal.reflect.DirectMethodHandleAccessor.invoke(DirectMethodHandleAccessor.java:104) + at java.base/java.lang.reflect.Method.invoke(Method.java:578) + at org.springframework.beans.factory.support.SimpleInstantiationStrategy.instantiate(SimpleInstantiationStrategy.java:154) + ... 48 common frames omitted +Caused by: org.apache.ibatis.builder.BuilderException: Error parsing Mapper XML. The XML location is 'file [/Users/longlongxiaogege/work/mengyin/code/lianmei/myself/backup/dc-backend/data-center/dc-system/target/classes/mapper/system/DcCodeRuleTestMapper.xml]'. Cause: org.apache.ibatis.builder.BuilderException: Error resolving class. Cause: org.apache.ibatis.type.TypeException: Could not resolve type alias 'DcCodeRuleTest'. Cause: java.lang.ClassNotFoundException: Cannot find class: DcCodeRuleTest + at org.apache.ibatis.builder.xml.XMLMapperBuilder.configurationElement(XMLMapperBuilder.java:123) + at org.apache.ibatis.builder.xml.XMLMapperBuilder.parse(XMLMapperBuilder.java:95) + at com.baomidou.mybatisplus.extension.spring.MybatisSqlSessionFactoryBean.buildSqlSessionFactory(MybatisSqlSessionFactoryBean.java:573) + ... 59 common frames omitted +Caused by: org.apache.ibatis.builder.BuilderException: Error resolving class. Cause: org.apache.ibatis.type.TypeException: Could not resolve type alias 'DcCodeRuleTest'. Cause: java.lang.ClassNotFoundException: Cannot find class: DcCodeRuleTest + at org.apache.ibatis.builder.BaseBuilder.resolveClass(BaseBuilder.java:118) + at org.apache.ibatis.builder.xml.XMLMapperBuilder.resultMapElement(XMLMapperBuilder.java:263) + at org.apache.ibatis.builder.xml.XMLMapperBuilder.resultMapElement(XMLMapperBuilder.java:254) + at org.apache.ibatis.builder.xml.XMLMapperBuilder.resultMapElements(XMLMapperBuilder.java:246) + at org.apache.ibatis.builder.xml.XMLMapperBuilder.configurationElement(XMLMapperBuilder.java:119) + ... 61 common frames omitted +Caused by: org.apache.ibatis.type.TypeException: Could not resolve type alias 'DcCodeRuleTest'. Cause: java.lang.ClassNotFoundException: Cannot find class: DcCodeRuleTest + at org.apache.ibatis.type.TypeAliasRegistry.resolveAlias(TypeAliasRegistry.java:120) + at org.apache.ibatis.builder.BaseBuilder.resolveAlias(BaseBuilder.java:149) + at org.apache.ibatis.builder.BaseBuilder.resolveClass(BaseBuilder.java:116) + ... 65 common frames omitted +Caused by: java.lang.ClassNotFoundException: Cannot find class: DcCodeRuleTest + at org.apache.ibatis.io.ClassLoaderWrapper.classForName(ClassLoaderWrapper.java:196) + at org.apache.ibatis.io.ClassLoaderWrapper.classForName(ClassLoaderWrapper.java:89) + at org.apache.ibatis.io.Resources.classForName(Resources.java:261) + at org.apache.ibatis.type.TypeAliasRegistry.resolveAlias(TypeAliasRegistry.java:116) + ... 67 common frames omitted +12:07:04.323 [restartedMain] ERROR o.s.b.SpringApplication - [reportFailure,870] - Application run failed +org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'accessoryService': Unsatisfied dependency expressed through field 'baseMapper'; nested exception is org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'accessoryMapper' defined in file [/Users/longlongxiaogege/work/mengyin/code/lianmei/myself/backup/dc-backend/data-center/dc-system/target/classes/com/dc/system/mapper/AccessoryMapper.class]: Unsatisfied dependency expressed through bean property 'sqlSessionFactory'; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'sqlSessionFactory' defined in class path resource [com/dc/framework/config/DataSourceConfiguration.class]: Bean instantiation via factory method failed; nested exception is org.springframework.beans.BeanInstantiationException: Failed to instantiate [org.apache.ibatis.session.SqlSessionFactory]: Factory method 'sqlSessionFactory' threw exception; nested exception is java.io.IOException: Failed to parse mapping resource: 'file [/Users/longlongxiaogege/work/mengyin/code/lianmei/myself/backup/dc-backend/data-center/dc-system/target/classes/mapper/system/DcCodeRuleTestMapper.xml]' + at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor$AutowiredFieldElement.resolveFieldValue(AutowiredAnnotationBeanPostProcessor.java:659) + at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor$AutowiredFieldElement.inject(AutowiredAnnotationBeanPostProcessor.java:639) + at org.springframework.beans.factory.annotation.InjectionMetadata.inject(InjectionMetadata.java:119) + at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor.postProcessProperties(AutowiredAnnotationBeanPostProcessor.java:399) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.populateBean(AbstractAutowireCapableBeanFactory.java:1431) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:619) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:542) + at org.springframework.beans.factory.support.AbstractBeanFactory.lambda$doGetBean$0(AbstractBeanFactory.java:335) + at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:234) + at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:333) + at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:208) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.preInstantiateSingletons(DefaultListableBeanFactory.java:953) + at org.springframework.context.support.AbstractApplicationContext.finishBeanFactoryInitialization(AbstractApplicationContext.java:918) + at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:583) + at org.springframework.boot.web.servlet.context.ServletWebServerApplicationContext.refresh(ServletWebServerApplicationContext.java:145) + at org.springframework.boot.SpringApplication.refresh(SpringApplication.java:780) + at org.springframework.boot.SpringApplication.refreshContext(SpringApplication.java:453) + at org.springframework.boot.SpringApplication.run(SpringApplication.java:343) + at org.springframework.boot.SpringApplication.run(SpringApplication.java:1370) + at org.springframework.boot.SpringApplication.run(SpringApplication.java:1359) + at com.dc.web.DcApplication.main(DcApplication.java:20) + at java.base/jdk.internal.reflect.DirectMethodHandleAccessor.invoke(DirectMethodHandleAccessor.java:104) + at java.base/java.lang.reflect.Method.invoke(Method.java:578) + at org.springframework.boot.devtools.restart.RestartLauncher.run(RestartLauncher.java:49) +Caused by: org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'accessoryMapper' defined in file [/Users/longlongxiaogege/work/mengyin/code/lianmei/myself/backup/dc-backend/data-center/dc-system/target/classes/com/dc/system/mapper/AccessoryMapper.class]: Unsatisfied dependency expressed through bean property 'sqlSessionFactory'; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'sqlSessionFactory' defined in class path resource [com/dc/framework/config/DataSourceConfiguration.class]: Bean instantiation via factory method failed; nested exception is org.springframework.beans.BeanInstantiationException: Failed to instantiate [org.apache.ibatis.session.SqlSessionFactory]: Factory method 'sqlSessionFactory' threw exception; nested exception is java.io.IOException: Failed to parse mapping resource: 'file [/Users/longlongxiaogege/work/mengyin/code/lianmei/myself/backup/dc-backend/data-center/dc-system/target/classes/mapper/system/DcCodeRuleTestMapper.xml]' + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.autowireByType(AbstractAutowireCapableBeanFactory.java:1534) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.populateBean(AbstractAutowireCapableBeanFactory.java:1417) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:619) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:542) + at org.springframework.beans.factory.support.AbstractBeanFactory.lambda$doGetBean$0(AbstractBeanFactory.java:335) + at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:234) + at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:333) + at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:208) + at org.springframework.beans.factory.config.DependencyDescriptor.resolveCandidate(DependencyDescriptor.java:276) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.doResolveDependency(DefaultListableBeanFactory.java:1389) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.resolveDependency(DefaultListableBeanFactory.java:1309) + at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor$AutowiredFieldElement.resolveFieldValue(AutowiredAnnotationBeanPostProcessor.java:656) + ... 23 common frames omitted +Caused by: org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'sqlSessionFactory' defined in class path resource [com/dc/framework/config/DataSourceConfiguration.class]: Bean instantiation via factory method failed; nested exception is org.springframework.beans.BeanInstantiationException: Failed to instantiate [org.apache.ibatis.session.SqlSessionFactory]: Factory method 'sqlSessionFactory' threw exception; nested exception is java.io.IOException: Failed to parse mapping resource: 'file [/Users/longlongxiaogege/work/mengyin/code/lianmei/myself/backup/dc-backend/data-center/dc-system/target/classes/mapper/system/DcCodeRuleTestMapper.xml]' + at org.springframework.beans.factory.support.ConstructorResolver.instantiate(ConstructorResolver.java:658) + at org.springframework.beans.factory.support.ConstructorResolver.instantiateUsingFactoryMethod(ConstructorResolver.java:638) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.instantiateUsingFactoryMethod(AbstractAutowireCapableBeanFactory.java:1352) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBeanInstance(AbstractAutowireCapableBeanFactory.java:1195) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:582) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:542) + at org.springframework.beans.factory.support.AbstractBeanFactory.lambda$doGetBean$0(AbstractBeanFactory.java:335) + at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:234) + at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:333) + at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:208) + at org.springframework.beans.factory.config.DependencyDescriptor.resolveCandidate(DependencyDescriptor.java:276) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.doResolveDependency(DefaultListableBeanFactory.java:1389) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.resolveDependency(DefaultListableBeanFactory.java:1309) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.autowireByType(AbstractAutowireCapableBeanFactory.java:1519) + ... 34 common frames omitted +Caused by: org.springframework.beans.BeanInstantiationException: Failed to instantiate [org.apache.ibatis.session.SqlSessionFactory]: Factory method 'sqlSessionFactory' threw exception; nested exception is java.io.IOException: Failed to parse mapping resource: 'file [/Users/longlongxiaogege/work/mengyin/code/lianmei/myself/backup/dc-backend/data-center/dc-system/target/classes/mapper/system/DcCodeRuleTestMapper.xml]' + at org.springframework.beans.factory.support.SimpleInstantiationStrategy.instantiate(SimpleInstantiationStrategy.java:185) + at org.springframework.beans.factory.support.ConstructorResolver.instantiate(ConstructorResolver.java:653) + ... 47 common frames omitted +Caused by: java.io.IOException: Failed to parse mapping resource: 'file [/Users/longlongxiaogege/work/mengyin/code/lianmei/myself/backup/dc-backend/data-center/dc-system/target/classes/mapper/system/DcCodeRuleTestMapper.xml]' + at com.baomidou.mybatisplus.extension.spring.MybatisSqlSessionFactoryBean.buildSqlSessionFactory(MybatisSqlSessionFactoryBean.java:575) + at com.baomidou.mybatisplus.extension.spring.MybatisSqlSessionFactoryBean.afterPropertiesSet(MybatisSqlSessionFactoryBean.java:444) + at com.baomidou.mybatisplus.extension.spring.MybatisSqlSessionFactoryBean.getObject(MybatisSqlSessionFactoryBean.java:608) + at com.dc.framework.config.DataSourceConfiguration.sqlSessionFactory(DataSourceConfiguration.java:109) + at com.dc.framework.config.DataSourceConfiguration$$EnhancerBySpringCGLIB$$4d99d59d.CGLIB$sqlSessionFactory$1(<generated>) + at com.dc.framework.config.DataSourceConfiguration$$EnhancerBySpringCGLIB$$4d99d59d$$FastClassBySpringCGLIB$$70bd98ee.invoke(<generated>) + at org.springframework.cglib.proxy.MethodProxy.invokeSuper(MethodProxy.java:244) + at org.springframework.context.annotation.ConfigurationClassEnhancer$BeanMethodInterceptor.intercept(ConfigurationClassEnhancer.java:331) + at com.dc.framework.config.DataSourceConfiguration$$EnhancerBySpringCGLIB$$4d99d59d.sqlSessionFactory(<generated>) + at java.base/jdk.internal.reflect.DirectMethodHandleAccessor.invoke(DirectMethodHandleAccessor.java:104) + at java.base/java.lang.reflect.Method.invoke(Method.java:578) + at org.springframework.beans.factory.support.SimpleInstantiationStrategy.instantiate(SimpleInstantiationStrategy.java:154) + ... 48 common frames omitted +Caused by: org.apache.ibatis.builder.BuilderException: Error parsing Mapper XML. The XML location is 'file [/Users/longlongxiaogege/work/mengyin/code/lianmei/myself/backup/dc-backend/data-center/dc-system/target/classes/mapper/system/DcCodeRuleTestMapper.xml]'. Cause: org.apache.ibatis.builder.BuilderException: Error resolving class. Cause: org.apache.ibatis.type.TypeException: Could not resolve type alias 'DcCodeRuleTest'. Cause: java.lang.ClassNotFoundException: Cannot find class: DcCodeRuleTest + at org.apache.ibatis.builder.xml.XMLMapperBuilder.configurationElement(XMLMapperBuilder.java:123) + at org.apache.ibatis.builder.xml.XMLMapperBuilder.parse(XMLMapperBuilder.java:95) + at com.baomidou.mybatisplus.extension.spring.MybatisSqlSessionFactoryBean.buildSqlSessionFactory(MybatisSqlSessionFactoryBean.java:573) + ... 59 common frames omitted +Caused by: org.apache.ibatis.builder.BuilderException: Error resolving class. Cause: org.apache.ibatis.type.TypeException: Could not resolve type alias 'DcCodeRuleTest'. Cause: java.lang.ClassNotFoundException: Cannot find class: DcCodeRuleTest + at org.apache.ibatis.builder.BaseBuilder.resolveClass(BaseBuilder.java:118) + at org.apache.ibatis.builder.xml.XMLMapperBuilder.resultMapElement(XMLMapperBuilder.java:263) + at org.apache.ibatis.builder.xml.XMLMapperBuilder.resultMapElement(XMLMapperBuilder.java:254) + at org.apache.ibatis.builder.xml.XMLMapperBuilder.resultMapElements(XMLMapperBuilder.java:246) + at org.apache.ibatis.builder.xml.XMLMapperBuilder.configurationElement(XMLMapperBuilder.java:119) + ... 61 common frames omitted +Caused by: org.apache.ibatis.type.TypeException: Could not resolve type alias 'DcCodeRuleTest'. Cause: java.lang.ClassNotFoundException: Cannot find class: DcCodeRuleTest + at org.apache.ibatis.type.TypeAliasRegistry.resolveAlias(TypeAliasRegistry.java:120) + at org.apache.ibatis.builder.BaseBuilder.resolveAlias(BaseBuilder.java:149) + at org.apache.ibatis.builder.BaseBuilder.resolveClass(BaseBuilder.java:116) + ... 65 common frames omitted +Caused by: java.lang.ClassNotFoundException: Cannot find class: DcCodeRuleTest + at org.apache.ibatis.io.ClassLoaderWrapper.classForName(ClassLoaderWrapper.java:196) + at org.apache.ibatis.io.ClassLoaderWrapper.classForName(ClassLoaderWrapper.java:89) + at org.apache.ibatis.io.Resources.classForName(Resources.java:261) + at org.apache.ibatis.type.TypeAliasRegistry.resolveAlias(TypeAliasRegistry.java:116) + ... 67 common frames omitted +12:07:25.821 [restartedMain] ERROR o.s.b.SpringApplication - [reportFailure,870] - Application run failed +org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'accessoryService': Unsatisfied dependency expressed through field 'baseMapper'; nested exception is org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'accessoryMapper' defined in file [/Users/longlongxiaogege/work/mengyin/code/lianmei/myself/backup/dc-backend/data-center/dc-system/target/classes/com/dc/system/mapper/AccessoryMapper.class]: Unsatisfied dependency expressed through bean property 'sqlSessionFactory'; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'sqlSessionFactory' defined in class path resource [com/dc/framework/config/DataSourceConfiguration.class]: Bean instantiation via factory method failed; nested exception is org.springframework.beans.BeanInstantiationException: Failed to instantiate [org.apache.ibatis.session.SqlSessionFactory]: Factory method 'sqlSessionFactory' threw exception; nested exception is java.io.IOException: Failed to parse mapping resource: 'file [/Users/longlongxiaogege/work/mengyin/code/lianmei/myself/backup/dc-backend/data-center/dc-system/target/classes/mapper/system/DcCodeRuleTestMapper.xml]' + at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor$AutowiredFieldElement.resolveFieldValue(AutowiredAnnotationBeanPostProcessor.java:659) + at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor$AutowiredFieldElement.inject(AutowiredAnnotationBeanPostProcessor.java:639) + at org.springframework.beans.factory.annotation.InjectionMetadata.inject(InjectionMetadata.java:119) + at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor.postProcessProperties(AutowiredAnnotationBeanPostProcessor.java:399) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.populateBean(AbstractAutowireCapableBeanFactory.java:1431) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:619) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:542) + at org.springframework.beans.factory.support.AbstractBeanFactory.lambda$doGetBean$0(AbstractBeanFactory.java:335) + at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:234) + at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:333) + at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:208) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.preInstantiateSingletons(DefaultListableBeanFactory.java:953) + at org.springframework.context.support.AbstractApplicationContext.finishBeanFactoryInitialization(AbstractApplicationContext.java:918) + at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:583) + at org.springframework.boot.web.servlet.context.ServletWebServerApplicationContext.refresh(ServletWebServerApplicationContext.java:145) + at org.springframework.boot.SpringApplication.refresh(SpringApplication.java:780) + at org.springframework.boot.SpringApplication.refreshContext(SpringApplication.java:453) + at org.springframework.boot.SpringApplication.run(SpringApplication.java:343) + at org.springframework.boot.SpringApplication.run(SpringApplication.java:1370) + at org.springframework.boot.SpringApplication.run(SpringApplication.java:1359) + at com.dc.web.DcApplication.main(DcApplication.java:20) + at java.base/jdk.internal.reflect.DirectMethodHandleAccessor.invoke(DirectMethodHandleAccessor.java:104) + at java.base/java.lang.reflect.Method.invoke(Method.java:578) + at org.springframework.boot.devtools.restart.RestartLauncher.run(RestartLauncher.java:49) +Caused by: org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'accessoryMapper' defined in file [/Users/longlongxiaogege/work/mengyin/code/lianmei/myself/backup/dc-backend/data-center/dc-system/target/classes/com/dc/system/mapper/AccessoryMapper.class]: Unsatisfied dependency expressed through bean property 'sqlSessionFactory'; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'sqlSessionFactory' defined in class path resource [com/dc/framework/config/DataSourceConfiguration.class]: Bean instantiation via factory method failed; nested exception is org.springframework.beans.BeanInstantiationException: Failed to instantiate [org.apache.ibatis.session.SqlSessionFactory]: Factory method 'sqlSessionFactory' threw exception; nested exception is java.io.IOException: Failed to parse mapping resource: 'file [/Users/longlongxiaogege/work/mengyin/code/lianmei/myself/backup/dc-backend/data-center/dc-system/target/classes/mapper/system/DcCodeRuleTestMapper.xml]' + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.autowireByType(AbstractAutowireCapableBeanFactory.java:1534) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.populateBean(AbstractAutowireCapableBeanFactory.java:1417) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:619) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:542) + at org.springframework.beans.factory.support.AbstractBeanFactory.lambda$doGetBean$0(AbstractBeanFactory.java:335) + at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:234) + at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:333) + at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:208) + at org.springframework.beans.factory.config.DependencyDescriptor.resolveCandidate(DependencyDescriptor.java:276) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.doResolveDependency(DefaultListableBeanFactory.java:1389) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.resolveDependency(DefaultListableBeanFactory.java:1309) + at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor$AutowiredFieldElement.resolveFieldValue(AutowiredAnnotationBeanPostProcessor.java:656) + ... 23 common frames omitted +Caused by: org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'sqlSessionFactory' defined in class path resource [com/dc/framework/config/DataSourceConfiguration.class]: Bean instantiation via factory method failed; nested exception is org.springframework.beans.BeanInstantiationException: Failed to instantiate [org.apache.ibatis.session.SqlSessionFactory]: Factory method 'sqlSessionFactory' threw exception; nested exception is java.io.IOException: Failed to parse mapping resource: 'file [/Users/longlongxiaogege/work/mengyin/code/lianmei/myself/backup/dc-backend/data-center/dc-system/target/classes/mapper/system/DcCodeRuleTestMapper.xml]' + at org.springframework.beans.factory.support.ConstructorResolver.instantiate(ConstructorResolver.java:658) + at org.springframework.beans.factory.support.ConstructorResolver.instantiateUsingFactoryMethod(ConstructorResolver.java:638) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.instantiateUsingFactoryMethod(AbstractAutowireCapableBeanFactory.java:1352) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBeanInstance(AbstractAutowireCapableBeanFactory.java:1195) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:582) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:542) + at org.springframework.beans.factory.support.AbstractBeanFactory.lambda$doGetBean$0(AbstractBeanFactory.java:335) + at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:234) + at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:333) + at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:208) + at org.springframework.beans.factory.config.DependencyDescriptor.resolveCandidate(DependencyDescriptor.java:276) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.doResolveDependency(DefaultListableBeanFactory.java:1389) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.resolveDependency(DefaultListableBeanFactory.java:1309) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.autowireByType(AbstractAutowireCapableBeanFactory.java:1519) + ... 34 common frames omitted +Caused by: org.springframework.beans.BeanInstantiationException: Failed to instantiate [org.apache.ibatis.session.SqlSessionFactory]: Factory method 'sqlSessionFactory' threw exception; nested exception is java.io.IOException: Failed to parse mapping resource: 'file [/Users/longlongxiaogege/work/mengyin/code/lianmei/myself/backup/dc-backend/data-center/dc-system/target/classes/mapper/system/DcCodeRuleTestMapper.xml]' + at org.springframework.beans.factory.support.SimpleInstantiationStrategy.instantiate(SimpleInstantiationStrategy.java:185) + at org.springframework.beans.factory.support.ConstructorResolver.instantiate(ConstructorResolver.java:653) + ... 47 common frames omitted +Caused by: java.io.IOException: Failed to parse mapping resource: 'file [/Users/longlongxiaogege/work/mengyin/code/lianmei/myself/backup/dc-backend/data-center/dc-system/target/classes/mapper/system/DcCodeRuleTestMapper.xml]' + at com.baomidou.mybatisplus.extension.spring.MybatisSqlSessionFactoryBean.buildSqlSessionFactory(MybatisSqlSessionFactoryBean.java:575) + at com.baomidou.mybatisplus.extension.spring.MybatisSqlSessionFactoryBean.afterPropertiesSet(MybatisSqlSessionFactoryBean.java:444) + at com.baomidou.mybatisplus.extension.spring.MybatisSqlSessionFactoryBean.getObject(MybatisSqlSessionFactoryBean.java:608) + at com.dc.framework.config.DataSourceConfiguration.sqlSessionFactory(DataSourceConfiguration.java:109) + at com.dc.framework.config.DataSourceConfiguration$$EnhancerBySpringCGLIB$$4d99d59d.CGLIB$sqlSessionFactory$1(<generated>) + at com.dc.framework.config.DataSourceConfiguration$$EnhancerBySpringCGLIB$$4d99d59d$$FastClassBySpringCGLIB$$70bd98ee.invoke(<generated>) + at org.springframework.cglib.proxy.MethodProxy.invokeSuper(MethodProxy.java:244) + at org.springframework.context.annotation.ConfigurationClassEnhancer$BeanMethodInterceptor.intercept(ConfigurationClassEnhancer.java:331) + at com.dc.framework.config.DataSourceConfiguration$$EnhancerBySpringCGLIB$$4d99d59d.sqlSessionFactory(<generated>) + at java.base/jdk.internal.reflect.DirectMethodHandleAccessor.invoke(DirectMethodHandleAccessor.java:104) + at java.base/java.lang.reflect.Method.invoke(Method.java:578) + at org.springframework.beans.factory.support.SimpleInstantiationStrategy.instantiate(SimpleInstantiationStrategy.java:154) + ... 48 common frames omitted +Caused by: org.apache.ibatis.builder.BuilderException: Error parsing Mapper XML. The XML location is 'file [/Users/longlongxiaogege/work/mengyin/code/lianmei/myself/backup/dc-backend/data-center/dc-system/target/classes/mapper/system/DcCodeRuleTestMapper.xml]'. Cause: org.apache.ibatis.builder.BuilderException: Error resolving class. Cause: org.apache.ibatis.type.TypeException: Could not resolve type alias 'DcCodeRuleTest'. Cause: java.lang.ClassNotFoundException: Cannot find class: DcCodeRuleTest + at org.apache.ibatis.builder.xml.XMLMapperBuilder.configurationElement(XMLMapperBuilder.java:123) + at org.apache.ibatis.builder.xml.XMLMapperBuilder.parse(XMLMapperBuilder.java:95) + at com.baomidou.mybatisplus.extension.spring.MybatisSqlSessionFactoryBean.buildSqlSessionFactory(MybatisSqlSessionFactoryBean.java:573) + ... 59 common frames omitted +Caused by: org.apache.ibatis.builder.BuilderException: Error resolving class. Cause: org.apache.ibatis.type.TypeException: Could not resolve type alias 'DcCodeRuleTest'. Cause: java.lang.ClassNotFoundException: Cannot find class: DcCodeRuleTest + at org.apache.ibatis.builder.BaseBuilder.resolveClass(BaseBuilder.java:118) + at org.apache.ibatis.builder.xml.XMLMapperBuilder.resultMapElement(XMLMapperBuilder.java:263) + at org.apache.ibatis.builder.xml.XMLMapperBuilder.resultMapElement(XMLMapperBuilder.java:254) + at org.apache.ibatis.builder.xml.XMLMapperBuilder.resultMapElements(XMLMapperBuilder.java:246) + at org.apache.ibatis.builder.xml.XMLMapperBuilder.configurationElement(XMLMapperBuilder.java:119) + ... 61 common frames omitted +Caused by: org.apache.ibatis.type.TypeException: Could not resolve type alias 'DcCodeRuleTest'. Cause: java.lang.ClassNotFoundException: Cannot find class: DcCodeRuleTest + at org.apache.ibatis.type.TypeAliasRegistry.resolveAlias(TypeAliasRegistry.java:120) + at org.apache.ibatis.builder.BaseBuilder.resolveAlias(BaseBuilder.java:149) + at org.apache.ibatis.builder.BaseBuilder.resolveClass(BaseBuilder.java:116) + ... 65 common frames omitted +Caused by: java.lang.ClassNotFoundException: Cannot find class: DcCodeRuleTest + at org.apache.ibatis.io.ClassLoaderWrapper.classForName(ClassLoaderWrapper.java:196) + at org.apache.ibatis.io.ClassLoaderWrapper.classForName(ClassLoaderWrapper.java:89) + at org.apache.ibatis.io.Resources.classForName(Resources.java:261) + at org.apache.ibatis.type.TypeAliasRegistry.resolveAlias(TypeAliasRegistry.java:116) + ... 67 common frames omitted +12:07:27.683 [restartedMain] ERROR o.s.b.SpringApplication - [reportFailure,870] - Application run failed +org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'accessoryService': Unsatisfied dependency expressed through field 'baseMapper'; nested exception is org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'accessoryMapper' defined in file [/Users/longlongxiaogege/work/mengyin/code/lianmei/myself/backup/dc-backend/data-center/dc-system/target/classes/com/dc/system/mapper/AccessoryMapper.class]: Unsatisfied dependency expressed through bean property 'sqlSessionFactory'; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'sqlSessionFactory' defined in class path resource [com/dc/framework/config/DataSourceConfiguration.class]: Bean instantiation via factory method failed; nested exception is org.springframework.beans.BeanInstantiationException: Failed to instantiate [org.apache.ibatis.session.SqlSessionFactory]: Factory method 'sqlSessionFactory' threw exception; nested exception is java.io.IOException: Failed to parse mapping resource: 'file [/Users/longlongxiaogege/work/mengyin/code/lianmei/myself/backup/dc-backend/data-center/dc-system/target/classes/mapper/system/DcCodeRuleTestMapper.xml]' + at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor$AutowiredFieldElement.resolveFieldValue(AutowiredAnnotationBeanPostProcessor.java:659) + at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor$AutowiredFieldElement.inject(AutowiredAnnotationBeanPostProcessor.java:639) + at org.springframework.beans.factory.annotation.InjectionMetadata.inject(InjectionMetadata.java:119) + at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor.postProcessProperties(AutowiredAnnotationBeanPostProcessor.java:399) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.populateBean(AbstractAutowireCapableBeanFactory.java:1431) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:619) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:542) + at org.springframework.beans.factory.support.AbstractBeanFactory.lambda$doGetBean$0(AbstractBeanFactory.java:335) + at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:234) + at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:333) + at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:208) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.preInstantiateSingletons(DefaultListableBeanFactory.java:953) + at org.springframework.context.support.AbstractApplicationContext.finishBeanFactoryInitialization(AbstractApplicationContext.java:918) + at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:583) + at org.springframework.boot.web.servlet.context.ServletWebServerApplicationContext.refresh(ServletWebServerApplicationContext.java:145) + at org.springframework.boot.SpringApplication.refresh(SpringApplication.java:780) + at org.springframework.boot.SpringApplication.refreshContext(SpringApplication.java:453) + at org.springframework.boot.SpringApplication.run(SpringApplication.java:343) + at org.springframework.boot.SpringApplication.run(SpringApplication.java:1370) + at org.springframework.boot.SpringApplication.run(SpringApplication.java:1359) + at com.dc.web.DcApplication.main(DcApplication.java:20) + at java.base/jdk.internal.reflect.DirectMethodHandleAccessor.invoke(DirectMethodHandleAccessor.java:104) + at java.base/java.lang.reflect.Method.invoke(Method.java:578) + at org.springframework.boot.devtools.restart.RestartLauncher.run(RestartLauncher.java:49) +Caused by: org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'accessoryMapper' defined in file [/Users/longlongxiaogege/work/mengyin/code/lianmei/myself/backup/dc-backend/data-center/dc-system/target/classes/com/dc/system/mapper/AccessoryMapper.class]: Unsatisfied dependency expressed through bean property 'sqlSessionFactory'; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'sqlSessionFactory' defined in class path resource [com/dc/framework/config/DataSourceConfiguration.class]: Bean instantiation via factory method failed; nested exception is org.springframework.beans.BeanInstantiationException: Failed to instantiate [org.apache.ibatis.session.SqlSessionFactory]: Factory method 'sqlSessionFactory' threw exception; nested exception is java.io.IOException: Failed to parse mapping resource: 'file [/Users/longlongxiaogege/work/mengyin/code/lianmei/myself/backup/dc-backend/data-center/dc-system/target/classes/mapper/system/DcCodeRuleTestMapper.xml]' + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.autowireByType(AbstractAutowireCapableBeanFactory.java:1534) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.populateBean(AbstractAutowireCapableBeanFactory.java:1417) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:619) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:542) + at org.springframework.beans.factory.support.AbstractBeanFactory.lambda$doGetBean$0(AbstractBeanFactory.java:335) + at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:234) + at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:333) + at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:208) + at org.springframework.beans.factory.config.DependencyDescriptor.resolveCandidate(DependencyDescriptor.java:276) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.doResolveDependency(DefaultListableBeanFactory.java:1389) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.resolveDependency(DefaultListableBeanFactory.java:1309) + at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor$AutowiredFieldElement.resolveFieldValue(AutowiredAnnotationBeanPostProcessor.java:656) + ... 23 common frames omitted +Caused by: org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'sqlSessionFactory' defined in class path resource [com/dc/framework/config/DataSourceConfiguration.class]: Bean instantiation via factory method failed; nested exception is org.springframework.beans.BeanInstantiationException: Failed to instantiate [org.apache.ibatis.session.SqlSessionFactory]: Factory method 'sqlSessionFactory' threw exception; nested exception is java.io.IOException: Failed to parse mapping resource: 'file [/Users/longlongxiaogege/work/mengyin/code/lianmei/myself/backup/dc-backend/data-center/dc-system/target/classes/mapper/system/DcCodeRuleTestMapper.xml]' + at org.springframework.beans.factory.support.ConstructorResolver.instantiate(ConstructorResolver.java:658) + at org.springframework.beans.factory.support.ConstructorResolver.instantiateUsingFactoryMethod(ConstructorResolver.java:638) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.instantiateUsingFactoryMethod(AbstractAutowireCapableBeanFactory.java:1352) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBeanInstance(AbstractAutowireCapableBeanFactory.java:1195) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:582) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:542) + at org.springframework.beans.factory.support.AbstractBeanFactory.lambda$doGetBean$0(AbstractBeanFactory.java:335) + at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:234) + at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:333) + at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:208) + at org.springframework.beans.factory.config.DependencyDescriptor.resolveCandidate(DependencyDescriptor.java:276) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.doResolveDependency(DefaultListableBeanFactory.java:1389) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.resolveDependency(DefaultListableBeanFactory.java:1309) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.autowireByType(AbstractAutowireCapableBeanFactory.java:1519) + ... 34 common frames omitted +Caused by: org.springframework.beans.BeanInstantiationException: Failed to instantiate [org.apache.ibatis.session.SqlSessionFactory]: Factory method 'sqlSessionFactory' threw exception; nested exception is java.io.IOException: Failed to parse mapping resource: 'file [/Users/longlongxiaogege/work/mengyin/code/lianmei/myself/backup/dc-backend/data-center/dc-system/target/classes/mapper/system/DcCodeRuleTestMapper.xml]' + at org.springframework.beans.factory.support.SimpleInstantiationStrategy.instantiate(SimpleInstantiationStrategy.java:185) + at org.springframework.beans.factory.support.ConstructorResolver.instantiate(ConstructorResolver.java:653) + ... 47 common frames omitted +Caused by: java.io.IOException: Failed to parse mapping resource: 'file [/Users/longlongxiaogege/work/mengyin/code/lianmei/myself/backup/dc-backend/data-center/dc-system/target/classes/mapper/system/DcCodeRuleTestMapper.xml]' + at com.baomidou.mybatisplus.extension.spring.MybatisSqlSessionFactoryBean.buildSqlSessionFactory(MybatisSqlSessionFactoryBean.java:575) + at com.baomidou.mybatisplus.extension.spring.MybatisSqlSessionFactoryBean.afterPropertiesSet(MybatisSqlSessionFactoryBean.java:444) + at com.baomidou.mybatisplus.extension.spring.MybatisSqlSessionFactoryBean.getObject(MybatisSqlSessionFactoryBean.java:608) + at com.dc.framework.config.DataSourceConfiguration.sqlSessionFactory(DataSourceConfiguration.java:109) + at com.dc.framework.config.DataSourceConfiguration$$EnhancerBySpringCGLIB$$4d99d59d.CGLIB$sqlSessionFactory$1(<generated>) + at com.dc.framework.config.DataSourceConfiguration$$EnhancerBySpringCGLIB$$4d99d59d$$FastClassBySpringCGLIB$$70bd98ee.invoke(<generated>) + at org.springframework.cglib.proxy.MethodProxy.invokeSuper(MethodProxy.java:244) + at org.springframework.context.annotation.ConfigurationClassEnhancer$BeanMethodInterceptor.intercept(ConfigurationClassEnhancer.java:331) + at com.dc.framework.config.DataSourceConfiguration$$EnhancerBySpringCGLIB$$4d99d59d.sqlSessionFactory(<generated>) + at java.base/jdk.internal.reflect.DirectMethodHandleAccessor.invoke(DirectMethodHandleAccessor.java:104) + at java.base/java.lang.reflect.Method.invoke(Method.java:578) + at org.springframework.beans.factory.support.SimpleInstantiationStrategy.instantiate(SimpleInstantiationStrategy.java:154) + ... 48 common frames omitted +Caused by: org.apache.ibatis.builder.BuilderException: Error parsing Mapper XML. The XML location is 'file [/Users/longlongxiaogege/work/mengyin/code/lianmei/myself/backup/dc-backend/data-center/dc-system/target/classes/mapper/system/DcCodeRuleTestMapper.xml]'. Cause: org.apache.ibatis.builder.BuilderException: Error resolving class. Cause: org.apache.ibatis.type.TypeException: Could not resolve type alias 'DcCodeRuleTest'. Cause: java.lang.ClassNotFoundException: Cannot find class: DcCodeRuleTest + at org.apache.ibatis.builder.xml.XMLMapperBuilder.configurationElement(XMLMapperBuilder.java:123) + at org.apache.ibatis.builder.xml.XMLMapperBuilder.parse(XMLMapperBuilder.java:95) + at com.baomidou.mybatisplus.extension.spring.MybatisSqlSessionFactoryBean.buildSqlSessionFactory(MybatisSqlSessionFactoryBean.java:573) + ... 59 common frames omitted +Caused by: org.apache.ibatis.builder.BuilderException: Error resolving class. Cause: org.apache.ibatis.type.TypeException: Could not resolve type alias 'DcCodeRuleTest'. Cause: java.lang.ClassNotFoundException: Cannot find class: DcCodeRuleTest + at org.apache.ibatis.builder.BaseBuilder.resolveClass(BaseBuilder.java:118) + at org.apache.ibatis.builder.xml.XMLMapperBuilder.resultMapElement(XMLMapperBuilder.java:263) + at org.apache.ibatis.builder.xml.XMLMapperBuilder.resultMapElement(XMLMapperBuilder.java:254) + at org.apache.ibatis.builder.xml.XMLMapperBuilder.resultMapElements(XMLMapperBuilder.java:246) + at org.apache.ibatis.builder.xml.XMLMapperBuilder.configurationElement(XMLMapperBuilder.java:119) + ... 61 common frames omitted +Caused by: org.apache.ibatis.type.TypeException: Could not resolve type alias 'DcCodeRuleTest'. Cause: java.lang.ClassNotFoundException: Cannot find class: DcCodeRuleTest + at org.apache.ibatis.type.TypeAliasRegistry.resolveAlias(TypeAliasRegistry.java:120) + at org.apache.ibatis.builder.BaseBuilder.resolveAlias(BaseBuilder.java:149) + at org.apache.ibatis.builder.BaseBuilder.resolveClass(BaseBuilder.java:116) + ... 65 common frames omitted +Caused by: java.lang.ClassNotFoundException: Cannot find class: DcCodeRuleTest + at org.apache.ibatis.io.ClassLoaderWrapper.classForName(ClassLoaderWrapper.java:196) + at org.apache.ibatis.io.ClassLoaderWrapper.classForName(ClassLoaderWrapper.java:89) + at org.apache.ibatis.io.Resources.classForName(Resources.java:261) + at org.apache.ibatis.type.TypeAliasRegistry.resolveAlias(TypeAliasRegistry.java:116) + ... 67 common frames omitted +12:12:52.281 [restartedMain] ERROR o.s.b.SpringApplication - [reportFailure,870] - Application run failed +org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'accessoryService': Unsatisfied dependency expressed through field 'baseMapper'; nested exception is org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'accessoryMapper' defined in file [/Users/longlongxiaogege/work/mengyin/code/lianmei/myself/backup/dc-backend/data-center/dc-system/target/classes/com/dc/system/mapper/AccessoryMapper.class]: Unsatisfied dependency expressed through bean property 'sqlSessionFactory'; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'sqlSessionFactory' defined in class path resource [com/dc/framework/config/DataSourceConfiguration.class]: Bean instantiation via factory method failed; nested exception is org.springframework.beans.BeanInstantiationException: Failed to instantiate [org.apache.ibatis.session.SqlSessionFactory]: Factory method 'sqlSessionFactory' threw exception; nested exception is java.io.IOException: Failed to parse mapping resource: 'file [/Users/longlongxiaogege/work/mengyin/code/lianmei/myself/backup/dc-backend/data-center/dc-system/target/classes/mapper/system/DcCodeRuleTestMapper.xml]' + at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor$AutowiredFieldElement.resolveFieldValue(AutowiredAnnotationBeanPostProcessor.java:659) + at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor$AutowiredFieldElement.inject(AutowiredAnnotationBeanPostProcessor.java:639) + at org.springframework.beans.factory.annotation.InjectionMetadata.inject(InjectionMetadata.java:119) + at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor.postProcessProperties(AutowiredAnnotationBeanPostProcessor.java:399) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.populateBean(AbstractAutowireCapableBeanFactory.java:1431) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:619) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:542) + at org.springframework.beans.factory.support.AbstractBeanFactory.lambda$doGetBean$0(AbstractBeanFactory.java:335) + at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:234) + at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:333) + at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:208) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.preInstantiateSingletons(DefaultListableBeanFactory.java:953) + at org.springframework.context.support.AbstractApplicationContext.finishBeanFactoryInitialization(AbstractApplicationContext.java:918) + at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:583) + at org.springframework.boot.web.servlet.context.ServletWebServerApplicationContext.refresh(ServletWebServerApplicationContext.java:145) + at org.springframework.boot.SpringApplication.refresh(SpringApplication.java:780) + at org.springframework.boot.SpringApplication.refreshContext(SpringApplication.java:453) + at org.springframework.boot.SpringApplication.run(SpringApplication.java:343) + at org.springframework.boot.SpringApplication.run(SpringApplication.java:1370) + at org.springframework.boot.SpringApplication.run(SpringApplication.java:1359) + at com.dc.web.DcApplication.main(DcApplication.java:20) + at java.base/jdk.internal.reflect.DirectMethodHandleAccessor.invoke(DirectMethodHandleAccessor.java:104) + at java.base/java.lang.reflect.Method.invoke(Method.java:578) + at org.springframework.boot.devtools.restart.RestartLauncher.run(RestartLauncher.java:49) +Caused by: org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'accessoryMapper' defined in file [/Users/longlongxiaogege/work/mengyin/code/lianmei/myself/backup/dc-backend/data-center/dc-system/target/classes/com/dc/system/mapper/AccessoryMapper.class]: Unsatisfied dependency expressed through bean property 'sqlSessionFactory'; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'sqlSessionFactory' defined in class path resource [com/dc/framework/config/DataSourceConfiguration.class]: Bean instantiation via factory method failed; nested exception is org.springframework.beans.BeanInstantiationException: Failed to instantiate [org.apache.ibatis.session.SqlSessionFactory]: Factory method 'sqlSessionFactory' threw exception; nested exception is java.io.IOException: Failed to parse mapping resource: 'file [/Users/longlongxiaogege/work/mengyin/code/lianmei/myself/backup/dc-backend/data-center/dc-system/target/classes/mapper/system/DcCodeRuleTestMapper.xml]' + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.autowireByType(AbstractAutowireCapableBeanFactory.java:1534) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.populateBean(AbstractAutowireCapableBeanFactory.java:1417) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:619) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:542) + at org.springframework.beans.factory.support.AbstractBeanFactory.lambda$doGetBean$0(AbstractBeanFactory.java:335) + at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:234) + at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:333) + at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:208) + at org.springframework.beans.factory.config.DependencyDescriptor.resolveCandidate(DependencyDescriptor.java:276) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.doResolveDependency(DefaultListableBeanFactory.java:1389) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.resolveDependency(DefaultListableBeanFactory.java:1309) + at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor$AutowiredFieldElement.resolveFieldValue(AutowiredAnnotationBeanPostProcessor.java:656) + ... 23 common frames omitted +Caused by: org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'sqlSessionFactory' defined in class path resource [com/dc/framework/config/DataSourceConfiguration.class]: Bean instantiation via factory method failed; nested exception is org.springframework.beans.BeanInstantiationException: Failed to instantiate [org.apache.ibatis.session.SqlSessionFactory]: Factory method 'sqlSessionFactory' threw exception; nested exception is java.io.IOException: Failed to parse mapping resource: 'file [/Users/longlongxiaogege/work/mengyin/code/lianmei/myself/backup/dc-backend/data-center/dc-system/target/classes/mapper/system/DcCodeRuleTestMapper.xml]' + at org.springframework.beans.factory.support.ConstructorResolver.instantiate(ConstructorResolver.java:658) + at org.springframework.beans.factory.support.ConstructorResolver.instantiateUsingFactoryMethod(ConstructorResolver.java:638) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.instantiateUsingFactoryMethod(AbstractAutowireCapableBeanFactory.java:1352) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBeanInstance(AbstractAutowireCapableBeanFactory.java:1195) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:582) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:542) + at org.springframework.beans.factory.support.AbstractBeanFactory.lambda$doGetBean$0(AbstractBeanFactory.java:335) + at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:234) + at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:333) + at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:208) + at org.springframework.beans.factory.config.DependencyDescriptor.resolveCandidate(DependencyDescriptor.java:276) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.doResolveDependency(DefaultListableBeanFactory.java:1389) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.resolveDependency(DefaultListableBeanFactory.java:1309) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.autowireByType(AbstractAutowireCapableBeanFactory.java:1519) + ... 34 common frames omitted +Caused by: org.springframework.beans.BeanInstantiationException: Failed to instantiate [org.apache.ibatis.session.SqlSessionFactory]: Factory method 'sqlSessionFactory' threw exception; nested exception is java.io.IOException: Failed to parse mapping resource: 'file [/Users/longlongxiaogege/work/mengyin/code/lianmei/myself/backup/dc-backend/data-center/dc-system/target/classes/mapper/system/DcCodeRuleTestMapper.xml]' + at org.springframework.beans.factory.support.SimpleInstantiationStrategy.instantiate(SimpleInstantiationStrategy.java:185) + at org.springframework.beans.factory.support.ConstructorResolver.instantiate(ConstructorResolver.java:653) + ... 47 common frames omitted +Caused by: java.io.IOException: Failed to parse mapping resource: 'file [/Users/longlongxiaogege/work/mengyin/code/lianmei/myself/backup/dc-backend/data-center/dc-system/target/classes/mapper/system/DcCodeRuleTestMapper.xml]' + at com.baomidou.mybatisplus.extension.spring.MybatisSqlSessionFactoryBean.buildSqlSessionFactory(MybatisSqlSessionFactoryBean.java:575) + at com.baomidou.mybatisplus.extension.spring.MybatisSqlSessionFactoryBean.afterPropertiesSet(MybatisSqlSessionFactoryBean.java:444) + at com.baomidou.mybatisplus.extension.spring.MybatisSqlSessionFactoryBean.getObject(MybatisSqlSessionFactoryBean.java:608) + at com.dc.framework.config.DataSourceConfiguration.sqlSessionFactory(DataSourceConfiguration.java:109) + at com.dc.framework.config.DataSourceConfiguration$$EnhancerBySpringCGLIB$$4d99d59d.CGLIB$sqlSessionFactory$1(<generated>) + at com.dc.framework.config.DataSourceConfiguration$$EnhancerBySpringCGLIB$$4d99d59d$$FastClassBySpringCGLIB$$70bd98ee.invoke(<generated>) + at org.springframework.cglib.proxy.MethodProxy.invokeSuper(MethodProxy.java:244) + at org.springframework.context.annotation.ConfigurationClassEnhancer$BeanMethodInterceptor.intercept(ConfigurationClassEnhancer.java:331) + at com.dc.framework.config.DataSourceConfiguration$$EnhancerBySpringCGLIB$$4d99d59d.sqlSessionFactory(<generated>) + at java.base/jdk.internal.reflect.DirectMethodHandleAccessor.invoke(DirectMethodHandleAccessor.java:104) + at java.base/java.lang.reflect.Method.invoke(Method.java:578) + at org.springframework.beans.factory.support.SimpleInstantiationStrategy.instantiate(SimpleInstantiationStrategy.java:154) + ... 48 common frames omitted +Caused by: org.apache.ibatis.builder.BuilderException: Error parsing Mapper XML. The XML location is 'file [/Users/longlongxiaogege/work/mengyin/code/lianmei/myself/backup/dc-backend/data-center/dc-system/target/classes/mapper/system/DcCodeRuleTestMapper.xml]'. Cause: org.apache.ibatis.builder.BuilderException: Error resolving class. Cause: org.apache.ibatis.type.TypeException: Could not resolve type alias 'DcCodeRuleTest'. Cause: java.lang.ClassNotFoundException: Cannot find class: DcCodeRuleTest + at org.apache.ibatis.builder.xml.XMLMapperBuilder.configurationElement(XMLMapperBuilder.java:123) + at org.apache.ibatis.builder.xml.XMLMapperBuilder.parse(XMLMapperBuilder.java:95) + at com.baomidou.mybatisplus.extension.spring.MybatisSqlSessionFactoryBean.buildSqlSessionFactory(MybatisSqlSessionFactoryBean.java:573) + ... 59 common frames omitted +Caused by: org.apache.ibatis.builder.BuilderException: Error resolving class. Cause: org.apache.ibatis.type.TypeException: Could not resolve type alias 'DcCodeRuleTest'. Cause: java.lang.ClassNotFoundException: Cannot find class: DcCodeRuleTest + at org.apache.ibatis.builder.BaseBuilder.resolveClass(BaseBuilder.java:118) + at org.apache.ibatis.builder.xml.XMLMapperBuilder.resultMapElement(XMLMapperBuilder.java:263) + at org.apache.ibatis.builder.xml.XMLMapperBuilder.resultMapElement(XMLMapperBuilder.java:254) + at org.apache.ibatis.builder.xml.XMLMapperBuilder.resultMapElements(XMLMapperBuilder.java:246) + at org.apache.ibatis.builder.xml.XMLMapperBuilder.configurationElement(XMLMapperBuilder.java:119) + ... 61 common frames omitted +Caused by: org.apache.ibatis.type.TypeException: Could not resolve type alias 'DcCodeRuleTest'. Cause: java.lang.ClassNotFoundException: Cannot find class: DcCodeRuleTest + at org.apache.ibatis.type.TypeAliasRegistry.resolveAlias(TypeAliasRegistry.java:120) + at org.apache.ibatis.builder.BaseBuilder.resolveAlias(BaseBuilder.java:149) + at org.apache.ibatis.builder.BaseBuilder.resolveClass(BaseBuilder.java:116) + ... 65 common frames omitted +Caused by: java.lang.ClassNotFoundException: Cannot find class: DcCodeRuleTest + at org.apache.ibatis.io.ClassLoaderWrapper.classForName(ClassLoaderWrapper.java:196) + at org.apache.ibatis.io.ClassLoaderWrapper.classForName(ClassLoaderWrapper.java:89) + at org.apache.ibatis.io.Resources.classForName(Resources.java:261) + at org.apache.ibatis.type.TypeAliasRegistry.resolveAlias(TypeAliasRegistry.java:116) + ... 67 common frames omitted +12:12:54.181 [restartedMain] ERROR o.s.b.SpringApplication - [reportFailure,870] - Application run failed +org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'accessoryService': Unsatisfied dependency expressed through field 'baseMapper'; nested exception is org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'accessoryMapper' defined in file [/Users/longlongxiaogege/work/mengyin/code/lianmei/myself/backup/dc-backend/data-center/dc-system/target/classes/com/dc/system/mapper/AccessoryMapper.class]: Unsatisfied dependency expressed through bean property 'sqlSessionFactory'; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'sqlSessionFactory' defined in class path resource [com/dc/framework/config/DataSourceConfiguration.class]: Bean instantiation via factory method failed; nested exception is org.springframework.beans.BeanInstantiationException: Failed to instantiate [org.apache.ibatis.session.SqlSessionFactory]: Factory method 'sqlSessionFactory' threw exception; nested exception is java.io.IOException: Failed to parse mapping resource: 'file [/Users/longlongxiaogege/work/mengyin/code/lianmei/myself/backup/dc-backend/data-center/dc-system/target/classes/mapper/system/DcCodeRuleTestMapper.xml]' + at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor$AutowiredFieldElement.resolveFieldValue(AutowiredAnnotationBeanPostProcessor.java:659) + at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor$AutowiredFieldElement.inject(AutowiredAnnotationBeanPostProcessor.java:639) + at org.springframework.beans.factory.annotation.InjectionMetadata.inject(InjectionMetadata.java:119) + at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor.postProcessProperties(AutowiredAnnotationBeanPostProcessor.java:399) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.populateBean(AbstractAutowireCapableBeanFactory.java:1431) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:619) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:542) + at org.springframework.beans.factory.support.AbstractBeanFactory.lambda$doGetBean$0(AbstractBeanFactory.java:335) + at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:234) + at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:333) + at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:208) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.preInstantiateSingletons(DefaultListableBeanFactory.java:953) + at org.springframework.context.support.AbstractApplicationContext.finishBeanFactoryInitialization(AbstractApplicationContext.java:918) + at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:583) + at org.springframework.boot.web.servlet.context.ServletWebServerApplicationContext.refresh(ServletWebServerApplicationContext.java:145) + at org.springframework.boot.SpringApplication.refresh(SpringApplication.java:780) + at org.springframework.boot.SpringApplication.refreshContext(SpringApplication.java:453) + at org.springframework.boot.SpringApplication.run(SpringApplication.java:343) + at org.springframework.boot.SpringApplication.run(SpringApplication.java:1370) + at org.springframework.boot.SpringApplication.run(SpringApplication.java:1359) + at com.dc.web.DcApplication.main(DcApplication.java:20) + at java.base/jdk.internal.reflect.DirectMethodHandleAccessor.invoke(DirectMethodHandleAccessor.java:104) + at java.base/java.lang.reflect.Method.invoke(Method.java:578) + at org.springframework.boot.devtools.restart.RestartLauncher.run(RestartLauncher.java:49) +Caused by: org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'accessoryMapper' defined in file [/Users/longlongxiaogege/work/mengyin/code/lianmei/myself/backup/dc-backend/data-center/dc-system/target/classes/com/dc/system/mapper/AccessoryMapper.class]: Unsatisfied dependency expressed through bean property 'sqlSessionFactory'; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'sqlSessionFactory' defined in class path resource [com/dc/framework/config/DataSourceConfiguration.class]: Bean instantiation via factory method failed; nested exception is org.springframework.beans.BeanInstantiationException: Failed to instantiate [org.apache.ibatis.session.SqlSessionFactory]: Factory method 'sqlSessionFactory' threw exception; nested exception is java.io.IOException: Failed to parse mapping resource: 'file [/Users/longlongxiaogege/work/mengyin/code/lianmei/myself/backup/dc-backend/data-center/dc-system/target/classes/mapper/system/DcCodeRuleTestMapper.xml]' + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.autowireByType(AbstractAutowireCapableBeanFactory.java:1534) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.populateBean(AbstractAutowireCapableBeanFactory.java:1417) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:619) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:542) + at org.springframework.beans.factory.support.AbstractBeanFactory.lambda$doGetBean$0(AbstractBeanFactory.java:335) + at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:234) + at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:333) + at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:208) + at org.springframework.beans.factory.config.DependencyDescriptor.resolveCandidate(DependencyDescriptor.java:276) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.doResolveDependency(DefaultListableBeanFactory.java:1389) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.resolveDependency(DefaultListableBeanFactory.java:1309) + at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor$AutowiredFieldElement.resolveFieldValue(AutowiredAnnotationBeanPostProcessor.java:656) + ... 23 common frames omitted +Caused by: org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'sqlSessionFactory' defined in class path resource [com/dc/framework/config/DataSourceConfiguration.class]: Bean instantiation via factory method failed; nested exception is org.springframework.beans.BeanInstantiationException: Failed to instantiate [org.apache.ibatis.session.SqlSessionFactory]: Factory method 'sqlSessionFactory' threw exception; nested exception is java.io.IOException: Failed to parse mapping resource: 'file [/Users/longlongxiaogege/work/mengyin/code/lianmei/myself/backup/dc-backend/data-center/dc-system/target/classes/mapper/system/DcCodeRuleTestMapper.xml]' + at org.springframework.beans.factory.support.ConstructorResolver.instantiate(ConstructorResolver.java:658) + at org.springframework.beans.factory.support.ConstructorResolver.instantiateUsingFactoryMethod(ConstructorResolver.java:638) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.instantiateUsingFactoryMethod(AbstractAutowireCapableBeanFactory.java:1352) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBeanInstance(AbstractAutowireCapableBeanFactory.java:1195) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:582) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:542) + at org.springframework.beans.factory.support.AbstractBeanFactory.lambda$doGetBean$0(AbstractBeanFactory.java:335) + at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:234) + at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:333) + at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:208) + at org.springframework.beans.factory.config.DependencyDescriptor.resolveCandidate(DependencyDescriptor.java:276) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.doResolveDependency(DefaultListableBeanFactory.java:1389) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.resolveDependency(DefaultListableBeanFactory.java:1309) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.autowireByType(AbstractAutowireCapableBeanFactory.java:1519) + ... 34 common frames omitted +Caused by: org.springframework.beans.BeanInstantiationException: Failed to instantiate [org.apache.ibatis.session.SqlSessionFactory]: Factory method 'sqlSessionFactory' threw exception; nested exception is java.io.IOException: Failed to parse mapping resource: 'file [/Users/longlongxiaogege/work/mengyin/code/lianmei/myself/backup/dc-backend/data-center/dc-system/target/classes/mapper/system/DcCodeRuleTestMapper.xml]' + at org.springframework.beans.factory.support.SimpleInstantiationStrategy.instantiate(SimpleInstantiationStrategy.java:185) + at org.springframework.beans.factory.support.ConstructorResolver.instantiate(ConstructorResolver.java:653) + ... 47 common frames omitted +Caused by: java.io.IOException: Failed to parse mapping resource: 'file [/Users/longlongxiaogege/work/mengyin/code/lianmei/myself/backup/dc-backend/data-center/dc-system/target/classes/mapper/system/DcCodeRuleTestMapper.xml]' + at com.baomidou.mybatisplus.extension.spring.MybatisSqlSessionFactoryBean.buildSqlSessionFactory(MybatisSqlSessionFactoryBean.java:575) + at com.baomidou.mybatisplus.extension.spring.MybatisSqlSessionFactoryBean.afterPropertiesSet(MybatisSqlSessionFactoryBean.java:444) + at com.baomidou.mybatisplus.extension.spring.MybatisSqlSessionFactoryBean.getObject(MybatisSqlSessionFactoryBean.java:608) + at com.dc.framework.config.DataSourceConfiguration.sqlSessionFactory(DataSourceConfiguration.java:109) + at com.dc.framework.config.DataSourceConfiguration$$EnhancerBySpringCGLIB$$4d99d59d.CGLIB$sqlSessionFactory$1(<generated>) + at com.dc.framework.config.DataSourceConfiguration$$EnhancerBySpringCGLIB$$4d99d59d$$FastClassBySpringCGLIB$$70bd98ee.invoke(<generated>) + at org.springframework.cglib.proxy.MethodProxy.invokeSuper(MethodProxy.java:244) + at org.springframework.context.annotation.ConfigurationClassEnhancer$BeanMethodInterceptor.intercept(ConfigurationClassEnhancer.java:331) + at com.dc.framework.config.DataSourceConfiguration$$EnhancerBySpringCGLIB$$4d99d59d.sqlSessionFactory(<generated>) + at java.base/jdk.internal.reflect.DirectMethodHandleAccessor.invoke(DirectMethodHandleAccessor.java:104) + at java.base/java.lang.reflect.Method.invoke(Method.java:578) + at org.springframework.beans.factory.support.SimpleInstantiationStrategy.instantiate(SimpleInstantiationStrategy.java:154) + ... 48 common frames omitted +Caused by: org.apache.ibatis.builder.BuilderException: Error parsing Mapper XML. The XML location is 'file [/Users/longlongxiaogege/work/mengyin/code/lianmei/myself/backup/dc-backend/data-center/dc-system/target/classes/mapper/system/DcCodeRuleTestMapper.xml]'. Cause: org.apache.ibatis.builder.BuilderException: Error resolving class. Cause: org.apache.ibatis.type.TypeException: Could not resolve type alias 'DcCodeRuleTest'. Cause: java.lang.ClassNotFoundException: Cannot find class: DcCodeRuleTest + at org.apache.ibatis.builder.xml.XMLMapperBuilder.configurationElement(XMLMapperBuilder.java:123) + at org.apache.ibatis.builder.xml.XMLMapperBuilder.parse(XMLMapperBuilder.java:95) + at com.baomidou.mybatisplus.extension.spring.MybatisSqlSessionFactoryBean.buildSqlSessionFactory(MybatisSqlSessionFactoryBean.java:573) + ... 59 common frames omitted +Caused by: org.apache.ibatis.builder.BuilderException: Error resolving class. Cause: org.apache.ibatis.type.TypeException: Could not resolve type alias 'DcCodeRuleTest'. Cause: java.lang.ClassNotFoundException: Cannot find class: DcCodeRuleTest + at org.apache.ibatis.builder.BaseBuilder.resolveClass(BaseBuilder.java:118) + at org.apache.ibatis.builder.xml.XMLMapperBuilder.resultMapElement(XMLMapperBuilder.java:263) + at org.apache.ibatis.builder.xml.XMLMapperBuilder.resultMapElement(XMLMapperBuilder.java:254) + at org.apache.ibatis.builder.xml.XMLMapperBuilder.resultMapElements(XMLMapperBuilder.java:246) + at org.apache.ibatis.builder.xml.XMLMapperBuilder.configurationElement(XMLMapperBuilder.java:119) + ... 61 common frames omitted +Caused by: org.apache.ibatis.type.TypeException: Could not resolve type alias 'DcCodeRuleTest'. Cause: java.lang.ClassNotFoundException: Cannot find class: DcCodeRuleTest + at org.apache.ibatis.type.TypeAliasRegistry.resolveAlias(TypeAliasRegistry.java:120) + at org.apache.ibatis.builder.BaseBuilder.resolveAlias(BaseBuilder.java:149) + at org.apache.ibatis.builder.BaseBuilder.resolveClass(BaseBuilder.java:116) + ... 65 common frames omitted +Caused by: java.lang.ClassNotFoundException: Cannot find class: DcCodeRuleTest + at org.apache.ibatis.io.ClassLoaderWrapper.classForName(ClassLoaderWrapper.java:196) + at org.apache.ibatis.io.ClassLoaderWrapper.classForName(ClassLoaderWrapper.java:89) + at org.apache.ibatis.io.Resources.classForName(Resources.java:261) + at org.apache.ibatis.type.TypeAliasRegistry.resolveAlias(TypeAliasRegistry.java:116) + ... 67 common frames omitted +12:13:16.609 [restartedMain] ERROR o.s.b.SpringApplication - [reportFailure,870] - Application run failed +org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'accessoryService': Unsatisfied dependency expressed through field 'baseMapper'; nested exception is org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'accessoryMapper' defined in file [/Users/longlongxiaogege/work/mengyin/code/lianmei/myself/backup/dc-backend/data-center/dc-system/target/classes/com/dc/system/mapper/AccessoryMapper.class]: Unsatisfied dependency expressed through bean property 'sqlSessionFactory'; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'sqlSessionFactory' defined in class path resource [com/dc/framework/config/DataSourceConfiguration.class]: Bean instantiation via factory method failed; nested exception is org.springframework.beans.BeanInstantiationException: Failed to instantiate [org.apache.ibatis.session.SqlSessionFactory]: Factory method 'sqlSessionFactory' threw exception; nested exception is java.io.IOException: Failed to parse mapping resource: 'file [/Users/longlongxiaogege/work/mengyin/code/lianmei/myself/backup/dc-backend/data-center/dc-system/target/classes/mapper/system/DcCodeRuleTestMapper.xml]' + at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor$AutowiredFieldElement.resolveFieldValue(AutowiredAnnotationBeanPostProcessor.java:659) + at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor$AutowiredFieldElement.inject(AutowiredAnnotationBeanPostProcessor.java:639) + at org.springframework.beans.factory.annotation.InjectionMetadata.inject(InjectionMetadata.java:119) + at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor.postProcessProperties(AutowiredAnnotationBeanPostProcessor.java:399) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.populateBean(AbstractAutowireCapableBeanFactory.java:1431) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:619) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:542) + at org.springframework.beans.factory.support.AbstractBeanFactory.lambda$doGetBean$0(AbstractBeanFactory.java:335) + at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:234) + at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:333) + at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:208) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.preInstantiateSingletons(DefaultListableBeanFactory.java:953) + at org.springframework.context.support.AbstractApplicationContext.finishBeanFactoryInitialization(AbstractApplicationContext.java:918) + at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:583) + at org.springframework.boot.web.servlet.context.ServletWebServerApplicationContext.refresh(ServletWebServerApplicationContext.java:145) + at org.springframework.boot.SpringApplication.refresh(SpringApplication.java:780) + at org.springframework.boot.SpringApplication.refreshContext(SpringApplication.java:453) + at org.springframework.boot.SpringApplication.run(SpringApplication.java:343) + at org.springframework.boot.SpringApplication.run(SpringApplication.java:1370) + at org.springframework.boot.SpringApplication.run(SpringApplication.java:1359) + at com.dc.web.DcApplication.main(DcApplication.java:20) + at java.base/jdk.internal.reflect.DirectMethodHandleAccessor.invoke(DirectMethodHandleAccessor.java:104) + at java.base/java.lang.reflect.Method.invoke(Method.java:578) + at org.springframework.boot.devtools.restart.RestartLauncher.run(RestartLauncher.java:49) +Caused by: org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'accessoryMapper' defined in file [/Users/longlongxiaogege/work/mengyin/code/lianmei/myself/backup/dc-backend/data-center/dc-system/target/classes/com/dc/system/mapper/AccessoryMapper.class]: Unsatisfied dependency expressed through bean property 'sqlSessionFactory'; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'sqlSessionFactory' defined in class path resource [com/dc/framework/config/DataSourceConfiguration.class]: Bean instantiation via factory method failed; nested exception is org.springframework.beans.BeanInstantiationException: Failed to instantiate [org.apache.ibatis.session.SqlSessionFactory]: Factory method 'sqlSessionFactory' threw exception; nested exception is java.io.IOException: Failed to parse mapping resource: 'file [/Users/longlongxiaogege/work/mengyin/code/lianmei/myself/backup/dc-backend/data-center/dc-system/target/classes/mapper/system/DcCodeRuleTestMapper.xml]' + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.autowireByType(AbstractAutowireCapableBeanFactory.java:1534) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.populateBean(AbstractAutowireCapableBeanFactory.java:1417) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:619) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:542) + at org.springframework.beans.factory.support.AbstractBeanFactory.lambda$doGetBean$0(AbstractBeanFactory.java:335) + at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:234) + at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:333) + at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:208) + at org.springframework.beans.factory.config.DependencyDescriptor.resolveCandidate(DependencyDescriptor.java:276) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.doResolveDependency(DefaultListableBeanFactory.java:1389) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.resolveDependency(DefaultListableBeanFactory.java:1309) + at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor$AutowiredFieldElement.resolveFieldValue(AutowiredAnnotationBeanPostProcessor.java:656) + ... 23 common frames omitted +Caused by: org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'sqlSessionFactory' defined in class path resource [com/dc/framework/config/DataSourceConfiguration.class]: Bean instantiation via factory method failed; nested exception is org.springframework.beans.BeanInstantiationException: Failed to instantiate [org.apache.ibatis.session.SqlSessionFactory]: Factory method 'sqlSessionFactory' threw exception; nested exception is java.io.IOException: Failed to parse mapping resource: 'file [/Users/longlongxiaogege/work/mengyin/code/lianmei/myself/backup/dc-backend/data-center/dc-system/target/classes/mapper/system/DcCodeRuleTestMapper.xml]' + at org.springframework.beans.factory.support.ConstructorResolver.instantiate(ConstructorResolver.java:658) + at org.springframework.beans.factory.support.ConstructorResolver.instantiateUsingFactoryMethod(ConstructorResolver.java:638) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.instantiateUsingFactoryMethod(AbstractAutowireCapableBeanFactory.java:1352) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBeanInstance(AbstractAutowireCapableBeanFactory.java:1195) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:582) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:542) + at org.springframework.beans.factory.support.AbstractBeanFactory.lambda$doGetBean$0(AbstractBeanFactory.java:335) + at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:234) + at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:333) + at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:208) + at org.springframework.beans.factory.config.DependencyDescriptor.resolveCandidate(DependencyDescriptor.java:276) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.doResolveDependency(DefaultListableBeanFactory.java:1389) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.resolveDependency(DefaultListableBeanFactory.java:1309) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.autowireByType(AbstractAutowireCapableBeanFactory.java:1519) + ... 34 common frames omitted +Caused by: org.springframework.beans.BeanInstantiationException: Failed to instantiate [org.apache.ibatis.session.SqlSessionFactory]: Factory method 'sqlSessionFactory' threw exception; nested exception is java.io.IOException: Failed to parse mapping resource: 'file [/Users/longlongxiaogege/work/mengyin/code/lianmei/myself/backup/dc-backend/data-center/dc-system/target/classes/mapper/system/DcCodeRuleTestMapper.xml]' + at org.springframework.beans.factory.support.SimpleInstantiationStrategy.instantiate(SimpleInstantiationStrategy.java:185) + at org.springframework.beans.factory.support.ConstructorResolver.instantiate(ConstructorResolver.java:653) + ... 47 common frames omitted +Caused by: java.io.IOException: Failed to parse mapping resource: 'file [/Users/longlongxiaogege/work/mengyin/code/lianmei/myself/backup/dc-backend/data-center/dc-system/target/classes/mapper/system/DcCodeRuleTestMapper.xml]' + at com.baomidou.mybatisplus.extension.spring.MybatisSqlSessionFactoryBean.buildSqlSessionFactory(MybatisSqlSessionFactoryBean.java:575) + at com.baomidou.mybatisplus.extension.spring.MybatisSqlSessionFactoryBean.afterPropertiesSet(MybatisSqlSessionFactoryBean.java:444) + at com.baomidou.mybatisplus.extension.spring.MybatisSqlSessionFactoryBean.getObject(MybatisSqlSessionFactoryBean.java:608) + at com.dc.framework.config.DataSourceConfiguration.sqlSessionFactory(DataSourceConfiguration.java:109) + at com.dc.framework.config.DataSourceConfiguration$$EnhancerBySpringCGLIB$$4d99d59d.CGLIB$sqlSessionFactory$1(<generated>) + at com.dc.framework.config.DataSourceConfiguration$$EnhancerBySpringCGLIB$$4d99d59d$$FastClassBySpringCGLIB$$70bd98ee.invoke(<generated>) + at org.springframework.cglib.proxy.MethodProxy.invokeSuper(MethodProxy.java:244) + at org.springframework.context.annotation.ConfigurationClassEnhancer$BeanMethodInterceptor.intercept(ConfigurationClassEnhancer.java:331) + at com.dc.framework.config.DataSourceConfiguration$$EnhancerBySpringCGLIB$$4d99d59d.sqlSessionFactory(<generated>) + at java.base/jdk.internal.reflect.DirectMethodHandleAccessor.invoke(DirectMethodHandleAccessor.java:104) + at java.base/java.lang.reflect.Method.invoke(Method.java:578) + at org.springframework.beans.factory.support.SimpleInstantiationStrategy.instantiate(SimpleInstantiationStrategy.java:154) + ... 48 common frames omitted +Caused by: org.apache.ibatis.builder.BuilderException: Error parsing Mapper XML. The XML location is 'file [/Users/longlongxiaogege/work/mengyin/code/lianmei/myself/backup/dc-backend/data-center/dc-system/target/classes/mapper/system/DcCodeRuleTestMapper.xml]'. Cause: org.apache.ibatis.builder.BuilderException: Error resolving class. Cause: org.apache.ibatis.type.TypeException: Could not resolve type alias 'DcCodeRuleTest'. Cause: java.lang.ClassNotFoundException: Cannot find class: DcCodeRuleTest + at org.apache.ibatis.builder.xml.XMLMapperBuilder.configurationElement(XMLMapperBuilder.java:123) + at org.apache.ibatis.builder.xml.XMLMapperBuilder.parse(XMLMapperBuilder.java:95) + at com.baomidou.mybatisplus.extension.spring.MybatisSqlSessionFactoryBean.buildSqlSessionFactory(MybatisSqlSessionFactoryBean.java:573) + ... 59 common frames omitted +Caused by: org.apache.ibatis.builder.BuilderException: Error resolving class. Cause: org.apache.ibatis.type.TypeException: Could not resolve type alias 'DcCodeRuleTest'. Cause: java.lang.ClassNotFoundException: Cannot find class: DcCodeRuleTest + at org.apache.ibatis.builder.BaseBuilder.resolveClass(BaseBuilder.java:118) + at org.apache.ibatis.builder.xml.XMLMapperBuilder.resultMapElement(XMLMapperBuilder.java:263) + at org.apache.ibatis.builder.xml.XMLMapperBuilder.resultMapElement(XMLMapperBuilder.java:254) + at org.apache.ibatis.builder.xml.XMLMapperBuilder.resultMapElements(XMLMapperBuilder.java:246) + at org.apache.ibatis.builder.xml.XMLMapperBuilder.configurationElement(XMLMapperBuilder.java:119) + ... 61 common frames omitted +Caused by: org.apache.ibatis.type.TypeException: Could not resolve type alias 'DcCodeRuleTest'. Cause: java.lang.ClassNotFoundException: Cannot find class: DcCodeRuleTest + at org.apache.ibatis.type.TypeAliasRegistry.resolveAlias(TypeAliasRegistry.java:120) + at org.apache.ibatis.builder.BaseBuilder.resolveAlias(BaseBuilder.java:149) + at org.apache.ibatis.builder.BaseBuilder.resolveClass(BaseBuilder.java:116) + ... 65 common frames omitted +Caused by: java.lang.ClassNotFoundException: Cannot find class: DcCodeRuleTest + at org.apache.ibatis.io.ClassLoaderWrapper.classForName(ClassLoaderWrapper.java:196) + at org.apache.ibatis.io.ClassLoaderWrapper.classForName(ClassLoaderWrapper.java:89) + at org.apache.ibatis.io.Resources.classForName(Resources.java:261) + at org.apache.ibatis.type.TypeAliasRegistry.resolveAlias(TypeAliasRegistry.java:116) + ... 67 common frames omitted +13:58:10.753 [http-nio-9000-exec-74] ERROR c.d.f.w.e.GlobalExceptionHandler - [handleRuntimeException,82] - 请求地址'/system/menu',发生未知异常. +org.springframework.dao.DuplicateKeyException: +### Error updating database. Cause: org.postgresql.util.PSQLException: ERROR: duplicate key value violates unique constraint "sys_menu_pkey" + 详细:Key (menu_id)=(2000) already exists. +### The error may exist in file [/Users/longlongxiaogege/work/mengyin/code/lianmei/myself/backup/dc-backend/data-center/dc-system/target/classes/mapper/system/SysMenuMapper.xml] +### The error may involve com.dc.system.mapper.SysMenuMapper.insertMenu-Inline +### The error occurred while setting parameters +### SQL: insert into sys_menu( parent_id, menu_name, order_num, path, component, is_frame, is_cache, menu_type, visible, status, icon, create_by, create_time )values( ?, ?, ?, ?, ?, ?::integer, ?::integer, ?, ?, ?::integer, ?, ?, current_timestamp ) +### Cause: org.postgresql.util.PSQLException: ERROR: duplicate key value violates unique constraint "sys_menu_pkey" + 详细:Key (menu_id)=(2000) already exists. +; ERROR: duplicate key value violates unique constraint "sys_menu_pkey" + 详细:Key (menu_id)=(2000) already exists.; nested exception is org.postgresql.util.PSQLException: ERROR: duplicate key value violates unique constraint "sys_menu_pkey" + 详细:Key (menu_id)=(2000) already exists. + at org.springframework.jdbc.support.SQLErrorCodeSQLExceptionTranslator.doTranslate(SQLErrorCodeSQLExceptionTranslator.java:247) + at org.springframework.jdbc.support.AbstractFallbackSQLExceptionTranslator.translate(AbstractFallbackSQLExceptionTranslator.java:70) + at org.mybatis.spring.MyBatisExceptionTranslator.translateExceptionIfPossible(MyBatisExceptionTranslator.java:91) + at org.mybatis.spring.SqlSessionTemplate$SqlSessionInterceptor.invoke(SqlSessionTemplate.java:441) + at jdk.proxy2/jdk.proxy2.$Proxy113.insert(Unknown Source) + at org.mybatis.spring.SqlSessionTemplate.insert(SqlSessionTemplate.java:272) + at com.baomidou.mybatisplus.core.override.MybatisMapperMethod.execute(MybatisMapperMethod.java:59) + at com.baomidou.mybatisplus.core.override.MybatisMapperProxy$PlainMethodInvoker.invoke(MybatisMapperProxy.java:148) + at com.baomidou.mybatisplus.core.override.MybatisMapperProxy.invoke(MybatisMapperProxy.java:89) + at jdk.proxy3/jdk.proxy3.$Proxy144.insertMenu(Unknown Source) + at com.dc.system.service.SysMenuService.insertMenu(SysMenuService.java:264) + at com.dc.system.service.SysMenuService$$FastClassBySpringCGLIB$$448eabff.invoke(<generated>) + at org.springframework.cglib.proxy.MethodProxy.invoke(MethodProxy.java:218) + at org.springframework.aop.framework.CglibAopProxy.invokeMethod(CglibAopProxy.java:386) + at org.springframework.aop.framework.CglibAopProxy.access$000(CglibAopProxy.java:85) + at org.springframework.aop.framework.CglibAopProxy$DynamicAdvisedInterceptor.intercept(CglibAopProxy.java:704) + at com.dc.system.service.SysMenuService$$EnhancerBySpringCGLIB$$549f8809.insertMenu(<generated>) + at com.dc.web.controller.system.SysMenuController.add(SysMenuController.java:87) + at com.dc.web.controller.system.SysMenuController$$FastClassBySpringCGLIB$$d4a924ff.invoke(<generated>) + at org.springframework.cglib.proxy.MethodProxy.invoke(MethodProxy.java:218) + at org.springframework.aop.framework.CglibAopProxy$CglibMethodInvocation.invokeJoinpoint(CglibAopProxy.java:793) + at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:163) + at org.springframework.aop.framework.CglibAopProxy$CglibMethodInvocation.proceed(CglibAopProxy.java:763) + at org.springframework.aop.aspectj.AspectJAfterThrowingAdvice.invoke(AspectJAfterThrowingAdvice.java:64) + at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:175) + at org.springframework.aop.framework.CglibAopProxy$CglibMethodInvocation.proceed(CglibAopProxy.java:763) + at org.springframework.aop.framework.adapter.AfterReturningAdviceInterceptor.invoke(AfterReturningAdviceInterceptor.java:57) + at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:175) + at org.springframework.aop.framework.CglibAopProxy$CglibMethodInvocation.proceed(CglibAopProxy.java:763) + at org.springframework.aop.interceptor.ExposeInvocationInterceptor.invoke(ExposeInvocationInterceptor.java:97) + at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:186) + at org.springframework.aop.framework.CglibAopProxy$CglibMethodInvocation.proceed(CglibAopProxy.java:763) + at org.springframework.aop.framework.CglibAopProxy$DynamicAdvisedInterceptor.intercept(CglibAopProxy.java:708) + at com.dc.web.controller.system.SysMenuController$$EnhancerBySpringCGLIB$$e8f58fa.add(<generated>) + at java.base/jdk.internal.reflect.DirectMethodHandleAccessor.invoke(DirectMethodHandleAccessor.java:104) + at java.base/java.lang.reflect.Method.invoke(Method.java:578) + at org.springframework.web.method.support.InvocableHandlerMethod.doInvoke(InvocableHandlerMethod.java:205) + at org.springframework.web.method.support.InvocableHandlerMethod.invokeForRequest(InvocableHandlerMethod.java:150) + at org.springframework.web.servlet.mvc.method.annotation.ServletInvocableHandlerMethod.invokeAndHandle(ServletInvocableHandlerMethod.java:117) + at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.invokeHandlerMethod(RequestMappingHandlerAdapter.java:895) + at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.handleInternal(RequestMappingHandlerAdapter.java:808) + at org.springframework.web.servlet.mvc.method.AbstractHandlerMethodAdapter.handle(AbstractHandlerMethodAdapter.java:87) + at org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:1067) + at org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:963) + at org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:1006) + at org.springframework.web.servlet.FrameworkServlet.doPost(FrameworkServlet.java:909) + at javax.servlet.http.HttpServlet.service(HttpServlet.java:681) + at org.springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.java:883) + at javax.servlet.http.HttpServlet.service(HttpServlet.java:764) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:227) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:53) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:111) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:111) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at com.dc.common.filter.RepeatableFilter.doFilter(RepeatableFilter.java:39) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:327) + at org.springframework.security.web.access.intercept.FilterSecurityInterceptor.invoke(FilterSecurityInterceptor.java:115) + at org.springframework.security.web.access.intercept.FilterSecurityInterceptor.doFilter(FilterSecurityInterceptor.java:81) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.access.ExceptionTranslationFilter.doFilter(ExceptionTranslationFilter.java:121) + at org.springframework.security.web.access.ExceptionTranslationFilter.doFilter(ExceptionTranslationFilter.java:115) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.session.SessionManagementFilter.doFilter(SessionManagementFilter.java:126) + at org.springframework.security.web.session.SessionManagementFilter.doFilter(SessionManagementFilter.java:81) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.authentication.AnonymousAuthenticationFilter.doFilter(AnonymousAuthenticationFilter.java:105) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.servletapi.SecurityContextHolderAwareRequestFilter.doFilter(SecurityContextHolderAwareRequestFilter.java:149) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.savedrequest.RequestCacheAwareFilter.doFilter(RequestCacheAwareFilter.java:63) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at com.dc.framework.security.filter.JwtAuthenticationTokenFilter.doFilterInternal(JwtAuthenticationTokenFilter.java:43) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:111) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.authentication.logout.LogoutFilter.doFilter(LogoutFilter.java:103) + at org.springframework.security.web.authentication.logout.LogoutFilter.doFilter(LogoutFilter.java:89) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.web.filter.CorsFilter.doFilterInternal(CorsFilter.java:91) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.header.HeaderWriterFilter.doHeadersAfter(HeaderWriterFilter.java:90) + at org.springframework.security.web.header.HeaderWriterFilter.doFilterInternal(HeaderWriterFilter.java:75) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.context.SecurityContextPersistenceFilter.doFilter(SecurityContextPersistenceFilter.java:110) + at org.springframework.security.web.context.SecurityContextPersistenceFilter.doFilter(SecurityContextPersistenceFilter.java:80) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.context.request.async.WebAsyncManagerIntegrationFilter.doFilterInternal(WebAsyncManagerIntegrationFilter.java:55) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.FilterChainProxy.doFilterInternal(FilterChainProxy.java:211) + at org.springframework.security.web.FilterChainProxy.doFilter(FilterChainProxy.java:183) + at org.springframework.web.filter.DelegatingFilterProxy.invokeDelegate(DelegatingFilterProxy.java:354) + at org.springframework.web.filter.DelegatingFilterProxy.doFilter(DelegatingFilterProxy.java:267) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.RequestContextFilter.doFilterInternal(RequestContextFilter.java:100) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.FormContentFilter.doFilterInternal(FormContentFilter.java:93) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.CharacterEncodingFilter.doFilterInternal(CharacterEncodingFilter.java:201) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at com.dc.common.filter.XssFilter.doFilter(XssFilter.java:51) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:197) + at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:97) + at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:541) + at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:135) + at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:92) + at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:78) + at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:360) + at org.apache.coyote.http11.Http11Processor.service(Http11Processor.java:399) + at org.apache.coyote.AbstractProcessorLight.process(AbstractProcessorLight.java:65) + at org.apache.coyote.AbstractProtocol$ConnectionHandler.process(AbstractProtocol.java:890) + at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1743) + at org.apache.tomcat.util.net.SocketProcessorBase.run(SocketProcessorBase.java:49) + at org.apache.tomcat.util.threads.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1191) + at org.apache.tomcat.util.threads.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:659) + at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61) + at java.base/java.lang.Thread.run(Thread.java:1589) +Caused by: org.postgresql.util.PSQLException: ERROR: duplicate key value violates unique constraint "sys_menu_pkey" + 详细:Key (menu_id)=(2000) already exists. + at org.postgresql.core.v3.QueryExecutorImpl.receiveErrorResponse(QueryExecutorImpl.java:2565) + at org.postgresql.core.v3.QueryExecutorImpl.processResults(QueryExecutorImpl.java:2297) + at org.postgresql.core.v3.QueryExecutorImpl.execute(QueryExecutorImpl.java:322) + at org.postgresql.jdbc.PgStatement.executeInternal(PgStatement.java:481) + at org.postgresql.jdbc.PgStatement.execute(PgStatement.java:401) + at org.postgresql.jdbc.PgPreparedStatement.executeWithFlags(PgPreparedStatement.java:164) + at org.postgresql.jdbc.PgPreparedStatement.execute(PgPreparedStatement.java:153) + at com.alibaba.druid.filter.FilterChainImpl.preparedStatement_execute(FilterChainImpl.java:3446) + at com.alibaba.druid.filter.FilterEventAdapter.preparedStatement_execute(FilterEventAdapter.java:434) + at com.alibaba.druid.filter.FilterChainImpl.preparedStatement_execute(FilterChainImpl.java:3444) + at com.alibaba.druid.proxy.jdbc.PreparedStatementProxyImpl.execute(PreparedStatementProxyImpl.java:152) + at com.alibaba.druid.pool.DruidPooledPreparedStatement.execute(DruidPooledPreparedStatement.java:483) + at org.apache.ibatis.executor.statement.PreparedStatementHandler.update(PreparedStatementHandler.java:47) + at org.apache.ibatis.executor.statement.RoutingStatementHandler.update(RoutingStatementHandler.java:74) + at java.base/jdk.internal.reflect.DirectMethodHandleAccessor.invoke(DirectMethodHandleAccessor.java:104) + at java.base/java.lang.reflect.Method.invoke(Method.java:578) + at org.apache.ibatis.plugin.Plugin.invoke(Plugin.java:64) + at jdk.proxy2/jdk.proxy2.$Proxy119.update(Unknown Source) + at org.apache.ibatis.executor.SimpleExecutor.doUpdate(SimpleExecutor.java:50) + at org.apache.ibatis.executor.BaseExecutor.update(BaseExecutor.java:117) + at org.apache.ibatis.executor.CachingExecutor.update(CachingExecutor.java:76) + at java.base/jdk.internal.reflect.DirectMethodHandleAccessor.invoke(DirectMethodHandleAccessor.java:104) + at java.base/java.lang.reflect.Method.invoke(Method.java:578) + at org.apache.ibatis.plugin.Invocation.proceed(Invocation.java:49) + at com.baomidou.mybatisplus.extension.plugins.MybatisPlusInterceptor.intercept(MybatisPlusInterceptor.java:106) + at org.apache.ibatis.plugin.Plugin.invoke(Plugin.java:62) + at jdk.proxy2/jdk.proxy2.$Proxy118.update(Unknown Source) + at java.base/jdk.internal.reflect.DirectMethodHandleAccessor.invoke(DirectMethodHandleAccessor.java:104) + at java.base/java.lang.reflect.Method.invoke(Method.java:578) + at org.apache.ibatis.plugin.Plugin.invoke(Plugin.java:64) + at jdk.proxy2/jdk.proxy2.$Proxy118.update(Unknown Source) + at org.apache.ibatis.session.defaults.DefaultSqlSession.update(DefaultSqlSession.java:194) + at org.apache.ibatis.session.defaults.DefaultSqlSession.insert(DefaultSqlSession.java:181) + at java.base/jdk.internal.reflect.DirectMethodHandleAccessor.invoke(DirectMethodHandleAccessor.java:104) + at java.base/java.lang.reflect.Method.invoke(Method.java:578) + at org.mybatis.spring.SqlSessionTemplate$SqlSessionInterceptor.invoke(SqlSessionTemplate.java:427) + ... 133 common frames omitted +13:59:41.844 [http-nio-9000-exec-76] ERROR c.d.f.w.e.GlobalExceptionHandler - [handleRuntimeException,82] - 请求地址'/system/menu',发生未知异常. +org.springframework.dao.DuplicateKeyException: +### Error updating database. Cause: org.postgresql.util.PSQLException: ERROR: duplicate key value violates unique constraint "sys_menu_pkey" + 详细:Key (menu_id)=(2001) already exists. +### The error may exist in file [/Users/longlongxiaogege/work/mengyin/code/lianmei/myself/backup/dc-backend/data-center/dc-system/target/classes/mapper/system/SysMenuMapper.xml] +### The error may involve com.dc.system.mapper.SysMenuMapper.insertMenu-Inline +### The error occurred while setting parameters +### SQL: insert into sys_menu( parent_id, menu_name, order_num, path, component, is_frame, is_cache, menu_type, visible, status, icon, create_by, create_time )values( ?, ?, ?, ?, ?, ?::integer, ?::integer, ?, ?, ?::integer, ?, ?, current_timestamp ) +### Cause: org.postgresql.util.PSQLException: ERROR: duplicate key value violates unique constraint "sys_menu_pkey" + 详细:Key (menu_id)=(2001) already exists. +; ERROR: duplicate key value violates unique constraint "sys_menu_pkey" + 详细:Key (menu_id)=(2001) already exists.; nested exception is org.postgresql.util.PSQLException: ERROR: duplicate key value violates unique constraint "sys_menu_pkey" + 详细:Key (menu_id)=(2001) already exists. + at org.springframework.jdbc.support.SQLErrorCodeSQLExceptionTranslator.doTranslate(SQLErrorCodeSQLExceptionTranslator.java:247) + at org.springframework.jdbc.support.AbstractFallbackSQLExceptionTranslator.translate(AbstractFallbackSQLExceptionTranslator.java:70) + at org.mybatis.spring.MyBatisExceptionTranslator.translateExceptionIfPossible(MyBatisExceptionTranslator.java:91) + at org.mybatis.spring.SqlSessionTemplate$SqlSessionInterceptor.invoke(SqlSessionTemplate.java:441) + at jdk.proxy2/jdk.proxy2.$Proxy113.insert(Unknown Source) + at org.mybatis.spring.SqlSessionTemplate.insert(SqlSessionTemplate.java:272) + at com.baomidou.mybatisplus.core.override.MybatisMapperMethod.execute(MybatisMapperMethod.java:59) + at com.baomidou.mybatisplus.core.override.MybatisMapperProxy$PlainMethodInvoker.invoke(MybatisMapperProxy.java:148) + at com.baomidou.mybatisplus.core.override.MybatisMapperProxy.invoke(MybatisMapperProxy.java:89) + at jdk.proxy3/jdk.proxy3.$Proxy144.insertMenu(Unknown Source) + at com.dc.system.service.SysMenuService.insertMenu(SysMenuService.java:264) + at com.dc.system.service.SysMenuService$$FastClassBySpringCGLIB$$448eabff.invoke(<generated>) + at org.springframework.cglib.proxy.MethodProxy.invoke(MethodProxy.java:218) + at org.springframework.aop.framework.CglibAopProxy.invokeMethod(CglibAopProxy.java:386) + at org.springframework.aop.framework.CglibAopProxy.access$000(CglibAopProxy.java:85) + at org.springframework.aop.framework.CglibAopProxy$DynamicAdvisedInterceptor.intercept(CglibAopProxy.java:704) + at com.dc.system.service.SysMenuService$$EnhancerBySpringCGLIB$$549f8809.insertMenu(<generated>) + at com.dc.web.controller.system.SysMenuController.add(SysMenuController.java:87) + at com.dc.web.controller.system.SysMenuController$$FastClassBySpringCGLIB$$d4a924ff.invoke(<generated>) + at org.springframework.cglib.proxy.MethodProxy.invoke(MethodProxy.java:218) + at org.springframework.aop.framework.CglibAopProxy$CglibMethodInvocation.invokeJoinpoint(CglibAopProxy.java:793) + at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:163) + at org.springframework.aop.framework.CglibAopProxy$CglibMethodInvocation.proceed(CglibAopProxy.java:763) + at org.springframework.aop.aspectj.AspectJAfterThrowingAdvice.invoke(AspectJAfterThrowingAdvice.java:64) + at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:175) + at org.springframework.aop.framework.CglibAopProxy$CglibMethodInvocation.proceed(CglibAopProxy.java:763) + at org.springframework.aop.framework.adapter.AfterReturningAdviceInterceptor.invoke(AfterReturningAdviceInterceptor.java:57) + at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:175) + at org.springframework.aop.framework.CglibAopProxy$CglibMethodInvocation.proceed(CglibAopProxy.java:763) + at org.springframework.aop.interceptor.ExposeInvocationInterceptor.invoke(ExposeInvocationInterceptor.java:97) + at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:186) + at org.springframework.aop.framework.CglibAopProxy$CglibMethodInvocation.proceed(CglibAopProxy.java:763) + at org.springframework.aop.framework.CglibAopProxy$DynamicAdvisedInterceptor.intercept(CglibAopProxy.java:708) + at com.dc.web.controller.system.SysMenuController$$EnhancerBySpringCGLIB$$e8f58fa.add(<generated>) + at java.base/jdk.internal.reflect.DirectMethodHandleAccessor.invoke(DirectMethodHandleAccessor.java:104) + at java.base/java.lang.reflect.Method.invoke(Method.java:578) + at org.springframework.web.method.support.InvocableHandlerMethod.doInvoke(InvocableHandlerMethod.java:205) + at org.springframework.web.method.support.InvocableHandlerMethod.invokeForRequest(InvocableHandlerMethod.java:150) + at org.springframework.web.servlet.mvc.method.annotation.ServletInvocableHandlerMethod.invokeAndHandle(ServletInvocableHandlerMethod.java:117) + at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.invokeHandlerMethod(RequestMappingHandlerAdapter.java:895) + at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.handleInternal(RequestMappingHandlerAdapter.java:808) + at org.springframework.web.servlet.mvc.method.AbstractHandlerMethodAdapter.handle(AbstractHandlerMethodAdapter.java:87) + at org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:1067) + at org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:963) + at org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:1006) + at org.springframework.web.servlet.FrameworkServlet.doPost(FrameworkServlet.java:909) + at javax.servlet.http.HttpServlet.service(HttpServlet.java:681) + at org.springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.java:883) + at javax.servlet.http.HttpServlet.service(HttpServlet.java:764) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:227) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:53) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:111) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:111) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at com.dc.common.filter.RepeatableFilter.doFilter(RepeatableFilter.java:39) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:327) + at org.springframework.security.web.access.intercept.FilterSecurityInterceptor.invoke(FilterSecurityInterceptor.java:115) + at org.springframework.security.web.access.intercept.FilterSecurityInterceptor.doFilter(FilterSecurityInterceptor.java:81) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.access.ExceptionTranslationFilter.doFilter(ExceptionTranslationFilter.java:121) + at org.springframework.security.web.access.ExceptionTranslationFilter.doFilter(ExceptionTranslationFilter.java:115) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.session.SessionManagementFilter.doFilter(SessionManagementFilter.java:126) + at org.springframework.security.web.session.SessionManagementFilter.doFilter(SessionManagementFilter.java:81) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.authentication.AnonymousAuthenticationFilter.doFilter(AnonymousAuthenticationFilter.java:105) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.servletapi.SecurityContextHolderAwareRequestFilter.doFilter(SecurityContextHolderAwareRequestFilter.java:149) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.savedrequest.RequestCacheAwareFilter.doFilter(RequestCacheAwareFilter.java:63) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at com.dc.framework.security.filter.JwtAuthenticationTokenFilter.doFilterInternal(JwtAuthenticationTokenFilter.java:43) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:111) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.authentication.logout.LogoutFilter.doFilter(LogoutFilter.java:103) + at org.springframework.security.web.authentication.logout.LogoutFilter.doFilter(LogoutFilter.java:89) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.web.filter.CorsFilter.doFilterInternal(CorsFilter.java:91) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.header.HeaderWriterFilter.doHeadersAfter(HeaderWriterFilter.java:90) + at org.springframework.security.web.header.HeaderWriterFilter.doFilterInternal(HeaderWriterFilter.java:75) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.context.SecurityContextPersistenceFilter.doFilter(SecurityContextPersistenceFilter.java:110) + at org.springframework.security.web.context.SecurityContextPersistenceFilter.doFilter(SecurityContextPersistenceFilter.java:80) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.context.request.async.WebAsyncManagerIntegrationFilter.doFilterInternal(WebAsyncManagerIntegrationFilter.java:55) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.FilterChainProxy.doFilterInternal(FilterChainProxy.java:211) + at org.springframework.security.web.FilterChainProxy.doFilter(FilterChainProxy.java:183) + at org.springframework.web.filter.DelegatingFilterProxy.invokeDelegate(DelegatingFilterProxy.java:354) + at org.springframework.web.filter.DelegatingFilterProxy.doFilter(DelegatingFilterProxy.java:267) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.RequestContextFilter.doFilterInternal(RequestContextFilter.java:100) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.FormContentFilter.doFilterInternal(FormContentFilter.java:93) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.CharacterEncodingFilter.doFilterInternal(CharacterEncodingFilter.java:201) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at com.dc.common.filter.XssFilter.doFilter(XssFilter.java:51) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:197) + at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:97) + at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:541) + at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:135) + at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:92) + at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:78) + at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:360) + at org.apache.coyote.http11.Http11Processor.service(Http11Processor.java:399) + at org.apache.coyote.AbstractProcessorLight.process(AbstractProcessorLight.java:65) + at org.apache.coyote.AbstractProtocol$ConnectionHandler.process(AbstractProtocol.java:890) + at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1743) + at org.apache.tomcat.util.net.SocketProcessorBase.run(SocketProcessorBase.java:49) + at org.apache.tomcat.util.threads.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1191) + at org.apache.tomcat.util.threads.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:659) + at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61) + at java.base/java.lang.Thread.run(Thread.java:1589) +Caused by: org.postgresql.util.PSQLException: ERROR: duplicate key value violates unique constraint "sys_menu_pkey" + 详细:Key (menu_id)=(2001) already exists. + at org.postgresql.core.v3.QueryExecutorImpl.receiveErrorResponse(QueryExecutorImpl.java:2565) + at org.postgresql.core.v3.QueryExecutorImpl.processResults(QueryExecutorImpl.java:2297) + at org.postgresql.core.v3.QueryExecutorImpl.execute(QueryExecutorImpl.java:322) + at org.postgresql.jdbc.PgStatement.executeInternal(PgStatement.java:481) + at org.postgresql.jdbc.PgStatement.execute(PgStatement.java:401) + at org.postgresql.jdbc.PgPreparedStatement.executeWithFlags(PgPreparedStatement.java:164) + at org.postgresql.jdbc.PgPreparedStatement.execute(PgPreparedStatement.java:153) + at com.alibaba.druid.filter.FilterChainImpl.preparedStatement_execute(FilterChainImpl.java:3446) + at com.alibaba.druid.filter.FilterEventAdapter.preparedStatement_execute(FilterEventAdapter.java:434) + at com.alibaba.druid.filter.FilterChainImpl.preparedStatement_execute(FilterChainImpl.java:3444) + at com.alibaba.druid.proxy.jdbc.PreparedStatementProxyImpl.execute(PreparedStatementProxyImpl.java:152) + at com.alibaba.druid.pool.DruidPooledPreparedStatement.execute(DruidPooledPreparedStatement.java:483) + at org.apache.ibatis.executor.statement.PreparedStatementHandler.update(PreparedStatementHandler.java:47) + at org.apache.ibatis.executor.statement.RoutingStatementHandler.update(RoutingStatementHandler.java:74) + at java.base/jdk.internal.reflect.DirectMethodHandleAccessor.invoke(DirectMethodHandleAccessor.java:104) + at java.base/java.lang.reflect.Method.invoke(Method.java:578) + at org.apache.ibatis.plugin.Plugin.invoke(Plugin.java:64) + at jdk.proxy2/jdk.proxy2.$Proxy119.update(Unknown Source) + at org.apache.ibatis.executor.SimpleExecutor.doUpdate(SimpleExecutor.java:50) + at org.apache.ibatis.executor.BaseExecutor.update(BaseExecutor.java:117) + at org.apache.ibatis.executor.CachingExecutor.update(CachingExecutor.java:76) + at java.base/jdk.internal.reflect.DirectMethodHandleAccessor.invoke(DirectMethodHandleAccessor.java:104) + at java.base/java.lang.reflect.Method.invoke(Method.java:578) + at org.apache.ibatis.plugin.Invocation.proceed(Invocation.java:49) + at com.baomidou.mybatisplus.extension.plugins.MybatisPlusInterceptor.intercept(MybatisPlusInterceptor.java:106) + at org.apache.ibatis.plugin.Plugin.invoke(Plugin.java:62) + at jdk.proxy2/jdk.proxy2.$Proxy118.update(Unknown Source) + at java.base/jdk.internal.reflect.DirectMethodHandleAccessor.invoke(DirectMethodHandleAccessor.java:104) + at java.base/java.lang.reflect.Method.invoke(Method.java:578) + at org.apache.ibatis.plugin.Plugin.invoke(Plugin.java:64) + at jdk.proxy2/jdk.proxy2.$Proxy118.update(Unknown Source) + at org.apache.ibatis.session.defaults.DefaultSqlSession.update(DefaultSqlSession.java:194) + at org.apache.ibatis.session.defaults.DefaultSqlSession.insert(DefaultSqlSession.java:181) + at java.base/jdk.internal.reflect.DirectMethodHandleAccessor.invoke(DirectMethodHandleAccessor.java:104) + at java.base/java.lang.reflect.Method.invoke(Method.java:578) + at org.mybatis.spring.SqlSessionTemplate$SqlSessionInterceptor.invoke(SqlSessionTemplate.java:427) + ... 133 common frames omitted +14:14:15.356 [http-nio-9000-exec-11] ERROR c.d.f.w.e.GlobalExceptionHandler - [handleRuntimeException,82] - 请求地址'/base/dcCodeRuleTest/list',发生未知异常. +org.springframework.jdbc.BadSqlGrammarException: +### Error querying database. Cause: org.postgresql.util.PSQLException: ERROR: syntax error at or near "," + 位置:130 +### The error may exist in com/dc/system/mapper/DcCodeRuleTestMapper.java (best guess) +### The error may involve defaultParameterMap +### The error occurred while setting parameters +### SQL: SELECT id,code,name,current_number,format_json,sort_code,description,tentant_id,revision,deptid,userid,dept_id,user_id,`version`,create_by,create_time,updated_by,updated_time,delete_by,delete_time FROM dc_code_rule_test WHERE (delete_time IS NULL) +### Cause: org.postgresql.util.PSQLException: ERROR: syntax error at or near "," + 位置:130 +; bad SQL grammar []; nested exception is org.postgresql.util.PSQLException: ERROR: syntax error at or near "," + 位置:130 + at org.springframework.jdbc.support.SQLErrorCodeSQLExceptionTranslator.doTranslate(SQLErrorCodeSQLExceptionTranslator.java:239) + at org.springframework.jdbc.support.AbstractFallbackSQLExceptionTranslator.translate(AbstractFallbackSQLExceptionTranslator.java:70) + at org.mybatis.spring.MyBatisExceptionTranslator.translateExceptionIfPossible(MyBatisExceptionTranslator.java:91) + at org.mybatis.spring.SqlSessionTemplate$SqlSessionInterceptor.invoke(SqlSessionTemplate.java:441) + at jdk.proxy2/jdk.proxy2.$Proxy113.selectList(Unknown Source) + at org.mybatis.spring.SqlSessionTemplate.selectList(SqlSessionTemplate.java:224) + at com.baomidou.mybatisplus.core.override.MybatisMapperMethod.executeForMany(MybatisMapperMethod.java:166) + at com.baomidou.mybatisplus.core.override.MybatisMapperMethod.execute(MybatisMapperMethod.java:77) + at com.baomidou.mybatisplus.core.override.MybatisMapperProxy$PlainMethodInvoker.invoke(MybatisMapperProxy.java:148) + at com.baomidou.mybatisplus.core.override.MybatisMapperProxy.invoke(MybatisMapperProxy.java:89) + at jdk.proxy3/jdk.proxy3.$Proxy115.selectList(Unknown Source) + at com.baomidou.mybatisplus.extension.service.IService.list(IService.java:370) + at com.baomidou.mybatisplus.extension.service.IService$$FastClassBySpringCGLIB$$f8525d18.invoke(<generated>) + at org.springframework.cglib.proxy.MethodProxy.invoke(MethodProxy.java:218) + at org.springframework.aop.framework.CglibAopProxy.invokeMethod(CglibAopProxy.java:386) + at org.springframework.aop.framework.CglibAopProxy.access$000(CglibAopProxy.java:85) + at org.springframework.aop.framework.CglibAopProxy$DynamicAdvisedInterceptor.intercept(CglibAopProxy.java:704) + at com.dc.system.service.DcCodeRuleTestService$$EnhancerBySpringCGLIB$$3def60f5.list(<generated>) + at com.dc.web.controller.system.DcCodeRuleTestController.export(DcCodeRuleTestController.java:106) + at com.dc.web.controller.system.DcCodeRuleTestController$$FastClassBySpringCGLIB$$e8ff59bf.invoke(<generated>) + at org.springframework.cglib.proxy.MethodProxy.invoke(MethodProxy.java:218) + at org.springframework.aop.framework.CglibAopProxy$CglibMethodInvocation.invokeJoinpoint(CglibAopProxy.java:793) + at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:163) + at org.springframework.aop.framework.CglibAopProxy$CglibMethodInvocation.proceed(CglibAopProxy.java:763) + at org.springframework.aop.interceptor.ExposeInvocationInterceptor.invoke(ExposeInvocationInterceptor.java:97) + at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:186) + at org.springframework.aop.framework.CglibAopProxy$CglibMethodInvocation.proceed(CglibAopProxy.java:763) + at org.springframework.aop.framework.CglibAopProxy$DynamicAdvisedInterceptor.intercept(CglibAopProxy.java:708) + at com.dc.web.controller.system.DcCodeRuleTestController$$EnhancerBySpringCGLIB$$9fbb007c.export(<generated>) + at java.base/jdk.internal.reflect.DirectMethodHandleAccessor.invoke(DirectMethodHandleAccessor.java:104) + at java.base/java.lang.reflect.Method.invoke(Method.java:578) + at org.springframework.web.method.support.InvocableHandlerMethod.doInvoke(InvocableHandlerMethod.java:205) + at org.springframework.web.method.support.InvocableHandlerMethod.invokeForRequest(InvocableHandlerMethod.java:150) + at org.springframework.web.servlet.mvc.method.annotation.ServletInvocableHandlerMethod.invokeAndHandle(ServletInvocableHandlerMethod.java:117) + at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.invokeHandlerMethod(RequestMappingHandlerAdapter.java:895) + at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.handleInternal(RequestMappingHandlerAdapter.java:808) + at org.springframework.web.servlet.mvc.method.AbstractHandlerMethodAdapter.handle(AbstractHandlerMethodAdapter.java:87) + at org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:1067) + at org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:963) + at org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:1006) + at org.springframework.web.servlet.FrameworkServlet.doGet(FrameworkServlet.java:898) + at javax.servlet.http.HttpServlet.service(HttpServlet.java:655) + at org.springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.java:883) + at javax.servlet.http.HttpServlet.service(HttpServlet.java:764) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:227) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:53) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:111) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:111) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at com.dc.common.filter.RepeatableFilter.doFilter(RepeatableFilter.java:35) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:327) + at org.springframework.security.web.access.intercept.FilterSecurityInterceptor.invoke(FilterSecurityInterceptor.java:115) + at org.springframework.security.web.access.intercept.FilterSecurityInterceptor.doFilter(FilterSecurityInterceptor.java:81) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.access.ExceptionTranslationFilter.doFilter(ExceptionTranslationFilter.java:121) + at org.springframework.security.web.access.ExceptionTranslationFilter.doFilter(ExceptionTranslationFilter.java:115) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.session.SessionManagementFilter.doFilter(SessionManagementFilter.java:126) + at org.springframework.security.web.session.SessionManagementFilter.doFilter(SessionManagementFilter.java:81) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.authentication.AnonymousAuthenticationFilter.doFilter(AnonymousAuthenticationFilter.java:105) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.servletapi.SecurityContextHolderAwareRequestFilter.doFilter(SecurityContextHolderAwareRequestFilter.java:149) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.savedrequest.RequestCacheAwareFilter.doFilter(RequestCacheAwareFilter.java:63) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at com.dc.framework.security.filter.JwtAuthenticationTokenFilter.doFilterInternal(JwtAuthenticationTokenFilter.java:43) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:111) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.authentication.logout.LogoutFilter.doFilter(LogoutFilter.java:103) + at org.springframework.security.web.authentication.logout.LogoutFilter.doFilter(LogoutFilter.java:89) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.web.filter.CorsFilter.doFilterInternal(CorsFilter.java:91) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.header.HeaderWriterFilter.doHeadersAfter(HeaderWriterFilter.java:90) + at org.springframework.security.web.header.HeaderWriterFilter.doFilterInternal(HeaderWriterFilter.java:75) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.context.SecurityContextPersistenceFilter.doFilter(SecurityContextPersistenceFilter.java:110) + at org.springframework.security.web.context.SecurityContextPersistenceFilter.doFilter(SecurityContextPersistenceFilter.java:80) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.context.request.async.WebAsyncManagerIntegrationFilter.doFilterInternal(WebAsyncManagerIntegrationFilter.java:55) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.FilterChainProxy.doFilterInternal(FilterChainProxy.java:211) + at org.springframework.security.web.FilterChainProxy.doFilter(FilterChainProxy.java:183) + at org.springframework.web.filter.DelegatingFilterProxy.invokeDelegate(DelegatingFilterProxy.java:354) + at org.springframework.web.filter.DelegatingFilterProxy.doFilter(DelegatingFilterProxy.java:267) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.RequestContextFilter.doFilterInternal(RequestContextFilter.java:100) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.FormContentFilter.doFilterInternal(FormContentFilter.java:93) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.CharacterEncodingFilter.doFilterInternal(CharacterEncodingFilter.java:201) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:197) + at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:97) + at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:541) + at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:135) + at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:92) + at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:78) + at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:360) + at org.apache.coyote.http11.Http11Processor.service(Http11Processor.java:399) + at org.apache.coyote.AbstractProcessorLight.process(AbstractProcessorLight.java:65) + at org.apache.coyote.AbstractProtocol$ConnectionHandler.process(AbstractProtocol.java:890) + at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1743) + at org.apache.tomcat.util.net.SocketProcessorBase.run(SocketProcessorBase.java:49) + at org.apache.tomcat.util.threads.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1191) + at org.apache.tomcat.util.threads.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:659) + at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61) + at java.base/java.lang.Thread.run(Thread.java:1589) +Caused by: org.postgresql.util.PSQLException: ERROR: syntax error at or near "," + 位置:130 + at org.postgresql.core.v3.QueryExecutorImpl.receiveErrorResponse(QueryExecutorImpl.java:2565) + at org.postgresql.core.v3.QueryExecutorImpl.processResults(QueryExecutorImpl.java:2297) + at org.postgresql.core.v3.QueryExecutorImpl.execute(QueryExecutorImpl.java:322) + at org.postgresql.jdbc.PgStatement.executeInternal(PgStatement.java:481) + at org.postgresql.jdbc.PgStatement.execute(PgStatement.java:401) + at org.postgresql.jdbc.PgPreparedStatement.executeWithFlags(PgPreparedStatement.java:164) + at org.postgresql.jdbc.PgPreparedStatement.execute(PgPreparedStatement.java:153) + at com.alibaba.druid.filter.FilterChainImpl.preparedStatement_execute(FilterChainImpl.java:3446) + at com.alibaba.druid.filter.FilterEventAdapter.preparedStatement_execute(FilterEventAdapter.java:434) + at com.alibaba.druid.filter.FilterChainImpl.preparedStatement_execute(FilterChainImpl.java:3444) + at com.alibaba.druid.proxy.jdbc.PreparedStatementProxyImpl.execute(PreparedStatementProxyImpl.java:152) + at com.alibaba.druid.pool.DruidPooledPreparedStatement.execute(DruidPooledPreparedStatement.java:483) + at org.apache.ibatis.executor.statement.PreparedStatementHandler.query(PreparedStatementHandler.java:64) + at org.apache.ibatis.executor.statement.RoutingStatementHandler.query(RoutingStatementHandler.java:79) + at java.base/jdk.internal.reflect.DirectMethodHandleAccessor.invoke(DirectMethodHandleAccessor.java:104) + at java.base/java.lang.reflect.Method.invoke(Method.java:578) + at org.apache.ibatis.plugin.Plugin.invoke(Plugin.java:64) + at jdk.proxy2/jdk.proxy2.$Proxy119.query(Unknown Source) + at org.apache.ibatis.executor.SimpleExecutor.doQuery(SimpleExecutor.java:63) + at org.apache.ibatis.executor.BaseExecutor.queryFromDatabase(BaseExecutor.java:325) + at org.apache.ibatis.executor.BaseExecutor.query(BaseExecutor.java:156) + at org.apache.ibatis.executor.CachingExecutor.query(CachingExecutor.java:109) + at com.baomidou.mybatisplus.extension.plugins.MybatisPlusInterceptor.intercept(MybatisPlusInterceptor.java:81) + at org.apache.ibatis.plugin.Plugin.invoke(Plugin.java:62) + at jdk.proxy2/jdk.proxy2.$Proxy118.query(Unknown Source) + at com.github.pagehelper.PageInterceptor.intercept(PageInterceptor.java:151) + at org.apache.ibatis.plugin.Plugin.invoke(Plugin.java:62) + at jdk.proxy2/jdk.proxy2.$Proxy118.query(Unknown Source) + at org.apache.ibatis.session.defaults.DefaultSqlSession.selectList(DefaultSqlSession.java:151) + at org.apache.ibatis.session.defaults.DefaultSqlSession.selectList(DefaultSqlSession.java:145) + at org.apache.ibatis.session.defaults.DefaultSqlSession.selectList(DefaultSqlSession.java:140) + at java.base/jdk.internal.reflect.DirectMethodHandleAccessor.invoke(DirectMethodHandleAccessor.java:104) + at java.base/java.lang.reflect.Method.invoke(Method.java:578) + at org.mybatis.spring.SqlSessionTemplate$SqlSessionInterceptor.invoke(SqlSessionTemplate.java:427) + ... 125 common frames omitted +14:15:04.163 [http-nio-9000-exec-12] ERROR c.d.f.w.e.GlobalExceptionHandler - [handleRuntimeException,82] - 请求地址'/base/dcCodeRuleTest/list',发生未知异常. +org.springframework.jdbc.BadSqlGrammarException: +### Error querying database. Cause: org.postgresql.util.PSQLException: ERROR: syntax error at or near "," + 位置:130 +### The error may exist in com/dc/system/mapper/DcCodeRuleTestMapper.java (best guess) +### The error may involve defaultParameterMap +### The error occurred while setting parameters +### SQL: SELECT id,code,name,current_number,format_json,sort_code,description,tentant_id,revision,deptid,userid,dept_id,user_id,`version`,create_by,create_time,updated_by,updated_time,delete_by,delete_time FROM dc_code_rule_test WHERE (delete_time IS NULL) +### Cause: org.postgresql.util.PSQLException: ERROR: syntax error at or near "," + 位置:130 +; bad SQL grammar []; nested exception is org.postgresql.util.PSQLException: ERROR: syntax error at or near "," + 位置:130 + at org.springframework.jdbc.support.SQLErrorCodeSQLExceptionTranslator.doTranslate(SQLErrorCodeSQLExceptionTranslator.java:239) + at org.springframework.jdbc.support.AbstractFallbackSQLExceptionTranslator.translate(AbstractFallbackSQLExceptionTranslator.java:70) + at org.mybatis.spring.MyBatisExceptionTranslator.translateExceptionIfPossible(MyBatisExceptionTranslator.java:91) + at org.mybatis.spring.SqlSessionTemplate$SqlSessionInterceptor.invoke(SqlSessionTemplate.java:441) + at jdk.proxy2/jdk.proxy2.$Proxy113.selectList(Unknown Source) + at org.mybatis.spring.SqlSessionTemplate.selectList(SqlSessionTemplate.java:224) + at com.baomidou.mybatisplus.core.override.MybatisMapperMethod.executeForMany(MybatisMapperMethod.java:166) + at com.baomidou.mybatisplus.core.override.MybatisMapperMethod.execute(MybatisMapperMethod.java:77) + at com.baomidou.mybatisplus.core.override.MybatisMapperProxy$PlainMethodInvoker.invoke(MybatisMapperProxy.java:148) + at com.baomidou.mybatisplus.core.override.MybatisMapperProxy.invoke(MybatisMapperProxy.java:89) + at jdk.proxy3/jdk.proxy3.$Proxy115.selectList(Unknown Source) + at com.baomidou.mybatisplus.extension.service.IService.list(IService.java:370) + at com.baomidou.mybatisplus.extension.service.IService$$FastClassBySpringCGLIB$$f8525d18.invoke(<generated>) + at org.springframework.cglib.proxy.MethodProxy.invoke(MethodProxy.java:218) + at org.springframework.aop.framework.CglibAopProxy.invokeMethod(CglibAopProxy.java:386) + at org.springframework.aop.framework.CglibAopProxy.access$000(CglibAopProxy.java:85) + at org.springframework.aop.framework.CglibAopProxy$DynamicAdvisedInterceptor.intercept(CglibAopProxy.java:704) + at com.dc.system.service.DcCodeRuleTestService$$EnhancerBySpringCGLIB$$3def60f5.list(<generated>) + at com.dc.web.controller.system.DcCodeRuleTestController.export(DcCodeRuleTestController.java:106) + at com.dc.web.controller.system.DcCodeRuleTestController$$FastClassBySpringCGLIB$$e8ff59bf.invoke(<generated>) + at org.springframework.cglib.proxy.MethodProxy.invoke(MethodProxy.java:218) + at org.springframework.aop.framework.CglibAopProxy$CglibMethodInvocation.invokeJoinpoint(CglibAopProxy.java:793) + at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:163) + at org.springframework.aop.framework.CglibAopProxy$CglibMethodInvocation.proceed(CglibAopProxy.java:763) + at org.springframework.aop.interceptor.ExposeInvocationInterceptor.invoke(ExposeInvocationInterceptor.java:97) + at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:186) + at org.springframework.aop.framework.CglibAopProxy$CglibMethodInvocation.proceed(CglibAopProxy.java:763) + at org.springframework.aop.framework.CglibAopProxy$DynamicAdvisedInterceptor.intercept(CglibAopProxy.java:708) + at com.dc.web.controller.system.DcCodeRuleTestController$$EnhancerBySpringCGLIB$$9fbb007c.export(<generated>) + at java.base/jdk.internal.reflect.DirectMethodHandleAccessor.invoke(DirectMethodHandleAccessor.java:104) + at java.base/java.lang.reflect.Method.invoke(Method.java:578) + at org.springframework.web.method.support.InvocableHandlerMethod.doInvoke(InvocableHandlerMethod.java:205) + at org.springframework.web.method.support.InvocableHandlerMethod.invokeForRequest(InvocableHandlerMethod.java:150) + at org.springframework.web.servlet.mvc.method.annotation.ServletInvocableHandlerMethod.invokeAndHandle(ServletInvocableHandlerMethod.java:117) + at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.invokeHandlerMethod(RequestMappingHandlerAdapter.java:895) + at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.handleInternal(RequestMappingHandlerAdapter.java:808) + at org.springframework.web.servlet.mvc.method.AbstractHandlerMethodAdapter.handle(AbstractHandlerMethodAdapter.java:87) + at org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:1067) + at org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:963) + at org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:1006) + at org.springframework.web.servlet.FrameworkServlet.doGet(FrameworkServlet.java:898) + at javax.servlet.http.HttpServlet.service(HttpServlet.java:655) + at org.springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.java:883) + at javax.servlet.http.HttpServlet.service(HttpServlet.java:764) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:227) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:53) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:111) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:111) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at com.dc.common.filter.RepeatableFilter.doFilter(RepeatableFilter.java:35) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:327) + at org.springframework.security.web.access.intercept.FilterSecurityInterceptor.invoke(FilterSecurityInterceptor.java:115) + at org.springframework.security.web.access.intercept.FilterSecurityInterceptor.doFilter(FilterSecurityInterceptor.java:81) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.access.ExceptionTranslationFilter.doFilter(ExceptionTranslationFilter.java:121) + at org.springframework.security.web.access.ExceptionTranslationFilter.doFilter(ExceptionTranslationFilter.java:115) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.session.SessionManagementFilter.doFilter(SessionManagementFilter.java:126) + at org.springframework.security.web.session.SessionManagementFilter.doFilter(SessionManagementFilter.java:81) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.authentication.AnonymousAuthenticationFilter.doFilter(AnonymousAuthenticationFilter.java:105) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.servletapi.SecurityContextHolderAwareRequestFilter.doFilter(SecurityContextHolderAwareRequestFilter.java:149) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.savedrequest.RequestCacheAwareFilter.doFilter(RequestCacheAwareFilter.java:63) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at com.dc.framework.security.filter.JwtAuthenticationTokenFilter.doFilterInternal(JwtAuthenticationTokenFilter.java:43) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:111) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.authentication.logout.LogoutFilter.doFilter(LogoutFilter.java:103) + at org.springframework.security.web.authentication.logout.LogoutFilter.doFilter(LogoutFilter.java:89) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.web.filter.CorsFilter.doFilterInternal(CorsFilter.java:91) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.header.HeaderWriterFilter.doHeadersAfter(HeaderWriterFilter.java:90) + at org.springframework.security.web.header.HeaderWriterFilter.doFilterInternal(HeaderWriterFilter.java:75) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.context.SecurityContextPersistenceFilter.doFilter(SecurityContextPersistenceFilter.java:110) + at org.springframework.security.web.context.SecurityContextPersistenceFilter.doFilter(SecurityContextPersistenceFilter.java:80) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.context.request.async.WebAsyncManagerIntegrationFilter.doFilterInternal(WebAsyncManagerIntegrationFilter.java:55) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:336) + at org.springframework.security.web.FilterChainProxy.doFilterInternal(FilterChainProxy.java:211) + at org.springframework.security.web.FilterChainProxy.doFilter(FilterChainProxy.java:183) + at org.springframework.web.filter.DelegatingFilterProxy.invokeDelegate(DelegatingFilterProxy.java:354) + at org.springframework.web.filter.DelegatingFilterProxy.doFilter(DelegatingFilterProxy.java:267) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.RequestContextFilter.doFilterInternal(RequestContextFilter.java:100) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.FormContentFilter.doFilterInternal(FormContentFilter.java:93) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.springframework.web.filter.CharacterEncodingFilter.doFilterInternal(CharacterEncodingFilter.java:201) + at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) + at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189) + at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162) + at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:197) + at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:97) + at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:541) + at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:135) + at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:92) + at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:78) + at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:360) + at org.apache.coyote.http11.Http11Processor.service(Http11Processor.java:399) + at org.apache.coyote.AbstractProcessorLight.process(AbstractProcessorLight.java:65) + at org.apache.coyote.AbstractProtocol$ConnectionHandler.process(AbstractProtocol.java:890) + at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1743) + at org.apache.tomcat.util.net.SocketProcessorBase.run(SocketProcessorBase.java:49) + at org.apache.tomcat.util.threads.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1191) + at org.apache.tomcat.util.threads.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:659) + at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61) + at java.base/java.lang.Thread.run(Thread.java:1589) +Caused by: org.postgresql.util.PSQLException: ERROR: syntax error at or near "," + 位置:130 + at org.postgresql.core.v3.QueryExecutorImpl.receiveErrorResponse(QueryExecutorImpl.java:2565) + at org.postgresql.core.v3.QueryExecutorImpl.processResults(QueryExecutorImpl.java:2297) + at org.postgresql.core.v3.QueryExecutorImpl.execute(QueryExecutorImpl.java:322) + at org.postgresql.jdbc.PgStatement.executeInternal(PgStatement.java:481) + at org.postgresql.jdbc.PgStatement.execute(PgStatement.java:401) + at org.postgresql.jdbc.PgPreparedStatement.executeWithFlags(PgPreparedStatement.java:164) + at org.postgresql.jdbc.PgPreparedStatement.execute(PgPreparedStatement.java:153) + at com.alibaba.druid.filter.FilterChainImpl.preparedStatement_execute(FilterChainImpl.java:3446) + at com.alibaba.druid.filter.FilterEventAdapter.preparedStatement_execute(FilterEventAdapter.java:434) + at com.alibaba.druid.filter.FilterChainImpl.preparedStatement_execute(FilterChainImpl.java:3444) + at com.alibaba.druid.proxy.jdbc.PreparedStatementProxyImpl.execute(PreparedStatementProxyImpl.java:152) + at com.alibaba.druid.pool.DruidPooledPreparedStatement.execute(DruidPooledPreparedStatement.java:483) + at org.apache.ibatis.executor.statement.PreparedStatementHandler.query(PreparedStatementHandler.java:64) + at org.apache.ibatis.executor.statement.RoutingStatementHandler.query(RoutingStatementHandler.java:79) + at java.base/jdk.internal.reflect.DirectMethodHandleAccessor.invoke(DirectMethodHandleAccessor.java:104) + at java.base/java.lang.reflect.Method.invoke(Method.java:578) + at org.apache.ibatis.plugin.Plugin.invoke(Plugin.java:64) + at jdk.proxy2/jdk.proxy2.$Proxy119.query(Unknown Source) + at org.apache.ibatis.executor.SimpleExecutor.doQuery(SimpleExecutor.java:63) + at org.apache.ibatis.executor.BaseExecutor.queryFromDatabase(BaseExecutor.java:325) + at org.apache.ibatis.executor.BaseExecutor.query(BaseExecutor.java:156) + at org.apache.ibatis.executor.CachingExecutor.query(CachingExecutor.java:109) + at com.baomidou.mybatisplus.extension.plugins.MybatisPlusInterceptor.intercept(MybatisPlusInterceptor.java:81) + at org.apache.ibatis.plugin.Plugin.invoke(Plugin.java:62) + at jdk.proxy2/jdk.proxy2.$Proxy118.query(Unknown Source) + at com.github.pagehelper.PageInterceptor.intercept(PageInterceptor.java:151) + at org.apache.ibatis.plugin.Plugin.invoke(Plugin.java:62) + at jdk.proxy2/jdk.proxy2.$Proxy118.query(Unknown Source) + at org.apache.ibatis.session.defaults.DefaultSqlSession.selectList(DefaultSqlSession.java:151) + at org.apache.ibatis.session.defaults.DefaultSqlSession.selectList(DefaultSqlSession.java:145) + at org.apache.ibatis.session.defaults.DefaultSqlSession.selectList(DefaultSqlSession.java:140) + at java.base/jdk.internal.reflect.DirectMethodHandleAccessor.invoke(DirectMethodHandleAccessor.java:104) + at java.base/java.lang.reflect.Method.invoke(Method.java:578) + at org.mybatis.spring.SqlSessionTemplate$SqlSessionInterceptor.invoke(SqlSessionTemplate.java:427) + ... 125 common frames omitted +14:49:42.262 [restartedMain] ERROR o.s.b.SpringApplication - [reportFailure,870] - Application run failed +org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'accessoryService': Unsatisfied dependency expressed through field 'baseMapper'; nested exception is org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'accessoryMapper' defined in file [/Users/longlongxiaogege/work/mengyin/code/lianmei/myself/backup/dc-backend/data-center/dc-system/target/classes/com/dc/system/mapper/AccessoryMapper.class]: Unsatisfied dependency expressed through bean property 'sqlSessionFactory'; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'sqlSessionFactory' defined in class path resource [com/dc/framework/config/DataSourceConfiguration.class]: Bean instantiation via factory method failed; nested exception is org.springframework.beans.BeanInstantiationException: Failed to instantiate [org.apache.ibatis.session.SqlSessionFactory]: Factory method 'sqlSessionFactory' threw exception; nested exception is java.io.IOException: Failed to parse mapping resource: 'file [/Users/longlongxiaogege/work/mengyin/code/lianmei/myself/backup/dc-backend/data-center/dc-system/target/classes/mapper/system/SysConfigMapper.xml]' + at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor$AutowiredFieldElement.resolveFieldValue(AutowiredAnnotationBeanPostProcessor.java:659) + at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor$AutowiredFieldElement.inject(AutowiredAnnotationBeanPostProcessor.java:639) + at org.springframework.beans.factory.annotation.InjectionMetadata.inject(InjectionMetadata.java:119) + at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor.postProcessProperties(AutowiredAnnotationBeanPostProcessor.java:399) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.populateBean(AbstractAutowireCapableBeanFactory.java:1431) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:619) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:542) + at org.springframework.beans.factory.support.AbstractBeanFactory.lambda$doGetBean$0(AbstractBeanFactory.java:335) + at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:234) + at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:333) + at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:208) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.preInstantiateSingletons(DefaultListableBeanFactory.java:953) + at org.springframework.context.support.AbstractApplicationContext.finishBeanFactoryInitialization(AbstractApplicationContext.java:918) + at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:583) + at org.springframework.boot.web.servlet.context.ServletWebServerApplicationContext.refresh(ServletWebServerApplicationContext.java:145) + at org.springframework.boot.SpringApplication.refresh(SpringApplication.java:780) + at org.springframework.boot.SpringApplication.refreshContext(SpringApplication.java:453) + at org.springframework.boot.SpringApplication.run(SpringApplication.java:343) + at org.springframework.boot.SpringApplication.run(SpringApplication.java:1370) + at org.springframework.boot.SpringApplication.run(SpringApplication.java:1359) + at com.dc.web.DcApplication.main(DcApplication.java:20) + at java.base/jdk.internal.reflect.DirectMethodHandleAccessor.invoke(DirectMethodHandleAccessor.java:104) + at java.base/java.lang.reflect.Method.invoke(Method.java:578) + at org.springframework.boot.devtools.restart.RestartLauncher.run(RestartLauncher.java:49) +Caused by: org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'accessoryMapper' defined in file [/Users/longlongxiaogege/work/mengyin/code/lianmei/myself/backup/dc-backend/data-center/dc-system/target/classes/com/dc/system/mapper/AccessoryMapper.class]: Unsatisfied dependency expressed through bean property 'sqlSessionFactory'; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'sqlSessionFactory' defined in class path resource [com/dc/framework/config/DataSourceConfiguration.class]: Bean instantiation via factory method failed; nested exception is org.springframework.beans.BeanInstantiationException: Failed to instantiate [org.apache.ibatis.session.SqlSessionFactory]: Factory method 'sqlSessionFactory' threw exception; nested exception is java.io.IOException: Failed to parse mapping resource: 'file [/Users/longlongxiaogege/work/mengyin/code/lianmei/myself/backup/dc-backend/data-center/dc-system/target/classes/mapper/system/SysConfigMapper.xml]' + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.autowireByType(AbstractAutowireCapableBeanFactory.java:1534) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.populateBean(AbstractAutowireCapableBeanFactory.java:1417) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:619) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:542) + at org.springframework.beans.factory.support.AbstractBeanFactory.lambda$doGetBean$0(AbstractBeanFactory.java:335) + at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:234) + at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:333) + at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:208) + at org.springframework.beans.factory.config.DependencyDescriptor.resolveCandidate(DependencyDescriptor.java:276) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.doResolveDependency(DefaultListableBeanFactory.java:1389) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.resolveDependency(DefaultListableBeanFactory.java:1309) + at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor$AutowiredFieldElement.resolveFieldValue(AutowiredAnnotationBeanPostProcessor.java:656) + ... 23 common frames omitted +Caused by: org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'sqlSessionFactory' defined in class path resource [com/dc/framework/config/DataSourceConfiguration.class]: Bean instantiation via factory method failed; nested exception is org.springframework.beans.BeanInstantiationException: Failed to instantiate [org.apache.ibatis.session.SqlSessionFactory]: Factory method 'sqlSessionFactory' threw exception; nested exception is java.io.IOException: Failed to parse mapping resource: 'file [/Users/longlongxiaogege/work/mengyin/code/lianmei/myself/backup/dc-backend/data-center/dc-system/target/classes/mapper/system/SysConfigMapper.xml]' + at org.springframework.beans.factory.support.ConstructorResolver.instantiate(ConstructorResolver.java:658) + at org.springframework.beans.factory.support.ConstructorResolver.instantiateUsingFactoryMethod(ConstructorResolver.java:638) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.instantiateUsingFactoryMethod(AbstractAutowireCapableBeanFactory.java:1352) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBeanInstance(AbstractAutowireCapableBeanFactory.java:1195) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:582) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:542) + at org.springframework.beans.factory.support.AbstractBeanFactory.lambda$doGetBean$0(AbstractBeanFactory.java:335) + at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:234) + at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:333) + at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:208) + at org.springframework.beans.factory.config.DependencyDescriptor.resolveCandidate(DependencyDescriptor.java:276) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.doResolveDependency(DefaultListableBeanFactory.java:1389) + at org.springframework.beans.factory.support.DefaultListableBeanFactory.resolveDependency(DefaultListableBeanFactory.java:1309) + at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.autowireByType(AbstractAutowireCapableBeanFactory.java:1519) + ... 34 common frames omitted +Caused by: org.springframework.beans.BeanInstantiationException: Failed to instantiate [org.apache.ibatis.session.SqlSessionFactory]: Factory method 'sqlSessionFactory' threw exception; nested exception is java.io.IOException: Failed to parse mapping resource: 'file [/Users/longlongxiaogege/work/mengyin/code/lianmei/myself/backup/dc-backend/data-center/dc-system/target/classes/mapper/system/SysConfigMapper.xml]' + at org.springframework.beans.factory.support.SimpleInstantiationStrategy.instantiate(SimpleInstantiationStrategy.java:185) + at org.springframework.beans.factory.support.ConstructorResolver.instantiate(ConstructorResolver.java:653) + ... 47 common frames omitted +Caused by: java.io.IOException: Failed to parse mapping resource: 'file [/Users/longlongxiaogege/work/mengyin/code/lianmei/myself/backup/dc-backend/data-center/dc-system/target/classes/mapper/system/SysConfigMapper.xml]' + at com.baomidou.mybatisplus.extension.spring.MybatisSqlSessionFactoryBean.buildSqlSessionFactory(MybatisSqlSessionFactoryBean.java:575) + at com.baomidou.mybatisplus.extension.spring.MybatisSqlSessionFactoryBean.afterPropertiesSet(MybatisSqlSessionFactoryBean.java:444) + at com.baomidou.mybatisplus.extension.spring.MybatisSqlSessionFactoryBean.getObject(MybatisSqlSessionFactoryBean.java:608) + at com.dc.framework.config.DataSourceConfiguration.sqlSessionFactory(DataSourceConfiguration.java:109) + at com.dc.framework.config.DataSourceConfiguration$$EnhancerBySpringCGLIB$$16af2aa7.CGLIB$sqlSessionFactory$1(<generated>) + at com.dc.framework.config.DataSourceConfiguration$$EnhancerBySpringCGLIB$$16af2aa7$$FastClassBySpringCGLIB$$fe615671.invoke(<generated>) + at org.springframework.cglib.proxy.MethodProxy.invokeSuper(MethodProxy.java:244) + at org.springframework.context.annotation.ConfigurationClassEnhancer$BeanMethodInterceptor.intercept(ConfigurationClassEnhancer.java:331) + at com.dc.framework.config.DataSourceConfiguration$$EnhancerBySpringCGLIB$$16af2aa7.sqlSessionFactory(<generated>) + at java.base/jdk.internal.reflect.DirectMethodHandleAccessor.invoke(DirectMethodHandleAccessor.java:104) + at java.base/java.lang.reflect.Method.invoke(Method.java:578) + at org.springframework.beans.factory.support.SimpleInstantiationStrategy.instantiate(SimpleInstantiationStrategy.java:154) + ... 48 common frames omitted +Caused by: java.io.FileNotFoundException: /Users/longlongxiaogege/work/mengyin/code/lianmei/myself/backup/dc-backend/data-center/dc-system/target/classes/mapper/system/SysConfigMapper.xml + at org.springframework.core.io.FileSystemResource.getInputStream(FileSystemResource.java:189) + at com.baomidou.mybatisplus.extension.spring.MybatisSqlSessionFactoryBean.buildSqlSessionFactory(MybatisSqlSessionFactoryBean.java:571) + ... 59 common frames omitted diff --git a/logs/sys-info.2023-03-08.log b/logs/sys-info.2023-03-08.log new file mode 100644 index 0000000..c4bec0a --- /dev/null +++ b/logs/sys-info.2023-03-08.log @@ -0,0 +1,154 @@ +11:21:45.587 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +11:21:45.587 [restartedMain] INFO c.win.WinApplication - [logStarting,55] - Starting WinApplication using Java 1.8.0_231 on LAPTOP-K8GOQEG9 with PID 71616 (D:\workspace\wenyin\win\win-admin\target\classes started by admin in D:\workspace\wenyin\win) +11:21:45.587 [restartedMain] INFO c.win.WinApplication - [logStartupProfileInfo,686] - The following 3 profiles are active: "druid", "mybatis", "dev" +11:21:48.562 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-8080"] +11:21:48.562 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +11:21:48.562 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +11:21:48.625 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +11:21:49.497 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,985] - {dataSource-1,tms} inited +11:21:49.497 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +11:21:49.497 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [tms] success +11:21:49.497 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [tms] +11:21:53.429 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +11:21:53.461 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +11:21:53.461 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +11:21:53.461 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +11:21:53.461 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +11:21:53.461 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +11:21:53.461 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +11:21:53.461 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@36470e5b +11:21:55.129 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Starting ProtocolHandler ["http-nio-8080"] +11:21:55.494 [restartedMain] INFO o.q.c.QuartzScheduler - [start,547] - Scheduler quartzScheduler_$_NON_CLUSTERED started. +11:21:55.510 [restartedMain] INFO c.win.WinApplication - [logStarted,61] - Started WinApplication in 10.474 seconds (JVM running for 11.006) +11:24:07.789 [http-nio-8080-exec-1] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring DispatcherServlet 'dispatcherServlet' +11:24:10.928 [schedule-pool-1] INFO sys-user - [run,56] - [192.168.0.90]内网IP[admin][Success][登录成功] +11:32:13.493 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +11:32:13.636 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +11:32:13.637 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +11:32:13.637 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +11:32:13.637 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +11:32:13.640 [SpringApplicationShutdownHook] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +11:32:13.642 [SpringApplicationShutdownHook] INFO c.a.d.p.DruidDataSource - [close,2105] - {dataSource-1} closing ... +11:32:13.645 [SpringApplicationShutdownHook] INFO c.a.d.p.DruidDataSource - [close,2178] - {dataSource-1} closed +11:32:19.098 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +11:32:19.100 [restartedMain] INFO c.win.WinApplication - [logStarting,55] - Starting WinApplication using Java 1.8.0_231 on LAPTOP-K8GOQEG9 with PID 70800 (D:\workspace\wenyin\win\win-admin\target\classes started by admin in D:\workspace\wenyin\win) +11:32:19.100 [restartedMain] INFO c.win.WinApplication - [logStartupProfileInfo,686] - The following 3 profiles are active: "druid", "mybatis", "dev" +11:32:21.861 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-8080"] +11:32:21.862 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +11:32:21.862 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +11:32:21.920 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +11:32:23.072 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,985] - {dataSource-1,tms} inited +11:32:23.074 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +11:32:23.075 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [tms] success +11:32:23.076 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [tms] +11:32:27.010 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +11:32:27.021 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +11:32:27.022 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +11:32:27.023 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +11:32:27.024 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +11:32:27.024 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +11:32:27.024 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +11:32:27.024 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@37570a9f +11:32:28.394 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Starting ProtocolHandler ["http-nio-8080"] +11:32:28.663 [restartedMain] INFO o.q.c.QuartzScheduler - [start,547] - Scheduler quartzScheduler_$_NON_CLUSTERED started. +11:32:28.674 [restartedMain] INFO c.win.WinApplication - [logStarted,61] - Started WinApplication in 10.058 seconds (JVM running for 10.559) +11:33:53.825 [http-nio-8080-exec-1] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring DispatcherServlet 'dispatcherServlet' +11:50:37.739 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +11:50:37.906 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +11:50:37.906 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +11:50:37.906 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +11:50:37.906 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +11:50:37.909 [SpringApplicationShutdownHook] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +11:50:37.910 [SpringApplicationShutdownHook] INFO c.a.d.p.DruidDataSource - [close,2105] - {dataSource-1} closing ... +11:50:37.913 [SpringApplicationShutdownHook] INFO c.a.d.p.DruidDataSource - [close,2178] - {dataSource-1} closed +11:52:57.376 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +11:52:57.379 [restartedMain] INFO c.win.WinApplication - [logStarting,55] - Starting WinApplication using Java 1.8.0_231 on LAPTOP-K8GOQEG9 with PID 77320 (D:\workspace\wenyin\win\win-admin\target\classes started by admin in D:\workspace\wenyin\win) +11:52:57.380 [restartedMain] INFO c.win.WinApplication - [logStartupProfileInfo,686] - The following 3 profiles are active: "druid", "mybatis", "dev" +11:53:00.110 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-8080"] +11:53:00.111 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +11:53:00.111 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +11:53:00.166 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +11:53:01.140 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,985] - {dataSource-1,tms} inited +11:53:01.141 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +11:53:01.142 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [tms] success +11:53:01.143 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [tms] +11:53:04.519 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +11:53:04.530 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +11:53:04.530 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +11:53:04.531 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +11:53:04.531 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +11:53:04.532 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +11:53:04.532 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +11:53:04.532 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@7247f4ec +11:53:05.991 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Starting ProtocolHandler ["http-nio-8080"] +11:53:06.240 [restartedMain] INFO o.q.c.QuartzScheduler - [start,547] - Scheduler quartzScheduler_$_NON_CLUSTERED started. +11:53:06.250 [restartedMain] INFO c.win.WinApplication - [logStarted,61] - Started WinApplication in 9.412 seconds (JVM running for 9.856) +11:53:44.078 [http-nio-8080-exec-2] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring DispatcherServlet 'dispatcherServlet' +12:53:15.495 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +12:53:15.667 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +12:53:15.683 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +12:53:15.683 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +12:53:15.683 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +12:53:15.686 [SpringApplicationShutdownHook] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +12:53:15.686 [SpringApplicationShutdownHook] INFO c.a.d.p.DruidDataSource - [close,2105] - {dataSource-1} closing ... +12:53:15.686 [SpringApplicationShutdownHook] INFO c.a.d.p.DruidDataSource - [close,2178] - {dataSource-1} closed +12:56:53.792 [restartedMain] INFO c.win.WinApplication - [logStarting,55] - Starting WinApplication using Java 1.8.0_231 on LAPTOP-K8GOQEG9 with PID 9468 (D:\workspace\wenyin\win\win-admin\target\classes started by admin in D:\workspace\wenyin\win) +12:56:53.792 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +12:56:53.794 [restartedMain] INFO c.win.WinApplication - [logStartupProfileInfo,686] - The following 3 profiles are active: "druid", "mybatis", "dev" +12:56:56.888 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-8080"] +12:56:56.889 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +12:56:56.889 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +12:56:56.949 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +12:56:57.836 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,985] - {dataSource-1,tms} inited +12:56:57.837 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +12:56:57.838 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [tms] success +12:56:57.839 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [tms] +12:57:01.034 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +12:57:01.050 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +12:57:01.050 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +12:57:01.051 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +12:57:01.052 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +12:57:01.052 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +12:57:01.052 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +12:57:01.052 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@50b7a179 +12:57:02.417 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Starting ProtocolHandler ["http-nio-8080"] +12:57:02.723 [restartedMain] INFO o.q.c.QuartzScheduler - [start,547] - Scheduler quartzScheduler_$_NON_CLUSTERED started. +12:57:02.731 [restartedMain] INFO c.win.WinApplication - [logStarted,61] - Started WinApplication in 9.509 seconds (JVM running for 10.746) +12:57:13.945 [http-nio-8080-exec-2] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring DispatcherServlet 'dispatcherServlet' +12:57:17.086 [schedule-pool-1] INFO sys-user - [run,56] - [192.168.0.80]内网IP[admin][Success][登录成功] +13:21:35.909 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +13:21:36.069 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +13:21:36.069 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +13:21:36.069 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +13:21:36.069 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +13:21:36.072 [SpringApplicationShutdownHook] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +13:21:36.074 [SpringApplicationShutdownHook] INFO c.a.d.p.DruidDataSource - [close,2105] - {dataSource-1} closing ... +13:21:36.077 [SpringApplicationShutdownHook] INFO c.a.d.p.DruidDataSource - [close,2178] - {dataSource-1} closed diff --git a/logs/sys-info.2023-03-09.log b/logs/sys-info.2023-03-09.log new file mode 100644 index 0000000..f194840 --- /dev/null +++ b/logs/sys-info.2023-03-09.log @@ -0,0 +1,41 @@ +08:40:47.081 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +08:40:47.083 [restartedMain] INFO c.win.WinApplication - [logStarting,55] - Starting WinApplication using Java 1.8.0_231 on LAPTOP-K8GOQEG9 with PID 3364 (D:\workspace\wenyin\win\win-admin\target\classes started by admin in D:\workspace\wenyin\win) +08:40:47.092 [restartedMain] INFO c.win.WinApplication - [logStartupProfileInfo,686] - The following 3 profiles are active: "druid", "mybatis", "dev" +08:40:50.298 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-8080"] +08:40:50.299 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +08:40:50.300 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +08:40:50.357 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +08:40:51.343 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,985] - {dataSource-1,tms} inited +08:40:51.344 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +08:40:51.345 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [tms] success +08:40:51.346 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [tms] +08:40:54.865 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +08:40:54.883 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +08:40:54.883 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +08:40:54.884 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +08:40:54.885 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +08:40:54.885 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +08:40:54.885 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +08:40:54.886 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@3a7785bb +08:40:56.332 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Starting ProtocolHandler ["http-nio-8080"] +08:40:56.621 [restartedMain] INFO o.q.c.QuartzScheduler - [start,547] - Scheduler quartzScheduler_$_NON_CLUSTERED started. +08:40:56.630 [restartedMain] INFO c.win.WinApplication - [logStarted,61] - Started WinApplication in 10.152 seconds (JVM running for 11.298) +08:41:14.139 [http-nio-8080-exec-1] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring DispatcherServlet 'dispatcherServlet' +08:41:19.006 [schedule-pool-1] INFO sys-user - [run,56] - [192.168.0.90]内网IP[admin][Success][登录成功] +13:07:27.222 [schedule-pool-1] INFO sys-user - [run,56] - [192.168.0.90]内网IP[admin][Error][验证码已失效] +13:07:32.302 [schedule-pool-2] INFO sys-user - [run,56] - [192.168.0.90]内网IP[admin][Success][登录成功] +16:50:23.268 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +16:50:23.467 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +16:50:23.468 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +16:50:23.468 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +16:50:23.469 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +16:50:23.472 [SpringApplicationShutdownHook] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +16:50:23.476 [SpringApplicationShutdownHook] INFO c.a.d.p.DruidDataSource - [close,2105] - {dataSource-1} closing ... +16:50:23.479 [SpringApplicationShutdownHook] INFO c.a.d.p.DruidDataSource - [close,2178] - {dataSource-1} closed diff --git a/logs/sys-info.2023-03-10.log b/logs/sys-info.2023-03-10.log new file mode 100644 index 0000000..f4bdcf9 --- /dev/null +++ b/logs/sys-info.2023-03-10.log @@ -0,0 +1,185 @@ +08:20:40.839 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +08:20:40.839 [restartedMain] INFO c.win.WinApplication - [logStarting,55] - Starting WinApplication using Java 1.8.0_231 on LAPTOP-K8GOQEG9 with PID 18624 (D:\workspace\wenyin\win\win-admin\target\classes started by admin in D:\workspace\wenyin\win) +08:20:40.851 [restartedMain] INFO c.win.WinApplication - [logStartupProfileInfo,686] - The following 3 profiles are active: "druid", "mybatis", "dev" +08:20:44.202 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-8080"] +08:20:44.203 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +08:20:44.203 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +08:20:44.262 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +08:20:45.598 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,985] - {dataSource-1,tms} inited +08:20:45.599 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +08:20:45.601 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [tms] success +08:20:45.601 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [tms] +08:20:48.946 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +08:20:48.960 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +08:20:48.960 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +08:20:48.961 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +08:20:48.962 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +08:20:48.963 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +08:20:48.963 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +08:20:48.963 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@3ffc4576 +08:20:50.234 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Starting ProtocolHandler ["http-nio-8080"] +08:20:50.558 [restartedMain] INFO o.q.c.QuartzScheduler - [start,547] - Scheduler quartzScheduler_$_NON_CLUSTERED started. +08:20:50.567 [restartedMain] INFO c.win.WinApplication - [logStarted,61] - Started WinApplication in 10.342 seconds (JVM running for 11.462) +08:56:17.351 [http-nio-8080-exec-2] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring DispatcherServlet 'dispatcherServlet' +08:56:24.549 [schedule-pool-1] INFO sys-user - [run,56] - [192.168.0.90]内网IP[admin][Success][登录成功] +11:03:00.213 [Thread-5] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +11:03:00.521 [Thread-5] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +11:03:00.522 [Thread-5] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +11:03:00.524 [Thread-5] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +11:03:00.526 [Thread-5] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +11:03:00.532 [Thread-5] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +11:03:00.542 [Thread-5] INFO c.a.d.p.DruidDataSource - [close,2105] - {dataSource-1} closing ... +11:03:00.557 [Thread-5] INFO c.a.d.p.DruidDataSource - [close,2178] - {dataSource-1} closed +11:03:01.355 [restartedMain] INFO c.win.WinApplication - [logStarting,55] - Starting WinApplication using Java 1.8.0_231 on LAPTOP-K8GOQEG9 with PID 18624 (D:\workspace\wenyin\win\win-admin\target\classes started by admin in D:\workspace\wenyin\win) +11:03:01.356 [restartedMain] INFO c.win.WinApplication - [logStartupProfileInfo,686] - The following 3 profiles are active: "druid", "mybatis", "dev" +11:03:02.370 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-8080"] +11:03:02.371 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +11:03:02.372 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +11:03:02.381 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +11:03:02.665 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,985] - {dataSource-2,tms} inited +11:03:02.665 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +11:03:02.665 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [tms] success +11:03:02.666 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [tms] +11:03:04.103 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +11:03:04.104 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +11:03:04.104 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +11:03:04.105 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +11:03:04.105 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +11:03:04.105 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +11:03:04.105 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +11:03:04.105 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@8f1da45 +11:03:04.852 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Starting ProtocolHandler ["http-nio-8080"] +11:03:04.930 [restartedMain] INFO o.q.c.QuartzScheduler - [start,547] - Scheduler quartzScheduler_$_NON_CLUSTERED started. +11:03:04.933 [restartedMain] INFO c.win.WinApplication - [logStarted,61] - Started WinApplication in 3.733 seconds (JVM running for 9745.827) +11:03:06.746 [Thread-9] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +11:03:06.964 [Thread-9] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +11:03:06.964 [Thread-9] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +11:03:06.965 [Thread-9] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +11:03:06.965 [Thread-9] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +11:03:06.968 [Thread-9] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +11:03:06.968 [Thread-9] INFO c.a.d.p.DruidDataSource - [close,2105] - {dataSource-2} closing ... +11:03:06.969 [Thread-9] INFO c.a.d.p.DruidDataSource - [close,2178] - {dataSource-2} closed +11:03:07.668 [restartedMain] INFO c.win.WinApplication - [logStarting,55] - Starting WinApplication using Java 1.8.0_231 on LAPTOP-K8GOQEG9 with PID 18624 (D:\workspace\wenyin\win\win-admin\target\classes started by admin in D:\workspace\wenyin\win) +11:03:07.669 [restartedMain] INFO c.win.WinApplication - [logStartupProfileInfo,686] - The following 3 profiles are active: "druid", "mybatis", "dev" +11:03:08.297 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-8080"] +11:03:08.298 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +11:03:08.298 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +11:03:08.305 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +11:03:08.411 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,985] - {dataSource-3,tms} inited +11:03:08.412 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +11:03:08.412 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [tms] success +11:03:08.412 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [tms] +11:03:09.513 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +11:03:09.514 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +11:03:09.515 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +11:03:09.515 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +11:03:09.515 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +11:03:09.515 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +11:03:09.516 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +11:03:09.516 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@7b772342 +11:03:10.147 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Starting ProtocolHandler ["http-nio-8080"] +11:03:10.207 [restartedMain] INFO o.q.c.QuartzScheduler - [start,547] - Scheduler quartzScheduler_$_NON_CLUSTERED started. +11:03:10.210 [restartedMain] INFO c.win.WinApplication - [logStarted,61] - Started WinApplication in 2.587 seconds (JVM running for 9751.104) +11:03:11.606 [Thread-13] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +11:03:11.769 [Thread-13] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +11:03:11.770 [Thread-13] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +11:03:11.770 [Thread-13] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +11:03:11.770 [Thread-13] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +11:03:11.773 [Thread-13] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +11:03:11.773 [Thread-13] INFO c.a.d.p.DruidDataSource - [close,2105] - {dataSource-3} closing ... +11:03:11.775 [Thread-13] INFO c.a.d.p.DruidDataSource - [close,2178] - {dataSource-3} closed +11:03:12.319 [restartedMain] INFO c.win.WinApplication - [logStarting,55] - Starting WinApplication using Java 1.8.0_231 on LAPTOP-K8GOQEG9 with PID 18624 (D:\workspace\wenyin\win\win-admin\target\classes started by admin in D:\workspace\wenyin\win) +11:03:12.319 [restartedMain] INFO c.win.WinApplication - [logStartupProfileInfo,686] - The following 3 profiles are active: "druid", "mybatis", "dev" +11:03:12.806 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-8080"] +11:03:12.807 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +11:03:12.807 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +11:03:12.812 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +11:03:12.894 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,985] - {dataSource-4,tms} inited +11:03:12.894 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +11:03:12.894 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [tms] success +11:03:12.894 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [tms] +11:03:13.699 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +11:03:13.699 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +11:03:13.700 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +11:03:13.700 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +11:03:13.700 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +11:03:13.700 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +11:03:13.700 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +11:03:13.700 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@1e790d9 +11:03:14.166 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Starting ProtocolHandler ["http-nio-8080"] +11:03:14.216 [restartedMain] INFO o.q.c.QuartzScheduler - [start,547] - Scheduler quartzScheduler_$_NON_CLUSTERED started. +11:03:14.218 [restartedMain] INFO c.win.WinApplication - [logStarted,61] - Started WinApplication in 1.934 seconds (JVM running for 9755.113) +11:07:01.662 [http-nio-8080-exec-1] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring DispatcherServlet 'dispatcherServlet' +11:07:19.356 [Thread-17] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +11:07:19.499 [Thread-17] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +11:07:19.499 [Thread-17] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +11:07:19.499 [Thread-17] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +11:07:19.499 [Thread-17] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +11:07:19.501 [Thread-17] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +11:07:19.501 [Thread-17] INFO c.a.d.p.DruidDataSource - [close,2105] - {dataSource-4} closing ... +11:07:19.502 [Thread-17] INFO c.a.d.p.DruidDataSource - [close,2178] - {dataSource-4} closed +11:07:19.936 [restartedMain] INFO c.win.WinApplication - [logStarting,55] - Starting WinApplication using Java 1.8.0_231 on LAPTOP-K8GOQEG9 with PID 18624 (D:\workspace\wenyin\win\win-admin\target\classes started by admin in D:\workspace\wenyin\win) +11:07:19.937 [restartedMain] INFO c.win.WinApplication - [logStartupProfileInfo,686] - The following 3 profiles are active: "druid", "mybatis", "dev" +11:07:20.707 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-8080"] +11:07:20.707 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +11:07:20.707 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +11:07:20.714 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +11:07:20.807 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,985] - {dataSource-5,tms} inited +11:07:20.807 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +11:07:20.807 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [tms] success +11:07:20.807 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [tms] +11:07:21.590 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +11:07:21.590 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +11:07:21.590 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +11:07:21.591 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +11:07:21.591 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +11:07:21.591 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +11:07:21.591 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +11:07:21.591 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@41076377 +11:07:21.996 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Starting ProtocolHandler ["http-nio-8080"] +11:07:22.049 [restartedMain] INFO o.q.c.QuartzScheduler - [start,547] - Scheduler quartzScheduler_$_NON_CLUSTERED started. +11:07:22.051 [restartedMain] INFO c.win.WinApplication - [logStarted,61] - Started WinApplication in 2.156 seconds (JVM running for 10002.944) +11:08:43.570 [http-nio-8080-exec-73] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring DispatcherServlet 'dispatcherServlet' +11:44:32.301 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +11:44:32.446 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +11:44:32.446 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +11:44:32.446 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +11:44:32.446 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +11:44:32.447 [SpringApplicationShutdownHook] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +11:44:32.448 [SpringApplicationShutdownHook] INFO c.a.d.p.DruidDataSource - [close,2105] - {dataSource-5} closing ... +11:44:32.448 [SpringApplicationShutdownHook] INFO c.a.d.p.DruidDataSource - [close,2178] - {dataSource-5} closed diff --git a/logs/sys-info.2023-07-06.log b/logs/sys-info.2023-07-06.log new file mode 100644 index 0000000..8772584 --- /dev/null +++ b/logs/sys-info.2023-07-06.log @@ -0,0 +1,78 @@ +08:56:17.211 [restartedMain] INFO c.w.w.WinApplication - [logStarting,55] - Starting WinApplication using Java 1.8.0_231 on LAPTOP-K8GOQEG9 with PID 34744 (D:\workspace\wenyin\win\win-admin\target\classes started by admin in D:\workspace\wenyin\win) +08:56:17.211 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +08:56:17.227 [restartedMain] INFO c.w.w.WinApplication - [logStartupProfileInfo,686] - The following 3 profiles are active: "druid", "mybatis", "dev" +08:56:19.099 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-8080"] +08:56:19.099 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +08:56:19.114 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +08:56:19.146 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +08:56:19.224 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Stopping service [Tomcat] +08:57:07.647 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +08:57:07.647 [restartedMain] INFO c.w.w.WinApplication - [logStarting,55] - Starting WinApplication using Java 1.8.0_231 on LAPTOP-K8GOQEG9 with PID 23604 (D:\workspace\wenyin\win\win-admin\target\classes started by admin in D:\workspace\wenyin\win) +08:57:07.647 [restartedMain] INFO c.w.w.WinApplication - [logStartupProfileInfo,686] - The following 3 profiles are active: "druid", "mybatis", "dev" +08:57:09.710 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-8080"] +08:57:09.710 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +08:57:09.710 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +08:57:09.772 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +08:57:09.976 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Stopping service [Tomcat] +08:59:32.504 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +08:59:32.519 [restartedMain] INFO c.w.w.WinApplication - [logStarting,55] - Starting WinApplication using Java 1.8.0_231 on LAPTOP-K8GOQEG9 with PID 33252 (D:\workspace\wenyin\win\win-admin\target\classes started by admin in D:\workspace\wenyin\win) +08:59:32.519 [restartedMain] INFO c.w.w.WinApplication - [logStartupProfileInfo,686] - The following 3 profiles are active: "druid", "mybatis", "dev" +08:59:34.592 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-8080"] +08:59:34.592 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +08:59:34.592 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +08:59:34.670 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +08:59:34.826 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Stopping service [Tomcat] +08:59:55.019 [restartedMain] INFO c.w.a.AppApplication - [logStarting,55] - Starting AppApplication using Java 1.8.0_231 on LAPTOP-K8GOQEG9 with PID 31584 (D:\workspace\wenyin\win\win-app\target\classes started by admin in D:\workspace\wenyin\win) +08:59:55.019 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +08:59:55.019 [restartedMain] INFO c.w.a.AppApplication - [logStartupProfileInfo,686] - The following 3 profiles are active: "druid", "mybatis", "dev" +08:59:57.430 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-8090"] +08:59:57.430 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +08:59:57.446 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +08:59:57.493 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +08:59:58.656 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,985] - {dataSource-1,ccwin} inited +08:59:58.656 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [ccwin] success +08:59:58.672 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +08:59:58.672 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [ccwin] +09:00:03.156 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Starting ProtocolHandler ["http-nio-8090"] +09:00:03.325 [restartedMain] INFO c.w.a.AppApplication - [logStarted,61] - Started AppApplication in 8.758 seconds (JVM running for 9.247) +09:01:47.170 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +09:01:47.170 [restartedMain] INFO c.w.w.WinApplication - [logStarting,55] - Starting WinApplication using Java 1.8.0_231 on LAPTOP-K8GOQEG9 with PID 35128 (D:\workspace\wenyin\win\win-admin\target\classes started by admin in D:\workspace\wenyin\win) +09:01:47.170 [restartedMain] INFO c.w.w.WinApplication - [logStartupProfileInfo,686] - The following 3 profiles are active: "druid", "mybatis", "dev" +09:01:49.798 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-8080"] +09:01:49.798 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +09:01:49.798 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +09:01:49.844 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +09:01:51.356 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,985] - {dataSource-1,ccwin} inited +09:01:51.356 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [ccwin] success +09:01:51.356 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +09:01:51.356 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [ccwin] +09:01:56.402 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +09:01:56.433 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +09:01:56.433 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +09:01:56.433 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +09:01:56.433 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +09:01:56.433 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +09:01:56.433 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +09:01:56.433 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@1e01f648 +09:01:56.766 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Starting ProtocolHandler ["http-nio-8080"] +09:01:56.940 [restartedMain] INFO o.q.c.QuartzScheduler - [start,547] - Scheduler quartzScheduler_$_NON_CLUSTERED started. +09:01:56.955 [restartedMain] INFO c.w.w.WinApplication - [logStarted,61] - Started WinApplication in 10.249 seconds (JVM running for 10.741) +09:05:53.710 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +09:05:53.871 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +09:05:53.881 [SpringApplicationShutdownHook] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +09:05:53.882 [SpringApplicationShutdownHook] INFO c.a.d.p.DruidDataSource - [close,2105] - {dataSource-1} closing ... +09:05:53.885 [SpringApplicationShutdownHook] INFO c.a.d.p.DruidDataSource - [close,2178] - {dataSource-1} closed +09:05:53.927 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +09:05:53.927 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +09:05:53.928 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +09:05:53.931 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +09:05:53.938 [SpringApplicationShutdownHook] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +09:05:53.940 [SpringApplicationShutdownHook] INFO c.a.d.p.DruidDataSource - [close,2105] - {dataSource-1} closing ... +09:05:53.942 [SpringApplicationShutdownHook] INFO c.a.d.p.DruidDataSource - [close,2178] - {dataSource-1} closed diff --git a/logs/sys-info.2023-07-19.log b/logs/sys-info.2023-07-19.log new file mode 100644 index 0000000..d5c4a50 --- /dev/null +++ b/logs/sys-info.2023-07-19.log @@ -0,0 +1,781 @@ +11:47:17.703 [restartedMain] INFO c.w.w.WinApplication - [logStarting,55] - Starting WinApplication using Java 1.8.0_231 on LAPTOP-K8GOQEG9 with PID 43880 (D:\workspace\wenyin\win\win-admin\target\classes started by admin in D:\workspace\wenyin\win) +11:47:17.698 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +11:47:17.707 [restartedMain] INFO c.w.w.WinApplication - [logStartupProfileInfo,686] - The following 3 profiles are active: "druid", "mybatis", "dev" +11:47:21.890 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,985] - {dataSource-1,ccwin} inited +11:47:21.892 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [ccwin] success +11:47:21.894 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +11:47:21.894 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [ccwin] +11:47:23.829 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +11:47:23.842 [restartedMain] INFO c.a.d.p.DruidDataSource - [close,2105] - {dataSource-1} closing ... +11:47:23.844 [restartedMain] INFO c.a.d.p.DruidDataSource - [close,2178] - {dataSource-1} closed +11:47:45.399 [restartedMain] INFO c.w.w.WinApplication - [logStarting,55] - Starting WinApplication using Java 1.8.0_231 on LAPTOP-K8GOQEG9 with PID 49600 (D:\workspace\wenyin\win\win-admin\target\classes started by admin in D:\workspace\wenyin\win) +11:47:45.398 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +11:47:45.400 [restartedMain] INFO c.w.w.WinApplication - [logStartupProfileInfo,686] - The following 3 profiles are active: "druid", "mybatis", "dev" +11:47:47.951 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-8080"] +11:47:47.951 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +11:47:47.951 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +11:47:47.996 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +11:47:49.168 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,985] - {dataSource-1,ccwin} inited +11:47:49.170 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [ccwin] success +11:47:49.172 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +11:47:49.173 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [ccwin] +11:47:54.320 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +11:47:54.337 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +11:47:54.338 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +11:47:54.339 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +11:47:54.340 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +11:47:54.340 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +11:47:54.340 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +11:47:54.341 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@1fd4709a +11:47:54.594 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Starting ProtocolHandler ["http-nio-8080"] +11:47:54.968 [restartedMain] INFO o.q.c.QuartzScheduler - [start,547] - Scheduler quartzScheduler_$_NON_CLUSTERED started. +11:47:54.977 [restartedMain] INFO c.w.w.WinApplication - [logStarted,61] - Started WinApplication in 10.046 seconds (JVM running for 10.458) +11:49:08.000 [http-nio-8080-exec-1] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring DispatcherServlet 'dispatcherServlet' +13:05:25.377 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +13:05:25.523 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +13:05:25.523 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +13:05:25.523 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +13:05:25.526 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +13:05:25.531 [SpringApplicationShutdownHook] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +13:05:25.533 [SpringApplicationShutdownHook] INFO c.a.d.p.DruidDataSource - [close,2105] - {dataSource-1} closing ... +13:05:25.534 [SpringApplicationShutdownHook] INFO c.a.d.p.DruidDataSource - [close,2178] - {dataSource-1} closed +13:07:06.741 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +13:07:06.745 [restartedMain] INFO c.w.w.WinApplication - [logStarting,55] - Starting WinApplication using Java 1.8.0_231 on LAPTOP-K8GOQEG9 with PID 48228 (D:\workspace\wenyin\win\win-admin\target\classes started by admin in D:\workspace\wenyin\win) +13:07:06.746 [restartedMain] INFO c.w.w.WinApplication - [logStartupProfileInfo,686] - The following 3 profiles are active: "druid", "mybatis", "dev" +13:07:09.324 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-8080"] +13:07:09.325 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +13:07:09.325 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +13:07:09.377 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +13:07:10.443 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,985] - {dataSource-1,ccwin} inited +13:07:10.446 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [ccwin] success +13:07:10.449 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +13:07:10.450 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [ccwin] +13:07:15.441 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +13:07:15.455 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +13:07:15.455 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +13:07:15.457 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +13:07:15.458 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +13:07:15.458 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +13:07:15.458 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +13:07:15.458 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@6bbda51e +13:07:15.703 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Starting ProtocolHandler ["http-nio-8080"] +13:07:15.887 [restartedMain] INFO o.q.c.QuartzScheduler - [start,547] - Scheduler quartzScheduler_$_NON_CLUSTERED started. +13:07:15.897 [restartedMain] INFO c.w.w.WinApplication - [logStarted,61] - Started WinApplication in 9.612 seconds (JVM running for 10.018) +13:07:27.884 [http-nio-8080-exec-1] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring DispatcherServlet 'dispatcherServlet' +13:09:21.466 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +13:09:21.613 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +13:09:21.613 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +13:09:21.613 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +13:09:21.616 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +13:09:21.619 [SpringApplicationShutdownHook] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +13:09:21.620 [SpringApplicationShutdownHook] INFO c.a.d.p.DruidDataSource - [close,2105] - {dataSource-1} closing ... +13:09:21.623 [SpringApplicationShutdownHook] INFO c.a.d.p.DruidDataSource - [close,2178] - {dataSource-1} closed +13:09:25.562 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +13:09:25.564 [restartedMain] INFO c.w.w.WinApplication - [logStarting,55] - Starting WinApplication using Java 1.8.0_231 on LAPTOP-K8GOQEG9 with PID 49264 (D:\workspace\wenyin\win\win-admin\target\classes started by admin in D:\workspace\wenyin\win) +13:09:25.564 [restartedMain] INFO c.w.w.WinApplication - [logStartupProfileInfo,686] - The following 3 profiles are active: "druid", "mybatis", "dev" +13:09:28.019 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-8080"] +13:09:28.020 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +13:09:28.020 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +13:09:28.067 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +13:09:29.236 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,985] - {dataSource-1,ccwin} inited +13:09:29.238 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [ccwin] success +13:09:29.240 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +13:09:29.241 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [ccwin] +13:09:33.884 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +13:09:33.898 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +13:09:33.898 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +13:09:33.899 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +13:09:33.901 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +13:09:33.901 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +13:09:33.901 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +13:09:33.901 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@41dc0e98 +13:09:34.179 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Starting ProtocolHandler ["http-nio-8080"] +13:09:34.354 [restartedMain] INFO o.q.c.QuartzScheduler - [start,547] - Scheduler quartzScheduler_$_NON_CLUSTERED started. +13:09:34.363 [restartedMain] INFO c.w.w.WinApplication - [logStarted,61] - Started WinApplication in 9.249 seconds (JVM running for 9.733) +13:10:54.379 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +13:10:54.540 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +13:10:54.540 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +13:10:54.540 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +13:10:54.543 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +13:10:54.546 [SpringApplicationShutdownHook] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +13:10:54.549 [SpringApplicationShutdownHook] INFO c.a.d.p.DruidDataSource - [close,2105] - {dataSource-1} closing ... +13:10:54.551 [SpringApplicationShutdownHook] INFO c.a.d.p.DruidDataSource - [close,2178] - {dataSource-1} closed +13:19:22.484 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +13:19:22.487 [restartedMain] INFO c.w.w.WinApplication - [logStarting,55] - Starting WinApplication using Java 1.8.0_231 on LAPTOP-K8GOQEG9 with PID 50184 (D:\workspace\wenyin\win\win-admin\target\classes started by admin in D:\workspace\wenyin\win) +13:19:22.488 [restartedMain] INFO c.w.w.WinApplication - [logStartupProfileInfo,686] - The following 3 profiles are active: "druid", "mybatis", "dev" +13:19:25.019 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-8080"] +13:19:25.020 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +13:19:25.020 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +13:19:25.068 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +13:19:26.311 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,985] - {dataSource-1,ccwin} inited +13:19:26.313 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [ccwin] success +13:19:26.315 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +13:19:26.315 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [ccwin] +13:19:31.070 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +13:19:31.086 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +13:19:31.087 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +13:19:31.088 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +13:19:31.089 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +13:19:31.090 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +13:19:31.090 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +13:19:31.090 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@a49d837 +13:19:31.365 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Starting ProtocolHandler ["http-nio-8080"] +13:19:31.528 [restartedMain] INFO o.q.c.QuartzScheduler - [start,547] - Scheduler quartzScheduler_$_NON_CLUSTERED started. +13:19:31.536 [restartedMain] INFO c.w.w.WinApplication - [logStarted,61] - Started WinApplication in 9.518 seconds (JVM running for 9.983) +13:19:58.235 [http-nio-8080-exec-2] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring DispatcherServlet 'dispatcherServlet' +13:19:58.300 [http-nio-8080-exec-2] INFO c.w.w.w.WebSocketServer - [onOpen,43] - + 建立连接 - org.apache.tomcat.websocket.WsSession@720b0154 +13:19:58.300 [http-nio-8080-exec-2] INFO c.w.w.w.WebSocketServer - [onOpen,44] - + 当前人数 - 1 +13:20:21.923 [http-nio-8080-exec-3] INFO c.w.w.w.WebSocketServer - [onOpen,43] - + 建立连接 - org.apache.tomcat.websocket.WsSession@1ee68c5d +13:20:21.923 [http-nio-8080-exec-3] INFO c.w.w.w.WebSocketServer - [onOpen,44] - + 当前人数 - 2 +13:23:10.907 [http-nio-8080-exec-6] INFO c.w.w.w.WebSocketServer - [onClose,54] - + 关闭连接 - org.apache.tomcat.websocket.WsSession@1ee68c5d +13:23:10.907 [http-nio-8080-exec-6] INFO c.w.w.w.WebSocketUsers - [remove,65] - + 正在移出用户 - 1 +13:23:10.907 [http-nio-8080-exec-6] INFO c.w.w.w.WebSocketUsers - [remove,69] - + 移出结果 - 成功 +13:23:20.822 [http-nio-8080-exec-4] INFO c.w.w.w.WebSocketServer - [onClose,54] - + 关闭连接 - org.apache.tomcat.websocket.WsSession@720b0154 +13:23:20.822 [http-nio-8080-exec-4] INFO c.w.w.w.WebSocketUsers - [remove,65] - + 正在移出用户 - 0 +13:23:20.822 [http-nio-8080-exec-4] INFO c.w.w.w.WebSocketUsers - [remove,69] - + 移出结果 - 成功 +13:27:04.285 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +13:27:04.434 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +13:27:04.434 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +13:27:04.435 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +13:27:04.438 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +13:27:04.441 [SpringApplicationShutdownHook] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +13:27:04.443 [SpringApplicationShutdownHook] INFO c.a.d.p.DruidDataSource - [close,2105] - {dataSource-1} closing ... +13:27:04.445 [SpringApplicationShutdownHook] INFO c.a.d.p.DruidDataSource - [close,2178] - {dataSource-1} closed +13:27:08.481 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +13:27:08.485 [restartedMain] INFO c.w.w.WinApplication - [logStarting,55] - Starting WinApplication using Java 1.8.0_231 on LAPTOP-K8GOQEG9 with PID 49004 (D:\workspace\wenyin\win\win-admin\target\classes started by admin in D:\workspace\wenyin\win) +13:27:08.485 [restartedMain] INFO c.w.w.WinApplication - [logStartupProfileInfo,686] - The following 3 profiles are active: "druid", "mybatis", "dev" +13:27:11.053 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-8080"] +13:27:11.054 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +13:27:11.054 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +13:27:11.109 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +13:27:12.361 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,985] - {dataSource-1,ccwin} inited +13:27:12.363 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [ccwin] success +13:27:12.365 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +13:27:12.365 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [ccwin] +13:27:17.232 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +13:27:17.245 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +13:27:17.245 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +13:27:17.246 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +13:27:17.247 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +13:27:17.247 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +13:27:17.247 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +13:27:17.248 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@2bf6f63c +13:27:17.515 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Starting ProtocolHandler ["http-nio-8080"] +13:27:17.673 [restartedMain] INFO o.q.c.QuartzScheduler - [start,547] - Scheduler quartzScheduler_$_NON_CLUSTERED started. +13:27:17.682 [restartedMain] INFO c.w.w.WinApplication - [logStarted,61] - Started WinApplication in 9.652 seconds (JVM running for 10.116) +13:28:01.598 [http-nio-8080-exec-1] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring DispatcherServlet 'dispatcherServlet' +13:28:01.668 [http-nio-8080-exec-1] INFO c.w.w.w.WebSocketServer - [onOpen,43] - + 建立连接 - org.apache.tomcat.websocket.WsSession@30906d9 +13:28:01.668 [http-nio-8080-exec-1] INFO c.w.w.w.WebSocketServer - [onOpen,44] - + 当前人数 - 1 +13:28:16.150 [http-nio-8080-exec-10] INFO c.w.w.w.WebSocketServer - [onClose,54] - + 关闭连接 - org.apache.tomcat.websocket.WsSession@30906d9 +13:28:16.150 [http-nio-8080-exec-10] INFO c.w.w.w.WebSocketUsers - [remove,65] - + 正在移出用户 - 0 +13:28:16.150 [http-nio-8080-exec-10] INFO c.w.w.w.WebSocketUsers - [remove,69] - + 移出结果 - 成功 +13:28:19.150 [http-nio-8080-exec-5] INFO c.w.w.w.WebSocketServer - [onOpen,43] - + 建立连接 - org.apache.tomcat.websocket.WsSession@221b6dcd +13:28:19.151 [http-nio-8080-exec-5] INFO c.w.w.w.WebSocketServer - [onOpen,44] - + 当前人数 - 1 +13:28:45.472 [http-nio-8080-exec-18] INFO c.w.w.w.WebSocketServer - [onOpen,43] - + 建立连接 - org.apache.tomcat.websocket.WsSession@68b11835 +13:28:45.472 [http-nio-8080-exec-18] INFO c.w.w.w.WebSocketServer - [onOpen,44] - + 当前人数 - 2 +13:42:56.360 [http-nio-8080-exec-21] INFO c.w.w.w.WebSocketServer - [onClose,54] - + 关闭连接 - org.apache.tomcat.websocket.WsSession@221b6dcd +13:42:56.360 [http-nio-8080-exec-21] INFO c.w.w.w.WebSocketUsers - [remove,65] - + 正在移出用户 - 1 +13:42:56.360 [http-nio-8080-exec-21] INFO c.w.w.w.WebSocketUsers - [remove,69] - + 移出结果 - 成功 +13:42:56.452 [http-nio-8080-exec-9] INFO c.w.w.w.WebSocketServer - [onClose,54] - + 关闭连接 - org.apache.tomcat.websocket.WsSession@68b11835 +13:42:56.452 [http-nio-8080-exec-9] INFO c.w.w.w.WebSocketUsers - [remove,65] - + 正在移出用户 - 2 +13:42:56.452 [http-nio-8080-exec-9] INFO c.w.w.w.WebSocketUsers - [remove,69] - + 移出结果 - 成功 +13:48:51.767 [schedule-pool-1] INFO sys-user - [run,56] - [127.0.0.1]内网IP[admin][Error][验证码错误] +13:48:54.866 [schedule-pool-1] INFO sys-user - [run,56] - [127.0.0.1]内网IP[admin][Success][登录成功] +13:49:08.314 [http-nio-8080-exec-8] INFO c.w.w.w.WebSocketServer - [onOpen,43] - + 建立连接 - org.apache.tomcat.websocket.WsSession@70daaeb7 +13:49:08.314 [http-nio-8080-exec-8] INFO c.w.w.w.WebSocketServer - [onOpen,44] - + 当前人数 - 1 +13:49:16.069 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +13:49:16.200 [SpringApplicationShutdownHook] INFO c.w.w.w.WebSocketServer - [onClose,54] - + 关闭连接 - org.apache.tomcat.websocket.WsSession@70daaeb7 +13:49:16.200 [SpringApplicationShutdownHook] INFO c.w.w.w.WebSocketUsers - [remove,65] - + 正在移出用户 - 3 +13:49:16.201 [SpringApplicationShutdownHook] INFO c.w.w.w.WebSocketUsers - [remove,69] - + 移出结果 - 成功 +13:49:16.227 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +13:49:16.228 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +13:49:16.228 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +13:49:16.231 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +13:49:16.233 [SpringApplicationShutdownHook] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +13:49:16.236 [SpringApplicationShutdownHook] INFO c.a.d.p.DruidDataSource - [close,2105] - {dataSource-1} closing ... +13:49:16.238 [SpringApplicationShutdownHook] INFO c.a.d.p.DruidDataSource - [close,2178] - {dataSource-1} closed +13:49:20.319 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +13:49:20.323 [restartedMain] INFO c.w.w.WinApplication - [logStarting,55] - Starting WinApplication using Java 1.8.0_231 on LAPTOP-K8GOQEG9 with PID 51044 (D:\workspace\wenyin\win\win-admin\target\classes started by admin in D:\workspace\wenyin\win) +13:49:20.324 [restartedMain] INFO c.w.w.WinApplication - [logStartupProfileInfo,686] - The following 3 profiles are active: "druid", "mybatis", "dev" +13:49:23.127 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-8080"] +13:49:23.128 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +13:49:23.128 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +13:49:23.177 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +13:49:24.280 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,985] - {dataSource-1,ccwin} inited +13:49:24.282 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [ccwin] success +13:49:24.286 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +13:49:24.286 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [ccwin] +13:49:29.051 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +13:49:29.067 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +13:49:29.068 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +13:49:29.069 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +13:49:29.070 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +13:49:29.070 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +13:49:29.070 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +13:49:29.071 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@57836689 +13:49:29.340 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Starting ProtocolHandler ["http-nio-8080"] +13:49:29.498 [restartedMain] INFO o.q.c.QuartzScheduler - [start,547] - Scheduler quartzScheduler_$_NON_CLUSTERED started. +13:49:29.507 [restartedMain] INFO c.w.w.WinApplication - [logStarted,61] - Started WinApplication in 9.667 seconds (JVM running for 10.145) +13:49:43.435 [http-nio-8080-exec-1] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring DispatcherServlet 'dispatcherServlet' +13:49:43.509 [http-nio-8080-exec-1] INFO c.w.w.w.WebSocketServer - [onOpen,48] - + 建立连接 - org.apache.tomcat.websocket.WsSession@4f84cf98 +13:49:43.510 [http-nio-8080-exec-1] INFO c.w.w.w.WebSocketServer - [onOpen,49] - + 当前人数 - 1 +13:49:46.911 [http-nio-8080-exec-2] INFO c.w.w.w.WebSocketUsers - [sendMessageToUserByText,111] - +[你已离线] +13:50:13.087 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +13:50:13.223 [SpringApplicationShutdownHook] INFO c.w.w.w.WebSocketServer - [onClose,59] - + 关闭连接 - org.apache.tomcat.websocket.WsSession@4f84cf98 +13:50:13.223 [SpringApplicationShutdownHook] INFO c.w.w.w.WebSocketUsers - [remove,65] - + 正在移出用户 - 0 +13:50:13.223 [SpringApplicationShutdownHook] INFO c.w.w.w.WebSocketUsers - [remove,69] - + 移出结果 - 成功 +13:50:13.235 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +13:50:13.235 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +13:50:13.235 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +13:50:13.238 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +13:50:13.241 [SpringApplicationShutdownHook] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +13:50:13.243 [SpringApplicationShutdownHook] INFO c.a.d.p.DruidDataSource - [close,2105] - {dataSource-1} closing ... +13:50:13.252 [SpringApplicationShutdownHook] INFO c.a.d.p.DruidDataSource - [close,2178] - {dataSource-1} closed +13:50:17.109 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +13:50:17.110 [restartedMain] INFO c.w.w.WinApplication - [logStarting,55] - Starting WinApplication using Java 1.8.0_231 on LAPTOP-K8GOQEG9 with PID 46220 (D:\workspace\wenyin\win\win-admin\target\classes started by admin in D:\workspace\wenyin\win) +13:50:17.111 [restartedMain] INFO c.w.w.WinApplication - [logStartupProfileInfo,686] - The following 3 profiles are active: "druid", "mybatis", "dev" +13:50:19.683 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-8080"] +13:50:19.683 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +13:50:19.684 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +13:50:19.734 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +13:50:21.017 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,985] - {dataSource-1,ccwin} inited +13:50:21.018 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [ccwin] success +13:50:21.020 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +13:50:21.020 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [ccwin] +13:50:25.727 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +13:50:25.775 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +13:50:25.775 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +13:50:25.776 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +13:50:25.777 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +13:50:25.777 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +13:50:25.777 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +13:50:25.778 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@5dafcaaa +13:50:26.012 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Starting ProtocolHandler ["http-nio-8080"] +13:50:26.172 [restartedMain] INFO o.q.c.QuartzScheduler - [start,547] - Scheduler quartzScheduler_$_NON_CLUSTERED started. +13:50:26.181 [restartedMain] INFO c.w.w.WinApplication - [logStarted,61] - Started WinApplication in 9.514 seconds (JVM running for 9.955) +13:50:30.529 [http-nio-8080-exec-3] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring DispatcherServlet 'dispatcherServlet' +13:50:30.597 [http-nio-8080-exec-3] INFO c.w.w.w.WebSocketServer - [onOpen,48] - + 建立连接 - org.apache.tomcat.websocket.WsSession@7831e2b5 +13:50:30.597 [http-nio-8080-exec-3] INFO c.w.w.w.WebSocketServer - [onOpen,49] - + 当前人数 - 1 +13:50:51.187 [http-nio-8080-exec-5] INFO c.w.w.w.WebSocketServer - [onOpen,48] - + 建立连接 - org.apache.tomcat.websocket.WsSession@25cbc6f2 +13:50:51.188 [http-nio-8080-exec-5] INFO c.w.w.w.WebSocketServer - [onOpen,49] - + 当前人数 - 2 +13:51:29.182 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +13:51:29.317 [SpringApplicationShutdownHook] INFO c.w.w.w.WebSocketServer - [onClose,59] - + 关闭连接 - org.apache.tomcat.websocket.WsSession@7831e2b5 +13:51:29.317 [SpringApplicationShutdownHook] INFO c.w.w.w.WebSocketUsers - [remove,65] - + 正在移出用户 - 0 +13:51:29.317 [SpringApplicationShutdownHook] INFO c.w.w.w.WebSocketUsers - [remove,69] - + 移出结果 - 成功 +13:51:29.318 [SpringApplicationShutdownHook] INFO c.w.w.w.WebSocketServer - [onClose,59] - + 关闭连接 - org.apache.tomcat.websocket.WsSession@25cbc6f2 +13:51:29.318 [SpringApplicationShutdownHook] INFO c.w.w.w.WebSocketUsers - [remove,65] - + 正在移出用户 - 1 +13:51:29.318 [SpringApplicationShutdownHook] INFO c.w.w.w.WebSocketUsers - [remove,69] - + 移出结果 - 成功 +13:51:29.329 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +13:51:29.329 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +13:51:29.330 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +13:51:29.333 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +13:51:29.336 [SpringApplicationShutdownHook] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +13:51:29.338 [SpringApplicationShutdownHook] INFO c.a.d.p.DruidDataSource - [close,2105] - {dataSource-1} closing ... +13:51:29.340 [SpringApplicationShutdownHook] INFO c.a.d.p.DruidDataSource - [close,2178] - {dataSource-1} closed +13:51:33.492 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +13:51:33.494 [restartedMain] INFO c.w.w.WinApplication - [logStarting,55] - Starting WinApplication using Java 1.8.0_231 on LAPTOP-K8GOQEG9 with PID 33312 (D:\workspace\wenyin\win\win-admin\target\classes started by admin in D:\workspace\wenyin\win) +13:51:33.495 [restartedMain] INFO c.w.w.WinApplication - [logStartupProfileInfo,686] - The following 3 profiles are active: "druid", "mybatis", "dev" +13:51:36.215 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-8080"] +13:51:36.216 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +13:51:36.217 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +13:51:36.278 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +13:51:37.812 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,985] - {dataSource-1,ccwin} inited +13:51:37.815 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [ccwin] success +13:51:37.818 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +13:51:37.818 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [ccwin] +13:51:43.199 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +13:51:43.212 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +13:51:43.212 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +13:51:43.213 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +13:51:43.214 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +13:51:43.214 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +13:51:43.214 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +13:51:43.214 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@1a92a7e5 +13:51:43.457 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Starting ProtocolHandler ["http-nio-8080"] +13:51:43.662 [http-nio-8080-exec-1] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring DispatcherServlet 'dispatcherServlet' +13:51:43.677 [restartedMain] INFO o.q.c.QuartzScheduler - [start,547] - Scheduler quartzScheduler_$_NON_CLUSTERED started. +13:51:43.686 [restartedMain] INFO c.w.w.WinApplication - [logStarted,61] - Started WinApplication in 10.689 seconds (JVM running for 11.219) +13:51:43.744 [http-nio-8080-exec-1] INFO c.w.w.w.WebSocketServer - [onOpen,48] - + 建立连接 - org.apache.tomcat.websocket.WsSession@5afd1a9e +13:51:43.745 [http-nio-8080-exec-1] INFO c.w.w.w.WebSocketServer - [onOpen,49] - + 当前人数 - 1 +13:51:43.754 [http-nio-8080-exec-2] INFO c.w.w.w.WebSocketServer - [onOpen,48] - + 建立连接 - org.apache.tomcat.websocket.WsSession@6ef32aae +13:51:43.755 [http-nio-8080-exec-2] INFO c.w.w.w.WebSocketServer - [onOpen,49] - + 当前人数 - 2 +13:51:46.228 [http-nio-8080-exec-6] INFO c.w.w.w.WebSocketServer - [onOpen,48] - + 建立连接 - org.apache.tomcat.websocket.WsSession@7730f85d +13:51:46.228 [http-nio-8080-exec-6] INFO c.w.w.w.WebSocketServer - [onOpen,49] - + 当前人数 - 3 +14:01:13.717 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +14:01:13.852 [SpringApplicationShutdownHook] INFO c.w.w.w.WebSocketServer - [onClose,59] - + 关闭连接 - org.apache.tomcat.websocket.WsSession@5afd1a9e +14:01:13.852 [SpringApplicationShutdownHook] INFO c.w.w.w.WebSocketUsers - [remove,65] - + 正在移出用户 - 0 +14:01:13.853 [SpringApplicationShutdownHook] INFO c.w.w.w.WebSocketUsers - [remove,69] - + 移出结果 - 成功 +14:01:13.853 [SpringApplicationShutdownHook] INFO c.w.w.w.WebSocketServer - [onClose,59] - + 关闭连接 - org.apache.tomcat.websocket.WsSession@6ef32aae +14:01:13.853 [SpringApplicationShutdownHook] INFO c.w.w.w.WebSocketUsers - [remove,65] - + 正在移出用户 - 1 +14:01:13.854 [SpringApplicationShutdownHook] INFO c.w.w.w.WebSocketUsers - [remove,69] - + 移出结果 - 成功 +14:01:13.854 [SpringApplicationShutdownHook] INFO c.w.w.w.WebSocketServer - [onClose,59] - + 关闭连接 - org.apache.tomcat.websocket.WsSession@7730f85d +14:01:13.854 [SpringApplicationShutdownHook] INFO c.w.w.w.WebSocketUsers - [remove,65] - + 正在移出用户 - 2 +14:01:13.854 [SpringApplicationShutdownHook] INFO c.w.w.w.WebSocketUsers - [remove,69] - + 移出结果 - 成功 +14:01:13.865 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +14:01:13.865 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +14:01:13.865 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +14:01:13.869 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +14:01:13.873 [SpringApplicationShutdownHook] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +14:01:13.874 [SpringApplicationShutdownHook] INFO c.a.d.p.DruidDataSource - [close,2105] - {dataSource-1} closing ... +14:01:13.877 [SpringApplicationShutdownHook] INFO c.a.d.p.DruidDataSource - [close,2178] - {dataSource-1} closed +14:01:17.803 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +14:01:17.804 [restartedMain] INFO c.w.w.WinApplication - [logStarting,55] - Starting WinApplication using Java 1.8.0_231 on LAPTOP-K8GOQEG9 with PID 38592 (D:\workspace\wenyin\win\win-admin\target\classes started by admin in D:\workspace\wenyin\win) +14:01:17.805 [restartedMain] INFO c.w.w.WinApplication - [logStartupProfileInfo,686] - The following 3 profiles are active: "druid", "mybatis", "dev" +14:01:20.402 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-8080"] +14:01:20.403 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +14:01:20.403 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +14:01:20.449 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +14:01:21.696 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,985] - {dataSource-1,ccwin} inited +14:01:21.698 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [ccwin] success +14:01:21.700 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +14:01:21.700 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [ccwin] +14:01:26.820 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +14:01:26.836 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +14:01:26.837 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +14:01:26.837 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +14:01:26.838 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +14:01:26.838 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +14:01:26.838 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +14:01:26.839 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@7fcbd2be +14:01:27.176 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Starting ProtocolHandler ["http-nio-8080"] +14:01:27.449 [restartedMain] INFO o.q.c.QuartzScheduler - [start,547] - Scheduler quartzScheduler_$_NON_CLUSTERED started. +14:01:27.460 [restartedMain] INFO c.w.w.WinApplication - [logStarted,61] - Started WinApplication in 10.131 seconds (JVM running for 10.591) +14:04:32.731 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +14:04:32.890 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +14:04:32.891 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +14:04:32.891 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +14:04:32.894 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +14:04:32.897 [SpringApplicationShutdownHook] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +14:04:32.898 [SpringApplicationShutdownHook] INFO c.a.d.p.DruidDataSource - [close,2105] - {dataSource-1} closing ... +14:04:32.901 [SpringApplicationShutdownHook] INFO c.a.d.p.DruidDataSource - [close,2178] - {dataSource-1} closed +14:04:36.988 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +14:04:36.989 [restartedMain] INFO c.w.w.WinApplication - [logStarting,55] - Starting WinApplication using Java 1.8.0_231 on LAPTOP-K8GOQEG9 with PID 50796 (D:\workspace\wenyin\win\win-admin\target\classes started by admin in D:\workspace\wenyin\win) +14:04:36.990 [restartedMain] INFO c.w.w.WinApplication - [logStartupProfileInfo,686] - The following 3 profiles are active: "druid", "mybatis", "dev" +14:04:39.525 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-8080"] +14:04:39.525 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +14:04:39.526 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +14:04:39.568 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +14:04:40.751 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,985] - {dataSource-1,ccwin} inited +14:04:40.754 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [ccwin] success +14:04:40.757 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +14:04:40.758 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [ccwin] +14:04:45.686 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +14:04:45.699 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +14:04:45.700 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +14:04:45.701 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +14:04:45.705 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +14:04:45.706 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +14:04:45.706 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +14:04:45.706 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@167dbdb1 +14:04:45.982 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Stopping service [Tomcat] +14:04:46.009 [restartedMain] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +14:04:46.009 [restartedMain] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +14:04:46.010 [restartedMain] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +14:04:46.013 [restartedMain] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +14:04:46.016 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +14:04:46.018 [restartedMain] INFO c.a.d.p.DruidDataSource - [close,2105] - {dataSource-1} closing ... +14:04:46.020 [restartedMain] INFO c.a.d.p.DruidDataSource - [close,2178] - {dataSource-1} closed +14:04:57.705 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +14:04:57.706 [restartedMain] INFO c.w.w.WinApplication - [logStarting,55] - Starting WinApplication using Java 1.8.0_231 on LAPTOP-K8GOQEG9 with PID 50620 (D:\workspace\wenyin\win\win-admin\target\classes started by admin in D:\workspace\wenyin\win) +14:04:57.706 [restartedMain] INFO c.w.w.WinApplication - [logStartupProfileInfo,686] - The following 3 profiles are active: "druid", "mybatis", "dev" +14:05:00.326 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-8080"] +14:05:00.326 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +14:05:00.327 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +14:05:00.371 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +14:05:01.661 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,985] - {dataSource-1,ccwin} inited +14:05:01.664 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [ccwin] success +14:05:01.667 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +14:05:01.667 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [ccwin] +14:05:07.024 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +14:05:07.038 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +14:05:07.038 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +14:05:07.040 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +14:05:07.042 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +14:05:07.042 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +14:05:07.042 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +14:05:07.042 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@12c1c2ab +14:05:07.508 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Stopping service [Tomcat] +14:05:07.534 [restartedMain] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +14:05:07.534 [restartedMain] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +14:05:07.536 [restartedMain] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +14:05:07.539 [restartedMain] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +14:05:07.542 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +14:05:07.544 [restartedMain] INFO c.a.d.p.DruidDataSource - [close,2105] - {dataSource-1} closing ... +14:05:07.546 [restartedMain] INFO c.a.d.p.DruidDataSource - [close,2178] - {dataSource-1} closed +14:05:47.818 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +14:05:47.820 [restartedMain] INFO c.w.w.WinApplication - [logStarting,55] - Starting WinApplication using Java 1.8.0_231 on LAPTOP-K8GOQEG9 with PID 51104 (D:\workspace\wenyin\win\win-admin\target\classes started by admin in D:\workspace\wenyin\win) +14:05:47.821 [restartedMain] INFO c.w.w.WinApplication - [logStartupProfileInfo,686] - The following 3 profiles are active: "druid", "mybatis", "dev" +14:05:50.543 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-8080"] +14:05:50.544 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +14:05:50.544 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +14:05:50.590 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +14:05:51.750 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,985] - {dataSource-1,ccwin} inited +14:05:51.753 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [ccwin] success +14:05:51.755 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +14:05:51.755 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [ccwin] +14:05:56.661 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +14:05:56.679 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +14:05:56.680 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +14:05:56.681 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +14:05:56.682 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +14:05:56.682 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +14:05:56.682 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +14:05:56.684 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@c290c24 +14:05:56.940 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Stopping service [Tomcat] +14:05:56.969 [restartedMain] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +14:05:56.970 [restartedMain] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +14:05:56.970 [restartedMain] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +14:05:56.973 [restartedMain] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +14:05:56.976 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +14:05:56.978 [restartedMain] INFO c.a.d.p.DruidDataSource - [close,2105] - {dataSource-1} closing ... +14:05:56.982 [restartedMain] INFO c.a.d.p.DruidDataSource - [close,2178] - {dataSource-1} closed +14:08:58.368 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +14:08:58.370 [restartedMain] INFO c.w.w.WinApplication - [logStarting,55] - Starting WinApplication using Java 1.8.0_231 on LAPTOP-K8GOQEG9 with PID 10216 (D:\workspace\wenyin\win\win-admin\target\classes started by admin in D:\workspace\wenyin\win) +14:08:58.371 [restartedMain] INFO c.w.w.WinApplication - [logStartupProfileInfo,686] - The following 3 profiles are active: "druid", "mybatis", "dev" +14:09:01.083 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-8080"] +14:09:01.084 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +14:09:01.084 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +14:09:01.139 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +14:09:02.308 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,985] - {dataSource-1,ccwin} inited +14:09:02.315 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [ccwin] success +14:09:02.319 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +14:09:02.320 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [ccwin] +14:09:07.296 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +14:09:07.309 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +14:09:07.310 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +14:09:07.311 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +14:09:07.312 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +14:09:07.313 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +14:09:07.313 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +14:09:07.313 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@111b5923 +14:09:07.568 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Stopping service [Tomcat] +14:09:07.598 [restartedMain] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +14:09:07.598 [restartedMain] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +14:09:07.599 [restartedMain] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +14:09:07.602 [restartedMain] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +14:09:07.606 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +14:09:07.608 [restartedMain] INFO c.a.d.p.DruidDataSource - [close,2105] - {dataSource-1} closing ... +14:09:07.610 [restartedMain] INFO c.a.d.p.DruidDataSource - [close,2178] - {dataSource-1} closed +14:09:27.869 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +14:09:27.870 [restartedMain] INFO c.w.w.WinApplication - [logStarting,55] - Starting WinApplication using Java 1.8.0_231 on LAPTOP-K8GOQEG9 with PID 17692 (D:\workspace\wenyin\win\win-admin\target\classes started by admin in D:\workspace\wenyin\win) +14:09:27.871 [restartedMain] INFO c.w.w.WinApplication - [logStartupProfileInfo,686] - The following 3 profiles are active: "druid", "mybatis", "dev" +14:09:30.465 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-8080"] +14:09:30.466 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +14:09:30.466 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +14:09:30.513 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +14:09:31.844 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,985] - {dataSource-1,ccwin} inited +14:09:31.847 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [ccwin] success +14:09:31.849 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +14:09:31.849 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [ccwin] +14:09:36.781 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +14:09:36.792 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +14:09:36.792 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +14:09:36.793 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +14:09:36.794 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +14:09:36.794 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +14:09:36.794 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +14:09:36.794 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@38c446c +14:09:37.036 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Starting ProtocolHandler ["http-nio-8080"] +14:09:37.261 [restartedMain] INFO o.q.c.QuartzScheduler - [start,547] - Scheduler quartzScheduler_$_NON_CLUSTERED started. +14:09:37.271 [restartedMain] INFO c.w.w.WinApplication - [logStarted,61] - Started WinApplication in 9.846 seconds (JVM running for 10.287) +14:09:43.899 [http-nio-8080-exec-2] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring DispatcherServlet 'dispatcherServlet' +14:10:46.353 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +14:10:46.502 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +14:10:46.502 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +14:10:46.502 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +14:10:46.506 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +14:10:46.509 [SpringApplicationShutdownHook] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +14:10:46.511 [SpringApplicationShutdownHook] INFO c.a.d.p.DruidDataSource - [close,2105] - {dataSource-1} closing ... +14:10:46.514 [SpringApplicationShutdownHook] INFO c.a.d.p.DruidDataSource - [close,2178] - {dataSource-1} closed +14:10:50.637 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +14:10:50.641 [restartedMain] INFO c.w.w.WinApplication - [logStarting,55] - Starting WinApplication using Java 1.8.0_231 on LAPTOP-K8GOQEG9 with PID 52072 (D:\workspace\wenyin\win\win-admin\target\classes started by admin in D:\workspace\wenyin\win) +14:10:50.642 [restartedMain] INFO c.w.w.WinApplication - [logStartupProfileInfo,686] - The following 3 profiles are active: "druid", "mybatis", "dev" +14:10:53.400 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-8080"] +14:10:53.401 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +14:10:53.401 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +14:10:53.445 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +14:10:54.736 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,985] - {dataSource-1,ccwin} inited +14:10:54.739 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [ccwin] success +14:10:54.743 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +14:10:54.744 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [ccwin] +14:10:59.613 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +14:10:59.627 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +14:10:59.627 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +14:10:59.629 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +14:10:59.630 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +14:10:59.630 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +14:10:59.630 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +14:10:59.631 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@3f86eb63 +14:10:59.900 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Starting ProtocolHandler ["http-nio-8080"] +14:11:00.181 [restartedMain] INFO o.q.c.QuartzScheduler - [start,547] - Scheduler quartzScheduler_$_NON_CLUSTERED started. +14:11:00.190 [restartedMain] INFO c.w.w.WinApplication - [logStarted,61] - Started WinApplication in 10.041 seconds (JVM running for 10.468) +14:11:04.967 [http-nio-8080-exec-2] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring DispatcherServlet 'dispatcherServlet' +14:11:05.033 [http-nio-8080-exec-2] INFO c.w.w.w.WebSocketServer - [onOpen,33] - sessionId - shebei1 +14:11:05.034 [http-nio-8080-exec-2] INFO c.w.w.w.WebSocketServer - [onOpen,45] - + 建立连接 - org.apache.tomcat.websocket.WsSession@168915f1 +14:11:05.034 [http-nio-8080-exec-2] INFO c.w.w.w.WebSocketServer - [onOpen,46] - + 当前人数 - 1 +14:11:08.042 [http-nio-8080-exec-1] INFO c.w.w.w.WebSocketServer - [onOpen,33] - sessionId - shebei1 +14:11:08.042 [http-nio-8080-exec-1] INFO c.w.w.w.WebSocketServer - [onOpen,45] - + 建立连接 - org.apache.tomcat.websocket.WsSession@42d3c89f +14:11:08.042 [http-nio-8080-exec-1] INFO c.w.w.w.WebSocketServer - [onOpen,46] - + 当前人数 - 2 +14:11:11.679 [http-nio-8080-exec-3] INFO c.w.w.w.WebSocketServer - [onMessage,86] - sessionId - shebei1 +14:12:49.216 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +14:12:49.356 [SpringApplicationShutdownHook] INFO c.w.w.w.WebSocketServer - [onClose,56] - + 关闭连接 - org.apache.tomcat.websocket.WsSession@168915f1 +14:12:49.357 [SpringApplicationShutdownHook] INFO c.w.w.w.WebSocketUsers - [remove,65] - + 正在移出用户 - 0 +14:12:49.357 [SpringApplicationShutdownHook] INFO c.w.w.w.WebSocketUsers - [remove,69] - + 移出结果 - 成功 +14:12:49.358 [SpringApplicationShutdownHook] INFO c.w.w.w.WebSocketServer - [onClose,56] - + 关闭连接 - org.apache.tomcat.websocket.WsSession@42d3c89f +14:12:49.358 [SpringApplicationShutdownHook] INFO c.w.w.w.WebSocketUsers - [remove,65] - + 正在移出用户 - 1 +14:12:49.358 [SpringApplicationShutdownHook] INFO c.w.w.w.WebSocketUsers - [remove,69] - + 移出结果 - 成功 +14:12:49.368 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +14:12:49.368 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +14:12:49.368 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +14:12:49.372 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +14:12:49.375 [SpringApplicationShutdownHook] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +14:12:49.377 [SpringApplicationShutdownHook] INFO c.a.d.p.DruidDataSource - [close,2105] - {dataSource-1} closing ... +14:12:49.379 [SpringApplicationShutdownHook] INFO c.a.d.p.DruidDataSource - [close,2178] - {dataSource-1} closed +14:12:53.337 [restartedMain] INFO c.w.w.WinApplication - [logStarting,55] - Starting WinApplication using Java 1.8.0_231 on LAPTOP-K8GOQEG9 with PID 44704 (D:\workspace\wenyin\win\win-admin\target\classes started by admin in D:\workspace\wenyin\win) +14:12:53.338 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +14:12:53.338 [restartedMain] INFO c.w.w.WinApplication - [logStartupProfileInfo,686] - The following 3 profiles are active: "druid", "mybatis", "dev" +14:12:56.042 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-8080"] +14:12:56.043 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +14:12:56.044 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +14:12:56.099 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +14:12:57.400 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,985] - {dataSource-1,ccwin} inited +14:12:57.405 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [ccwin] success +14:12:57.408 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +14:12:57.408 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [ccwin] +14:13:02.441 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +14:13:02.458 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +14:13:02.458 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +14:13:02.459 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +14:13:02.460 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +14:13:02.460 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +14:13:02.460 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +14:13:02.461 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@36a5931a +14:13:02.923 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Starting ProtocolHandler ["http-nio-8080"] +14:13:03.197 [restartedMain] INFO o.q.c.QuartzScheduler - [start,547] - Scheduler quartzScheduler_$_NON_CLUSTERED started. +14:13:03.205 [restartedMain] INFO c.w.w.WinApplication - [logStarted,61] - Started WinApplication in 10.327 seconds (JVM running for 10.794) +14:13:06.909 [http-nio-8080-exec-1] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring DispatcherServlet 'dispatcherServlet' +14:13:06.970 [http-nio-8080-exec-1] INFO c.w.w.w.WebSocketServer - [onOpen,33] - sessionId - shebei1 +14:13:06.971 [http-nio-8080-exec-1] INFO c.w.w.w.WebSocketServer - [onOpen,45] - + 建立连接 - org.apache.tomcat.websocket.WsSession@6d0af53b +14:13:06.971 [http-nio-8080-exec-1] INFO c.w.w.w.WebSocketServer - [onOpen,46] - + 当前人数 - 1 +14:13:08.964 [http-nio-8080-exec-2] INFO c.w.w.w.WebSocketServer - [onOpen,33] - sessionId - shebei1 +14:13:08.964 [http-nio-8080-exec-2] INFO c.w.w.w.WebSocketServer - [onOpen,45] - + 建立连接 - org.apache.tomcat.websocket.WsSession@5bec9ae0 +14:13:08.964 [http-nio-8080-exec-2] INFO c.w.w.w.WebSocketServer - [onOpen,46] - + 当前人数 - 1 +14:13:11.586 [http-nio-8080-exec-3] INFO c.w.w.w.WebSocketServer - [onMessage,86] - sessionId - shebei1 +14:13:14.976 [http-nio-8080-exec-4] INFO c.w.w.w.WebSocketServer - [onMessage,86] - sessionId - shebei1 +14:13:15.745 [http-nio-8080-exec-5] INFO c.w.w.w.WebSocketServer - [onMessage,86] - sessionId - shebei1 +14:13:17.233 [http-nio-8080-exec-6] INFO c.w.w.w.WebSocketServer - [onMessage,86] - sessionId - shebei1 +14:13:17.776 [http-nio-8080-exec-8] INFO c.w.w.w.WebSocketServer - [onMessage,86] - sessionId - shebei1 +14:13:24.920 [http-nio-8080-exec-9] INFO c.w.w.w.WebSocketServer - [onMessage,86] - sessionId - shebei1 +14:14:37.646 [http-nio-8080-exec-25] INFO c.w.w.w.WebSocketServer - [onOpen,33] - sessionId - shebei1 +14:14:37.646 [http-nio-8080-exec-25] INFO c.w.w.w.WebSocketServer - [onOpen,45] - + 建立连接 - org.apache.tomcat.websocket.WsSession@751dc741 +14:14:37.646 [http-nio-8080-exec-25] INFO c.w.w.w.WebSocketServer - [onOpen,46] - + 当前人数 - 1 +14:14:40.226 [http-nio-8080-exec-22] INFO c.w.w.w.WebSocketServer - [onMessage,86] - sessionId - shebei1 +14:53:01.452 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +14:53:01.594 [SpringApplicationShutdownHook] INFO c.w.w.w.WebSocketServer - [onClose,56] - + 关闭连接 - org.apache.tomcat.websocket.WsSession@6d0af53b +14:53:01.595 [SpringApplicationShutdownHook] INFO c.w.w.w.WebSocketUsers - [remove,65] - + 正在移出用户 - 0 +14:53:01.595 [SpringApplicationShutdownHook] INFO c.w.w.w.WebSocketServer - [onClose,56] - + 关闭连接 - org.apache.tomcat.websocket.WsSession@5bec9ae0 +14:53:01.596 [SpringApplicationShutdownHook] INFO c.w.w.w.WebSocketUsers - [remove,65] - + 正在移出用户 - 1 +14:53:01.596 [SpringApplicationShutdownHook] INFO c.w.w.w.WebSocketServer - [onClose,56] - + 关闭连接 - org.apache.tomcat.websocket.WsSession@751dc741 +14:53:01.597 [SpringApplicationShutdownHook] INFO c.w.w.w.WebSocketUsers - [remove,65] - + 正在移出用户 - 2 +14:53:01.609 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +14:53:01.609 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +14:53:01.610 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +14:53:01.614 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +14:53:01.617 [SpringApplicationShutdownHook] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +14:53:01.618 [SpringApplicationShutdownHook] INFO c.a.d.p.DruidDataSource - [close,2105] - {dataSource-1} closing ... +14:53:01.619 [SpringApplicationShutdownHook] INFO c.a.d.p.DruidDataSource - [close,2178] - {dataSource-1} closed diff --git a/logs/sys-info.2023-07-20.log b/logs/sys-info.2023-07-20.log new file mode 100644 index 0000000..ca66349 --- /dev/null +++ b/logs/sys-info.2023-07-20.log @@ -0,0 +1,821 @@ +10:01:44.292 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +10:01:44.295 [restartedMain] INFO c.w.w.WinApplication - [logStarting,55] - Starting WinApplication using Java 1.8.0_231 on LAPTOP-K8GOQEG9 with PID 34284 (D:\workspace\wenyin\win\win-admin\target\classes started by admin in D:\workspace\wenyin\win) +10:01:44.307 [restartedMain] INFO c.w.w.WinApplication - [logStartupProfileInfo,686] - The following 3 profiles are active: "druid", "mybatis", "dev" +10:01:48.499 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-8080"] +10:01:48.502 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +10:01:48.504 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +10:01:48.591 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +10:01:51.330 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,985] - {dataSource-1,ccwin} inited +10:01:51.333 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [ccwin] success +10:01:51.337 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +10:01:51.337 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [ccwin] +10:01:59.529 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +10:01:59.547 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +10:01:59.548 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +10:01:59.552 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +10:01:59.555 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +10:01:59.556 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +10:01:59.556 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +10:01:59.556 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@3b27ad0a +10:01:59.941 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Starting ProtocolHandler ["http-nio-8080"] +10:02:00.207 [restartedMain] INFO o.q.c.QuartzScheduler - [start,547] - Scheduler quartzScheduler_$_NON_CLUSTERED started. +10:02:00.214 [restartedMain] INFO c.w.w.WinApplication - [logStarted,61] - Started WinApplication in 16.5 seconds (JVM running for 17.043) +10:02:23.853 [http-nio-8080-exec-1] INFO o.a.t.u.h.p.Cookie - [log,173] - A cookie header was received [Hm_lvt_931a8de1263e8fcdea855e1b3c00abff=1687155670,1687337520;] that contained an invalid cookie. That cookie will be ignored. + Note: further occurrences of this error will be logged at DEBUG level. +10:02:24.059 [http-nio-8080-exec-9] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring DispatcherServlet 'dispatcherServlet' +10:06:32.365 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +10:06:32.538 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +10:06:32.538 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +10:06:32.538 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +10:06:32.541 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +10:06:32.546 [SpringApplicationShutdownHook] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +10:06:32.548 [SpringApplicationShutdownHook] INFO c.a.d.p.DruidDataSource - [close,2105] - {dataSource-1} closing ... +10:06:32.551 [SpringApplicationShutdownHook] INFO c.a.d.p.DruidDataSource - [close,2178] - {dataSource-1} closed +11:38:26.509 [restartedMain] INFO c.w.w.WinApplication - [logStarting,55] - Starting WinApplication using Java 1.8.0_231 on LAPTOP-K8GOQEG9 with PID 53120 (D:\workspace\wenyin\win\win-admin\target\classes started by admin in D:\workspace\wenyin\win) +11:38:26.508 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +11:38:26.510 [restartedMain] INFO c.w.w.WinApplication - [logStartupProfileInfo,686] - The following 3 profiles are active: "druid", "mybatis", "dev" +11:38:29.328 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-8080"] +11:38:29.329 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +11:38:29.330 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +11:38:29.381 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +11:38:30.647 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,985] - {dataSource-1,ccwin} inited +11:38:30.649 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [ccwin] success +11:38:30.651 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +11:38:30.652 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [ccwin] +11:38:30.967 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +11:38:30.972 [restartedMain] INFO c.a.d.p.DruidDataSource - [close,2105] - {dataSource-1} closing ... +11:38:30.973 [restartedMain] INFO c.a.d.p.DruidDataSource - [close,2178] - {dataSource-1} closed +11:38:31.000 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Stopping service [Tomcat] +12:40:36.502 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +12:40:36.504 [restartedMain] INFO c.w.w.WinApplication - [logStarting,55] - Starting WinApplication using Java 1.8.0_231 on LAPTOP-K8GOQEG9 with PID 39896 (D:\workspace\wenyin\win\win-admin\target\classes started by admin in D:\workspace\wenyin\win) +12:40:36.505 [restartedMain] INFO c.w.w.WinApplication - [logStartupProfileInfo,686] - The following 3 profiles are active: "druid", "mybatis", "dev" +12:40:39.381 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-8080"] +12:40:39.381 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +12:40:39.382 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +12:40:39.428 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +12:40:40.840 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,985] - {dataSource-1,ccwin} inited +12:40:40.844 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [ccwin] success +12:40:40.848 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +12:40:40.849 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [ccwin] +12:40:41.177 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +12:40:41.182 [restartedMain] INFO c.a.d.p.DruidDataSource - [close,2105] - {dataSource-1} closing ... +12:40:41.183 [restartedMain] INFO c.a.d.p.DruidDataSource - [close,2178] - {dataSource-1} closed +12:40:41.210 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Stopping service [Tomcat] +12:41:23.758 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +12:41:23.759 [restartedMain] INFO c.w.w.WinApplication - [logStarting,55] - Starting WinApplication using Java 1.8.0_231 on LAPTOP-K8GOQEG9 with PID 37564 (D:\workspace\wenyin\win\win-admin\target\classes started by admin in D:\workspace\wenyin\win) +12:41:23.759 [restartedMain] INFO c.w.w.WinApplication - [logStartupProfileInfo,686] - The following 3 profiles are active: "druid", "mybatis", "dev" +12:41:26.683 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-8080"] +12:41:26.684 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +12:41:26.684 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +12:41:26.734 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +12:41:28.274 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,985] - {dataSource-1,ccwin} inited +12:41:28.276 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [ccwin] success +12:41:28.278 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +12:41:28.278 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [ccwin] +12:41:34.651 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +12:41:34.666 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +12:41:34.666 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +12:41:34.667 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +12:41:34.668 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +12:41:34.668 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +12:41:34.669 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +12:41:34.669 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@7bb382b9 +12:41:34.937 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Starting ProtocolHandler ["http-nio-8080"] +12:41:35.129 [restartedMain] INFO o.q.c.QuartzScheduler - [start,547] - Scheduler quartzScheduler_$_NON_CLUSTERED started. +12:41:35.136 [restartedMain] INFO c.w.w.WinApplication - [logStarted,61] - Started WinApplication in 11.861 seconds (JVM running for 12.282) +12:42:57.467 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +12:42:57.631 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +12:42:57.631 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +12:42:57.632 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +12:42:57.635 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +12:42:57.638 [SpringApplicationShutdownHook] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +12:42:57.640 [SpringApplicationShutdownHook] INFO c.a.d.p.DruidDataSource - [close,2105] - {dataSource-1} closing ... +12:42:57.643 [SpringApplicationShutdownHook] INFO c.a.d.p.DruidDataSource - [close,2178] - {dataSource-1} closed +12:43:04.297 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +12:43:04.297 [restartedMain] INFO c.w.w.WinApplication - [logStarting,55] - Starting WinApplication using Java 1.8.0_231 on LAPTOP-K8GOQEG9 with PID 43848 (D:\workspace\wenyin\win\win-admin\target\classes started by admin in D:\workspace\wenyin\win) +12:43:04.298 [restartedMain] INFO c.w.w.WinApplication - [logStartupProfileInfo,686] - The following 3 profiles are active: "druid", "mybatis", "dev" +12:43:07.201 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-8080"] +12:43:07.202 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +12:43:07.202 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +12:43:07.261 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +12:43:08.632 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,985] - {dataSource-1,ccwin} inited +12:43:08.636 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [ccwin] success +12:43:08.639 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +12:43:08.640 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [ccwin] +12:43:14.758 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +12:43:14.772 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +12:43:14.773 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +12:43:14.774 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +12:43:14.775 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +12:43:14.775 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +12:43:14.775 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +12:43:14.775 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@1027dbcb +12:43:15.044 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Starting ProtocolHandler ["http-nio-8080"] +12:43:15.237 [restartedMain] INFO o.q.c.QuartzScheduler - [start,547] - Scheduler quartzScheduler_$_NON_CLUSTERED started. +12:43:15.245 [restartedMain] INFO c.w.w.WinApplication - [logStarted,61] - Started WinApplication in 11.411 seconds (JVM running for 11.879) +12:44:59.934 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +12:45:00.097 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +12:45:00.097 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +12:45:00.097 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +12:45:00.101 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +12:45:00.106 [SpringApplicationShutdownHook] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +12:45:00.108 [SpringApplicationShutdownHook] INFO c.a.d.p.DruidDataSource - [close,2105] - {dataSource-1} closing ... +12:45:00.111 [SpringApplicationShutdownHook] INFO c.a.d.p.DruidDataSource - [close,2178] - {dataSource-1} closed +12:45:47.138 [restartedMain] INFO c.w.w.WinApplication - [logStarting,55] - Starting WinApplication using Java 1.8.0_231 on LAPTOP-K8GOQEG9 with PID 50288 (D:\workspace\wenyin\win\win-admin\target\classes started by admin in D:\workspace\wenyin\win) +12:45:47.138 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +12:45:47.139 [restartedMain] INFO c.w.w.WinApplication - [logStartupProfileInfo,686] - The following 3 profiles are active: "druid", "mybatis", "dev" +12:45:50.384 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-8080"] +12:45:50.385 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +12:45:50.385 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +12:45:50.446 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +12:45:52.097 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,985] - {dataSource-1,ccwin} inited +12:45:52.100 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [ccwin] success +12:45:52.102 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +12:45:52.103 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [ccwin] +12:45:56.039 [restartedMain] INFO o.f.s.b.ProcessEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +12:45:56.650 [restartedMain] INFO o.f.s.b.c.CmmnEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +12:45:56.801 [restartedMain] INFO o.f.s.b.d.DmnEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +12:45:56.858 [restartedMain] INFO o.f.s.b.f.FormEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +12:45:56.927 [restartedMain] INFO o.f.s.b.e.EventRegistryAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +12:45:56.981 [restartedMain] INFO o.f.s.b.a.AppEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +12:45:57.005 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1073] - Found 7 Engine Configurators in total: +12:45:57.005 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.engine.spring.configurator.SpringProcessEngineConfigurator (priority:50000) +12:45:57.006 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.eventregistry.spring.configurator.SpringEventRegistryConfigurator (priority:100000) +12:45:57.006 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.idm.spring.configurator.SpringIdmEngineConfigurator (priority:150000) +12:45:57.006 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.dmn.spring.configurator.SpringDmnEngineConfigurator (priority:200000) +12:45:57.006 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.form.spring.configurator.SpringFormEngineConfigurator (priority:300000) +12:45:57.006 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.content.spring.configurator.SpringContentEngineConfigurator (priority:400000) +12:45:57.006 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.cmmn.spring.configurator.SpringCmmnEngineConfigurator (priority:500000) +12:45:57.007 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.engine.spring.configurator.SpringProcessEngineConfigurator (priority:50000) +12:45:57.010 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.eventregistry.spring.configurator.SpringEventRegistryConfigurator (priority:100000) +12:45:57.014 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.idm.spring.configurator.SpringIdmEngineConfigurator (priority:150000) +12:45:57.015 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.dmn.spring.configurator.SpringDmnEngineConfigurator (priority:200000) +12:45:57.017 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.form.spring.configurator.SpringFormEngineConfigurator (priority:300000) +12:45:57.018 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.content.spring.configurator.SpringContentEngineConfigurator (priority:400000) +12:45:57.019 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.cmmn.spring.configurator.SpringCmmnEngineConfigurator (priority:500000) +12:45:57.824 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.engine.spring.configurator.SpringProcessEngineConfigurator (priority:50000) +12:45:58.469 [restartedMain] INFO o.f.e.i.ProcessEngineImpl - [<init>,89] - ProcessEngine default created +12:45:58.511 [restartedMain] INFO o.f.e.i.c.ValidateV5EntitiesCmd - [execute,43] - Total of v5 deployments found: 0 +12:45:58.618 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.eventregistry.spring.configurator.SpringEventRegistryConfigurator (priority:100000) +12:45:59.110 [restartedMain] INFO l.lockservice - [log,23] - Successfully acquired change log lock +12:45:59.688 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.FLW_EV_DATABASECHANGELOG +12:45:59.751 [restartedMain] INFO l.lockservice - [log,23] - Successfully released change log lock +12:45:59.765 [restartedMain] INFO o.f.e.i.EventRegistryEngineImpl - [<init>,53] - EventRegistryEngine default created +12:45:59.766 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.idm.spring.configurator.SpringIdmEngineConfigurator (priority:150000) +12:45:59.811 [restartedMain] INFO o.f.i.e.i.IdmEngineImpl - [<init>,52] - IdmEngine default created +12:45:59.812 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.dmn.spring.configurator.SpringDmnEngineConfigurator (priority:200000) +12:45:59.989 [restartedMain] INFO l.lockservice - [log,23] - Successfully acquired change log lock +12:46:00.079 [restartedMain] INFO liquibase.changelog - [log,23] - Creating database history table with name: ccwin.ACT_DMN_DATABASECHANGELOG +12:46:00.140 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_DMN_DATABASECHANGELOG +12:46:00.289 [restartedMain] INFO liquibase.changelog - [log,23] - Table ACT_DMN_DEPLOYMENT created +12:46:00.329 [restartedMain] INFO liquibase.changelog - [log,23] - Table ACT_DMN_DEPLOYMENT_RESOURCE created +12:46:00.370 [restartedMain] INFO liquibase.changelog - [log,23] - Table ACT_DMN_DECISION_TABLE created +12:46:00.380 [restartedMain] INFO liquibase.changelog - [log,23] - ChangeSet org/flowable/dmn/db/liquibase/flowable-dmn-db-changelog.xml::1::activiti ran successfully in 161ms +12:46:00.471 [restartedMain] INFO liquibase.changelog - [log,23] - Table ACT_DMN_HI_DECISION_EXECUTION created +12:46:00.479 [restartedMain] INFO liquibase.changelog - [log,23] - ChangeSet org/flowable/dmn/db/liquibase/flowable-dmn-db-changelog.xml::2::flowable ran successfully in 51ms +12:46:00.561 [restartedMain] INFO liquibase.changelog - [log,23] - Columns SCOPE_TYPE_(varchar(255)) added to ACT_DMN_HI_DECISION_EXECUTION +12:46:00.569 [restartedMain] INFO liquibase.changelog - [log,23] - ChangeSet org/flowable/dmn/db/liquibase/flowable-dmn-db-changelog.xml::3::flowable ran successfully in 40ms +12:46:00.670 [restartedMain] INFO liquibase.changelog - [log,23] - Column ACT_DMN_DECISION_TABLE.PARENT_DEPLOYMENT_ID_ dropped +12:46:00.681 [restartedMain] INFO liquibase.changelog - [log,23] - ChangeSet org/flowable/dmn/db/liquibase/flowable-dmn-db-changelog.xml::4::flowable ran successfully in 72ms +12:46:00.798 [restartedMain] INFO liquibase.changelog - [log,23] - ACT_DMN_DEPLOYMENT.DEPLOY_TIME_ datatype was changed to datetime(3) +12:46:00.869 [restartedMain] INFO liquibase.changelog - [log,23] - ACT_DMN_HI_DECISION_EXECUTION.START_TIME_ datatype was changed to datetime(3) +12:46:00.938 [restartedMain] INFO liquibase.changelog - [log,23] - ACT_DMN_HI_DECISION_EXECUTION.END_TIME_ datatype was changed to datetime(3) +12:46:00.942 [restartedMain] INFO liquibase.changelog - [log,23] - ChangeSet org/flowable/dmn/db/liquibase/flowable-dmn-db-changelog.xml::5::flowable ran successfully in 222ms +12:46:00.997 [restartedMain] INFO liquibase.changelog - [log,23] - Index ACT_IDX_DEC_TBL_UNIQ created +12:46:01.003 [restartedMain] INFO liquibase.changelog - [log,23] - ChangeSet org/flowable/dmn/db/liquibase/flowable-dmn-db-changelog.xml::6::flowable ran successfully in 35ms +12:46:01.058 [restartedMain] INFO liquibase.changelog - [log,23] - Index ACT_IDX_DEC_TBL_UNIQ dropped from table ACT_DMN_DECISION_TABLE +12:46:01.083 [restartedMain] INFO liquibase.changelog - [log,23] - Table ACT_DMN_DECISION_TABLE renamed to ACT_DMN_DECISION +12:46:01.108 [restartedMain] INFO liquibase.changelog - [log,23] - Index ACT_IDX_DMN_DEC_UNIQ created +12:46:01.113 [restartedMain] INFO liquibase.changelog - [log,23] - ChangeSet org/flowable/dmn/db/liquibase/flowable-dmn-db-changelog.xml::7::flowable ran successfully in 83ms +12:46:01.181 [restartedMain] INFO liquibase.changelog - [log,23] - Columns DECISION_TYPE_(varchar(255)) added to ACT_DMN_DECISION +12:46:01.188 [restartedMain] INFO liquibase.changelog - [log,23] - ChangeSet org/flowable/dmn/db/liquibase/flowable-dmn-db-changelog.xml::8::flowable ran successfully in 44ms +12:46:01.241 [restartedMain] INFO l.lockservice - [log,23] - Successfully released change log lock +12:46:01.252 [restartedMain] INFO o.f.d.e.i.DmnEngineImpl - [<init>,55] - DmnEngine default created +12:46:01.254 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.form.spring.configurator.SpringFormEngineConfigurator (priority:300000) +12:46:01.440 [restartedMain] INFO l.lockservice - [log,23] - Successfully acquired change log lock +12:46:01.518 [restartedMain] INFO liquibase.changelog - [log,23] - Creating database history table with name: ccwin.ACT_FO_DATABASECHANGELOG +12:46:01.590 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_FO_DATABASECHANGELOG +12:46:01.707 [restartedMain] INFO liquibase.changelog - [log,23] - Table ACT_FO_FORM_DEPLOYMENT created +12:46:01.755 [restartedMain] INFO liquibase.changelog - [log,23] - Table ACT_FO_FORM_RESOURCE created +12:46:01.797 [restartedMain] INFO liquibase.changelog - [log,23] - Table ACT_FO_FORM_DEFINITION created +12:46:01.831 [restartedMain] INFO liquibase.changelog - [log,23] - Table ACT_FO_FORM_INSTANCE created +12:46:01.837 [restartedMain] INFO liquibase.changelog - [log,23] - ChangeSet org/flowable/form/db/liquibase/flowable-form-db-changelog.xml::1::activiti ran successfully in 174ms +12:46:01.911 [restartedMain] INFO liquibase.changelog - [log,23] - Columns SCOPE_ID_(varchar(255)),SCOPE_TYPE_(varchar(255)),SCOPE_DEFINITION_ID_(varchar(255)) added to ACT_FO_FORM_INSTANCE +12:46:01.917 [restartedMain] INFO liquibase.changelog - [log,23] - ChangeSet org/flowable/form/db/liquibase/flowable-form-db-changelog.xml::2::flowable ran successfully in 44ms +12:46:02.003 [restartedMain] INFO liquibase.changelog - [log,23] - Column ACT_FO_FORM_DEFINITION.PARENT_DEPLOYMENT_ID_ dropped +12:46:02.010 [restartedMain] INFO liquibase.changelog - [log,23] - ChangeSet org/flowable/form/db/liquibase/flowable-form-db-changelog.xml::3::flowable ran successfully in 64ms +12:46:02.118 [restartedMain] INFO liquibase.changelog - [log,23] - ACT_FO_FORM_DEPLOYMENT.DEPLOY_TIME_ datatype was changed to datetime(3) +12:46:02.189 [restartedMain] INFO liquibase.changelog - [log,23] - ACT_FO_FORM_INSTANCE.SUBMITTED_DATE_ datatype was changed to datetime(3) +12:46:02.196 [restartedMain] INFO liquibase.changelog - [log,23] - ChangeSet org/flowable/form/db/liquibase/flowable-form-db-changelog.xml::4::flowable ran successfully in 151ms +12:46:02.256 [restartedMain] INFO liquibase.changelog - [log,23] - Index ACT_IDX_FORM_DEF_UNIQ created +12:46:02.261 [restartedMain] INFO liquibase.changelog - [log,23] - ChangeSet org/flowable/form/db/liquibase/flowable-form-db-changelog.xml::5::flowable ran successfully in 37ms +12:46:02.321 [restartedMain] INFO liquibase.changelog - [log,23] - Index ACT_IDX_FORM_TASK created +12:46:02.356 [restartedMain] INFO liquibase.changelog - [log,23] - Index ACT_IDX_FORM_PROC created +12:46:02.394 [restartedMain] INFO liquibase.changelog - [log,23] - Index ACT_IDX_FORM_SCOPE created +12:46:02.399 [restartedMain] INFO liquibase.changelog - [log,23] - ChangeSet org/flowable/form/db/liquibase/flowable-form-db-changelog.xml::6::flowable ran successfully in 108ms +12:46:02.445 [restartedMain] INFO l.lockservice - [log,23] - Successfully released change log lock +12:46:02.458 [restartedMain] INFO o.f.f.e.i.FormEngineImpl - [<init>,52] - FormEngine default created +12:46:02.459 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.content.spring.configurator.SpringContentEngineConfigurator (priority:400000) +12:46:02.465 [restartedMain] INFO o.f.c.s.SpringContentEngineConfiguration - [initContentStorage,196] - Content file system root : C:\Users\23082\content +12:46:02.835 [restartedMain] INFO l.lockservice - [log,23] - Successfully acquired change log lock +12:46:02.909 [restartedMain] INFO liquibase.changelog - [log,23] - Creating database history table with name: ccwin.ACT_CO_DATABASECHANGELOG +12:46:02.976 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_CO_DATABASECHANGELOG +12:46:03.069 [restartedMain] INFO liquibase.changelog - [log,23] - Table ACT_CO_CONTENT_ITEM created +12:46:03.111 [restartedMain] INFO liquibase.changelog - [log,23] - Index idx_contitem_taskid created +12:46:03.143 [restartedMain] INFO liquibase.changelog - [log,23] - Index idx_contitem_procid created +12:46:03.149 [restartedMain] INFO liquibase.changelog - [log,23] - ChangeSet org/flowable/content/db/liquibase/flowable-content-db-changelog.xml::1::activiti ran successfully in 127ms +12:46:03.221 [restartedMain] INFO liquibase.changelog - [log,23] - Columns SCOPE_ID_(varchar(255)),SCOPE_TYPE_(varchar(255)) added to ACT_CO_CONTENT_ITEM +12:46:03.259 [restartedMain] INFO liquibase.changelog - [log,23] - Index idx_contitem_scope created +12:46:03.269 [restartedMain] INFO liquibase.changelog - [log,23] - ChangeSet org/flowable/content/db/liquibase/flowable-content-db-changelog.xml::2::flowable ran successfully in 83ms +12:46:03.327 [restartedMain] INFO l.lockservice - [log,23] - Successfully released change log lock +12:46:03.351 [restartedMain] INFO o.f.c.e.i.ContentEngineImpl - [<init>,48] - ContentEngine default created +12:46:03.353 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.cmmn.spring.configurator.SpringCmmnEngineConfigurator (priority:500000) +12:46:03.861 [restartedMain] INFO l.lockservice - [log,23] - Successfully acquired change log lock +12:46:03.937 [restartedMain] INFO liquibase.changelog - [log,23] - Creating database history table with name: ccwin.ACT_CMMN_DATABASECHANGELOG +12:46:04.009 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_CMMN_DATABASECHANGELOG +12:46:04.134 [restartedMain] INFO liquibase.changelog - [log,23] - Table ACT_CMMN_DEPLOYMENT created +12:46:04.177 [restartedMain] INFO liquibase.changelog - [log,23] - Table ACT_CMMN_DEPLOYMENT_RESOURCE created +12:46:04.256 [restartedMain] INFO liquibase.changelog - [log,23] - Foreign key constraint added to ACT_CMMN_DEPLOYMENT_RESOURCE (DEPLOYMENT_ID_) +12:46:04.295 [restartedMain] INFO liquibase.changelog - [log,23] - Index ACT_IDX_CMMN_RSRC_DPL created +12:46:04.339 [restartedMain] INFO liquibase.changelog - [log,23] - Table ACT_CMMN_CASEDEF created +12:46:04.419 [restartedMain] INFO liquibase.changelog - [log,23] - Foreign key constraint added to ACT_CMMN_CASEDEF (DEPLOYMENT_ID_) +12:46:04.457 [restartedMain] INFO liquibase.changelog - [log,23] - Index ACT_IDX_CASE_DEF_DPLY created +12:46:04.501 [restartedMain] INFO liquibase.changelog - [log,23] - Table ACT_CMMN_RU_CASE_INST created +12:46:04.584 [restartedMain] INFO liquibase.changelog - [log,23] - Foreign key constraint added to ACT_CMMN_RU_CASE_INST (CASE_DEF_ID_) +12:46:04.623 [restartedMain] INFO liquibase.changelog - [log,23] - Index ACT_IDX_CASE_INST_CASE_DEF created +12:46:04.655 [restartedMain] INFO liquibase.changelog - [log,23] - Index ACT_IDX_CASE_INST_PARENT created +12:46:04.699 [restartedMain] INFO liquibase.changelog - [log,23] - Table ACT_CMMN_RU_PLAN_ITEM_INST created +12:46:04.772 [restartedMain] INFO liquibase.changelog - [log,23] - Foreign key constraint added to ACT_CMMN_RU_PLAN_ITEM_INST (CASE_DEF_ID_) +12:46:04.826 [restartedMain] INFO liquibase.changelog - [log,23] - Index ACT_IDX_PLAN_ITEM_CASE_DEF created +12:46:04.906 [restartedMain] INFO liquibase.changelog - [log,23] - Foreign key constraint added to ACT_CMMN_RU_PLAN_ITEM_INST (CASE_INST_ID_) +12:46:04.946 [restartedMain] INFO liquibase.changelog - [log,23] - Index ACT_IDX_PLAN_ITEM_CASE_INST created +12:46:05.000 [restartedMain] INFO liquibase.changelog - [log,23] - Table ACT_CMMN_RU_SENTRY_PART_INST created +12:46:05.080 [restartedMain] INFO liquibase.changelog - [log,23] - Foreign key constraint added to ACT_CMMN_RU_SENTRY_PART_INST (CASE_DEF_ID_) +12:46:05.120 [restartedMain] INFO liquibase.changelog - [log,23] - Index ACT_IDX_SENTRY_CASE_DEF created +12:46:05.200 [restartedMain] INFO liquibase.changelog - [log,23] - Foreign key constraint added to ACT_CMMN_RU_SENTRY_PART_INST (CASE_INST_ID_) +12:46:05.242 [restartedMain] INFO liquibase.changelog - [log,23] - Index ACT_IDX_SENTRY_CASE_INST created +12:46:05.330 [restartedMain] INFO liquibase.changelog - [log,23] - Foreign key constraint added to ACT_CMMN_RU_SENTRY_PART_INST (PLAN_ITEM_INST_ID_) +12:46:05.367 [restartedMain] INFO liquibase.changelog - [log,23] - Index ACT_IDX_SENTRY_PLAN_ITEM created +12:46:05.409 [restartedMain] INFO liquibase.changelog - [log,23] - Table ACT_CMMN_RU_MIL_INST created +12:46:05.487 [restartedMain] INFO liquibase.changelog - [log,23] - Foreign key constraint added to ACT_CMMN_RU_MIL_INST (CASE_DEF_ID_) +12:46:05.524 [restartedMain] INFO liquibase.changelog - [log,23] - Index ACT_IDX_MIL_CASE_DEF created +12:46:05.612 [restartedMain] INFO liquibase.changelog - [log,23] - Foreign key constraint added to ACT_CMMN_RU_MIL_INST (CASE_INST_ID_) +12:46:05.649 [restartedMain] INFO liquibase.changelog - [log,23] - Index ACT_IDX_MIL_CASE_INST created +12:46:05.690 [restartedMain] INFO liquibase.changelog - [log,23] - Table ACT_CMMN_HI_CASE_INST created +12:46:05.729 [restartedMain] INFO liquibase.changelog - [log,23] - Table ACT_CMMN_HI_MIL_INST created +12:46:05.739 [restartedMain] INFO liquibase.changelog - [log,23] - ChangeSet org/flowable/cmmn/db/liquibase/flowable-cmmn-db-changelog.xml::1::flowable ran successfully in 1651ms +12:46:05.851 [restartedMain] INFO liquibase.changelog - [log,23] - Columns DGRM_RESOURCE_NAME_(varchar(4000)),HAS_START_FORM_KEY_(boolean) added to ACT_CMMN_CASEDEF +12:46:05.887 [restartedMain] INFO liquibase.changelog - [log,23] - Columns GENERATED_(boolean) added to ACT_CMMN_DEPLOYMENT_RESOURCE +12:46:05.940 [restartedMain] INFO liquibase.changelog - [log,23] - Columns LOCK_TIME_(datetime) added to ACT_CMMN_RU_CASE_INST +12:46:05.985 [restartedMain] INFO liquibase.changelog - [log,23] - Columns ITEM_DEFINITION_ID_(varchar(255)),ITEM_DEFINITION_TYPE_(varchar(255)) added to ACT_CMMN_RU_PLAN_ITEM_INST +12:46:05.993 [restartedMain] INFO liquibase.changelog - [log,23] - ChangeSet org/flowable/cmmn/db/liquibase/flowable-cmmn-db-changelog.xml::2::flowable ran successfully in 203ms +12:46:06.090 [restartedMain] INFO liquibase.changelog - [log,23] - Columns IS_COMPLETEABLE_(boolean) added to ACT_CMMN_RU_PLAN_ITEM_INST +12:46:06.140 [restartedMain] INFO liquibase.changelog - [log,23] - Columns IS_COMPLETEABLE_(boolean) added to ACT_CMMN_RU_CASE_INST +12:46:06.179 [restartedMain] INFO liquibase.changelog - [log,23] - Index ACT_IDX_PLAN_ITEM_STAGE_INST created +12:46:06.221 [restartedMain] INFO liquibase.changelog - [log,23] - Columns IS_COUNT_ENABLED_(boolean) added to ACT_CMMN_RU_PLAN_ITEM_INST +12:46:06.258 [restartedMain] INFO liquibase.changelog - [log,23] - Columns VAR_COUNT_(integer) added to ACT_CMMN_RU_PLAN_ITEM_INST +12:46:06.302 [restartedMain] INFO liquibase.changelog - [log,23] - Columns SENTRY_PART_INST_COUNT_(integer) added to ACT_CMMN_RU_PLAN_ITEM_INST +12:46:06.309 [restartedMain] INFO liquibase.changelog - [log,23] - ChangeSet org/flowable/cmmn/db/liquibase/flowable-cmmn-db-changelog.xml::3::flowable ran successfully in 258ms +12:46:06.395 [restartedMain] INFO liquibase.changelog - [log,23] - Table ACT_CMMN_HI_PLAN_ITEM_INST created +12:46:06.440 [restartedMain] INFO liquibase.changelog - [log,23] - Columns TENANT_ID_(varchar(255)) added to ACT_CMMN_RU_MIL_INST +12:46:06.477 [restartedMain] INFO liquibase.changelog - [log,23] - Columns TENANT_ID_(varchar(255)) added to ACT_CMMN_HI_MIL_INST +12:46:06.486 [restartedMain] INFO liquibase.changelog - [log,23] - ChangeSet org/flowable/cmmn/db/liquibase/flowable-cmmn-db-changelog.xml::4::flowable ran successfully in 136ms +12:46:06.606 [restartedMain] INFO liquibase.changelog - [log,23] - ACT_CMMN_DEPLOYMENT.DEPLOY_TIME_ datatype was changed to datetime(3) +12:46:06.710 [restartedMain] INFO liquibase.changelog - [log,23] - ACT_CMMN_RU_CASE_INST.START_TIME_ datatype was changed to datetime(3) +12:46:06.804 [restartedMain] INFO liquibase.changelog - [log,23] - ACT_CMMN_RU_PLAN_ITEM_INST.START_TIME_ datatype was changed to datetime(3) +12:46:06.898 [restartedMain] INFO liquibase.changelog - [log,23] - ACT_CMMN_RU_SENTRY_PART_INST.TIME_STAMP_ datatype was changed to datetime(3) +12:46:06.980 [restartedMain] INFO liquibase.changelog - [log,23] - ACT_CMMN_RU_MIL_INST.TIME_STAMP_ datatype was changed to datetime(3) +12:46:07.046 [restartedMain] INFO liquibase.changelog - [log,23] - ACT_CMMN_HI_CASE_INST.START_TIME_ datatype was changed to datetime(3) +12:46:07.120 [restartedMain] INFO liquibase.changelog - [log,23] - ACT_CMMN_HI_CASE_INST.END_TIME_ datatype was changed to datetime(3) +12:46:07.190 [restartedMain] INFO liquibase.changelog - [log,23] - ACT_CMMN_HI_MIL_INST.TIME_STAMP_ datatype was changed to datetime(3) +12:46:07.272 [restartedMain] INFO liquibase.changelog - [log,23] - ACT_CMMN_RU_CASE_INST.LOCK_TIME_ datatype was changed to datetime(3) +12:46:07.348 [restartedMain] INFO liquibase.changelog - [log,23] - ACT_CMMN_HI_PLAN_ITEM_INST.CREATED_TIME_ datatype was changed to datetime(3) +12:46:07.414 [restartedMain] INFO liquibase.changelog - [log,23] - ACT_CMMN_HI_PLAN_ITEM_INST.LAST_AVAILABLE_TIME_ datatype was changed to datetime(3) +12:46:07.484 [restartedMain] INFO liquibase.changelog - [log,23] - ACT_CMMN_HI_PLAN_ITEM_INST.LAST_ENABLED_TIME_ datatype was changed to datetime(3) +12:46:07.559 [restartedMain] INFO liquibase.changelog - [log,23] - ACT_CMMN_HI_PLAN_ITEM_INST.LAST_DISABLED_TIME_ datatype was changed to datetime(3) +12:46:07.640 [restartedMain] INFO liquibase.changelog - [log,23] - ACT_CMMN_HI_PLAN_ITEM_INST.LAST_STARTED_TIME_ datatype was changed to datetime(3) +12:46:07.714 [restartedMain] INFO liquibase.changelog - [log,23] - ACT_CMMN_HI_PLAN_ITEM_INST.LAST_SUSPENDED_TIME_ datatype was changed to datetime(3) +12:46:07.793 [restartedMain] INFO liquibase.changelog - [log,23] - ACT_CMMN_HI_PLAN_ITEM_INST.COMPLETED_TIME_ datatype was changed to datetime(3) +12:46:07.869 [restartedMain] INFO liquibase.changelog - [log,23] - ACT_CMMN_HI_PLAN_ITEM_INST.OCCURRED_TIME_ datatype was changed to datetime(3) +12:46:07.942 [restartedMain] INFO liquibase.changelog - [log,23] - ACT_CMMN_HI_PLAN_ITEM_INST.TERMINATED_TIME_ datatype was changed to datetime(3) +12:46:08.009 [restartedMain] INFO liquibase.changelog - [log,23] - ACT_CMMN_HI_PLAN_ITEM_INST.EXIT_TIME_ datatype was changed to datetime(3) +12:46:08.071 [restartedMain] INFO liquibase.changelog - [log,23] - ACT_CMMN_HI_PLAN_ITEM_INST.ENDED_TIME_ datatype was changed to datetime(3) +12:46:08.143 [restartedMain] INFO liquibase.changelog - [log,23] - ACT_CMMN_HI_PLAN_ITEM_INST.LAST_UPDATED_TIME_ datatype was changed to datetime(3) +12:46:08.150 [restartedMain] INFO liquibase.changelog - [log,23] - ChangeSet org/flowable/cmmn/db/liquibase/flowable-cmmn-db-changelog.xml::5::flowable ran successfully in 1619ms +12:46:08.232 [restartedMain] INFO liquibase.changelog - [log,23] - Index ACT_IDX_CASE_DEF_UNIQ created +12:46:08.241 [restartedMain] INFO liquibase.changelog - [log,23] - ChangeSet org/flowable/cmmn/db/liquibase/flowable-cmmn-db-changelog.xml::6::flowable ran successfully in 52ms +12:46:08.310 [restartedMain] INFO liquibase.changelog - [log,23] - Column ACT_CMMN_RU_PLAN_ITEM_INST.START_TIME_ renamed to CREATE_TIME_ +12:46:08.335 [restartedMain] INFO liquibase.changelog - [log,23] - Column ACT_CMMN_HI_PLAN_ITEM_INST.CREATED_TIME_ renamed to CREATE_TIME_ +12:46:08.389 [restartedMain] INFO liquibase.changelog - [log,23] - Columns LAST_AVAILABLE_TIME_(datetime(3)),LAST_ENABLED_TIME_(datetime(3)),LAST_DISABLED_TIME_(datetime(3)),LAST_STARTED_TIME_(datetime(3)),LAST_SUSPENDED_TIME_(datetime(3)),COMPLETED_TIME_(datetime(3)),OCCURRED_TIME_(datetime(3)),TERMINATED_TIME_(datetime(3)),EXIT_TIME_(datetime(3)),ENDED_TIME_(datetime(3)),ENTRY_CRITERION_ID_(varchar(255)),EXIT_CRITERION_ID_(varchar(255)) added to ACT_CMMN_RU_PLAN_ITEM_INST +12:46:08.431 [restartedMain] INFO liquibase.changelog - [log,23] - Columns ENTRY_CRITERION_ID_(varchar(255)),EXIT_CRITERION_ID_(varchar(255)) added to ACT_CMMN_HI_PLAN_ITEM_INST +12:46:08.444 [restartedMain] INFO liquibase.changelog - [log,23] - ChangeSet org/flowable/cmmn/db/liquibase/flowable-cmmn-db-changelog.xml::7::flowable ran successfully in 171ms +12:46:08.530 [restartedMain] INFO liquibase.changelog - [log,23] - Columns SHOW_IN_OVERVIEW_(boolean) added to ACT_CMMN_HI_PLAN_ITEM_INST +12:46:08.538 [restartedMain] INFO liquibase.changelog - [log,23] - ChangeSet org/flowable/cmmn/db/liquibase/flowable-cmmn-db-changelog.xml::8::flowable ran successfully in 48ms +12:46:08.628 [restartedMain] INFO liquibase.changelog - [log,23] - Columns EXTRA_VALUE_(varchar(255)) added to ACT_CMMN_RU_PLAN_ITEM_INST +12:46:08.671 [restartedMain] INFO liquibase.changelog - [log,23] - Columns EXTRA_VALUE_(varchar(255)) added to ACT_CMMN_HI_PLAN_ITEM_INST +12:46:08.690 [restartedMain] INFO liquibase.changelog - [log,23] - ChangeSet org/flowable/cmmn/db/liquibase/flowable-cmmn-db-changelog.xml::9::flowable ran successfully in 110ms +12:46:08.770 [restartedMain] INFO liquibase.changelog - [log,23] - Columns REFERENCE_ID_(varchar(255)) added to ACT_CMMN_RU_CASE_INST +12:46:08.819 [restartedMain] INFO liquibase.changelog - [log,23] - Columns REFERENCE_TYPE_(varchar(255)) added to ACT_CMMN_RU_CASE_INST +12:46:08.859 [restartedMain] INFO liquibase.changelog - [log,23] - Index ACT_IDX_CASE_INST_REF_ID_ created +12:46:08.893 [restartedMain] INFO liquibase.changelog - [log,23] - Columns REFERENCE_ID_(varchar(255)) added to ACT_CMMN_HI_CASE_INST +12:46:08.939 [restartedMain] INFO liquibase.changelog - [log,23] - Columns REFERENCE_TYPE_(varchar(255)) added to ACT_CMMN_HI_CASE_INST +12:46:08.946 [restartedMain] INFO liquibase.changelog - [log,23] - ChangeSet org/flowable/cmmn/db/liquibase/flowable-cmmn-db-changelog.xml::10::flowable ran successfully in 223ms +12:46:09.040 [restartedMain] INFO liquibase.changelog - [log,23] - Columns DERIVED_CASE_DEF_ID_(varchar(255)) added to ACT_CMMN_RU_PLAN_ITEM_INST +12:46:09.080 [restartedMain] INFO liquibase.changelog - [log,23] - Columns DERIVED_CASE_DEF_ID_(varchar(255)) added to ACT_CMMN_HI_PLAN_ITEM_INST +12:46:09.090 [restartedMain] INFO liquibase.changelog - [log,23] - ChangeSet org/flowable/cmmn/db/liquibase/flowable-cmmn-db-changelog.xml::11::flowable ran successfully in 103ms +12:46:09.185 [restartedMain] INFO liquibase.changelog - [log,23] - Columns LOCK_OWNER_(varchar(255)) added to ACT_CMMN_RU_CASE_INST +12:46:09.198 [restartedMain] INFO liquibase.changelog - [log,23] - ChangeSet org/flowable/cmmn/db/liquibase/flowable-cmmn-db-changelog.xml::12::flowable ran successfully in 72ms +12:46:09.274 [restartedMain] INFO liquibase.changelog - [log,23] - Columns LAST_UNAVAILABLE_TIME_(datetime(3)) added to ACT_CMMN_RU_PLAN_ITEM_INST +12:46:09.319 [restartedMain] INFO liquibase.changelog - [log,23] - Columns LAST_UNAVAILABLE_TIME_(datetime(3)) added to ACT_CMMN_HI_PLAN_ITEM_INST +12:46:09.330 [restartedMain] INFO liquibase.changelog - [log,23] - ChangeSet org/flowable/cmmn/db/liquibase/flowable-cmmn-db-changelog.xml::13::flowable ran successfully in 101ms +12:46:09.414 [restartedMain] INFO liquibase.changelog - [log,23] - Columns LAST_REACTIVATION_TIME_(datetime(3)),LAST_REACTIVATION_USER_ID_(varchar(255)) added to ACT_CMMN_RU_CASE_INST +12:46:09.460 [restartedMain] INFO liquibase.changelog - [log,23] - Columns LAST_REACTIVATION_TIME_(datetime(3)),LAST_REACTIVATION_USER_ID_(varchar(255)) added to ACT_CMMN_HI_CASE_INST +12:46:09.468 [restartedMain] INFO liquibase.changelog - [log,23] - ChangeSet org/flowable/cmmn/db/liquibase/flowable-cmmn-db-changelog.xml::14::flowable ran successfully in 99ms +12:46:09.555 [restartedMain] INFO liquibase.changelog - [log,23] - Columns BUSINESS_STATUS_(varchar(255)) added to ACT_CMMN_RU_CASE_INST +12:46:09.591 [restartedMain] INFO liquibase.changelog - [log,23] - Columns BUSINESS_STATUS_(varchar(255)) added to ACT_CMMN_HI_CASE_INST +12:46:09.599 [restartedMain] INFO liquibase.changelog - [log,23] - ChangeSet org/flowable/cmmn/db/liquibase/flowable-cmmn-db-changelog.xml::16::flowable ran successfully in 92ms +12:46:09.658 [restartedMain] INFO l.lockservice - [log,23] - Successfully released change log lock +12:46:09.673 [restartedMain] INFO o.f.c.e.i.CmmnEngineImpl - [<init>,72] - CmmnEngine default created +12:46:09.961 [restartedMain] INFO l.lockservice - [log,23] - Successfully acquired change log lock +12:46:10.033 [restartedMain] INFO liquibase.changelog - [log,23] - Creating database history table with name: ccwin.ACT_APP_DATABASECHANGELOG +12:46:10.099 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_APP_DATABASECHANGELOG +12:46:10.190 [restartedMain] INFO liquibase.changelog - [log,23] - Table ACT_APP_DEPLOYMENT created +12:46:10.231 [restartedMain] INFO liquibase.changelog - [log,23] - Table ACT_APP_DEPLOYMENT_RESOURCE created +12:46:10.310 [restartedMain] INFO liquibase.changelog - [log,23] - Foreign key constraint added to ACT_APP_DEPLOYMENT_RESOURCE (DEPLOYMENT_ID_) +12:46:10.346 [restartedMain] INFO liquibase.changelog - [log,23] - Index ACT_IDX_APP_RSRC_DPL created +12:46:10.388 [restartedMain] INFO liquibase.changelog - [log,23] - Table ACT_APP_APPDEF created +12:46:10.489 [restartedMain] INFO liquibase.changelog - [log,23] - Foreign key constraint added to ACT_APP_APPDEF (DEPLOYMENT_ID_) +12:46:10.529 [restartedMain] INFO liquibase.changelog - [log,23] - Index ACT_IDX_APP_DEF_DPLY created +12:46:10.537 [restartedMain] INFO liquibase.changelog - [log,23] - ChangeSet org/flowable/app/db/liquibase/flowable-app-db-changelog.xml::1::flowable ran successfully in 396ms +12:46:10.655 [restartedMain] INFO liquibase.changelog - [log,23] - ACT_APP_DEPLOYMENT.DEPLOY_TIME_ datatype was changed to datetime(3) +12:46:10.672 [restartedMain] INFO liquibase.changelog - [log,23] - ChangeSet org/flowable/app/db/liquibase/flowable-app-db-changelog.xml::2::flowable ran successfully in 86ms +12:46:10.744 [restartedMain] INFO liquibase.changelog - [log,23] - Index ACT_IDX_APP_DEF_UNIQ created +12:46:10.760 [restartedMain] INFO liquibase.changelog - [log,23] - ChangeSet org/flowable/app/db/liquibase/flowable-app-db-changelog.xml::3::flowable ran successfully in 50ms +12:46:10.841 [restartedMain] INFO l.lockservice - [log,23] - Successfully released change log lock +12:46:10.860 [restartedMain] INFO o.f.a.e.i.AppEngineImpl - [<init>,48] - AppEngine default created +12:46:13.683 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +12:46:13.705 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +12:46:13.705 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +12:46:13.707 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +12:46:13.708 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +12:46:13.708 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +12:46:13.709 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +12:46:13.709 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@52203a25 +12:46:14.116 [restartedMain] INFO o.f.j.s.i.a.AbstractAsyncExecutor - [start,108] - Starting up the async job executor [org.flowable.spring.job.service.SpringAsyncExecutor] for engine cmmn +12:46:14.162 [Thread-10] INFO o.f.j.s.i.a.ResetExpiredJobsRunnable - [run,63] - starting to reset expired jobs for engine cmmn +12:46:14.163 [restartedMain] INFO o.f.j.s.i.a.AbstractAsyncExecutor - [start,108] - Starting up the async job executor [org.flowable.spring.job.service.SpringAsyncExecutor] for engine bpmn +12:46:14.164 [Thread-8] INFO o.f.j.s.i.a.AcquireAsyncJobsDueRunnable - [run,106] - starting to acquire async jobs due for engine cmmn +12:46:14.164 [Thread-9] INFO o.f.j.s.i.a.AcquireTimerJobsRunnable - [run,109] - starting to acquire async jobs due for engine cmmn +12:46:14.200 [Thread-12] INFO o.f.j.s.i.a.AcquireTimerJobsRunnable - [run,109] - starting to acquire async jobs due for engine bpmn +12:46:14.200 [Thread-11] INFO o.f.j.s.i.a.AcquireAsyncJobsDueRunnable - [run,106] - starting to acquire async jobs due for engine bpmn +12:46:14.200 [Thread-13] INFO o.f.j.s.i.a.ResetExpiredJobsRunnable - [run,63] - starting to reset expired jobs for engine bpmn +12:46:14.200 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Starting ProtocolHandler ["http-nio-8080"] +12:46:14.617 [restartedMain] INFO o.q.c.QuartzScheduler - [start,547] - Scheduler quartzScheduler_$_NON_CLUSTERED started. +12:46:14.632 [restartedMain] INFO c.w.w.WinApplication - [logStarted,61] - Started WinApplication in 27.957 seconds (JVM running for 28.433) +12:47:15.736 [Thread-5] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +12:47:16.103 [Thread-5] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +12:47:16.103 [Thread-5] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +12:47:16.103 [Thread-5] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +12:47:16.107 [Thread-5] INFO o.f.j.s.i.a.AbstractAsyncExecutor - [shutdown,165] - Shutting down the async job executor [org.flowable.spring.job.service.SpringAsyncExecutor] for engine cmmn +12:47:16.108 [flowable-cmmn-acquire-async-jobs] INFO o.f.j.s.i.a.AcquireAsyncJobsDueRunnable - [run,143] - stopped async job due acquisition for engine cmmn +12:47:16.108 [flowable-cmmn-acquire-timer-jobs] INFO o.f.j.s.i.a.AcquireTimerJobsRunnable - [run,131] - stopped async job due acquisition for engine cmmn +12:47:16.108 [flowable-cmmn-reset-expired-jobs] INFO o.f.j.s.i.a.ResetExpiredJobsRunnable - [run,90] - stopped resetting expired jobs for engine cmmn +12:47:16.234 [Thread-5] INFO o.f.j.s.i.a.AbstractAsyncExecutor - [shutdown,165] - Shutting down the async job executor [org.flowable.spring.job.service.SpringAsyncExecutor] for engine bpmn +12:47:16.235 [flowable-bpmn-acquire-async-jobs] INFO o.f.j.s.i.a.AcquireAsyncJobsDueRunnable - [run,143] - stopped async job due acquisition for engine bpmn +12:47:16.235 [flowable-bpmn-acquire-timer-jobs] INFO o.f.j.s.i.a.AcquireTimerJobsRunnable - [run,131] - stopped async job due acquisition for engine bpmn +12:47:16.235 [flowable-bpmn-reset-expired-jobs] INFO o.f.j.s.i.a.ResetExpiredJobsRunnable - [run,90] - stopped resetting expired jobs for engine bpmn +12:47:16.361 [Thread-5] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +12:47:16.363 [Thread-5] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +12:47:16.365 [Thread-5] INFO c.a.d.p.DruidDataSource - [close,2105] - {dataSource-1} closing ... +12:47:16.369 [Thread-5] INFO c.a.d.p.DruidDataSource - [close,2178] - {dataSource-1} closed +12:47:44.091 [restartedMain] INFO c.w.w.WinApplication - [logStarting,55] - Starting WinApplication using Java 1.8.0_231 on LAPTOP-K8GOQEG9 with PID 52236 (D:\workspace\wenyin\win\win-admin\target\classes started by admin in D:\workspace\wenyin\win) +12:47:44.091 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +12:47:44.092 [restartedMain] INFO c.w.w.WinApplication - [logStartupProfileInfo,686] - The following 3 profiles are active: "druid", "mybatis", "dev" +12:47:47.387 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-8080"] +12:47:47.387 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +12:47:47.388 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +12:47:47.460 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +12:47:49.059 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,985] - {dataSource-1,ccwin} inited +12:47:49.061 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [ccwin] success +12:47:49.063 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +12:47:49.063 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [ccwin] +12:47:52.547 [restartedMain] INFO o.f.s.b.ProcessEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +12:47:53.134 [restartedMain] INFO o.f.s.b.c.CmmnEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +12:47:53.262 [restartedMain] INFO o.f.s.b.d.DmnEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +12:47:53.316 [restartedMain] INFO o.f.s.b.f.FormEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +12:47:53.386 [restartedMain] INFO o.f.s.b.e.EventRegistryAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +12:47:53.435 [restartedMain] INFO o.f.s.b.a.AppEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +12:47:53.460 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1073] - Found 7 Engine Configurators in total: +12:47:53.461 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.engine.spring.configurator.SpringProcessEngineConfigurator (priority:50000) +12:47:53.461 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.eventregistry.spring.configurator.SpringEventRegistryConfigurator (priority:100000) +12:47:53.461 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.idm.spring.configurator.SpringIdmEngineConfigurator (priority:150000) +12:47:53.462 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.dmn.spring.configurator.SpringDmnEngineConfigurator (priority:200000) +12:47:53.462 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.form.spring.configurator.SpringFormEngineConfigurator (priority:300000) +12:47:53.462 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.content.spring.configurator.SpringContentEngineConfigurator (priority:400000) +12:47:53.462 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.cmmn.spring.configurator.SpringCmmnEngineConfigurator (priority:500000) +12:47:53.463 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.engine.spring.configurator.SpringProcessEngineConfigurator (priority:50000) +12:47:53.472 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.eventregistry.spring.configurator.SpringEventRegistryConfigurator (priority:100000) +12:47:53.479 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.idm.spring.configurator.SpringIdmEngineConfigurator (priority:150000) +12:47:53.482 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.dmn.spring.configurator.SpringDmnEngineConfigurator (priority:200000) +12:47:53.484 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.form.spring.configurator.SpringFormEngineConfigurator (priority:300000) +12:47:53.488 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.content.spring.configurator.SpringContentEngineConfigurator (priority:400000) +12:47:53.490 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.cmmn.spring.configurator.SpringCmmnEngineConfigurator (priority:500000) +12:47:54.331 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.engine.spring.configurator.SpringProcessEngineConfigurator (priority:50000) +12:47:54.671 [restartedMain] INFO o.f.e.i.ProcessEngineImpl - [<init>,89] - ProcessEngine default created +12:47:54.702 [restartedMain] INFO o.f.e.i.c.ValidateV5EntitiesCmd - [execute,43] - Total of v5 deployments found: 0 +12:47:54.801 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.eventregistry.spring.configurator.SpringEventRegistryConfigurator (priority:100000) +12:47:55.610 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.FLW_EV_DATABASECHANGELOG +12:47:55.659 [restartedMain] INFO o.f.e.i.EventRegistryEngineImpl - [<init>,53] - EventRegistryEngine default created +12:47:55.660 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.idm.spring.configurator.SpringIdmEngineConfigurator (priority:150000) +12:47:55.724 [restartedMain] INFO o.f.i.e.i.IdmEngineImpl - [<init>,52] - IdmEngine default created +12:47:55.725 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.dmn.spring.configurator.SpringDmnEngineConfigurator (priority:200000) +12:47:55.860 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_DMN_DATABASECHANGELOG +12:47:55.904 [restartedMain] INFO o.f.d.e.i.DmnEngineImpl - [<init>,55] - DmnEngine default created +12:47:55.906 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.form.spring.configurator.SpringFormEngineConfigurator (priority:300000) +12:47:56.020 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_FO_DATABASECHANGELOG +12:47:56.073 [restartedMain] INFO o.f.f.e.i.FormEngineImpl - [<init>,52] - FormEngine default created +12:47:56.075 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.content.spring.configurator.SpringContentEngineConfigurator (priority:400000) +12:47:56.081 [restartedMain] INFO o.f.c.s.SpringContentEngineConfiguration - [initContentStorage,196] - Content file system root : C:\Users\23082\content +12:47:56.342 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_CO_DATABASECHANGELOG +12:47:56.363 [restartedMain] INFO o.f.c.e.i.ContentEngineImpl - [<init>,48] - ContentEngine default created +12:47:56.365 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.cmmn.spring.configurator.SpringCmmnEngineConfigurator (priority:500000) +12:47:56.533 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_CMMN_DATABASECHANGELOG +12:47:56.574 [restartedMain] INFO o.f.c.e.i.CmmnEngineImpl - [<init>,72] - CmmnEngine default created +12:47:56.669 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_APP_DATABASECHANGELOG +12:47:56.693 [restartedMain] INFO o.f.a.e.i.AppEngineImpl - [<init>,48] - AppEngine default created +12:47:59.673 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +12:47:59.696 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +12:47:59.696 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +12:47:59.698 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +12:47:59.699 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +12:47:59.699 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +12:47:59.700 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +12:47:59.700 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@2f2de913 +12:48:00.122 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Starting ProtocolHandler ["http-nio-8080"] +12:48:00.575 [restartedMain] INFO o.q.c.QuartzScheduler - [start,547] - Scheduler quartzScheduler_$_NON_CLUSTERED started. +12:48:00.586 [restartedMain] INFO c.w.w.WinApplication - [logStarted,61] - Started WinApplication in 16.953 seconds (JVM running for 17.426) +12:52:26.197 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +12:52:26.360 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +12:52:26.360 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +12:52:26.360 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +12:52:26.510 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +12:52:26.513 [SpringApplicationShutdownHook] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +12:52:26.515 [SpringApplicationShutdownHook] INFO c.a.d.p.DruidDataSource - [close,2105] - {dataSource-1} closing ... +12:52:26.519 [SpringApplicationShutdownHook] INFO c.a.d.p.DruidDataSource - [close,2178] - {dataSource-1} closed +13:32:59.939 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +13:32:59.942 [restartedMain] INFO c.w.w.WinApplication - [logStarting,55] - Starting WinApplication using Java 1.8.0_231 on LAPTOP-K8GOQEG9 with PID 10724 (D:\workspace\wenyin\win\win-admin\target\classes started by admin in D:\workspace\wenyin\win) +13:32:59.942 [restartedMain] INFO c.w.w.WinApplication - [logStartupProfileInfo,686] - The following 3 profiles are active: "druid", "mybatis", "dev" +13:33:04.070 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-8080"] +13:33:04.071 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +13:33:04.071 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +13:33:04.138 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +13:33:06.203 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,985] - {dataSource-1,ccwin} inited +13:33:06.207 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [ccwin] success +13:33:06.210 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +13:33:06.210 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [ccwin] +13:33:10.682 [restartedMain] INFO o.f.s.b.ProcessEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +13:33:11.300 [restartedMain] INFO o.f.s.b.c.CmmnEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +13:33:11.462 [restartedMain] INFO o.f.s.b.d.DmnEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +13:33:11.506 [restartedMain] INFO o.f.s.b.f.FormEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +13:33:11.555 [restartedMain] INFO o.f.s.b.e.EventRegistryAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +13:33:11.596 [restartedMain] INFO o.f.s.b.a.AppEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +13:33:11.618 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1073] - Found 7 Engine Configurators in total: +13:33:11.619 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.engine.spring.configurator.SpringProcessEngineConfigurator (priority:50000) +13:33:11.619 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.eventregistry.spring.configurator.SpringEventRegistryConfigurator (priority:100000) +13:33:11.619 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.idm.spring.configurator.SpringIdmEngineConfigurator (priority:150000) +13:33:11.619 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.dmn.spring.configurator.SpringDmnEngineConfigurator (priority:200000) +13:33:11.619 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.form.spring.configurator.SpringFormEngineConfigurator (priority:300000) +13:33:11.620 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.content.spring.configurator.SpringContentEngineConfigurator (priority:400000) +13:33:11.620 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.cmmn.spring.configurator.SpringCmmnEngineConfigurator (priority:500000) +13:33:11.620 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.engine.spring.configurator.SpringProcessEngineConfigurator (priority:50000) +13:33:11.624 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.eventregistry.spring.configurator.SpringEventRegistryConfigurator (priority:100000) +13:33:11.628 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.idm.spring.configurator.SpringIdmEngineConfigurator (priority:150000) +13:33:11.629 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.dmn.spring.configurator.SpringDmnEngineConfigurator (priority:200000) +13:33:11.630 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.form.spring.configurator.SpringFormEngineConfigurator (priority:300000) +13:33:11.631 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.content.spring.configurator.SpringContentEngineConfigurator (priority:400000) +13:33:11.632 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.cmmn.spring.configurator.SpringCmmnEngineConfigurator (priority:500000) +13:33:12.354 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.engine.spring.configurator.SpringProcessEngineConfigurator (priority:50000) +13:33:12.723 [restartedMain] INFO o.f.e.i.ProcessEngineImpl - [<init>,89] - ProcessEngine default created +13:33:12.765 [restartedMain] INFO o.f.e.i.c.ValidateV5EntitiesCmd - [execute,43] - Total of v5 deployments found: 0 +13:33:12.873 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.eventregistry.spring.configurator.SpringEventRegistryConfigurator (priority:100000) +13:33:13.775 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.FLW_EV_DATABASECHANGELOG +13:33:13.816 [restartedMain] INFO o.f.e.i.EventRegistryEngineImpl - [<init>,53] - EventRegistryEngine default created +13:33:13.818 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.idm.spring.configurator.SpringIdmEngineConfigurator (priority:150000) +13:33:13.883 [restartedMain] INFO o.f.i.e.i.IdmEngineImpl - [<init>,52] - IdmEngine default created +13:33:13.884 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.dmn.spring.configurator.SpringDmnEngineConfigurator (priority:200000) +13:33:14.024 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_DMN_DATABASECHANGELOG +13:33:14.094 [restartedMain] INFO o.f.d.e.i.DmnEngineImpl - [<init>,55] - DmnEngine default created +13:33:14.095 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.form.spring.configurator.SpringFormEngineConfigurator (priority:300000) +13:33:14.213 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_FO_DATABASECHANGELOG +13:33:14.287 [restartedMain] INFO o.f.f.e.i.FormEngineImpl - [<init>,52] - FormEngine default created +13:33:14.290 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.content.spring.configurator.SpringContentEngineConfigurator (priority:400000) +13:33:14.293 [restartedMain] INFO o.f.c.s.SpringContentEngineConfiguration - [initContentStorage,196] - Content file system root : C:\Users\23082\content +13:33:14.584 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_CO_DATABASECHANGELOG +13:33:14.622 [restartedMain] INFO o.f.c.e.i.ContentEngineImpl - [<init>,48] - ContentEngine default created +13:33:14.623 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.cmmn.spring.configurator.SpringCmmnEngineConfigurator (priority:500000) +13:33:14.814 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_CMMN_DATABASECHANGELOG +13:33:14.862 [restartedMain] INFO o.f.c.e.i.CmmnEngineImpl - [<init>,72] - CmmnEngine default created +13:33:14.984 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_APP_DATABASECHANGELOG +13:33:15.033 [restartedMain] INFO o.f.a.e.i.AppEngineImpl - [<init>,48] - AppEngine default created +13:33:18.748 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +13:33:18.769 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +13:33:18.769 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +13:33:18.770 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +13:33:18.772 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +13:33:18.772 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +13:33:18.772 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +13:33:18.772 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@24ea6fe8 +13:33:19.246 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Starting ProtocolHandler ["http-nio-8080"] +13:33:19.913 [restartedMain] INFO o.q.c.QuartzScheduler - [start,547] - Scheduler quartzScheduler_$_NON_CLUSTERED started. +13:33:19.925 [restartedMain] INFO c.w.w.WinApplication - [logStarted,61] - Started WinApplication in 20.561 seconds (JVM running for 21.288) +14:32:22.697 [http-nio-8080-exec-6] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring DispatcherServlet 'dispatcherServlet' +14:32:30.388 [schedule-pool-1] INFO sys-user - [run,56] - [127.0.0.1]内网IP[admin][Success][登录成功] +14:43:45.312 [http-nio-8080-exec-71] INFO o.a.t.u.h.p.Cookie - [log,173] - A cookie header was received [Hm_lvt_931a8de1263e8fcdea855e1b3c00abff=1687155670,1687337520;] that contained an invalid cookie. That cookie will be ignored. + Note: further occurrences of this error will be logged at DEBUG level. +15:34:43.564 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +15:34:43.753 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +15:34:43.753 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +15:34:43.753 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +15:34:44.133 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +15:34:44.136 [SpringApplicationShutdownHook] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +15:34:44.143 [SpringApplicationShutdownHook] INFO c.a.d.p.DruidDataSource - [close,2105] - {dataSource-1} closing ... +15:34:44.151 [SpringApplicationShutdownHook] INFO c.a.d.p.DruidDataSource - [close,2178] - {dataSource-1} closed +15:38:48.935 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +15:38:48.937 [restartedMain] INFO c.w.w.WinApplication - [logStarting,55] - Starting WinApplication using Java 1.8.0_231 on LAPTOP-K8GOQEG9 with PID 55472 (D:\workspace\wenyin\win\win-admin\target\classes started by admin in D:\workspace\wenyin\win) +15:38:48.938 [restartedMain] INFO c.w.w.WinApplication - [logStartupProfileInfo,686] - The following 3 profiles are active: "druid", "mybatis", "dev" +15:38:52.522 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-8080"] +15:38:52.522 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +15:38:52.523 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +15:38:52.591 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +15:38:54.454 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,985] - {dataSource-1,ccwin} inited +15:38:54.457 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [ccwin] success +15:38:54.459 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +15:38:54.459 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [ccwin] +15:38:59.304 [restartedMain] INFO o.f.s.b.ProcessEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +15:38:59.853 [restartedMain] INFO o.f.s.b.c.CmmnEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +15:39:00.021 [restartedMain] INFO o.f.s.b.d.DmnEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +15:39:00.074 [restartedMain] INFO o.f.s.b.f.FormEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +15:39:00.120 [restartedMain] INFO o.f.s.b.e.EventRegistryAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +15:39:00.151 [restartedMain] INFO o.f.s.b.a.AppEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +15:39:00.168 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1073] - Found 7 Engine Configurators in total: +15:39:00.168 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.engine.spring.configurator.SpringProcessEngineConfigurator (priority:50000) +15:39:00.168 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.eventregistry.spring.configurator.SpringEventRegistryConfigurator (priority:100000) +15:39:00.168 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.idm.spring.configurator.SpringIdmEngineConfigurator (priority:150000) +15:39:00.169 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.dmn.spring.configurator.SpringDmnEngineConfigurator (priority:200000) +15:39:00.169 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.form.spring.configurator.SpringFormEngineConfigurator (priority:300000) +15:39:00.169 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.content.spring.configurator.SpringContentEngineConfigurator (priority:400000) +15:39:00.169 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.cmmn.spring.configurator.SpringCmmnEngineConfigurator (priority:500000) +15:39:00.169 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.engine.spring.configurator.SpringProcessEngineConfigurator (priority:50000) +15:39:00.173 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.eventregistry.spring.configurator.SpringEventRegistryConfigurator (priority:100000) +15:39:00.176 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.idm.spring.configurator.SpringIdmEngineConfigurator (priority:150000) +15:39:00.177 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.dmn.spring.configurator.SpringDmnEngineConfigurator (priority:200000) +15:39:00.178 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.form.spring.configurator.SpringFormEngineConfigurator (priority:300000) +15:39:00.179 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.content.spring.configurator.SpringContentEngineConfigurator (priority:400000) +15:39:00.180 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.cmmn.spring.configurator.SpringCmmnEngineConfigurator (priority:500000) +15:39:00.854 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.engine.spring.configurator.SpringProcessEngineConfigurator (priority:50000) +15:39:01.220 [restartedMain] INFO o.f.e.i.ProcessEngineImpl - [<init>,89] - ProcessEngine default created +15:39:01.259 [restartedMain] INFO o.f.e.i.c.ValidateV5EntitiesCmd - [execute,43] - Total of v5 deployments found: 0 +15:39:01.359 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.eventregistry.spring.configurator.SpringEventRegistryConfigurator (priority:100000) +15:39:02.213 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.FLW_EV_DATABASECHANGELOG +15:39:02.284 [restartedMain] INFO o.f.e.i.EventRegistryEngineImpl - [<init>,53] - EventRegistryEngine default created +15:39:02.286 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.idm.spring.configurator.SpringIdmEngineConfigurator (priority:150000) +15:39:02.368 [restartedMain] INFO o.f.i.e.i.IdmEngineImpl - [<init>,52] - IdmEngine default created +15:39:02.369 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.dmn.spring.configurator.SpringDmnEngineConfigurator (priority:200000) +15:39:02.521 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_DMN_DATABASECHANGELOG +15:39:02.579 [restartedMain] INFO o.f.d.e.i.DmnEngineImpl - [<init>,55] - DmnEngine default created +15:39:02.580 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.form.spring.configurator.SpringFormEngineConfigurator (priority:300000) +15:39:02.706 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_FO_DATABASECHANGELOG +15:39:02.791 [restartedMain] INFO o.f.f.e.i.FormEngineImpl - [<init>,52] - FormEngine default created +15:39:02.793 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.content.spring.configurator.SpringContentEngineConfigurator (priority:400000) +15:39:02.796 [restartedMain] INFO o.f.c.s.SpringContentEngineConfiguration - [initContentStorage,196] - Content file system root : C:\Users\23082\content +15:39:03.100 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_CO_DATABASECHANGELOG +15:39:03.150 [restartedMain] INFO o.f.c.e.i.ContentEngineImpl - [<init>,48] - ContentEngine default created +15:39:03.153 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.cmmn.spring.configurator.SpringCmmnEngineConfigurator (priority:500000) +15:39:03.494 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_CMMN_DATABASECHANGELOG +15:39:03.561 [restartedMain] INFO o.f.c.e.i.CmmnEngineImpl - [<init>,72] - CmmnEngine default created +15:39:03.689 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_APP_DATABASECHANGELOG +15:39:03.739 [restartedMain] INFO o.f.a.e.i.AppEngineImpl - [<init>,48] - AppEngine default created +15:39:06.773 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +15:39:06.799 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +15:39:06.799 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +15:39:06.801 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +15:39:06.803 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +15:39:06.803 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +15:39:06.803 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +15:39:06.804 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@49645c +15:39:07.272 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Starting ProtocolHandler ["http-nio-8080"] +15:39:07.649 [restartedMain] INFO o.q.c.QuartzScheduler - [start,547] - Scheduler quartzScheduler_$_NON_CLUSTERED started. +15:39:07.658 [restartedMain] INFO c.w.w.WinApplication - [logStarted,61] - Started WinApplication in 19.339 seconds (JVM running for 20.029) +16:28:38.495 [Thread-5] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +16:28:38.699 [Thread-5] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +16:28:38.699 [Thread-5] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +16:28:38.699 [Thread-5] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +16:28:39.118 [Thread-5] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +16:28:39.122 [Thread-5] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +16:28:39.126 [Thread-5] INFO c.a.d.p.DruidDataSource - [close,2105] - {dataSource-1} closing ... +16:28:39.132 [Thread-5] INFO c.a.d.p.DruidDataSource - [close,2178] - {dataSource-1} closed +16:52:45.505 [restartedMain] INFO c.w.w.WinApplication - [logStarting,55] - Starting WinApplication using Java 1.8.0_231 on LAPTOP-K8GOQEG9 with PID 55472 (D:\workspace\wenyin\win\win-admin\target\classes started by admin in D:\workspace\wenyin\win) +16:52:45.505 [restartedMain] INFO c.w.w.WinApplication - [logStartupProfileInfo,686] - The following 3 profiles are active: "druid", "mybatis", "dev" +16:52:46.449 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +16:52:46.449 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +16:52:46.459 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +16:52:46.600 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,985] - {dataSource-2,ccwin} inited +16:52:46.600 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [ccwin] success +16:52:46.600 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +16:52:46.600 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [ccwin] +16:52:47.778 [restartedMain] INFO o.f.s.b.ProcessEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +16:52:47.974 [restartedMain] INFO o.f.s.b.c.CmmnEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +16:52:48.077 [restartedMain] INFO o.f.s.b.d.DmnEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +16:52:48.106 [restartedMain] INFO o.f.s.b.f.FormEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +16:52:48.134 [restartedMain] INFO o.f.s.b.e.EventRegistryAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +16:52:48.159 [restartedMain] INFO o.f.s.b.a.AppEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +16:52:48.173 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1073] - Found 7 Engine Configurators in total: +16:52:48.173 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.engine.spring.configurator.SpringProcessEngineConfigurator (priority:50000) +16:52:48.174 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.eventregistry.spring.configurator.SpringEventRegistryConfigurator (priority:100000) +16:52:48.174 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.idm.spring.configurator.SpringIdmEngineConfigurator (priority:150000) +16:52:48.174 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.dmn.spring.configurator.SpringDmnEngineConfigurator (priority:200000) +16:52:48.174 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.form.spring.configurator.SpringFormEngineConfigurator (priority:300000) +16:52:48.174 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.content.spring.configurator.SpringContentEngineConfigurator (priority:400000) +16:52:48.174 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.cmmn.spring.configurator.SpringCmmnEngineConfigurator (priority:500000) +16:52:48.174 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.engine.spring.configurator.SpringProcessEngineConfigurator (priority:50000) +16:52:48.176 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.eventregistry.spring.configurator.SpringEventRegistryConfigurator (priority:100000) +16:52:48.177 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.idm.spring.configurator.SpringIdmEngineConfigurator (priority:150000) +16:52:48.178 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.dmn.spring.configurator.SpringDmnEngineConfigurator (priority:200000) +16:52:48.179 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.form.spring.configurator.SpringFormEngineConfigurator (priority:300000) +16:52:48.179 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.content.spring.configurator.SpringContentEngineConfigurator (priority:400000) +16:52:48.180 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.cmmn.spring.configurator.SpringCmmnEngineConfigurator (priority:500000) +16:52:48.674 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.engine.spring.configurator.SpringProcessEngineConfigurator (priority:50000) +16:52:48.744 [restartedMain] INFO o.f.e.i.ProcessEngineImpl - [<init>,89] - ProcessEngine default created +16:52:48.771 [restartedMain] INFO o.f.e.i.c.ValidateV5EntitiesCmd - [execute,43] - Total of v5 deployments found: 0 +16:52:48.871 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.eventregistry.spring.configurator.SpringEventRegistryConfigurator (priority:100000) +16:52:49.078 [restartedMain] INFO o.f.e.i.EventRegistryEngineImpl - [<init>,53] - EventRegistryEngine default created +16:52:49.079 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.idm.spring.configurator.SpringIdmEngineConfigurator (priority:150000) +16:52:49.161 [restartedMain] INFO o.f.i.e.i.IdmEngineImpl - [<init>,52] - IdmEngine default created +16:52:49.162 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.dmn.spring.configurator.SpringDmnEngineConfigurator (priority:200000) +16:52:49.322 [restartedMain] INFO o.f.d.e.i.DmnEngineImpl - [<init>,55] - DmnEngine default created +16:52:49.322 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.form.spring.configurator.SpringFormEngineConfigurator (priority:300000) +16:52:49.473 [restartedMain] INFO o.f.f.e.i.FormEngineImpl - [<init>,52] - FormEngine default created +16:52:49.474 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.content.spring.configurator.SpringContentEngineConfigurator (priority:400000) +16:52:49.475 [restartedMain] INFO o.f.c.s.SpringContentEngineConfiguration - [initContentStorage,196] - Content file system root : C:\Users\23082\content +16:52:49.609 [restartedMain] INFO o.f.c.e.i.ContentEngineImpl - [<init>,48] - ContentEngine default created +16:52:49.610 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.cmmn.spring.configurator.SpringCmmnEngineConfigurator (priority:500000) +16:52:49.750 [restartedMain] INFO o.f.c.e.i.CmmnEngineImpl - [<init>,72] - CmmnEngine default created +16:52:49.893 [restartedMain] INFO o.f.a.e.i.AppEngineImpl - [<init>,48] - AppEngine default created +16:52:50.747 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +16:52:50.748 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +16:52:50.748 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +16:52:50.748 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +16:52:50.748 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +16:52:50.749 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +16:52:50.749 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +16:52:50.749 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@7b95dbe +16:52:51.128 [restartedMain] INFO o.q.c.QuartzScheduler - [start,547] - Scheduler quartzScheduler_$_NON_CLUSTERED started. +16:52:51.131 [restartedMain] INFO c.w.w.WinApplication - [logStarted,61] - Started WinApplication in 5.691 seconds (JVM running for 4443.501) +16:52:51.132 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +16:52:51.292 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +16:52:51.293 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +16:52:51.293 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +16:52:51.353 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +16:52:51.355 [SpringApplicationShutdownHook] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +16:52:51.355 [SpringApplicationShutdownHook] INFO c.a.d.p.DruidDataSource - [close,2105] - {dataSource-2} closing ... +16:52:51.355 [SpringApplicationShutdownHook] INFO c.a.d.p.DruidDataSource - [close,2178] - {dataSource-2} closed +16:52:55.590 [restartedMain] INFO c.w.w.WinApplication - [logStarting,55] - Starting WinApplication using Java 1.8.0_231 on LAPTOP-K8GOQEG9 with PID 57256 (D:\workspace\wenyin\win\win-admin\target\classes started by admin in D:\workspace\wenyin\win) +16:52:55.590 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +16:52:55.592 [restartedMain] INFO c.w.w.WinApplication - [logStartupProfileInfo,686] - The following 3 profiles are active: "druid", "mybatis", "dev" +16:52:59.268 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-8080"] +16:52:59.269 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +16:52:59.269 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +16:52:59.333 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +16:53:01.106 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,985] - {dataSource-1,ccwin} inited +16:53:01.108 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [ccwin] success +16:53:01.109 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +16:53:01.110 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [ccwin] +16:53:05.355 [restartedMain] INFO o.f.s.b.ProcessEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +16:53:05.962 [restartedMain] INFO o.f.s.b.c.CmmnEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +16:53:06.075 [restartedMain] INFO o.f.s.b.d.DmnEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +16:53:06.119 [restartedMain] INFO o.f.s.b.f.FormEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +16:53:06.184 [restartedMain] INFO o.f.s.b.e.EventRegistryAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +16:53:06.225 [restartedMain] INFO o.f.s.b.a.AppEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +16:53:06.244 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1073] - Found 7 Engine Configurators in total: +16:53:06.244 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.engine.spring.configurator.SpringProcessEngineConfigurator (priority:50000) +16:53:06.245 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.eventregistry.spring.configurator.SpringEventRegistryConfigurator (priority:100000) +16:53:06.245 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.idm.spring.configurator.SpringIdmEngineConfigurator (priority:150000) +16:53:06.245 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.dmn.spring.configurator.SpringDmnEngineConfigurator (priority:200000) +16:53:06.245 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.form.spring.configurator.SpringFormEngineConfigurator (priority:300000) +16:53:06.245 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.content.spring.configurator.SpringContentEngineConfigurator (priority:400000) +16:53:06.245 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.cmmn.spring.configurator.SpringCmmnEngineConfigurator (priority:500000) +16:53:06.245 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.engine.spring.configurator.SpringProcessEngineConfigurator (priority:50000) +16:53:06.250 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.eventregistry.spring.configurator.SpringEventRegistryConfigurator (priority:100000) +16:53:06.253 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.idm.spring.configurator.SpringIdmEngineConfigurator (priority:150000) +16:53:06.254 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.dmn.spring.configurator.SpringDmnEngineConfigurator (priority:200000) +16:53:06.256 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.form.spring.configurator.SpringFormEngineConfigurator (priority:300000) +16:53:06.257 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.content.spring.configurator.SpringContentEngineConfigurator (priority:400000) +16:53:06.258 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.cmmn.spring.configurator.SpringCmmnEngineConfigurator (priority:500000) +16:53:06.969 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.engine.spring.configurator.SpringProcessEngineConfigurator (priority:50000) +16:53:07.301 [restartedMain] INFO o.f.e.i.ProcessEngineImpl - [<init>,89] - ProcessEngine default created +16:53:07.332 [restartedMain] INFO o.f.e.i.c.ValidateV5EntitiesCmd - [execute,43] - Total of v5 deployments found: 0 +16:53:07.439 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.eventregistry.spring.configurator.SpringEventRegistryConfigurator (priority:100000) +16:53:08.212 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.FLW_EV_DATABASECHANGELOG +16:53:08.262 [restartedMain] INFO o.f.e.i.EventRegistryEngineImpl - [<init>,53] - EventRegistryEngine default created +16:53:08.263 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.idm.spring.configurator.SpringIdmEngineConfigurator (priority:150000) +16:53:08.341 [restartedMain] INFO o.f.i.e.i.IdmEngineImpl - [<init>,52] - IdmEngine default created +16:53:08.342 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.dmn.spring.configurator.SpringDmnEngineConfigurator (priority:200000) +16:53:08.471 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_DMN_DATABASECHANGELOG +16:53:08.510 [restartedMain] INFO o.f.d.e.i.DmnEngineImpl - [<init>,55] - DmnEngine default created +16:53:08.511 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.form.spring.configurator.SpringFormEngineConfigurator (priority:300000) +16:53:08.620 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_FO_DATABASECHANGELOG +16:53:08.660 [restartedMain] INFO o.f.f.e.i.FormEngineImpl - [<init>,52] - FormEngine default created +16:53:08.662 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.content.spring.configurator.SpringContentEngineConfigurator (priority:400000) +16:53:08.665 [restartedMain] INFO o.f.c.s.SpringContentEngineConfiguration - [initContentStorage,196] - Content file system root : C:\Users\23082\content +16:53:08.942 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_CO_DATABASECHANGELOG +16:53:08.982 [restartedMain] INFO o.f.c.e.i.ContentEngineImpl - [<init>,48] - ContentEngine default created +16:53:08.984 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.cmmn.spring.configurator.SpringCmmnEngineConfigurator (priority:500000) +16:53:09.171 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_CMMN_DATABASECHANGELOG +16:53:09.222 [restartedMain] INFO o.f.c.e.i.CmmnEngineImpl - [<init>,72] - CmmnEngine default created +16:53:09.337 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_APP_DATABASECHANGELOG +16:53:09.379 [restartedMain] INFO o.f.a.e.i.AppEngineImpl - [<init>,48] - AppEngine default created +16:53:12.387 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +16:53:12.409 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +16:53:12.409 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +16:53:12.411 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +16:53:12.412 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +16:53:12.412 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +16:53:12.413 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +16:53:12.413 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@3c5ca2fe +16:53:12.762 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Starting ProtocolHandler ["http-nio-8080"] +16:53:13.206 [restartedMain] INFO o.q.c.QuartzScheduler - [start,547] - Scheduler quartzScheduler_$_NON_CLUSTERED started. +16:53:13.216 [restartedMain] INFO c.w.w.WinApplication - [logStarted,61] - Started WinApplication in 18.114 seconds (JVM running for 18.592) +17:17:59.437 [http-nio-8080-exec-1] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring DispatcherServlet 'dispatcherServlet' +17:30:51.612 [http-nio-8080-exec-70] INFO o.a.t.u.h.p.Cookie - [log,173] - A cookie header was received [Hm_lvt_931a8de1263e8fcdea855e1b3c00abff=1687155670,1687337520;] that contained an invalid cookie. That cookie will be ignored. + Note: further occurrences of this error will be logged at DEBUG level. +17:39:56.212 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +17:39:56.381 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +17:39:56.381 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +17:39:56.381 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +17:39:56.501 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +17:39:56.503 [SpringApplicationShutdownHook] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +17:39:56.507 [SpringApplicationShutdownHook] INFO c.a.d.p.DruidDataSource - [close,2105] - {dataSource-1} closing ... +17:39:56.513 [SpringApplicationShutdownHook] INFO c.a.d.p.DruidDataSource - [close,2178] - {dataSource-1} closed diff --git a/logs/sys-info.2023-07-21.log b/logs/sys-info.2023-07-21.log new file mode 100644 index 0000000..7a8a3dc --- /dev/null +++ b/logs/sys-info.2023-07-21.log @@ -0,0 +1,243 @@ +09:44:00.444 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +09:44:00.445 [restartedMain] INFO c.w.w.WinApplication - [logStarting,55] - Starting WinApplication using Java 1.8.0_231 on LAPTOP-K8GOQEG9 with PID 54044 (D:\workspace\wenyin\win\win-admin\target\classes started by admin in D:\workspace\wenyin\win) +09:44:00.453 [restartedMain] INFO c.w.w.WinApplication - [logStartupProfileInfo,686] - The following 3 profiles are active: "druid", "mybatis", "dev" +09:44:04.261 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-8080"] +09:44:04.262 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +09:44:04.263 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +09:44:04.346 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +09:44:06.082 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,985] - {dataSource-1,ccwin} inited +09:44:06.084 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [ccwin] success +09:44:06.085 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +09:44:06.086 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [ccwin] +09:44:10.271 [restartedMain] INFO o.f.s.b.ProcessEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +09:44:10.816 [restartedMain] INFO o.f.s.b.c.CmmnEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +09:44:10.983 [restartedMain] INFO o.f.s.b.d.DmnEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +09:44:11.033 [restartedMain] INFO o.f.s.b.f.FormEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +09:44:11.096 [restartedMain] INFO o.f.s.b.e.EventRegistryAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +09:44:11.159 [restartedMain] INFO o.f.s.b.a.AppEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +09:44:11.177 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1073] - Found 7 Engine Configurators in total: +09:44:11.177 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.engine.spring.configurator.SpringProcessEngineConfigurator (priority:50000) +09:44:11.178 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.eventregistry.spring.configurator.SpringEventRegistryConfigurator (priority:100000) +09:44:11.178 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.idm.spring.configurator.SpringIdmEngineConfigurator (priority:150000) +09:44:11.178 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.dmn.spring.configurator.SpringDmnEngineConfigurator (priority:200000) +09:44:11.178 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.form.spring.configurator.SpringFormEngineConfigurator (priority:300000) +09:44:11.178 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.content.spring.configurator.SpringContentEngineConfigurator (priority:400000) +09:44:11.179 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.cmmn.spring.configurator.SpringCmmnEngineConfigurator (priority:500000) +09:44:11.179 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.engine.spring.configurator.SpringProcessEngineConfigurator (priority:50000) +09:44:11.184 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.eventregistry.spring.configurator.SpringEventRegistryConfigurator (priority:100000) +09:44:11.187 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.idm.spring.configurator.SpringIdmEngineConfigurator (priority:150000) +09:44:11.188 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.dmn.spring.configurator.SpringDmnEngineConfigurator (priority:200000) +09:44:11.190 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.form.spring.configurator.SpringFormEngineConfigurator (priority:300000) +09:44:11.191 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.content.spring.configurator.SpringContentEngineConfigurator (priority:400000) +09:44:11.192 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.cmmn.spring.configurator.SpringCmmnEngineConfigurator (priority:500000) +09:44:12.015 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.engine.spring.configurator.SpringProcessEngineConfigurator (priority:50000) +09:44:12.394 [restartedMain] INFO o.f.e.i.ProcessEngineImpl - [<init>,89] - ProcessEngine default created +09:44:12.432 [restartedMain] INFO o.f.e.i.c.ValidateV5EntitiesCmd - [execute,43] - Total of v5 deployments found: 0 +09:44:12.533 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.eventregistry.spring.configurator.SpringEventRegistryConfigurator (priority:100000) +09:44:13.465 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.FLW_EV_DATABASECHANGELOG +09:44:13.532 [restartedMain] INFO o.f.e.i.EventRegistryEngineImpl - [<init>,53] - EventRegistryEngine default created +09:44:13.534 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.idm.spring.configurator.SpringIdmEngineConfigurator (priority:150000) +09:44:13.633 [restartedMain] INFO o.f.i.e.i.IdmEngineImpl - [<init>,52] - IdmEngine default created +09:44:13.635 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.dmn.spring.configurator.SpringDmnEngineConfigurator (priority:200000) +09:44:13.784 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_DMN_DATABASECHANGELOG +09:44:13.826 [restartedMain] INFO o.f.d.e.i.DmnEngineImpl - [<init>,55] - DmnEngine default created +09:44:13.827 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.form.spring.configurator.SpringFormEngineConfigurator (priority:300000) +09:44:13.965 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_FO_DATABASECHANGELOG +09:44:14.004 [restartedMain] INFO o.f.f.e.i.FormEngineImpl - [<init>,52] - FormEngine default created +09:44:14.007 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.content.spring.configurator.SpringContentEngineConfigurator (priority:400000) +09:44:14.010 [restartedMain] INFO o.f.c.s.SpringContentEngineConfiguration - [initContentStorage,196] - Content file system root : C:\Users\23082\content +09:44:14.296 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_CO_DATABASECHANGELOG +09:44:14.353 [restartedMain] INFO o.f.c.e.i.ContentEngineImpl - [<init>,48] - ContentEngine default created +09:44:14.355 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.cmmn.spring.configurator.SpringCmmnEngineConfigurator (priority:500000) +09:44:14.552 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_CMMN_DATABASECHANGELOG +09:44:14.602 [restartedMain] INFO o.f.c.e.i.CmmnEngineImpl - [<init>,72] - CmmnEngine default created +09:44:14.728 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_APP_DATABASECHANGELOG +09:44:14.782 [restartedMain] INFO o.f.a.e.i.AppEngineImpl - [<init>,48] - AppEngine default created +09:44:17.774 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +09:44:17.795 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +09:44:17.795 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +09:44:17.796 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +09:44:17.797 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +09:44:17.797 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +09:44:17.797 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +09:44:17.797 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@1c0991a2 +09:44:18.246 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Starting ProtocolHandler ["http-nio-8080"] +09:44:18.707 [restartedMain] INFO o.q.c.QuartzScheduler - [start,547] - Scheduler quartzScheduler_$_NON_CLUSTERED started. +09:44:18.719 [restartedMain] INFO c.w.w.WinApplication - [logStarted,61] - Started WinApplication in 18.795 seconds (JVM running for 19.848) +09:44:40.401 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +09:44:40.587 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +09:44:40.588 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +09:44:40.588 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +09:44:40.713 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +09:44:40.717 [SpringApplicationShutdownHook] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +09:44:40.720 [SpringApplicationShutdownHook] INFO c.a.d.p.DruidDataSource - [close,2105] - {dataSource-1} closing ... +09:44:40.723 [SpringApplicationShutdownHook] INFO c.a.d.p.DruidDataSource - [close,2178] - {dataSource-1} closed +10:20:05.703 [restartedMain] INFO c.w.w.WinApplication - [logStarting,55] - Starting WinApplication using Java 1.8.0_231 on LAPTOP-K8GOQEG9 with PID 50920 (D:\workspace\wenyin\win\win-admin\target\classes started by admin in D:\workspace\wenyin\win) +10:20:05.704 [restartedMain] INFO c.w.w.WinApplication - [logStartupProfileInfo,686] - The following 3 profiles are active: "druid", "mybatis", "dev" +10:20:05.707 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +10:20:09.283 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-8080"] +10:20:09.284 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +10:20:09.284 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +10:20:09.341 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +10:20:11.109 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,996] - {dataSource-1,ccwin} inited +10:20:11.110 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [ccwin] success +10:20:11.111 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +10:20:11.112 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [ccwin] +10:20:14.829 [restartedMain] INFO o.f.s.b.ProcessEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +10:20:15.634 [restartedMain] INFO o.f.s.b.c.CmmnEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +10:20:15.751 [restartedMain] INFO o.f.s.b.d.DmnEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +10:20:15.802 [restartedMain] INFO o.f.s.b.f.FormEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +10:20:15.871 [restartedMain] INFO o.f.s.b.e.EventRegistryAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +10:20:15.918 [restartedMain] INFO o.f.s.b.a.AppEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +10:20:15.936 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1073] - Found 7 Engine Configurators in total: +10:20:15.936 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.engine.spring.configurator.SpringProcessEngineConfigurator (priority:50000) +10:20:15.937 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.eventregistry.spring.configurator.SpringEventRegistryConfigurator (priority:100000) +10:20:15.937 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.idm.spring.configurator.SpringIdmEngineConfigurator (priority:150000) +10:20:15.937 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.dmn.spring.configurator.SpringDmnEngineConfigurator (priority:200000) +10:20:15.937 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.form.spring.configurator.SpringFormEngineConfigurator (priority:300000) +10:20:15.937 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.content.spring.configurator.SpringContentEngineConfigurator (priority:400000) +10:20:15.937 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.cmmn.spring.configurator.SpringCmmnEngineConfigurator (priority:500000) +10:20:15.937 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.engine.spring.configurator.SpringProcessEngineConfigurator (priority:50000) +10:20:15.941 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.eventregistry.spring.configurator.SpringEventRegistryConfigurator (priority:100000) +10:20:15.944 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.idm.spring.configurator.SpringIdmEngineConfigurator (priority:150000) +10:20:15.945 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.dmn.spring.configurator.SpringDmnEngineConfigurator (priority:200000) +10:20:15.947 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.form.spring.configurator.SpringFormEngineConfigurator (priority:300000) +10:20:15.947 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.content.spring.configurator.SpringContentEngineConfigurator (priority:400000) +10:20:15.948 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.cmmn.spring.configurator.SpringCmmnEngineConfigurator (priority:500000) +10:20:16.693 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.engine.spring.configurator.SpringProcessEngineConfigurator (priority:50000) +10:20:17.019 [restartedMain] INFO o.f.e.i.ProcessEngineImpl - [<init>,89] - ProcessEngine default created +10:20:17.046 [restartedMain] INFO o.f.e.i.c.ValidateV5EntitiesCmd - [execute,43] - Total of v5 deployments found: 0 +10:20:17.190 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.eventregistry.spring.configurator.SpringEventRegistryConfigurator (priority:100000) +10:20:17.963 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.FLW_EV_DATABASECHANGELOG +10:20:18.032 [restartedMain] INFO o.f.e.i.EventRegistryEngineImpl - [<init>,53] - EventRegistryEngine default created +10:20:18.033 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.idm.spring.configurator.SpringIdmEngineConfigurator (priority:150000) +10:20:18.131 [restartedMain] INFO o.f.i.e.i.IdmEngineImpl - [<init>,52] - IdmEngine default created +10:20:18.133 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.dmn.spring.configurator.SpringDmnEngineConfigurator (priority:200000) +10:20:18.271 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_DMN_DATABASECHANGELOG +10:20:18.317 [restartedMain] INFO o.f.d.e.i.DmnEngineImpl - [<init>,55] - DmnEngine default created +10:20:18.318 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.form.spring.configurator.SpringFormEngineConfigurator (priority:300000) +10:20:18.442 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_FO_DATABASECHANGELOG +10:20:18.519 [restartedMain] INFO o.f.f.e.i.FormEngineImpl - [<init>,52] - FormEngine default created +10:20:18.520 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.content.spring.configurator.SpringContentEngineConfigurator (priority:400000) +10:20:18.523 [restartedMain] INFO o.f.c.s.SpringContentEngineConfiguration - [initContentStorage,196] - Content file system root : C:\Users\23082\content +10:20:18.822 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_CO_DATABASECHANGELOG +10:20:18.883 [restartedMain] INFO o.f.c.e.i.ContentEngineImpl - [<init>,48] - ContentEngine default created +10:20:18.884 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.cmmn.spring.configurator.SpringCmmnEngineConfigurator (priority:500000) +10:20:19.066 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_CMMN_DATABASECHANGELOG +10:20:19.121 [restartedMain] INFO o.f.c.e.i.CmmnEngineImpl - [<init>,72] - CmmnEngine default created +10:20:19.236 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_APP_DATABASECHANGELOG +10:20:19.302 [restartedMain] INFO o.f.a.e.i.AppEngineImpl - [<init>,48] - AppEngine default created +10:20:22.065 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +10:20:22.085 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +10:20:22.085 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +10:20:22.087 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +10:20:22.088 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +10:20:22.088 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +10:20:22.088 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +10:20:22.088 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@68ba70bd +10:20:22.532 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Starting ProtocolHandler ["http-nio-8080"] +10:20:22.983 [restartedMain] INFO o.q.c.QuartzScheduler - [start,547] - Scheduler quartzScheduler_$_NON_CLUSTERED started. +10:20:22.993 [restartedMain] INFO c.w.w.WinApplication - [logStarted,61] - Started WinApplication in 17.785 seconds (JVM running for 18.532) +10:56:11.009 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +10:56:11.158 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +10:56:11.158 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +10:56:11.158 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +10:56:11.452 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +10:56:11.455 [SpringApplicationShutdownHook] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +10:56:11.458 [SpringApplicationShutdownHook] INFO c.a.d.p.DruidDataSource - [close,2138] - {dataSource-1} closing ... +10:56:11.460 [SpringApplicationShutdownHook] INFO c.a.d.p.DruidDataSource - [close,2211] - {dataSource-1} closed +11:04:15.572 [restartedMain] INFO c.w.w.WinApplication - [logStarting,55] - Starting WinApplication using Java 1.8.0_231 on LAPTOP-K8GOQEG9 with PID 27848 (D:\workspace\wenyin\win\win-admin\target\classes started by admin in D:\workspace\wenyin\win) +11:04:15.574 [restartedMain] INFO c.w.w.WinApplication - [logStartupProfileInfo,686] - The following 3 profiles are active: "druid", "mybatis", "dev" +11:04:15.579 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +11:04:18.821 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-8080"] +11:04:18.822 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +11:04:18.822 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +11:04:18.887 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +11:04:20.517 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,996] - {dataSource-1,ccwin} inited +11:04:20.518 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [ccwin] success +11:04:20.519 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +11:04:20.519 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [ccwin] +11:04:24.454 [restartedMain] INFO o.f.s.b.ProcessEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +11:04:25.087 [restartedMain] INFO o.f.s.b.c.CmmnEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +11:04:25.242 [restartedMain] INFO o.f.s.b.d.DmnEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +11:04:25.317 [restartedMain] INFO o.f.s.b.f.FormEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +11:04:25.394 [restartedMain] INFO o.f.s.b.e.EventRegistryAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +11:04:25.456 [restartedMain] INFO o.f.s.b.a.AppEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +11:04:25.477 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1073] - Found 7 Engine Configurators in total: +11:04:25.478 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.engine.spring.configurator.SpringProcessEngineConfigurator (priority:50000) +11:04:25.478 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.eventregistry.spring.configurator.SpringEventRegistryConfigurator (priority:100000) +11:04:25.478 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.idm.spring.configurator.SpringIdmEngineConfigurator (priority:150000) +11:04:25.478 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.dmn.spring.configurator.SpringDmnEngineConfigurator (priority:200000) +11:04:25.478 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.form.spring.configurator.SpringFormEngineConfigurator (priority:300000) +11:04:25.478 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.content.spring.configurator.SpringContentEngineConfigurator (priority:400000) +11:04:25.479 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.cmmn.spring.configurator.SpringCmmnEngineConfigurator (priority:500000) +11:04:25.479 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.engine.spring.configurator.SpringProcessEngineConfigurator (priority:50000) +11:04:25.483 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.eventregistry.spring.configurator.SpringEventRegistryConfigurator (priority:100000) +11:04:25.485 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.idm.spring.configurator.SpringIdmEngineConfigurator (priority:150000) +11:04:25.487 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.dmn.spring.configurator.SpringDmnEngineConfigurator (priority:200000) +11:04:25.488 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.form.spring.configurator.SpringFormEngineConfigurator (priority:300000) +11:04:25.489 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.content.spring.configurator.SpringContentEngineConfigurator (priority:400000) +11:04:25.490 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.cmmn.spring.configurator.SpringCmmnEngineConfigurator (priority:500000) +11:04:26.203 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.engine.spring.configurator.SpringProcessEngineConfigurator (priority:50000) +11:04:26.524 [restartedMain] INFO o.f.e.i.ProcessEngineImpl - [<init>,89] - ProcessEngine default created +11:04:26.562 [restartedMain] INFO o.f.e.i.c.ValidateV5EntitiesCmd - [execute,43] - Total of v5 deployments found: 0 +11:04:26.665 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.eventregistry.spring.configurator.SpringEventRegistryConfigurator (priority:100000) +11:04:27.477 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.FLW_EV_DATABASECHANGELOG +11:04:27.526 [restartedMain] INFO o.f.e.i.EventRegistryEngineImpl - [<init>,53] - EventRegistryEngine default created +11:04:27.527 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.idm.spring.configurator.SpringIdmEngineConfigurator (priority:150000) +11:04:27.596 [restartedMain] INFO o.f.i.e.i.IdmEngineImpl - [<init>,52] - IdmEngine default created +11:04:27.598 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.dmn.spring.configurator.SpringDmnEngineConfigurator (priority:200000) +11:04:27.727 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_DMN_DATABASECHANGELOG +11:04:27.775 [restartedMain] INFO o.f.d.e.i.DmnEngineImpl - [<init>,55] - DmnEngine default created +11:04:27.777 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.form.spring.configurator.SpringFormEngineConfigurator (priority:300000) +11:04:27.903 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_FO_DATABASECHANGELOG +11:04:27.966 [restartedMain] INFO o.f.f.e.i.FormEngineImpl - [<init>,52] - FormEngine default created +11:04:27.968 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.content.spring.configurator.SpringContentEngineConfigurator (priority:400000) +11:04:27.971 [restartedMain] INFO o.f.c.s.SpringContentEngineConfiguration - [initContentStorage,196] - Content file system root : C:\Users\23082\content +11:04:28.238 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_CO_DATABASECHANGELOG +11:04:28.287 [restartedMain] INFO o.f.c.e.i.ContentEngineImpl - [<init>,48] - ContentEngine default created +11:04:28.288 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.cmmn.spring.configurator.SpringCmmnEngineConfigurator (priority:500000) +11:04:28.469 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_CMMN_DATABASECHANGELOG +11:04:28.519 [restartedMain] INFO o.f.c.e.i.CmmnEngineImpl - [<init>,72] - CmmnEngine default created +11:04:28.622 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_APP_DATABASECHANGELOG +11:04:28.642 [restartedMain] INFO o.f.a.e.i.AppEngineImpl - [<init>,48] - AppEngine default created +11:04:31.620 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +11:04:31.652 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +11:04:31.652 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +11:04:31.652 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +11:04:31.652 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +11:04:31.652 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +11:04:31.652 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +11:04:31.652 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@693b6ed1 +11:04:31.983 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Starting ProtocolHandler ["http-nio-8080"] +11:04:32.331 [restartedMain] INFO o.q.c.QuartzScheduler - [start,547] - Scheduler quartzScheduler_$_NON_CLUSTERED started. +11:04:32.347 [restartedMain] INFO c.w.w.WinApplication - [logStarted,61] - Started WinApplication in 17.33 seconds (JVM running for 18.046) +11:08:05.374 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +11:08:05.529 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +11:08:05.529 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +11:08:05.529 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +11:08:05.666 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +11:08:05.669 [SpringApplicationShutdownHook] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +11:08:05.671 [SpringApplicationShutdownHook] INFO c.a.d.p.DruidDataSource - [close,2138] - {dataSource-1} closing ... +11:08:05.674 [SpringApplicationShutdownHook] INFO c.a.d.p.DruidDataSource - [close,2211] - {dataSource-1} closed diff --git a/logs/sys-info.2023-07-24.log b/logs/sys-info.2023-07-24.log new file mode 100644 index 0000000..73bfb8c --- /dev/null +++ b/logs/sys-info.2023-07-24.log @@ -0,0 +1,1037 @@ +07:36:08.141 [restartedMain] INFO c.w.w.WinApplication - [logStarting,55] - Starting WinApplication using Java 1.8.0_231 on LAPTOP-K8GOQEG9 with PID 49864 (D:\workspace\wenyin\win\win-admin\target\classes started by admin in D:\workspace\wenyin\win) +07:36:08.141 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +07:36:08.157 [restartedMain] INFO c.w.w.WinApplication - [logStartupProfileInfo,686] - The following 3 profiles are active: "druid", "mybatis", "dev" +07:36:11.881 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-8080"] +07:36:11.881 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +07:36:11.881 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +07:36:11.991 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +07:36:13.738 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,996] - {dataSource-1,ccwin} inited +07:36:13.738 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [ccwin] success +07:36:13.738 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +07:36:13.738 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [ccwin] +07:36:17.886 [restartedMain] INFO o.f.s.b.ProcessEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +07:36:18.467 [restartedMain] INFO o.f.s.b.c.CmmnEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +07:36:18.593 [restartedMain] INFO o.f.s.b.d.DmnEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +07:36:18.640 [restartedMain] INFO o.f.s.b.f.FormEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +07:36:18.687 [restartedMain] INFO o.f.s.b.e.EventRegistryAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +07:36:18.734 [restartedMain] INFO o.f.s.b.a.AppEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +07:36:18.765 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1073] - Found 7 Engine Configurators in total: +07:36:18.765 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.engine.spring.configurator.SpringProcessEngineConfigurator (priority:50000) +07:36:18.765 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.eventregistry.spring.configurator.SpringEventRegistryConfigurator (priority:100000) +07:36:18.765 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.idm.spring.configurator.SpringIdmEngineConfigurator (priority:150000) +07:36:18.765 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.dmn.spring.configurator.SpringDmnEngineConfigurator (priority:200000) +07:36:18.765 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.form.spring.configurator.SpringFormEngineConfigurator (priority:300000) +07:36:18.765 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.content.spring.configurator.SpringContentEngineConfigurator (priority:400000) +07:36:18.765 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.cmmn.spring.configurator.SpringCmmnEngineConfigurator (priority:500000) +07:36:18.765 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.engine.spring.configurator.SpringProcessEngineConfigurator (priority:50000) +07:36:18.765 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.eventregistry.spring.configurator.SpringEventRegistryConfigurator (priority:100000) +07:36:18.781 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.idm.spring.configurator.SpringIdmEngineConfigurator (priority:150000) +07:36:18.781 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.dmn.spring.configurator.SpringDmnEngineConfigurator (priority:200000) +07:36:18.781 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.form.spring.configurator.SpringFormEngineConfigurator (priority:300000) +07:36:18.781 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.content.spring.configurator.SpringContentEngineConfigurator (priority:400000) +07:36:18.781 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.cmmn.spring.configurator.SpringCmmnEngineConfigurator (priority:500000) +07:36:19.472 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.engine.spring.configurator.SpringProcessEngineConfigurator (priority:50000) +07:36:19.754 [restartedMain] INFO o.f.e.i.ProcessEngineImpl - [<init>,89] - ProcessEngine default created +07:36:19.786 [restartedMain] INFO o.f.e.i.c.ValidateV5EntitiesCmd - [execute,43] - Total of v5 deployments found: 0 +07:36:19.833 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.eventregistry.spring.configurator.SpringEventRegistryConfigurator (priority:100000) +07:36:20.618 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.FLW_EV_DATABASECHANGELOG +07:36:20.665 [restartedMain] INFO o.f.e.i.EventRegistryEngineImpl - [<init>,53] - EventRegistryEngine default created +07:36:20.665 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.idm.spring.configurator.SpringIdmEngineConfigurator (priority:150000) +07:36:20.712 [restartedMain] INFO o.f.i.e.i.IdmEngineImpl - [<init>,52] - IdmEngine default created +07:36:20.712 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.dmn.spring.configurator.SpringDmnEngineConfigurator (priority:200000) +07:36:20.822 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_DMN_DATABASECHANGELOG +07:36:20.853 [restartedMain] INFO o.f.d.e.i.DmnEngineImpl - [<init>,55] - DmnEngine default created +07:36:20.869 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.form.spring.configurator.SpringFormEngineConfigurator (priority:300000) +07:36:20.963 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_FO_DATABASECHANGELOG +07:36:20.979 [restartedMain] INFO o.f.f.e.i.FormEngineImpl - [<init>,52] - FormEngine default created +07:36:20.979 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.content.spring.configurator.SpringContentEngineConfigurator (priority:400000) +07:36:20.979 [restartedMain] INFO o.f.c.s.SpringContentEngineConfiguration - [initContentStorage,196] - Content file system root : C:\Users\23082\content +07:36:21.235 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_CO_DATABASECHANGELOG +07:36:21.245 [restartedMain] INFO o.f.c.e.i.ContentEngineImpl - [<init>,48] - ContentEngine default created +07:36:21.261 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.cmmn.spring.configurator.SpringCmmnEngineConfigurator (priority:500000) +07:36:21.418 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_CMMN_DATABASECHANGELOG +07:36:21.449 [restartedMain] INFO o.f.c.e.i.CmmnEngineImpl - [<init>,72] - CmmnEngine default created +07:36:21.536 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_APP_DATABASECHANGELOG +07:36:21.559 [restartedMain] INFO o.f.a.e.i.AppEngineImpl - [<init>,48] - AppEngine default created +07:36:24.745 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +07:36:24.776 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +07:36:24.776 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +07:36:24.776 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +07:36:24.776 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +07:36:24.776 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +07:36:24.776 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +07:36:24.776 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@7b309bec +07:36:25.169 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Starting ProtocolHandler ["http-nio-8080"] +07:36:25.545 [restartedMain] INFO o.q.c.QuartzScheduler - [start,547] - Scheduler quartzScheduler_$_NON_CLUSTERED started. +07:36:25.548 [restartedMain] INFO c.w.w.WinApplication - [logStarted,61] - Started WinApplication in 17.921 seconds (JVM running for 19.045) +07:37:59.549 [http-nio-8080-exec-2] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring DispatcherServlet 'dispatcherServlet' +07:38:05.554 [schedule-pool-1] INFO sys-user - [run,56] - [127.0.0.1]内网IP[admin][Success][登录成功] +07:38:15.603 [http-nio-8080-exec-9] INFO o.a.t.u.h.p.Cookie - [log,173] - A cookie header was received [Hm_lvt_931a8de1263e8fcdea855e1b3c00abff=1687155670,1687337520;] that contained an invalid cookie. That cookie will be ignored. + Note: further occurrences of this error will be logged at DEBUG level. +07:40:22.348 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +07:40:22.505 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +07:40:22.505 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +07:40:22.505 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +07:40:22.633 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +07:40:22.635 [SpringApplicationShutdownHook] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +07:40:22.638 [SpringApplicationShutdownHook] INFO c.a.d.p.DruidDataSource - [close,2138] - {dataSource-1} closing ... +07:40:22.642 [SpringApplicationShutdownHook] INFO c.a.d.p.DruidDataSource - [close,2211] - {dataSource-1} closed +07:40:27.348 [restartedMain] INFO c.w.w.WinApplication - [logStarting,55] - Starting WinApplication using Java 1.8.0_231 on LAPTOP-K8GOQEG9 with PID 48812 (D:\workspace\wenyin\win\win-admin\target\classes started by admin in D:\workspace\wenyin\win) +07:40:27.349 [restartedMain] INFO c.w.w.WinApplication - [logStartupProfileInfo,686] - The following 3 profiles are active: "druid", "mybatis", "dev" +07:40:27.352 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +07:40:30.758 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-8080"] +07:40:30.759 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +07:40:30.759 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +07:40:30.814 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +07:40:32.288 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,996] - {dataSource-1,ccwin} inited +07:40:32.290 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [ccwin] success +07:40:32.292 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +07:40:32.292 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [ccwin] +07:40:36.212 [restartedMain] INFO o.f.s.b.ProcessEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +07:40:36.780 [restartedMain] INFO o.f.s.b.c.CmmnEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +07:40:36.899 [restartedMain] INFO o.f.s.b.d.DmnEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +07:40:36.944 [restartedMain] INFO o.f.s.b.f.FormEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +07:40:36.991 [restartedMain] INFO o.f.s.b.e.EventRegistryAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +07:40:37.064 [restartedMain] INFO o.f.s.b.a.AppEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +07:40:37.107 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1073] - Found 7 Engine Configurators in total: +07:40:37.108 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.engine.spring.configurator.SpringProcessEngineConfigurator (priority:50000) +07:40:37.109 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.eventregistry.spring.configurator.SpringEventRegistryConfigurator (priority:100000) +07:40:37.109 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.idm.spring.configurator.SpringIdmEngineConfigurator (priority:150000) +07:40:37.109 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.dmn.spring.configurator.SpringDmnEngineConfigurator (priority:200000) +07:40:37.109 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.form.spring.configurator.SpringFormEngineConfigurator (priority:300000) +07:40:37.109 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.content.spring.configurator.SpringContentEngineConfigurator (priority:400000) +07:40:37.109 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.cmmn.spring.configurator.SpringCmmnEngineConfigurator (priority:500000) +07:40:37.110 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.engine.spring.configurator.SpringProcessEngineConfigurator (priority:50000) +07:40:37.115 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.eventregistry.spring.configurator.SpringEventRegistryConfigurator (priority:100000) +07:40:37.120 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.idm.spring.configurator.SpringIdmEngineConfigurator (priority:150000) +07:40:37.122 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.dmn.spring.configurator.SpringDmnEngineConfigurator (priority:200000) +07:40:37.125 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.form.spring.configurator.SpringFormEngineConfigurator (priority:300000) +07:40:37.127 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.content.spring.configurator.SpringContentEngineConfigurator (priority:400000) +07:40:37.128 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.cmmn.spring.configurator.SpringCmmnEngineConfigurator (priority:500000) +07:40:37.934 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.engine.spring.configurator.SpringProcessEngineConfigurator (priority:50000) +07:40:38.212 [restartedMain] INFO o.f.e.i.ProcessEngineImpl - [<init>,89] - ProcessEngine default created +07:40:38.236 [restartedMain] INFO o.f.e.i.c.ValidateV5EntitiesCmd - [execute,43] - Total of v5 deployments found: 0 +07:40:38.285 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.eventregistry.spring.configurator.SpringEventRegistryConfigurator (priority:100000) +07:40:39.061 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.FLW_EV_DATABASECHANGELOG +07:40:39.095 [restartedMain] INFO o.f.e.i.EventRegistryEngineImpl - [<init>,53] - EventRegistryEngine default created +07:40:39.097 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.idm.spring.configurator.SpringIdmEngineConfigurator (priority:150000) +07:40:39.139 [restartedMain] INFO o.f.i.e.i.IdmEngineImpl - [<init>,52] - IdmEngine default created +07:40:39.140 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.dmn.spring.configurator.SpringDmnEngineConfigurator (priority:200000) +07:40:39.252 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_DMN_DATABASECHANGELOG +07:40:39.282 [restartedMain] INFO o.f.d.e.i.DmnEngineImpl - [<init>,55] - DmnEngine default created +07:40:39.283 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.form.spring.configurator.SpringFormEngineConfigurator (priority:300000) +07:40:39.374 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_FO_DATABASECHANGELOG +07:40:39.396 [restartedMain] INFO o.f.f.e.i.FormEngineImpl - [<init>,52] - FormEngine default created +07:40:39.398 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.content.spring.configurator.SpringContentEngineConfigurator (priority:400000) +07:40:39.401 [restartedMain] INFO o.f.c.s.SpringContentEngineConfiguration - [initContentStorage,196] - Content file system root : C:\Users\23082\content +07:40:39.659 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_CO_DATABASECHANGELOG +07:40:39.692 [restartedMain] INFO o.f.c.e.i.ContentEngineImpl - [<init>,48] - ContentEngine default created +07:40:39.693 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.cmmn.spring.configurator.SpringCmmnEngineConfigurator (priority:500000) +07:40:39.885 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_CMMN_DATABASECHANGELOG +07:40:39.946 [restartedMain] INFO o.f.c.e.i.CmmnEngineImpl - [<init>,72] - CmmnEngine default created +07:40:40.038 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_APP_DATABASECHANGELOG +07:40:40.078 [restartedMain] INFO o.f.a.e.i.AppEngineImpl - [<init>,48] - AppEngine default created +07:40:42.733 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +07:40:42.749 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +07:40:42.749 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +07:40:42.750 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +07:40:42.751 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +07:40:42.751 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +07:40:42.751 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +07:40:42.751 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@77875d8d +07:40:43.121 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Starting ProtocolHandler ["http-nio-8080"] +07:40:43.583 [restartedMain] INFO o.q.c.QuartzScheduler - [start,547] - Scheduler quartzScheduler_$_NON_CLUSTERED started. +07:40:43.592 [restartedMain] INFO c.w.w.WinApplication - [logStarted,61] - Started WinApplication in 16.764 seconds (JVM running for 17.348) +07:40:48.205 [http-nio-8080-exec-1] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring DispatcherServlet 'dispatcherServlet' +07:47:27.194 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +07:47:27.339 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +07:47:27.339 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +07:47:27.339 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +07:47:27.403 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +07:47:27.404 [SpringApplicationShutdownHook] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +07:47:27.407 [SpringApplicationShutdownHook] INFO c.a.d.p.DruidDataSource - [close,2138] - {dataSource-1} closing ... +07:47:27.410 [SpringApplicationShutdownHook] INFO c.a.d.p.DruidDataSource - [close,2211] - {dataSource-1} closed +07:47:32.726 [restartedMain] INFO c.w.w.WinApplication - [logStarting,55] - Starting WinApplication using Java 1.8.0_231 on LAPTOP-K8GOQEG9 with PID 24336 (D:\workspace\wenyin\win\win-admin\target\classes started by admin in D:\workspace\wenyin\win) +07:47:32.728 [restartedMain] INFO c.w.w.WinApplication - [logStartupProfileInfo,686] - The following 3 profiles are active: "druid", "mybatis", "dev" +07:47:32.731 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +07:47:36.062 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-8080"] +07:47:36.063 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +07:47:36.064 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +07:47:36.164 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +07:47:38.097 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,996] - {dataSource-1,ccwin} inited +07:47:38.099 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [ccwin] success +07:47:38.101 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +07:47:38.101 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [ccwin] +07:47:41.896 [restartedMain] INFO o.f.s.b.ProcessEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +07:47:42.427 [restartedMain] INFO o.f.s.b.c.CmmnEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +07:47:42.551 [restartedMain] INFO o.f.s.b.d.DmnEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +07:47:42.599 [restartedMain] INFO o.f.s.b.f.FormEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +07:47:42.654 [restartedMain] INFO o.f.s.b.e.EventRegistryAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +07:47:42.692 [restartedMain] INFO o.f.s.b.a.AppEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +07:47:42.713 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1073] - Found 7 Engine Configurators in total: +07:47:42.714 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.engine.spring.configurator.SpringProcessEngineConfigurator (priority:50000) +07:47:42.714 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.eventregistry.spring.configurator.SpringEventRegistryConfigurator (priority:100000) +07:47:42.715 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.idm.spring.configurator.SpringIdmEngineConfigurator (priority:150000) +07:47:42.715 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.dmn.spring.configurator.SpringDmnEngineConfigurator (priority:200000) +07:47:42.715 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.form.spring.configurator.SpringFormEngineConfigurator (priority:300000) +07:47:42.715 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.content.spring.configurator.SpringContentEngineConfigurator (priority:400000) +07:47:42.715 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.cmmn.spring.configurator.SpringCmmnEngineConfigurator (priority:500000) +07:47:42.715 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.engine.spring.configurator.SpringProcessEngineConfigurator (priority:50000) +07:47:42.720 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.eventregistry.spring.configurator.SpringEventRegistryConfigurator (priority:100000) +07:47:42.725 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.idm.spring.configurator.SpringIdmEngineConfigurator (priority:150000) +07:47:42.728 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.dmn.spring.configurator.SpringDmnEngineConfigurator (priority:200000) +07:47:42.731 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.form.spring.configurator.SpringFormEngineConfigurator (priority:300000) +07:47:42.734 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.content.spring.configurator.SpringContentEngineConfigurator (priority:400000) +07:47:42.735 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.cmmn.spring.configurator.SpringCmmnEngineConfigurator (priority:500000) +07:47:43.580 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.engine.spring.configurator.SpringProcessEngineConfigurator (priority:50000) +07:47:43.874 [restartedMain] INFO o.f.e.i.ProcessEngineImpl - [<init>,89] - ProcessEngine default created +07:47:43.901 [restartedMain] INFO o.f.e.i.c.ValidateV5EntitiesCmd - [execute,43] - Total of v5 deployments found: 0 +07:47:43.968 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.eventregistry.spring.configurator.SpringEventRegistryConfigurator (priority:100000) +07:47:44.748 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.FLW_EV_DATABASECHANGELOG +07:47:44.790 [restartedMain] INFO o.f.e.i.EventRegistryEngineImpl - [<init>,53] - EventRegistryEngine default created +07:47:44.791 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.idm.spring.configurator.SpringIdmEngineConfigurator (priority:150000) +07:47:44.843 [restartedMain] INFO o.f.i.e.i.IdmEngineImpl - [<init>,52] - IdmEngine default created +07:47:44.845 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.dmn.spring.configurator.SpringDmnEngineConfigurator (priority:200000) +07:47:44.963 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_DMN_DATABASECHANGELOG +07:47:44.996 [restartedMain] INFO o.f.d.e.i.DmnEngineImpl - [<init>,55] - DmnEngine default created +07:47:44.998 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.form.spring.configurator.SpringFormEngineConfigurator (priority:300000) +07:47:45.097 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_FO_DATABASECHANGELOG +07:47:45.132 [restartedMain] INFO o.f.f.e.i.FormEngineImpl - [<init>,52] - FormEngine default created +07:47:45.134 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.content.spring.configurator.SpringContentEngineConfigurator (priority:400000) +07:47:45.137 [restartedMain] INFO o.f.c.s.SpringContentEngineConfiguration - [initContentStorage,196] - Content file system root : C:\Users\23082\content +07:47:45.389 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_CO_DATABASECHANGELOG +07:47:45.417 [restartedMain] INFO o.f.c.e.i.ContentEngineImpl - [<init>,48] - ContentEngine default created +07:47:45.418 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.cmmn.spring.configurator.SpringCmmnEngineConfigurator (priority:500000) +07:47:45.575 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_CMMN_DATABASECHANGELOG +07:47:45.629 [restartedMain] INFO o.f.c.e.i.CmmnEngineImpl - [<init>,72] - CmmnEngine default created +07:47:45.722 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_APP_DATABASECHANGELOG +07:47:45.752 [restartedMain] INFO o.f.a.e.i.AppEngineImpl - [<init>,48] - AppEngine default created +07:47:48.213 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +07:47:48.229 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +07:47:48.230 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +07:47:48.230 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +07:47:48.232 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +07:47:48.232 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +07:47:48.232 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +07:47:48.232 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@5f9c8e1e +07:47:48.670 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Starting ProtocolHandler ["http-nio-8080"] +07:47:49.164 [restartedMain] INFO o.q.c.QuartzScheduler - [start,547] - Scheduler quartzScheduler_$_NON_CLUSTERED started. +07:47:49.174 [restartedMain] INFO c.w.w.WinApplication - [logStarted,61] - Started WinApplication in 16.923 seconds (JVM running for 17.487) +07:47:52.754 [http-nio-8080-exec-2] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring DispatcherServlet 'dispatcherServlet' +07:49:44.268 [Thread-5] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +07:49:45.097 [Thread-5] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +07:49:45.097 [Thread-5] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +07:49:45.097 [Thread-5] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +07:49:45.157 [Thread-5] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +07:49:45.159 [Thread-5] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +07:49:45.161 [Thread-5] INFO c.a.d.p.DruidDataSource - [close,2138] - {dataSource-1} closing ... +07:49:45.164 [Thread-5] INFO c.a.d.p.DruidDataSource - [close,2211] - {dataSource-1} closed +07:50:03.200 [restartedMain] INFO c.w.w.WinApplication - [logStarting,55] - Starting WinApplication using Java 1.8.0_231 on LAPTOP-K8GOQEG9 with PID 24336 (D:\workspace\wenyin\win\win-admin\target\classes started by admin in D:\workspace\wenyin\win) +07:50:03.201 [restartedMain] INFO c.w.w.WinApplication - [logStartupProfileInfo,686] - The following 3 profiles are active: "druid", "mybatis", "dev" +07:50:03.966 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +07:50:03.967 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +07:50:03.972 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +07:50:04.063 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,996] - {dataSource-2,ccwin} inited +07:50:04.064 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [ccwin] success +07:50:04.064 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +07:50:04.064 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [ccwin] +07:50:05.405 [restartedMain] INFO o.f.s.b.ProcessEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +07:50:05.607 [restartedMain] INFO o.f.s.b.c.CmmnEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +07:50:05.700 [restartedMain] INFO o.f.s.b.d.DmnEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +07:50:05.747 [restartedMain] INFO o.f.s.b.f.FormEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +07:50:05.778 [restartedMain] INFO o.f.s.b.e.EventRegistryAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +07:50:05.818 [restartedMain] INFO o.f.s.b.a.AppEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +07:50:05.845 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1073] - Found 7 Engine Configurators in total: +07:50:05.847 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.engine.spring.configurator.SpringProcessEngineConfigurator (priority:50000) +07:50:05.848 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.eventregistry.spring.configurator.SpringEventRegistryConfigurator (priority:100000) +07:50:05.848 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.idm.spring.configurator.SpringIdmEngineConfigurator (priority:150000) +07:50:05.848 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.dmn.spring.configurator.SpringDmnEngineConfigurator (priority:200000) +07:50:05.848 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.form.spring.configurator.SpringFormEngineConfigurator (priority:300000) +07:50:05.848 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.content.spring.configurator.SpringContentEngineConfigurator (priority:400000) +07:50:05.849 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.cmmn.spring.configurator.SpringCmmnEngineConfigurator (priority:500000) +07:50:05.849 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.engine.spring.configurator.SpringProcessEngineConfigurator (priority:50000) +07:50:05.852 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.eventregistry.spring.configurator.SpringEventRegistryConfigurator (priority:100000) +07:50:05.856 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.idm.spring.configurator.SpringIdmEngineConfigurator (priority:150000) +07:50:05.860 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.dmn.spring.configurator.SpringDmnEngineConfigurator (priority:200000) +07:50:05.863 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.form.spring.configurator.SpringFormEngineConfigurator (priority:300000) +07:50:05.864 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.content.spring.configurator.SpringContentEngineConfigurator (priority:400000) +07:50:05.866 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.cmmn.spring.configurator.SpringCmmnEngineConfigurator (priority:500000) +07:50:06.530 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.engine.spring.configurator.SpringProcessEngineConfigurator (priority:50000) +07:50:06.576 [restartedMain] INFO o.f.e.i.ProcessEngineImpl - [<init>,89] - ProcessEngine default created +07:50:06.587 [restartedMain] INFO o.f.e.i.c.ValidateV5EntitiesCmd - [execute,43] - Total of v5 deployments found: 0 +07:50:06.632 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.eventregistry.spring.configurator.SpringEventRegistryConfigurator (priority:100000) +07:50:06.736 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.FLW_EV_DATABASECHANGELOG +07:50:06.757 [restartedMain] INFO o.f.e.i.EventRegistryEngineImpl - [<init>,53] - EventRegistryEngine default created +07:50:06.758 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.idm.spring.configurator.SpringIdmEngineConfigurator (priority:150000) +07:50:06.788 [restartedMain] INFO o.f.i.e.i.IdmEngineImpl - [<init>,52] - IdmEngine default created +07:50:06.788 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.dmn.spring.configurator.SpringDmnEngineConfigurator (priority:200000) +07:50:06.870 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_DMN_DATABASECHANGELOG +07:50:06.890 [restartedMain] INFO o.f.d.e.i.DmnEngineImpl - [<init>,55] - DmnEngine default created +07:50:06.891 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.form.spring.configurator.SpringFormEngineConfigurator (priority:300000) +07:50:06.985 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_FO_DATABASECHANGELOG +07:50:07.021 [restartedMain] INFO o.f.f.e.i.FormEngineImpl - [<init>,52] - FormEngine default created +07:50:07.022 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.content.spring.configurator.SpringContentEngineConfigurator (priority:400000) +07:50:07.022 [restartedMain] INFO o.f.c.s.SpringContentEngineConfiguration - [initContentStorage,196] - Content file system root : C:\Users\23082\content +07:50:07.107 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_CO_DATABASECHANGELOG +07:50:07.139 [restartedMain] INFO o.f.c.e.i.ContentEngineImpl - [<init>,48] - ContentEngine default created +07:50:07.140 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.cmmn.spring.configurator.SpringCmmnEngineConfigurator (priority:500000) +07:50:07.236 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_CMMN_DATABASECHANGELOG +07:50:07.270 [restartedMain] INFO o.f.c.e.i.CmmnEngineImpl - [<init>,72] - CmmnEngine default created +07:50:07.365 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_APP_DATABASECHANGELOG +07:50:07.386 [restartedMain] INFO o.f.a.e.i.AppEngineImpl - [<init>,48] - AppEngine default created +07:50:08.362 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +07:50:08.362 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +07:50:08.362 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +07:50:08.362 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +07:50:08.362 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +07:50:08.363 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +07:50:08.363 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +07:50:08.363 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@54721041 +07:50:08.630 [restartedMain] INFO o.q.c.QuartzScheduler - [start,547] - Scheduler quartzScheduler_$_NON_CLUSTERED started. +07:50:08.633 [restartedMain] INFO c.w.w.WinApplication - [logStarted,61] - Started WinApplication in 5.493 seconds (JVM running for 156.938) +07:50:32.617 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +07:50:32.773 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +07:50:32.773 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +07:50:32.773 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +07:50:32.821 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +07:50:32.824 [SpringApplicationShutdownHook] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +07:50:32.825 [SpringApplicationShutdownHook] INFO c.a.d.p.DruidDataSource - [close,2138] - {dataSource-2} closing ... +07:50:32.825 [SpringApplicationShutdownHook] INFO c.a.d.p.DruidDataSource - [close,2211] - {dataSource-2} closed +07:50:39.108 [restartedMain] INFO c.w.w.WinApplication - [logStarting,55] - Starting WinApplication using Java 1.8.0_231 on LAPTOP-K8GOQEG9 with PID 52476 (D:\workspace\wenyin\win\win-admin\target\classes started by admin in D:\workspace\wenyin\win) +07:50:39.110 [restartedMain] INFO c.w.w.WinApplication - [logStartupProfileInfo,686] - The following 3 profiles are active: "druid", "mybatis", "dev" +07:50:39.114 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +07:50:42.873 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-8080"] +07:50:42.874 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +07:50:42.874 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +07:50:42.928 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +07:50:44.674 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,996] - {dataSource-1,ccwin} inited +07:50:44.677 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [ccwin] success +07:50:44.680 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +07:50:44.681 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [ccwin] +07:50:48.190 [restartedMain] INFO o.f.s.b.ProcessEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +07:50:48.824 [restartedMain] INFO o.f.s.b.c.CmmnEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +07:50:48.955 [restartedMain] INFO o.f.s.b.d.DmnEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +07:50:49.010 [restartedMain] INFO o.f.s.b.f.FormEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +07:50:49.058 [restartedMain] INFO o.f.s.b.e.EventRegistryAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +07:50:49.098 [restartedMain] INFO o.f.s.b.a.AppEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +07:50:49.116 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1073] - Found 7 Engine Configurators in total: +07:50:49.117 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.engine.spring.configurator.SpringProcessEngineConfigurator (priority:50000) +07:50:49.117 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.eventregistry.spring.configurator.SpringEventRegistryConfigurator (priority:100000) +07:50:49.117 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.idm.spring.configurator.SpringIdmEngineConfigurator (priority:150000) +07:50:49.117 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.dmn.spring.configurator.SpringDmnEngineConfigurator (priority:200000) +07:50:49.118 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.form.spring.configurator.SpringFormEngineConfigurator (priority:300000) +07:50:49.118 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.content.spring.configurator.SpringContentEngineConfigurator (priority:400000) +07:50:49.118 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.cmmn.spring.configurator.SpringCmmnEngineConfigurator (priority:500000) +07:50:49.118 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.engine.spring.configurator.SpringProcessEngineConfigurator (priority:50000) +07:50:49.121 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.eventregistry.spring.configurator.SpringEventRegistryConfigurator (priority:100000) +07:50:49.125 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.idm.spring.configurator.SpringIdmEngineConfigurator (priority:150000) +07:50:49.126 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.dmn.spring.configurator.SpringDmnEngineConfigurator (priority:200000) +07:50:49.128 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.form.spring.configurator.SpringFormEngineConfigurator (priority:300000) +07:50:49.129 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.content.spring.configurator.SpringContentEngineConfigurator (priority:400000) +07:50:49.130 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.cmmn.spring.configurator.SpringCmmnEngineConfigurator (priority:500000) +07:50:49.955 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.engine.spring.configurator.SpringProcessEngineConfigurator (priority:50000) +07:50:50.231 [restartedMain] INFO o.f.e.i.ProcessEngineImpl - [<init>,89] - ProcessEngine default created +07:50:50.254 [restartedMain] INFO o.f.e.i.c.ValidateV5EntitiesCmd - [execute,43] - Total of v5 deployments found: 0 +07:50:50.298 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.eventregistry.spring.configurator.SpringEventRegistryConfigurator (priority:100000) +07:50:51.074 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.FLW_EV_DATABASECHANGELOG +07:50:51.115 [restartedMain] INFO o.f.e.i.EventRegistryEngineImpl - [<init>,53] - EventRegistryEngine default created +07:50:51.116 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.idm.spring.configurator.SpringIdmEngineConfigurator (priority:150000) +07:50:51.157 [restartedMain] INFO o.f.i.e.i.IdmEngineImpl - [<init>,52] - IdmEngine default created +07:50:51.158 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.dmn.spring.configurator.SpringDmnEngineConfigurator (priority:200000) +07:50:51.268 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_DMN_DATABASECHANGELOG +07:50:51.293 [restartedMain] INFO o.f.d.e.i.DmnEngineImpl - [<init>,55] - DmnEngine default created +07:50:51.295 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.form.spring.configurator.SpringFormEngineConfigurator (priority:300000) +07:50:51.387 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_FO_DATABASECHANGELOG +07:50:51.409 [restartedMain] INFO o.f.f.e.i.FormEngineImpl - [<init>,52] - FormEngine default created +07:50:51.411 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.content.spring.configurator.SpringContentEngineConfigurator (priority:400000) +07:50:51.414 [restartedMain] INFO o.f.c.s.SpringContentEngineConfiguration - [initContentStorage,196] - Content file system root : C:\Users\23082\content +07:50:51.666 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_CO_DATABASECHANGELOG +07:50:51.697 [restartedMain] INFO o.f.c.e.i.ContentEngineImpl - [<init>,48] - ContentEngine default created +07:50:51.698 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.cmmn.spring.configurator.SpringCmmnEngineConfigurator (priority:500000) +07:50:51.847 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_CMMN_DATABASECHANGELOG +07:50:51.878 [restartedMain] INFO o.f.c.e.i.CmmnEngineImpl - [<init>,72] - CmmnEngine default created +07:50:51.958 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_APP_DATABASECHANGELOG +07:50:51.977 [restartedMain] INFO o.f.a.e.i.AppEngineImpl - [<init>,48] - AppEngine default created +07:50:54.515 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +07:50:54.530 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +07:50:54.531 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +07:50:54.532 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +07:50:54.533 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +07:50:54.533 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +07:50:54.533 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +07:50:54.534 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@548031ea +07:50:54.990 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Starting ProtocolHandler ["http-nio-8080"] +07:50:55.508 [restartedMain] INFO o.q.c.QuartzScheduler - [start,547] - Scheduler quartzScheduler_$_NON_CLUSTERED started. +07:50:55.517 [restartedMain] INFO c.w.w.WinApplication - [logStarted,61] - Started WinApplication in 16.909 seconds (JVM running for 17.399) +07:50:59.245 [http-nio-8080-exec-1] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring DispatcherServlet 'dispatcherServlet' +08:08:53.085 [http-nio-8080-exec-32] INFO c.w.w.w.WebSocketServer - [onOpen,33] - sessionId - message +08:08:53.086 [http-nio-8080-exec-32] INFO c.w.w.w.WebSocketServer - [onOpen,45] - + 建立连接 - org.apache.tomcat.websocket.WsSession@32a980c2 +08:08:53.086 [http-nio-8080-exec-32] INFO c.w.w.w.WebSocketServer - [onOpen,46] - + 当前人数 - 1 +08:08:55.845 [http-nio-8080-exec-52] INFO c.w.w.w.WebSocketServer - [onMessage,87] - sessionId - message +08:09:14.982 [http-nio-8080-exec-35] INFO c.w.w.w.WebSocketServer - [onClose,56] - + 关闭连接 - org.apache.tomcat.websocket.WsSession@32a980c2 +08:09:14.982 [http-nio-8080-exec-35] INFO c.w.w.w.WebSocketUsers - [remove,65] - + 正在移出用户 - 0 +08:17:00.170 [http-nio-8080-exec-87] INFO o.a.t.u.h.p.Cookie - [log,173] - A cookie header was received [Hm_lvt_931a8de1263e8fcdea855e1b3c00abff=1687155670,1687337520;] that contained an invalid cookie. That cookie will be ignored. + Note: further occurrences of this error will be logged at DEBUG level. +08:43:18.076 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +08:43:18.956 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +08:43:18.957 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +08:43:18.957 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +08:43:19.080 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +08:43:19.085 [SpringApplicationShutdownHook] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +08:43:19.088 [SpringApplicationShutdownHook] INFO c.a.d.p.DruidDataSource - [close,2138] - {dataSource-1} closing ... +08:43:19.093 [SpringApplicationShutdownHook] INFO c.a.d.p.DruidDataSource - [close,2211] - {dataSource-1} closed +08:43:22.284 [restartedMain] INFO c.w.w.WinApplication - [logStarting,55] - Starting WinApplication using Java 1.8.0_231 on LAPTOP-K8GOQEG9 with PID 56112 (D:\workspace\wenyin\win\win-admin\target\classes started by admin in D:\workspace\wenyin\win) +08:43:22.286 [restartedMain] INFO c.w.w.WinApplication - [logStartupProfileInfo,686] - The following 3 profiles are active: "druid", "mybatis", "dev" +08:43:22.290 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +08:43:25.469 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-8080"] +08:43:25.470 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +08:43:25.470 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +08:43:25.536 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +08:43:27.071 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,996] - {dataSource-1,ccwin} inited +08:43:27.073 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [ccwin] success +08:43:27.075 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +08:43:27.075 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [ccwin] +08:43:31.271 [restartedMain] INFO o.f.s.b.ProcessEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +08:43:31.840 [restartedMain] INFO o.f.s.b.c.CmmnEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +08:43:31.966 [restartedMain] INFO o.f.s.b.d.DmnEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +08:43:32.020 [restartedMain] INFO o.f.s.b.f.FormEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +08:43:32.087 [restartedMain] INFO o.f.s.b.e.EventRegistryAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +08:43:32.151 [restartedMain] INFO o.f.s.b.a.AppEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +08:43:32.182 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1073] - Found 7 Engine Configurators in total: +08:43:32.183 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.engine.spring.configurator.SpringProcessEngineConfigurator (priority:50000) +08:43:32.183 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.eventregistry.spring.configurator.SpringEventRegistryConfigurator (priority:100000) +08:43:32.183 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.idm.spring.configurator.SpringIdmEngineConfigurator (priority:150000) +08:43:32.184 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.dmn.spring.configurator.SpringDmnEngineConfigurator (priority:200000) +08:43:32.184 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.form.spring.configurator.SpringFormEngineConfigurator (priority:300000) +08:43:32.184 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.content.spring.configurator.SpringContentEngineConfigurator (priority:400000) +08:43:32.184 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.cmmn.spring.configurator.SpringCmmnEngineConfigurator (priority:500000) +08:43:32.185 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.engine.spring.configurator.SpringProcessEngineConfigurator (priority:50000) +08:43:32.190 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.eventregistry.spring.configurator.SpringEventRegistryConfigurator (priority:100000) +08:43:32.194 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.idm.spring.configurator.SpringIdmEngineConfigurator (priority:150000) +08:43:32.197 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.dmn.spring.configurator.SpringDmnEngineConfigurator (priority:200000) +08:43:32.200 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.form.spring.configurator.SpringFormEngineConfigurator (priority:300000) +08:43:32.202 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.content.spring.configurator.SpringContentEngineConfigurator (priority:400000) +08:43:32.203 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.cmmn.spring.configurator.SpringCmmnEngineConfigurator (priority:500000) +08:43:32.996 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.engine.spring.configurator.SpringProcessEngineConfigurator (priority:50000) +08:43:33.422 [restartedMain] INFO o.f.e.i.ProcessEngineImpl - [<init>,89] - ProcessEngine default created +08:43:33.568 [restartedMain] INFO o.f.e.i.c.ValidateV5EntitiesCmd - [execute,43] - Total of v5 deployments found: 0 +08:43:33.790 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.eventregistry.spring.configurator.SpringEventRegistryConfigurator (priority:100000) +08:43:34.771 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.FLW_EV_DATABASECHANGELOG +08:43:34.836 [restartedMain] INFO o.f.e.i.EventRegistryEngineImpl - [<init>,53] - EventRegistryEngine default created +08:43:34.838 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.idm.spring.configurator.SpringIdmEngineConfigurator (priority:150000) +08:43:34.937 [restartedMain] INFO o.f.i.e.i.IdmEngineImpl - [<init>,52] - IdmEngine default created +08:43:34.938 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.dmn.spring.configurator.SpringDmnEngineConfigurator (priority:200000) +08:43:35.102 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_DMN_DATABASECHANGELOG +08:43:35.152 [restartedMain] INFO o.f.d.e.i.DmnEngineImpl - [<init>,55] - DmnEngine default created +08:43:35.153 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.form.spring.configurator.SpringFormEngineConfigurator (priority:300000) +08:43:35.322 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_FO_DATABASECHANGELOG +08:43:35.401 [restartedMain] INFO o.f.f.e.i.FormEngineImpl - [<init>,52] - FormEngine default created +08:43:35.403 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.content.spring.configurator.SpringContentEngineConfigurator (priority:400000) +08:43:35.409 [restartedMain] INFO o.f.c.s.SpringContentEngineConfiguration - [initContentStorage,196] - Content file system root : C:\Users\23082\content +08:43:35.765 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_CO_DATABASECHANGELOG +08:43:35.814 [restartedMain] INFO o.f.c.e.i.ContentEngineImpl - [<init>,48] - ContentEngine default created +08:43:35.816 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.cmmn.spring.configurator.SpringCmmnEngineConfigurator (priority:500000) +08:43:36.021 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_CMMN_DATABASECHANGELOG +08:43:36.101 [restartedMain] INFO o.f.c.e.i.CmmnEngineImpl - [<init>,72] - CmmnEngine default created +08:43:36.252 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_APP_DATABASECHANGELOG +08:43:36.302 [restartedMain] INFO o.f.a.e.i.AppEngineImpl - [<init>,48] - AppEngine default created +08:43:39.015 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +08:43:39.034 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +08:43:39.035 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +08:43:39.036 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +08:43:39.037 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +08:43:39.038 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +08:43:39.038 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +08:43:39.038 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@34a90507 +08:43:39.568 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Starting ProtocolHandler ["http-nio-8080"] +08:43:40.132 [restartedMain] INFO o.q.c.QuartzScheduler - [start,547] - Scheduler quartzScheduler_$_NON_CLUSTERED started. +08:43:40.143 [restartedMain] INFO c.w.w.WinApplication - [logStarted,61] - Started WinApplication in 18.38 seconds (JVM running for 18.964) +08:43:51.586 [http-nio-8080-exec-1] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring DispatcherServlet 'dispatcherServlet' +08:45:28.944 [Thread-5] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +08:45:29.491 [Thread-5] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +08:45:29.492 [Thread-5] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +08:45:29.492 [Thread-5] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +08:45:29.626 [Thread-5] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +08:45:29.628 [Thread-5] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +08:45:29.630 [Thread-5] INFO c.a.d.p.DruidDataSource - [close,2138] - {dataSource-1} closing ... +08:45:29.633 [Thread-5] INFO c.a.d.p.DruidDataSource - [close,2211] - {dataSource-1} closed +08:45:48.764 [restartedMain] INFO c.w.w.WinApplication - [logStarting,55] - Starting WinApplication using Java 1.8.0_231 on LAPTOP-K8GOQEG9 with PID 64296 (D:\workspace\wenyin\win\win-admin\target\classes started by admin in D:\workspace\wenyin\win) +08:45:48.766 [restartedMain] INFO c.w.w.WinApplication - [logStartupProfileInfo,686] - The following 3 profiles are active: "druid", "mybatis", "dev" +08:45:48.770 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +08:45:51.916 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-8080"] +08:45:51.917 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +08:45:51.917 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +08:45:51.973 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +08:45:53.361 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,996] - {dataSource-1,ccwin} inited +08:45:53.364 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [ccwin] success +08:45:53.366 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +08:45:53.366 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [ccwin] +08:46:43.639 [restartedMain] INFO c.w.w.WinApplication - [logStarting,55] - Starting WinApplication using Java 1.8.0_231 on LAPTOP-K8GOQEG9 with PID 37768 (D:\workspace\wenyin\win\win-admin\target\classes started by admin in D:\workspace\wenyin\win) +08:46:43.641 [restartedMain] INFO c.w.w.WinApplication - [logStartupProfileInfo,686] - The following 3 profiles are active: "druid", "mybatis", "dev" +08:46:43.643 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +08:46:48.511 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,996] - {dataSource-1,ccwin} inited +08:46:48.516 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [ccwin] success +08:46:48.520 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +08:46:48.520 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [ccwin] +08:46:53.111 [restartedMain] INFO o.f.s.b.ProcessEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +08:46:53.855 [restartedMain] INFO o.f.s.b.c.CmmnEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +08:46:53.989 [restartedMain] INFO o.f.s.b.d.DmnEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +08:46:54.034 [restartedMain] INFO o.f.s.b.f.FormEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +08:46:54.089 [restartedMain] INFO o.f.s.b.e.EventRegistryAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +08:46:54.132 [restartedMain] INFO o.f.s.b.a.AppEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +08:46:54.157 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1073] - Found 7 Engine Configurators in total: +08:46:54.158 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.engine.spring.configurator.SpringProcessEngineConfigurator (priority:50000) +08:46:54.158 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.eventregistry.spring.configurator.SpringEventRegistryConfigurator (priority:100000) +08:46:54.159 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.idm.spring.configurator.SpringIdmEngineConfigurator (priority:150000) +08:46:54.159 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.dmn.spring.configurator.SpringDmnEngineConfigurator (priority:200000) +08:46:54.159 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.form.spring.configurator.SpringFormEngineConfigurator (priority:300000) +08:46:54.159 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.content.spring.configurator.SpringContentEngineConfigurator (priority:400000) +08:46:54.160 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.cmmn.spring.configurator.SpringCmmnEngineConfigurator (priority:500000) +08:46:54.160 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.engine.spring.configurator.SpringProcessEngineConfigurator (priority:50000) +08:46:54.166 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.eventregistry.spring.configurator.SpringEventRegistryConfigurator (priority:100000) +08:46:54.175 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.idm.spring.configurator.SpringIdmEngineConfigurator (priority:150000) +08:46:54.178 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.dmn.spring.configurator.SpringDmnEngineConfigurator (priority:200000) +08:46:54.181 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.form.spring.configurator.SpringFormEngineConfigurator (priority:300000) +08:46:54.183 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.content.spring.configurator.SpringContentEngineConfigurator (priority:400000) +08:46:54.184 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.cmmn.spring.configurator.SpringCmmnEngineConfigurator (priority:500000) +08:46:54.967 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.engine.spring.configurator.SpringProcessEngineConfigurator (priority:50000) +08:46:55.387 [restartedMain] INFO o.f.e.i.ProcessEngineImpl - [<init>,89] - ProcessEngine default created +08:46:55.427 [restartedMain] INFO o.f.e.i.c.ValidateV5EntitiesCmd - [execute,43] - Total of v5 deployments found: 0 +08:46:55.544 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.eventregistry.spring.configurator.SpringEventRegistryConfigurator (priority:100000) +08:46:56.485 [restartedMain] INFO o.f.e.i.EventRegistryEngineImpl - [<init>,53] - EventRegistryEngine default created +08:46:56.488 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.idm.spring.configurator.SpringIdmEngineConfigurator (priority:150000) +08:46:56.587 [restartedMain] INFO o.f.i.e.i.IdmEngineImpl - [<init>,52] - IdmEngine default created +08:46:56.589 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.dmn.spring.configurator.SpringDmnEngineConfigurator (priority:200000) +08:46:56.784 [restartedMain] INFO o.f.d.e.i.DmnEngineImpl - [<init>,55] - DmnEngine default created +08:46:56.786 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.form.spring.configurator.SpringFormEngineConfigurator (priority:300000) +08:46:56.954 [restartedMain] INFO o.f.f.e.i.FormEngineImpl - [<init>,52] - FormEngine default created +08:46:56.956 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.content.spring.configurator.SpringContentEngineConfigurator (priority:400000) +08:46:56.959 [restartedMain] INFO o.f.c.s.SpringContentEngineConfiguration - [initContentStorage,196] - Content file system root : C:\Users\23082\content +08:46:57.279 [restartedMain] INFO o.f.c.e.i.ContentEngineImpl - [<init>,48] - ContentEngine default created +08:46:57.280 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.cmmn.spring.configurator.SpringCmmnEngineConfigurator (priority:500000) +08:46:57.498 [restartedMain] INFO o.f.c.e.i.CmmnEngineImpl - [<init>,72] - CmmnEngine default created +08:46:57.658 [restartedMain] INFO o.f.a.e.i.AppEngineImpl - [<init>,48] - AppEngine default created +08:47:01.005 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +08:47:01.037 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +08:47:01.037 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +08:47:01.039 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +08:47:01.041 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +08:47:01.041 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +08:47:01.041 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +08:47:01.041 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@6ed6fee9 +08:47:02.052 [restartedMain] INFO o.q.c.QuartzScheduler - [start,547] - Scheduler quartzScheduler_$_NON_CLUSTERED started. +08:47:02.062 [restartedMain] INFO c.w.w.WinApplication - [logStarted,61] - Started WinApplication in 18.948 seconds (JVM running for 19.433) +08:47:02.065 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +08:47:02.231 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +08:47:02.231 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +08:47:02.231 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +08:47:02.317 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +08:47:02.321 [SpringApplicationShutdownHook] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +08:47:02.323 [SpringApplicationShutdownHook] INFO c.a.d.p.DruidDataSource - [close,2138] - {dataSource-1} closing ... +08:47:02.327 [SpringApplicationShutdownHook] INFO c.a.d.p.DruidDataSource - [close,2211] - {dataSource-1} closed +08:48:01.477 [restartedMain] INFO c.w.w.WinApplication - [logStarting,55] - Starting WinApplication using Java 1.8.0_231 on LAPTOP-K8GOQEG9 with PID 63768 (D:\workspace\wenyin\win\win-admin\target\classes started by admin in D:\workspace\wenyin\win) +08:48:01.479 [restartedMain] INFO c.w.w.WinApplication - [logStartupProfileInfo,686] - The following 3 profiles are active: "druid", "mybatis", "dev" +08:48:01.483 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +08:48:05.106 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-8080"] +08:48:05.108 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +08:48:05.108 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +08:48:05.208 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +08:48:06.985 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,996] - {dataSource-1,ccwin} inited +08:48:06.986 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [ccwin] success +08:48:06.988 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +08:48:06.988 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [ccwin] +08:48:10.965 [restartedMain] INFO o.f.s.b.ProcessEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +08:48:11.492 [restartedMain] INFO o.f.s.b.c.CmmnEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +08:48:11.615 [restartedMain] INFO o.f.s.b.d.DmnEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +08:48:11.660 [restartedMain] INFO o.f.s.b.f.FormEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +08:48:11.707 [restartedMain] INFO o.f.s.b.e.EventRegistryAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +08:48:11.748 [restartedMain] INFO o.f.s.b.a.AppEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +08:48:11.766 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1073] - Found 7 Engine Configurators in total: +08:48:11.767 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.engine.spring.configurator.SpringProcessEngineConfigurator (priority:50000) +08:48:11.767 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.eventregistry.spring.configurator.SpringEventRegistryConfigurator (priority:100000) +08:48:11.767 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.idm.spring.configurator.SpringIdmEngineConfigurator (priority:150000) +08:48:11.767 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.dmn.spring.configurator.SpringDmnEngineConfigurator (priority:200000) +08:48:11.767 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.form.spring.configurator.SpringFormEngineConfigurator (priority:300000) +08:48:11.767 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.content.spring.configurator.SpringContentEngineConfigurator (priority:400000) +08:48:11.767 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.cmmn.spring.configurator.SpringCmmnEngineConfigurator (priority:500000) +08:48:11.768 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.engine.spring.configurator.SpringProcessEngineConfigurator (priority:50000) +08:48:11.771 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.eventregistry.spring.configurator.SpringEventRegistryConfigurator (priority:100000) +08:48:11.773 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.idm.spring.configurator.SpringIdmEngineConfigurator (priority:150000) +08:48:11.774 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.dmn.spring.configurator.SpringDmnEngineConfigurator (priority:200000) +08:48:11.776 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.form.spring.configurator.SpringFormEngineConfigurator (priority:300000) +08:48:11.777 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.content.spring.configurator.SpringContentEngineConfigurator (priority:400000) +08:48:11.778 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.cmmn.spring.configurator.SpringCmmnEngineConfigurator (priority:500000) +08:48:12.727 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.engine.spring.configurator.SpringProcessEngineConfigurator (priority:50000) +08:48:13.114 [restartedMain] INFO o.f.e.i.ProcessEngineImpl - [<init>,89] - ProcessEngine default created +08:48:13.160 [restartedMain] INFO o.f.e.i.c.ValidateV5EntitiesCmd - [execute,43] - Total of v5 deployments found: 0 +08:48:13.288 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.eventregistry.spring.configurator.SpringEventRegistryConfigurator (priority:100000) +08:48:14.092 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.FLW_EV_DATABASECHANGELOG +08:48:14.169 [restartedMain] INFO o.f.e.i.EventRegistryEngineImpl - [<init>,53] - EventRegistryEngine default created +08:48:14.171 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.idm.spring.configurator.SpringIdmEngineConfigurator (priority:150000) +08:48:14.270 [restartedMain] INFO o.f.i.e.i.IdmEngineImpl - [<init>,52] - IdmEngine default created +08:48:14.271 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.dmn.spring.configurator.SpringDmnEngineConfigurator (priority:200000) +08:48:14.438 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_DMN_DATABASECHANGELOG +08:48:14.489 [restartedMain] INFO o.f.d.e.i.DmnEngineImpl - [<init>,55] - DmnEngine default created +08:48:14.490 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.form.spring.configurator.SpringFormEngineConfigurator (priority:300000) +08:48:14.630 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_FO_DATABASECHANGELOG +08:48:14.689 [restartedMain] INFO o.f.f.e.i.FormEngineImpl - [<init>,52] - FormEngine default created +08:48:14.692 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.content.spring.configurator.SpringContentEngineConfigurator (priority:400000) +08:48:14.695 [restartedMain] INFO o.f.c.s.SpringContentEngineConfiguration - [initContentStorage,196] - Content file system root : C:\Users\23082\content +08:48:15.010 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_CO_DATABASECHANGELOG +08:48:15.066 [restartedMain] INFO o.f.c.e.i.ContentEngineImpl - [<init>,48] - ContentEngine default created +08:48:15.068 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.cmmn.spring.configurator.SpringCmmnEngineConfigurator (priority:500000) +08:48:15.259 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_CMMN_DATABASECHANGELOG +08:48:15.339 [restartedMain] INFO o.f.c.e.i.CmmnEngineImpl - [<init>,72] - CmmnEngine default created +08:48:15.480 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_APP_DATABASECHANGELOG +08:48:15.549 [restartedMain] INFO o.f.a.e.i.AppEngineImpl - [<init>,48] - AppEngine default created +08:48:18.249 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +08:48:18.267 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +08:48:18.267 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +08:48:18.268 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +08:48:18.269 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +08:48:18.270 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +08:48:18.270 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +08:48:18.270 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@7270bbe +08:48:18.708 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Starting ProtocolHandler ["http-nio-8080"] +08:48:19.125 [restartedMain] INFO o.q.c.QuartzScheduler - [start,547] - Scheduler quartzScheduler_$_NON_CLUSTERED started. +08:48:19.136 [restartedMain] INFO c.w.w.WinApplication - [logStarted,61] - Started WinApplication in 18.172 seconds (JVM running for 18.693) +08:48:25.573 [http-nio-8080-exec-1] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring DispatcherServlet 'dispatcherServlet' +08:48:51.191 [Thread-5] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +08:48:51.348 [Thread-5] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +08:48:51.348 [Thread-5] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +08:48:51.348 [Thread-5] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +08:48:51.493 [Thread-5] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +08:48:51.496 [Thread-5] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +08:48:51.499 [Thread-5] INFO c.a.d.p.DruidDataSource - [close,2138] - {dataSource-1} closing ... +08:48:51.502 [Thread-5] INFO c.a.d.p.DruidDataSource - [close,2211] - {dataSource-1} closed +08:49:21.275 [restartedMain] INFO c.w.w.WinApplication - [logStarting,55] - Starting WinApplication using Java 1.8.0_231 on LAPTOP-K8GOQEG9 with PID 62440 (D:\workspace\wenyin\win\win-admin\target\classes started by admin in D:\workspace\wenyin\win) +08:49:21.278 [restartedMain] INFO c.w.w.WinApplication - [logStartupProfileInfo,686] - The following 3 profiles are active: "druid", "mybatis", "dev" +08:49:21.284 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +08:49:24.766 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-8080"] +08:49:24.767 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +08:49:24.767 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +08:49:24.836 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +08:49:26.423 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,996] - {dataSource-1,ccwin} inited +08:49:26.426 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [ccwin] success +08:49:26.428 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +08:49:26.428 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [ccwin] +08:49:32.848 [restartedMain] INFO o.f.s.b.ProcessEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +08:49:33.434 [restartedMain] INFO o.f.s.b.c.CmmnEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +08:49:33.659 [restartedMain] INFO o.f.s.b.d.DmnEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +08:49:33.716 [restartedMain] INFO o.f.s.b.f.FormEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +08:49:33.776 [restartedMain] INFO o.f.s.b.e.EventRegistryAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +08:49:33.813 [restartedMain] INFO o.f.s.b.a.AppEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +08:49:33.832 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1073] - Found 7 Engine Configurators in total: +08:49:33.832 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.engine.spring.configurator.SpringProcessEngineConfigurator (priority:50000) +08:49:33.833 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.eventregistry.spring.configurator.SpringEventRegistryConfigurator (priority:100000) +08:49:33.833 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.idm.spring.configurator.SpringIdmEngineConfigurator (priority:150000) +08:49:33.833 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.dmn.spring.configurator.SpringDmnEngineConfigurator (priority:200000) +08:49:33.833 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.form.spring.configurator.SpringFormEngineConfigurator (priority:300000) +08:49:33.833 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.content.spring.configurator.SpringContentEngineConfigurator (priority:400000) +08:49:33.833 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.cmmn.spring.configurator.SpringCmmnEngineConfigurator (priority:500000) +08:49:33.833 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.engine.spring.configurator.SpringProcessEngineConfigurator (priority:50000) +08:49:33.838 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.eventregistry.spring.configurator.SpringEventRegistryConfigurator (priority:100000) +08:49:33.842 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.idm.spring.configurator.SpringIdmEngineConfigurator (priority:150000) +08:49:33.844 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.dmn.spring.configurator.SpringDmnEngineConfigurator (priority:200000) +08:49:33.846 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.form.spring.configurator.SpringFormEngineConfigurator (priority:300000) +08:49:33.848 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.content.spring.configurator.SpringContentEngineConfigurator (priority:400000) +08:49:33.849 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.cmmn.spring.configurator.SpringCmmnEngineConfigurator (priority:500000) +08:49:34.600 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.engine.spring.configurator.SpringProcessEngineConfigurator (priority:50000) +08:49:35.017 [restartedMain] INFO o.f.e.i.ProcessEngineImpl - [<init>,89] - ProcessEngine default created +08:49:35.088 [restartedMain] INFO o.f.e.i.c.ValidateV5EntitiesCmd - [execute,43] - Total of v5 deployments found: 0 +08:49:35.350 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.eventregistry.spring.configurator.SpringEventRegistryConfigurator (priority:100000) +08:49:36.371 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.FLW_EV_DATABASECHANGELOG +08:49:36.563 [restartedMain] INFO o.f.e.i.EventRegistryEngineImpl - [<init>,53] - EventRegistryEngine default created +08:49:36.564 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.idm.spring.configurator.SpringIdmEngineConfigurator (priority:150000) +08:49:36.837 [restartedMain] INFO o.f.i.e.i.IdmEngineImpl - [<init>,52] - IdmEngine default created +08:49:36.839 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.dmn.spring.configurator.SpringDmnEngineConfigurator (priority:200000) +08:49:37.180 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_DMN_DATABASECHANGELOG +08:49:37.317 [restartedMain] INFO o.f.d.e.i.DmnEngineImpl - [<init>,55] - DmnEngine default created +08:49:37.319 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.form.spring.configurator.SpringFormEngineConfigurator (priority:300000) +08:49:37.597 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_FO_DATABASECHANGELOG +08:49:37.737 [restartedMain] INFO o.f.f.e.i.FormEngineImpl - [<init>,52] - FormEngine default created +08:49:37.739 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.content.spring.configurator.SpringContentEngineConfigurator (priority:400000) +08:49:37.742 [restartedMain] INFO o.f.c.s.SpringContentEngineConfiguration - [initContentStorage,196] - Content file system root : C:\Users\23082\content +08:49:38.107 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_CO_DATABASECHANGELOG +08:49:38.211 [restartedMain] INFO o.f.c.e.i.ContentEngineImpl - [<init>,48] - ContentEngine default created +08:49:38.213 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.cmmn.spring.configurator.SpringCmmnEngineConfigurator (priority:500000) +08:49:38.482 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_CMMN_DATABASECHANGELOG +08:49:38.562 [restartedMain] INFO o.f.c.e.i.CmmnEngineImpl - [<init>,72] - CmmnEngine default created +08:49:38.702 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_APP_DATABASECHANGELOG +08:49:38.765 [restartedMain] INFO o.f.a.e.i.AppEngineImpl - [<init>,48] - AppEngine default created +08:49:41.643 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +08:49:41.658 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +08:49:41.659 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +08:49:41.660 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +08:49:41.661 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +08:49:41.661 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +08:49:41.661 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +08:49:41.661 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@7a603ec9 +08:49:42.174 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Starting ProtocolHandler ["http-nio-8080"] +08:49:42.694 [restartedMain] INFO o.q.c.QuartzScheduler - [start,547] - Scheduler quartzScheduler_$_NON_CLUSTERED started. +08:49:42.704 [restartedMain] INFO c.w.w.WinApplication - [logStarted,61] - Started WinApplication in 22.016 seconds (JVM running for 22.584) +08:49:54.160 [http-nio-8080-exec-6] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring DispatcherServlet 'dispatcherServlet' +08:50:40.095 [http-nio-8080-exec-8] INFO o.a.t.u.h.p.Cookie - [log,173] - A cookie header was received [Hm_lvt_931a8de1263e8fcdea855e1b3c00abff=1687155670,1687337520;] that contained an invalid cookie. That cookie will be ignored. + Note: further occurrences of this error will be logged at DEBUG level. +08:54:29.579 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +08:54:29.747 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +08:54:29.747 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +08:54:29.748 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +08:54:29.889 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +08:54:29.891 [SpringApplicationShutdownHook] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +08:54:29.893 [SpringApplicationShutdownHook] INFO c.a.d.p.DruidDataSource - [close,2138] - {dataSource-1} closing ... +08:54:29.896 [SpringApplicationShutdownHook] INFO c.a.d.p.DruidDataSource - [close,2211] - {dataSource-1} closed +08:54:36.123 [restartedMain] INFO c.w.w.WinApplication - [logStarting,55] - Starting WinApplication using Java 1.8.0_231 on LAPTOP-K8GOQEG9 with PID 53968 (D:\workspace\wenyin\win\win-admin\target\classes started by admin in D:\workspace\wenyin\win) +08:54:36.124 [restartedMain] INFO c.w.w.WinApplication - [logStartupProfileInfo,686] - The following 3 profiles are active: "druid", "mybatis", "dev" +08:54:36.127 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +08:54:39.460 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-8080"] +08:54:39.460 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +08:54:39.461 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +08:54:39.521 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +08:54:41.117 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,996] - {dataSource-1,ccwin} inited +08:54:41.120 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [ccwin] success +08:54:41.122 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +08:54:41.123 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [ccwin] +08:54:45.072 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +08:54:45.088 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +08:54:45.088 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +08:54:45.089 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +08:54:45.090 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +08:54:45.091 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +08:54:45.091 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +08:54:45.091 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@509c701f +08:54:45.399 [restartedMain] INFO o.f.s.b.ProcessEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +08:54:46.027 [restartedMain] INFO o.f.s.b.c.CmmnEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +08:54:46.151 [restartedMain] INFO o.f.s.b.d.DmnEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +08:54:46.207 [restartedMain] INFO o.f.s.b.f.FormEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +08:54:46.266 [restartedMain] INFO o.f.s.b.e.EventRegistryAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +08:54:46.303 [restartedMain] INFO o.f.s.b.a.AppEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +08:54:46.346 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1073] - Found 7 Engine Configurators in total: +08:54:46.347 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.engine.spring.configurator.SpringProcessEngineConfigurator (priority:50000) +08:54:46.347 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.eventregistry.spring.configurator.SpringEventRegistryConfigurator (priority:100000) +08:54:46.347 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.idm.spring.configurator.SpringIdmEngineConfigurator (priority:150000) +08:54:46.347 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.dmn.spring.configurator.SpringDmnEngineConfigurator (priority:200000) +08:54:46.347 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.form.spring.configurator.SpringFormEngineConfigurator (priority:300000) +08:54:46.348 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.content.spring.configurator.SpringContentEngineConfigurator (priority:400000) +08:54:46.348 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.cmmn.spring.configurator.SpringCmmnEngineConfigurator (priority:500000) +08:54:46.348 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.engine.spring.configurator.SpringProcessEngineConfigurator (priority:50000) +08:54:46.353 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.eventregistry.spring.configurator.SpringEventRegistryConfigurator (priority:100000) +08:54:46.358 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.idm.spring.configurator.SpringIdmEngineConfigurator (priority:150000) +08:54:46.359 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.dmn.spring.configurator.SpringDmnEngineConfigurator (priority:200000) +08:54:46.361 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.form.spring.configurator.SpringFormEngineConfigurator (priority:300000) +08:54:46.362 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.content.spring.configurator.SpringContentEngineConfigurator (priority:400000) +08:54:46.363 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.cmmn.spring.configurator.SpringCmmnEngineConfigurator (priority:500000) +08:54:47.178 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.engine.spring.configurator.SpringProcessEngineConfigurator (priority:50000) +08:54:47.499 [restartedMain] INFO o.f.e.i.ProcessEngineImpl - [<init>,89] - ProcessEngine default created +08:54:47.540 [restartedMain] INFO o.f.e.i.c.ValidateV5EntitiesCmd - [execute,43] - Total of v5 deployments found: 0 +08:54:47.641 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.eventregistry.spring.configurator.SpringEventRegistryConfigurator (priority:100000) +08:54:48.482 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.FLW_EV_DATABASECHANGELOG +08:54:48.538 [restartedMain] INFO o.f.e.i.EventRegistryEngineImpl - [<init>,53] - EventRegistryEngine default created +08:54:48.540 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.idm.spring.configurator.SpringIdmEngineConfigurator (priority:150000) +08:54:48.640 [restartedMain] INFO o.f.i.e.i.IdmEngineImpl - [<init>,52] - IdmEngine default created +08:54:48.641 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.dmn.spring.configurator.SpringDmnEngineConfigurator (priority:200000) +08:54:48.834 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_DMN_DATABASECHANGELOG +08:54:48.889 [restartedMain] INFO o.f.d.e.i.DmnEngineImpl - [<init>,55] - DmnEngine default created +08:54:48.890 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.form.spring.configurator.SpringFormEngineConfigurator (priority:300000) +08:54:49.010 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_FO_DATABASECHANGELOG +08:54:49.051 [restartedMain] INFO o.f.f.e.i.FormEngineImpl - [<init>,52] - FormEngine default created +08:54:49.052 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.content.spring.configurator.SpringContentEngineConfigurator (priority:400000) +08:54:49.056 [restartedMain] INFO o.f.c.s.SpringContentEngineConfiguration - [initContentStorage,196] - Content file system root : C:\Users\23082\content +08:54:49.343 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_CO_DATABASECHANGELOG +08:54:49.419 [restartedMain] INFO o.f.c.e.i.ContentEngineImpl - [<init>,48] - ContentEngine default created +08:54:49.420 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.cmmn.spring.configurator.SpringCmmnEngineConfigurator (priority:500000) +08:54:49.609 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_CMMN_DATABASECHANGELOG +08:54:49.669 [restartedMain] INFO o.f.c.e.i.CmmnEngineImpl - [<init>,72] - CmmnEngine default created +08:54:49.782 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_APP_DATABASECHANGELOG +08:54:49.827 [restartedMain] INFO o.f.a.e.i.AppEngineImpl - [<init>,48] - AppEngine default created +08:54:53.141 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Starting ProtocolHandler ["http-nio-8080"] +08:54:53.511 [restartedMain] INFO o.q.c.QuartzScheduler - [start,547] - Scheduler quartzScheduler_$_NON_CLUSTERED started. +08:54:53.520 [restartedMain] INFO c.w.w.WinApplication - [logStarted,61] - Started WinApplication in 17.923 seconds (JVM running for 18.475) +08:54:59.969 [http-nio-8080-exec-1] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring DispatcherServlet 'dispatcherServlet' +09:29:16.715 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +09:29:16.987 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +09:29:16.988 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +09:29:16.988 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +09:29:16.988 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +09:29:16.990 [SpringApplicationShutdownHook] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +09:29:16.993 [SpringApplicationShutdownHook] INFO c.a.d.p.DruidDataSource - [close,2138] - {dataSource-1} closing ... +09:29:16.996 [SpringApplicationShutdownHook] INFO c.a.d.p.DruidDataSource - [close,2211] - {dataSource-1} closed +09:29:20.252 [restartedMain] INFO c.w.w.WinApplication - [logStarting,55] - Starting WinApplication using Java 1.8.0_231 on LAPTOP-K8GOQEG9 with PID 58828 (D:\workspace\wenyin\win\win-admin\target\classes started by admin in D:\workspace\wenyin\win) +09:29:20.253 [restartedMain] INFO c.w.w.WinApplication - [logStartupProfileInfo,686] - The following 3 profiles are active: "druid", "mybatis", "dev" +09:29:20.256 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +09:29:23.585 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-8080"] +09:29:23.585 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +09:29:23.586 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +09:29:23.644 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +09:29:25.444 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,996] - {dataSource-1,ccwin} inited +09:29:25.445 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [ccwin] success +09:29:25.446 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +09:29:25.447 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [ccwin] +09:29:28.893 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +09:29:28.908 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +09:29:28.909 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +09:29:28.909 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +09:29:28.910 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +09:29:28.911 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +09:29:28.911 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +09:29:28.911 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@7b9a644c +09:29:29.224 [restartedMain] INFO o.f.s.b.ProcessEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +09:29:29.744 [restartedMain] INFO o.f.s.b.c.CmmnEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +09:29:29.854 [restartedMain] INFO o.f.s.b.d.DmnEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +09:29:29.899 [restartedMain] INFO o.f.s.b.f.FormEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +09:29:29.947 [restartedMain] INFO o.f.s.b.e.EventRegistryAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +09:29:29.978 [restartedMain] INFO o.f.s.b.a.AppEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +09:29:29.998 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1073] - Found 7 Engine Configurators in total: +09:29:29.998 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.engine.spring.configurator.SpringProcessEngineConfigurator (priority:50000) +09:29:29.998 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.eventregistry.spring.configurator.SpringEventRegistryConfigurator (priority:100000) +09:29:29.998 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.idm.spring.configurator.SpringIdmEngineConfigurator (priority:150000) +09:29:29.999 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.dmn.spring.configurator.SpringDmnEngineConfigurator (priority:200000) +09:29:29.999 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.form.spring.configurator.SpringFormEngineConfigurator (priority:300000) +09:29:29.999 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.content.spring.configurator.SpringContentEngineConfigurator (priority:400000) +09:29:29.999 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.cmmn.spring.configurator.SpringCmmnEngineConfigurator (priority:500000) +09:29:29.999 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.engine.spring.configurator.SpringProcessEngineConfigurator (priority:50000) +09:29:30.002 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.eventregistry.spring.configurator.SpringEventRegistryConfigurator (priority:100000) +09:29:30.004 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.idm.spring.configurator.SpringIdmEngineConfigurator (priority:150000) +09:29:30.005 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.dmn.spring.configurator.SpringDmnEngineConfigurator (priority:200000) +09:29:30.007 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.form.spring.configurator.SpringFormEngineConfigurator (priority:300000) +09:29:30.008 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.content.spring.configurator.SpringContentEngineConfigurator (priority:400000) +09:29:30.009 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.cmmn.spring.configurator.SpringCmmnEngineConfigurator (priority:500000) +09:29:30.747 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.engine.spring.configurator.SpringProcessEngineConfigurator (priority:50000) +09:29:31.085 [restartedMain] INFO o.f.e.i.ProcessEngineImpl - [<init>,89] - ProcessEngine default created +09:29:31.124 [restartedMain] INFO o.f.e.i.c.ValidateV5EntitiesCmd - [execute,43] - Total of v5 deployments found: 0 +09:29:31.232 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.eventregistry.spring.configurator.SpringEventRegistryConfigurator (priority:100000) +09:29:32.047 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.FLW_EV_DATABASECHANGELOG +09:29:32.104 [restartedMain] INFO o.f.e.i.EventRegistryEngineImpl - [<init>,53] - EventRegistryEngine default created +09:29:32.106 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.idm.spring.configurator.SpringIdmEngineConfigurator (priority:150000) +09:29:32.187 [restartedMain] INFO o.f.i.e.i.IdmEngineImpl - [<init>,52] - IdmEngine default created +09:29:32.189 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.dmn.spring.configurator.SpringDmnEngineConfigurator (priority:200000) +09:29:32.337 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_DMN_DATABASECHANGELOG +09:29:32.385 [restartedMain] INFO o.f.d.e.i.DmnEngineImpl - [<init>,55] - DmnEngine default created +09:29:32.386 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.form.spring.configurator.SpringFormEngineConfigurator (priority:300000) +09:29:32.504 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_FO_DATABASECHANGELOG +09:29:32.552 [restartedMain] INFO o.f.f.e.i.FormEngineImpl - [<init>,52] - FormEngine default created +09:29:32.554 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.content.spring.configurator.SpringContentEngineConfigurator (priority:400000) +09:29:32.557 [restartedMain] INFO o.f.c.s.SpringContentEngineConfiguration - [initContentStorage,196] - Content file system root : C:\Users\23082\content +09:29:32.861 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_CO_DATABASECHANGELOG +09:29:32.904 [restartedMain] INFO o.f.c.e.i.ContentEngineImpl - [<init>,48] - ContentEngine default created +09:29:32.905 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.cmmn.spring.configurator.SpringCmmnEngineConfigurator (priority:500000) +09:29:33.096 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_CMMN_DATABASECHANGELOG +09:29:33.154 [restartedMain] INFO o.f.c.e.i.CmmnEngineImpl - [<init>,72] - CmmnEngine default created +09:29:33.258 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_APP_DATABASECHANGELOG +09:29:33.303 [restartedMain] INFO o.f.a.e.i.AppEngineImpl - [<init>,48] - AppEngine default created +09:29:36.269 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Starting ProtocolHandler ["http-nio-8080"] +09:29:36.633 [restartedMain] INFO o.q.c.QuartzScheduler - [start,547] - Scheduler quartzScheduler_$_NON_CLUSTERED started. +09:29:36.642 [restartedMain] INFO c.w.w.WinApplication - [logStarted,61] - Started WinApplication in 16.903 seconds (JVM running for 17.54) +09:52:22.315 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +09:52:33.778 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +09:52:33.780 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +09:52:33.782 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +09:52:33.784 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +09:52:33.813 [SpringApplicationShutdownHook] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +09:52:33.835 [SpringApplicationShutdownHook] INFO c.a.d.p.DruidDataSource - [close,2138] - {dataSource-1} closing ... +09:52:33.860 [SpringApplicationShutdownHook] INFO c.a.d.p.DruidDataSource - [close,2211] - {dataSource-1} closed +10:42:41.225 [restartedMain] INFO c.w.w.WinApplication - [logStarting,55] - Starting WinApplication using Java 1.8.0_231 on LAPTOP-K8GOQEG9 with PID 34236 (D:\workspace\wenyin\win\win-admin\target\classes started by admin in D:\workspace\wenyin\win) +10:42:41.227 [restartedMain] INFO c.w.w.WinApplication - [logStartupProfileInfo,686] - The following 3 profiles are active: "druid", "mybatis", "dev" +10:42:41.231 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +10:42:44.629 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-8080"] +10:42:44.629 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +10:42:44.630 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +10:42:44.691 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +10:42:46.291 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,996] - {dataSource-1,ccwin} inited +10:42:46.292 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [ccwin] success +10:42:46.294 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +10:42:46.294 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [ccwin] +10:42:49.837 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +10:42:49.856 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +10:42:49.857 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +10:42:49.858 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +10:42:49.859 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +10:42:49.860 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +10:42:49.860 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +10:42:49.860 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@3160aa38 +10:42:50.216 [restartedMain] INFO o.f.s.b.ProcessEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +10:42:50.882 [restartedMain] INFO o.f.s.b.c.CmmnEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +10:42:51.021 [restartedMain] INFO o.f.s.b.d.DmnEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +10:42:51.074 [restartedMain] INFO o.f.s.b.f.FormEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +10:42:51.155 [restartedMain] INFO o.f.s.b.e.EventRegistryAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +10:42:51.199 [restartedMain] INFO o.f.s.b.a.AppEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +10:42:51.228 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1073] - Found 7 Engine Configurators in total: +10:42:51.229 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.engine.spring.configurator.SpringProcessEngineConfigurator (priority:50000) +10:42:51.229 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.eventregistry.spring.configurator.SpringEventRegistryConfigurator (priority:100000) +10:42:51.230 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.idm.spring.configurator.SpringIdmEngineConfigurator (priority:150000) +10:42:51.230 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.dmn.spring.configurator.SpringDmnEngineConfigurator (priority:200000) +10:42:51.230 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.form.spring.configurator.SpringFormEngineConfigurator (priority:300000) +10:42:51.230 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.content.spring.configurator.SpringContentEngineConfigurator (priority:400000) +10:42:51.230 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.cmmn.spring.configurator.SpringCmmnEngineConfigurator (priority:500000) +10:42:51.231 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.engine.spring.configurator.SpringProcessEngineConfigurator (priority:50000) +10:42:51.238 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.eventregistry.spring.configurator.SpringEventRegistryConfigurator (priority:100000) +10:42:51.244 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.idm.spring.configurator.SpringIdmEngineConfigurator (priority:150000) +10:42:51.246 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.dmn.spring.configurator.SpringDmnEngineConfigurator (priority:200000) +10:42:51.249 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.form.spring.configurator.SpringFormEngineConfigurator (priority:300000) +10:42:51.251 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.content.spring.configurator.SpringContentEngineConfigurator (priority:400000) +10:42:51.252 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.cmmn.spring.configurator.SpringCmmnEngineConfigurator (priority:500000) +10:42:52.169 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.engine.spring.configurator.SpringProcessEngineConfigurator (priority:50000) +10:42:52.557 [restartedMain] INFO o.f.e.i.ProcessEngineImpl - [<init>,89] - ProcessEngine default created +10:42:52.593 [restartedMain] INFO o.f.e.i.c.ValidateV5EntitiesCmd - [execute,43] - Total of v5 deployments found: 0 +10:42:52.755 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.eventregistry.spring.configurator.SpringEventRegistryConfigurator (priority:100000) +10:42:53.648 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.FLW_EV_DATABASECHANGELOG +10:42:53.728 [restartedMain] INFO o.f.e.i.EventRegistryEngineImpl - [<init>,53] - EventRegistryEngine default created +10:42:53.729 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.idm.spring.configurator.SpringIdmEngineConfigurator (priority:150000) +10:42:53.836 [restartedMain] INFO o.f.i.e.i.IdmEngineImpl - [<init>,52] - IdmEngine default created +10:42:53.838 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.dmn.spring.configurator.SpringDmnEngineConfigurator (priority:200000) +10:42:54.012 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_DMN_DATABASECHANGELOG +10:42:54.093 [restartedMain] INFO o.f.d.e.i.DmnEngineImpl - [<init>,55] - DmnEngine default created +10:42:54.094 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.form.spring.configurator.SpringFormEngineConfigurator (priority:300000) +10:42:54.248 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_FO_DATABASECHANGELOG +10:42:54.329 [restartedMain] INFO o.f.f.e.i.FormEngineImpl - [<init>,52] - FormEngine default created +10:42:54.332 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.content.spring.configurator.SpringContentEngineConfigurator (priority:400000) +10:42:54.334 [restartedMain] INFO o.f.c.s.SpringContentEngineConfiguration - [initContentStorage,196] - Content file system root : C:\Users\23082\content +10:42:54.641 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_CO_DATABASECHANGELOG +10:42:54.700 [restartedMain] INFO o.f.c.e.i.ContentEngineImpl - [<init>,48] - ContentEngine default created +10:42:54.700 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.cmmn.spring.configurator.SpringCmmnEngineConfigurator (priority:500000) +10:42:54.935 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_CMMN_DATABASECHANGELOG +10:42:54.994 [restartedMain] INFO o.f.c.e.i.CmmnEngineImpl - [<init>,72] - CmmnEngine default created +10:42:55.090 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_APP_DATABASECHANGELOG +10:42:55.121 [restartedMain] INFO o.f.a.e.i.AppEngineImpl - [<init>,48] - AppEngine default created +10:42:59.038 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Starting ProtocolHandler ["http-nio-8080"] +10:42:59.454 [restartedMain] INFO o.q.c.QuartzScheduler - [start,547] - Scheduler quartzScheduler_$_NON_CLUSTERED started. +10:42:59.463 [restartedMain] INFO c.w.w.WinApplication - [logStarted,61] - Started WinApplication in 18.811 seconds (JVM running for 19.408) +12:58:44.223 [http-nio-8080-exec-1] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring DispatcherServlet 'dispatcherServlet' +12:59:03.793 [lettuce-eventExecutorLoop-1-6] INFO i.l.c.p.ConnectionWatchdog - [log,171] - Reconnecting, last destination was dev.ccwin-in.com/222.169.228.163:23114 +12:59:03.842 [lettuce-nioEventLoop-4-2] INFO i.l.c.p.ReconnectionHandler - [lambda$null$3,174] - Reconnected to dev.ccwin-in.com:23114 +13:23:01.626 [schedule-pool-1] INFO sys-user - [run,56] - [127.0.0.1]内网IP[admin][Error][验证码错误] +13:23:06.103 [schedule-pool-1] INFO sys-user - [run,56] - [127.0.0.1]内网IP[admin][Success][登录成功] +13:24:27.370 [http-nio-8080-exec-50] INFO c.w.w.w.WebSocketServer - [onOpen,33] - sessionId - message +13:24:27.371 [http-nio-8080-exec-50] INFO c.w.w.w.WebSocketServer - [onOpen,45] - + 建立连接 - org.apache.tomcat.websocket.WsSession@5184e9ab +13:24:27.371 [http-nio-8080-exec-50] INFO c.w.w.w.WebSocketServer - [onOpen,46] - + 当前人数 - 1 +13:24:29.253 [http-nio-8080-exec-51] INFO c.w.w.w.WebSocketServer - [onMessage,87] - sessionId - message +13:24:34.562 [http-nio-8080-exec-54] INFO o.a.t.u.h.p.Cookie - [log,173] - A cookie header was received [Hm_lvt_931a8de1263e8fcdea855e1b3c00abff=1687155670,1687337520;] that contained an invalid cookie. That cookie will be ignored. + Note: further occurrences of this error will be logged at DEBUG level. +13:49:05.293 [http-nio-8080-exec-72] INFO c.w.w.w.WebSocketServer - [onClose,56] - + 关闭连接 - org.apache.tomcat.websocket.WsSession@5184e9ab +13:49:05.293 [http-nio-8080-exec-72] INFO c.w.w.w.WebSocketUsers - [remove,65] - + 正在移出用户 - 0 +13:49:05.294 [http-nio-8080-exec-72] INFO c.w.w.w.WebSocketServer - [onError,73] - + 连接异常 - 0 +13:49:05.294 [http-nio-8080-exec-72] INFO c.w.w.w.WebSocketServer - [onError,74] - + 异常信息 - {} +java.io.EOFException: null + at org.apache.tomcat.util.net.NioEndpoint$NioSocketWrapper.fillReadBuffer(NioEndpoint.java:1339) + at org.apache.tomcat.util.net.NioEndpoint$NioSocketWrapper.read(NioEndpoint.java:1226) + at org.apache.tomcat.websocket.server.WsFrameServer.onDataAvailable(WsFrameServer.java:75) + at org.apache.tomcat.websocket.server.WsFrameServer.doOnDataAvailable(WsFrameServer.java:183) + at org.apache.tomcat.websocket.server.WsFrameServer.notifyDataAvailable(WsFrameServer.java:162) + at org.apache.tomcat.websocket.server.WsHttpUpgradeHandler.upgradeDispatch(WsHttpUpgradeHandler.java:157) + at org.apache.coyote.http11.upgrade.UpgradeProcessorInternal.dispatch(UpgradeProcessorInternal.java:60) + at org.apache.coyote.AbstractProcessorLight.process(AbstractProcessorLight.java:59) + at org.apache.coyote.AbstractProtocol$ConnectionHandler.process(AbstractProtocol.java:890) + at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1743) + at org.apache.tomcat.util.net.SocketProcessorBase.run(SocketProcessorBase.java:49) + at org.apache.tomcat.util.threads.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1191) + at org.apache.tomcat.util.threads.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:659) + at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61) + at java.lang.Thread.run(Thread.java:748) +13:49:05.295 [http-nio-8080-exec-72] INFO c.w.w.w.WebSocketUsers - [remove,65] - + 正在移出用户 - 0 +14:17:19.993 [lettuce-eventExecutorLoop-1-2] INFO i.l.c.p.ConnectionWatchdog - [log,171] - Reconnecting, last destination was dev.ccwin-in.com/222.169.228.163:23114 +14:17:20.042 [lettuce-nioEventLoop-4-3] INFO i.l.c.p.ReconnectionHandler - [lambda$null$3,174] - Reconnected to dev.ccwin-in.com:23114 +14:17:20.085 [schedule-pool-2] INFO sys-user - [run,56] - [127.0.0.1]内网IP[admin][Logout][退出成功] +15:53:44.326 [schedule-pool-1] INFO sys-user - [run,56] - [127.0.0.1]内网IP[admin][Success][登录成功] +15:54:03.400 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +15:54:03.692 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +15:54:03.692 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +15:54:03.693 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +15:54:03.693 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +15:54:03.695 [SpringApplicationShutdownHook] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +15:54:03.700 [SpringApplicationShutdownHook] INFO c.a.d.p.DruidDataSource - [close,2138] - {dataSource-1} closing ... +15:54:03.706 [SpringApplicationShutdownHook] INFO c.a.d.p.DruidDataSource - [close,2211] - {dataSource-1} closed diff --git a/logs/sys-info.2023-07-25.log b/logs/sys-info.2023-07-25.log new file mode 100644 index 0000000..0c1ca27 --- /dev/null +++ b/logs/sys-info.2023-07-25.log @@ -0,0 +1,167 @@ +08:10:37.189 [restartedMain] INFO c.w.w.WinApplication - [logStarting,55] - Starting WinApplication using Java 1.8.0_231 on LAPTOP-K8GOQEG9 with PID 66480 (D:\workspace\wenyin\win\win-admin\target\classes started by admin in D:\workspace\wenyin\win) +08:10:37.202 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +08:10:37.203 [restartedMain] INFO c.w.w.WinApplication - [logStartupProfileInfo,686] - The following 3 profiles are active: "druid", "mybatis", "dev" +08:10:41.670 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-8080"] +08:10:41.671 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +08:10:41.672 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +08:10:41.754 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +08:10:44.617 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,996] - {dataSource-1,ccwin} inited +08:10:44.619 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [ccwin] success +08:10:44.620 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +08:10:44.621 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [ccwin] +08:10:49.215 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +08:10:49.243 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +08:10:49.244 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +08:10:49.245 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +08:10:49.246 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +08:10:49.246 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +08:10:49.246 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +08:10:49.246 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@775337e8 +08:10:49.576 [restartedMain] INFO o.f.s.b.ProcessEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +08:10:50.220 [restartedMain] INFO o.f.s.b.c.CmmnEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +08:10:50.344 [restartedMain] INFO o.f.s.b.d.DmnEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +08:10:50.398 [restartedMain] INFO o.f.s.b.f.FormEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +08:10:50.449 [restartedMain] INFO o.f.s.b.e.EventRegistryAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +08:10:50.483 [restartedMain] INFO o.f.s.b.a.AppEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +08:10:50.507 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1073] - Found 7 Engine Configurators in total: +08:10:50.508 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.engine.spring.configurator.SpringProcessEngineConfigurator (priority:50000) +08:10:50.508 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.eventregistry.spring.configurator.SpringEventRegistryConfigurator (priority:100000) +08:10:50.508 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.idm.spring.configurator.SpringIdmEngineConfigurator (priority:150000) +08:10:50.508 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.dmn.spring.configurator.SpringDmnEngineConfigurator (priority:200000) +08:10:50.508 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.form.spring.configurator.SpringFormEngineConfigurator (priority:300000) +08:10:50.509 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.content.spring.configurator.SpringContentEngineConfigurator (priority:400000) +08:10:50.509 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.cmmn.spring.configurator.SpringCmmnEngineConfigurator (priority:500000) +08:10:50.509 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.engine.spring.configurator.SpringProcessEngineConfigurator (priority:50000) +08:10:50.514 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.eventregistry.spring.configurator.SpringEventRegistryConfigurator (priority:100000) +08:10:50.517 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.idm.spring.configurator.SpringIdmEngineConfigurator (priority:150000) +08:10:50.518 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.dmn.spring.configurator.SpringDmnEngineConfigurator (priority:200000) +08:10:50.520 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.form.spring.configurator.SpringFormEngineConfigurator (priority:300000) +08:10:50.522 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.content.spring.configurator.SpringContentEngineConfigurator (priority:400000) +08:10:50.522 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.cmmn.spring.configurator.SpringCmmnEngineConfigurator (priority:500000) +08:10:51.417 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.engine.spring.configurator.SpringProcessEngineConfigurator (priority:50000) +08:10:51.820 [restartedMain] INFO o.f.e.i.ProcessEngineImpl - [<init>,89] - ProcessEngine default created +08:10:51.861 [restartedMain] INFO o.f.e.i.c.ValidateV5EntitiesCmd - [execute,43] - Total of v5 deployments found: 0 +08:10:52.010 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.eventregistry.spring.configurator.SpringEventRegistryConfigurator (priority:100000) +08:10:52.921 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.FLW_EV_DATABASECHANGELOG +08:10:52.999 [restartedMain] INFO o.f.e.i.EventRegistryEngineImpl - [<init>,53] - EventRegistryEngine default created +08:10:53.001 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.idm.spring.configurator.SpringIdmEngineConfigurator (priority:150000) +08:10:53.100 [restartedMain] INFO o.f.i.e.i.IdmEngineImpl - [<init>,52] - IdmEngine default created +08:10:53.102 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.dmn.spring.configurator.SpringDmnEngineConfigurator (priority:200000) +08:10:53.260 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_DMN_DATABASECHANGELOG +08:10:53.318 [restartedMain] INFO o.f.d.e.i.DmnEngineImpl - [<init>,55] - DmnEngine default created +08:10:53.319 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.form.spring.configurator.SpringFormEngineConfigurator (priority:300000) +08:10:53.461 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_FO_DATABASECHANGELOG +08:10:53.527 [restartedMain] INFO o.f.f.e.i.FormEngineImpl - [<init>,52] - FormEngine default created +08:10:53.531 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.content.spring.configurator.SpringContentEngineConfigurator (priority:400000) +08:10:53.535 [restartedMain] INFO o.f.c.s.SpringContentEngineConfiguration - [initContentStorage,196] - Content file system root : C:\Users\23082\content +08:10:53.866 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_CO_DATABASECHANGELOG +08:10:53.907 [restartedMain] INFO o.f.c.e.i.ContentEngineImpl - [<init>,48] - ContentEngine default created +08:10:53.909 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.cmmn.spring.configurator.SpringCmmnEngineConfigurator (priority:500000) +08:10:54.137 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_CMMN_DATABASECHANGELOG +08:10:54.231 [restartedMain] INFO o.f.c.e.i.CmmnEngineImpl - [<init>,72] - CmmnEngine default created +08:10:54.370 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_APP_DATABASECHANGELOG +08:10:54.430 [restartedMain] INFO o.f.a.e.i.AppEngineImpl - [<init>,48] - AppEngine default created +08:10:59.317 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Starting ProtocolHandler ["http-nio-8080"] +08:10:59.696 [restartedMain] INFO o.q.c.QuartzScheduler - [start,547] - Scheduler quartzScheduler_$_NON_CLUSTERED started. +08:10:59.708 [restartedMain] INFO c.w.w.WinApplication - [logStarted,61] - Started WinApplication in 23.169 seconds (JVM running for 24.403) +08:11:02.887 [http-nio-8080-exec-3] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring DispatcherServlet 'dispatcherServlet' +08:11:05.691 [schedule-pool-1] INFO sys-user - [run,56] - [127.0.0.1]内网IP[admin][Success][登录成功] +10:42:40.243 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +10:42:40.763 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +10:42:40.763 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +10:42:40.763 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +10:42:40.764 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +10:42:40.766 [SpringApplicationShutdownHook] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +10:42:40.771 [SpringApplicationShutdownHook] INFO c.a.d.p.DruidDataSource - [close,2138] - {dataSource-1} closing ... +10:42:40.778 [SpringApplicationShutdownHook] INFO c.a.d.p.DruidDataSource - [close,2211] - {dataSource-1} closed +10:42:47.818 [restartedMain] INFO c.w.w.WinApplication - [logStarting,55] - Starting WinApplication using Java 1.8.0_231 on LAPTOP-K8GOQEG9 with PID 71588 (D:\workspace\wenyin\win\win-admin\target\classes started by admin in D:\workspace\wenyin\win) +10:42:47.820 [restartedMain] INFO c.w.w.WinApplication - [logStartupProfileInfo,686] - The following 3 profiles are active: "druid", "mybatis", "dev" +10:42:47.824 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +10:42:51.482 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-8080"] +10:42:51.483 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +10:42:51.483 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +10:42:51.553 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +10:42:53.245 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,996] - {dataSource-1,ccwin} inited +10:42:53.247 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [ccwin] success +10:42:53.248 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +10:42:53.248 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [ccwin] +10:42:56.834 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +10:42:56.848 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +10:42:56.848 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +10:42:56.849 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +10:42:56.850 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +10:42:56.850 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +10:42:56.850 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +10:42:56.850 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@21765fc2 +10:42:57.292 [restartedMain] INFO o.f.s.b.ProcessEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +10:42:57.728 [restartedMain] INFO o.f.s.b.c.CmmnEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +10:42:57.837 [restartedMain] INFO o.f.s.b.d.DmnEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +10:42:57.886 [restartedMain] INFO o.f.s.b.f.FormEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +10:42:57.945 [restartedMain] INFO o.f.s.b.e.EventRegistryAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +10:42:57.997 [restartedMain] INFO o.f.s.b.a.AppEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +10:42:58.021 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1073] - Found 7 Engine Configurators in total: +10:42:58.021 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.engine.spring.configurator.SpringProcessEngineConfigurator (priority:50000) +10:42:58.021 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.eventregistry.spring.configurator.SpringEventRegistryConfigurator (priority:100000) +10:42:58.021 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.idm.spring.configurator.SpringIdmEngineConfigurator (priority:150000) +10:42:58.022 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.dmn.spring.configurator.SpringDmnEngineConfigurator (priority:200000) +10:42:58.022 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.form.spring.configurator.SpringFormEngineConfigurator (priority:300000) +10:42:58.022 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.content.spring.configurator.SpringContentEngineConfigurator (priority:400000) +10:42:58.022 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.cmmn.spring.configurator.SpringCmmnEngineConfigurator (priority:500000) +10:42:58.022 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.engine.spring.configurator.SpringProcessEngineConfigurator (priority:50000) +10:42:58.026 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.eventregistry.spring.configurator.SpringEventRegistryConfigurator (priority:100000) +10:42:58.030 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.idm.spring.configurator.SpringIdmEngineConfigurator (priority:150000) +10:42:58.031 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.dmn.spring.configurator.SpringDmnEngineConfigurator (priority:200000) +10:42:58.033 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.form.spring.configurator.SpringFormEngineConfigurator (priority:300000) +10:42:58.034 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.content.spring.configurator.SpringContentEngineConfigurator (priority:400000) +10:42:58.035 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.cmmn.spring.configurator.SpringCmmnEngineConfigurator (priority:500000) +10:42:58.805 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.engine.spring.configurator.SpringProcessEngineConfigurator (priority:50000) +10:42:59.162 [restartedMain] INFO o.f.e.i.ProcessEngineImpl - [<init>,89] - ProcessEngine default created +10:42:59.201 [restartedMain] INFO o.f.e.i.c.ValidateV5EntitiesCmd - [execute,43] - Total of v5 deployments found: 0 +10:42:59.320 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.eventregistry.spring.configurator.SpringEventRegistryConfigurator (priority:100000) +10:43:00.290 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.FLW_EV_DATABASECHANGELOG +10:43:00.351 [restartedMain] INFO o.f.e.i.EventRegistryEngineImpl - [<init>,53] - EventRegistryEngine default created +10:43:00.353 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.idm.spring.configurator.SpringIdmEngineConfigurator (priority:150000) +10:43:00.440 [restartedMain] INFO o.f.i.e.i.IdmEngineImpl - [<init>,52] - IdmEngine default created +10:43:00.442 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.dmn.spring.configurator.SpringDmnEngineConfigurator (priority:200000) +10:43:00.599 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_DMN_DATABASECHANGELOG +10:43:00.660 [restartedMain] INFO o.f.d.e.i.DmnEngineImpl - [<init>,55] - DmnEngine default created +10:43:00.661 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.form.spring.configurator.SpringFormEngineConfigurator (priority:300000) +10:43:00.802 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_FO_DATABASECHANGELOG +10:43:00.843 [restartedMain] INFO o.f.f.e.i.FormEngineImpl - [<init>,52] - FormEngine default created +10:43:00.845 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.content.spring.configurator.SpringContentEngineConfigurator (priority:400000) +10:43:00.849 [restartedMain] INFO o.f.c.s.SpringContentEngineConfiguration - [initContentStorage,196] - Content file system root : C:\Users\23082\content +10:43:01.131 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_CO_DATABASECHANGELOG +10:43:01.163 [restartedMain] INFO o.f.c.e.i.ContentEngineImpl - [<init>,48] - ContentEngine default created +10:43:01.164 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.cmmn.spring.configurator.SpringCmmnEngineConfigurator (priority:500000) +10:43:01.346 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_CMMN_DATABASECHANGELOG +10:43:01.395 [restartedMain] INFO o.f.c.e.i.CmmnEngineImpl - [<init>,72] - CmmnEngine default created +10:43:01.490 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_APP_DATABASECHANGELOG +10:43:01.521 [restartedMain] INFO o.f.a.e.i.AppEngineImpl - [<init>,48] - AppEngine default created +10:43:04.913 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Starting ProtocolHandler ["http-nio-8080"] +10:43:05.304 [restartedMain] INFO o.q.c.QuartzScheduler - [start,547] - Scheduler quartzScheduler_$_NON_CLUSTERED started. +10:43:05.314 [restartedMain] INFO c.w.w.WinApplication - [logStarted,61] - Started WinApplication in 18.035 seconds (JVM running for 18.728) +10:44:02.449 [http-nio-8080-exec-1] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring DispatcherServlet 'dispatcherServlet' +10:53:12.276 [http-nio-8080-exec-22] INFO o.a.t.u.h.p.Cookie - [log,173] - A cookie header was received [Hm_lvt_931a8de1263e8fcdea855e1b3c00abff=1687155670,1687337520;] that contained an invalid cookie. That cookie will be ignored. + Note: further occurrences of this error will be logged at DEBUG level. +13:56:33.056 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +13:56:33.656 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +13:56:33.656 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +13:56:33.656 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +13:56:33.656 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +13:56:33.671 [SpringApplicationShutdownHook] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +13:56:33.671 [SpringApplicationShutdownHook] INFO c.a.d.p.DruidDataSource - [close,2138] - {dataSource-1} closing ... +13:56:33.687 [SpringApplicationShutdownHook] INFO c.a.d.p.DruidDataSource - [close,2211] - {dataSource-1} closed diff --git a/logs/sys-info.2023-07-27.log b/logs/sys-info.2023-07-27.log new file mode 100644 index 0000000..97968e1 --- /dev/null +++ b/logs/sys-info.2023-07-27.log @@ -0,0 +1,862 @@ +10:54:09.178 [restartedMain] INFO c.w.w.WinApplication - [logStarting,55] - Starting WinApplication using Java 1.8.0_231 on LAPTOP-K8GOQEG9 with PID 20304 (D:\workspace\wenyin\win\win-admin\target\classes started by admin in D:\workspace\wenyin\win) +10:54:09.183 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +10:54:09.189 [restartedMain] INFO c.w.w.WinApplication - [logStartupProfileInfo,686] - The following 3 profiles are active: "druid", "mybatis", "dev" +10:54:13.096 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-8080"] +10:54:13.098 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +10:54:13.098 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +10:54:13.173 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +10:54:14.822 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,996] - {dataSource-1,ccwin} inited +10:54:14.824 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [ccwin] success +10:54:14.825 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +10:54:14.826 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [ccwin] +10:54:18.323 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +10:54:18.336 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +10:54:18.337 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +10:54:18.338 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +10:54:18.338 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +10:54:18.339 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +10:54:18.339 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +10:54:18.339 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@38cd8925 +10:54:18.734 [restartedMain] INFO o.f.s.b.ProcessEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +10:54:19.227 [restartedMain] INFO o.f.s.b.c.CmmnEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +10:54:19.343 [restartedMain] INFO o.f.s.b.d.DmnEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +10:54:19.397 [restartedMain] INFO o.f.s.b.f.FormEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +10:54:19.444 [restartedMain] INFO o.f.s.b.e.EventRegistryAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +10:54:19.478 [restartedMain] INFO o.f.s.b.a.AppEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +10:54:19.499 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1073] - Found 7 Engine Configurators in total: +10:54:19.499 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.engine.spring.configurator.SpringProcessEngineConfigurator (priority:50000) +10:54:19.500 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.eventregistry.spring.configurator.SpringEventRegistryConfigurator (priority:100000) +10:54:19.500 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.idm.spring.configurator.SpringIdmEngineConfigurator (priority:150000) +10:54:19.500 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.dmn.spring.configurator.SpringDmnEngineConfigurator (priority:200000) +10:54:19.500 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.form.spring.configurator.SpringFormEngineConfigurator (priority:300000) +10:54:19.500 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.content.spring.configurator.SpringContentEngineConfigurator (priority:400000) +10:54:19.500 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.cmmn.spring.configurator.SpringCmmnEngineConfigurator (priority:500000) +10:54:19.500 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.engine.spring.configurator.SpringProcessEngineConfigurator (priority:50000) +10:54:19.504 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.eventregistry.spring.configurator.SpringEventRegistryConfigurator (priority:100000) +10:54:19.507 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.idm.spring.configurator.SpringIdmEngineConfigurator (priority:150000) +10:54:19.508 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.dmn.spring.configurator.SpringDmnEngineConfigurator (priority:200000) +10:54:19.509 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.form.spring.configurator.SpringFormEngineConfigurator (priority:300000) +10:54:19.510 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.content.spring.configurator.SpringContentEngineConfigurator (priority:400000) +10:54:19.511 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.cmmn.spring.configurator.SpringCmmnEngineConfigurator (priority:500000) +10:54:20.286 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.engine.spring.configurator.SpringProcessEngineConfigurator (priority:50000) +10:54:20.579 [restartedMain] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +10:54:20.580 [restartedMain] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +10:54:20.580 [restartedMain] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +10:54:20.580 [restartedMain] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +10:54:20.583 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +10:54:20.586 [restartedMain] INFO c.a.d.p.DruidDataSource - [close,2138] - {dataSource-1} closing ... +10:54:20.589 [restartedMain] INFO c.a.d.p.DruidDataSource - [close,2211] - {dataSource-1} closed +10:54:20.779 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Stopping service [Tomcat] +10:55:00.199 [restartedMain] INFO c.w.w.WinApplication - [logStarting,55] - Starting WinApplication using Java 1.8.0_231 on LAPTOP-K8GOQEG9 with PID 15132 (D:\workspace\wenyin\win\win-admin\target\classes started by admin in D:\workspace\wenyin\win) +10:55:00.201 [restartedMain] INFO c.w.w.WinApplication - [logStartupProfileInfo,686] - The following 3 profiles are active: "druid", "mybatis", "dev" +10:55:00.204 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +10:55:03.546 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-8080"] +10:55:03.547 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +10:55:03.547 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +10:55:03.605 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +10:55:05.041 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,996] - {dataSource-1,ccwin} inited +10:55:05.044 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [ccwin] success +10:55:05.046 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +10:55:05.047 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [ccwin] +10:55:08.396 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +10:55:08.412 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +10:55:08.413 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +10:55:08.414 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +10:55:08.415 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +10:55:08.415 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +10:55:08.415 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +10:55:08.415 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@33a59419 +10:55:08.630 [restartedMain] INFO o.f.s.b.ProcessEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +10:55:09.070 [restartedMain] INFO o.f.s.b.c.CmmnEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +10:55:09.171 [restartedMain] INFO o.f.s.b.d.DmnEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +10:55:09.217 [restartedMain] INFO o.f.s.b.f.FormEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +10:55:09.263 [restartedMain] INFO o.f.s.b.e.EventRegistryAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +10:55:09.300 [restartedMain] INFO o.f.s.b.a.AppEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +10:55:09.319 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1073] - Found 7 Engine Configurators in total: +10:55:09.319 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.engine.spring.configurator.SpringProcessEngineConfigurator (priority:50000) +10:55:09.319 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.eventregistry.spring.configurator.SpringEventRegistryConfigurator (priority:100000) +10:55:09.319 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.idm.spring.configurator.SpringIdmEngineConfigurator (priority:150000) +10:55:09.319 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.dmn.spring.configurator.SpringDmnEngineConfigurator (priority:200000) +10:55:09.319 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.form.spring.configurator.SpringFormEngineConfigurator (priority:300000) +10:55:09.319 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.content.spring.configurator.SpringContentEngineConfigurator (priority:400000) +10:55:09.320 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.cmmn.spring.configurator.SpringCmmnEngineConfigurator (priority:500000) +10:55:09.320 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.engine.spring.configurator.SpringProcessEngineConfigurator (priority:50000) +10:55:09.322 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.eventregistry.spring.configurator.SpringEventRegistryConfigurator (priority:100000) +10:55:09.325 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.idm.spring.configurator.SpringIdmEngineConfigurator (priority:150000) +10:55:09.326 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.dmn.spring.configurator.SpringDmnEngineConfigurator (priority:200000) +10:55:09.327 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.form.spring.configurator.SpringFormEngineConfigurator (priority:300000) +10:55:09.328 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.content.spring.configurator.SpringContentEngineConfigurator (priority:400000) +10:55:09.329 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.cmmn.spring.configurator.SpringCmmnEngineConfigurator (priority:500000) +10:55:10.114 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.engine.spring.configurator.SpringProcessEngineConfigurator (priority:50000) +10:55:10.370 [restartedMain] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +10:55:10.370 [restartedMain] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +10:55:10.371 [restartedMain] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +10:55:10.371 [restartedMain] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +10:55:10.373 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +10:55:10.375 [restartedMain] INFO c.a.d.p.DruidDataSource - [close,2138] - {dataSource-1} closing ... +10:55:10.378 [restartedMain] INFO c.a.d.p.DruidDataSource - [close,2211] - {dataSource-1} closed +10:55:10.552 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Stopping service [Tomcat] +11:34:29.403 [restartedMain] INFO c.w.w.WinApplication - [logStarting,55] - Starting WinApplication using Java 1.8.0_231 on LAPTOP-K8GOQEG9 with PID 22316 (D:\workspace\wenyin\win\win-admin\target\classes started by admin in D:\workspace\wenyin\win) +11:34:29.404 [restartedMain] INFO c.w.w.WinApplication - [logStartupProfileInfo,686] - The following 3 profiles are active: "druid", "mybatis", "dev" +11:34:29.407 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +11:34:32.973 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-8080"] +11:34:32.974 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +11:34:32.974 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +11:34:33.036 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +11:34:33.214 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Stopping service [Tomcat] +11:35:34.671 [restartedMain] INFO c.w.w.WinApplication - [logStarting,55] - Starting WinApplication using Java 1.8.0_231 on LAPTOP-K8GOQEG9 with PID 22228 (D:\workspace\wenyin\win\win-admin\target\classes started by admin in D:\workspace\wenyin\win) +11:35:34.672 [restartedMain] INFO c.w.w.WinApplication - [logStartupProfileInfo,686] - The following 3 profiles are active: "druid", "mybatis", "dev" +11:35:34.677 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +11:35:37.857 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-8080"] +11:35:37.858 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +11:35:37.858 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +11:35:37.918 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +11:35:39.381 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,996] - {dataSource-1,ccwin} inited +11:35:39.382 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [ccwin] success +11:35:39.383 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +11:35:39.383 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [ccwin] +11:35:42.855 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +11:35:42.870 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +11:35:42.870 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +11:35:42.871 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +11:35:42.872 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +11:35:42.873 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +11:35:42.873 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +11:35:42.873 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@4b04a29 +11:35:43.157 [restartedMain] INFO o.f.s.b.ProcessEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +11:35:43.634 [restartedMain] INFO o.f.s.b.c.CmmnEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +11:35:43.735 [restartedMain] INFO o.f.s.b.d.DmnEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +11:35:43.773 [restartedMain] INFO o.f.s.b.f.FormEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +11:35:43.812 [restartedMain] INFO o.f.s.b.e.EventRegistryAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +11:35:43.852 [restartedMain] INFO o.f.s.b.a.AppEngineAutoConfiguration - [discoverDeploymentResources,104] - No deployment resources were found for autodeployment +11:35:43.909 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1073] - Found 7 Engine Configurators in total: +11:35:43.909 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.engine.spring.configurator.SpringProcessEngineConfigurator (priority:50000) +11:35:43.909 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.eventregistry.spring.configurator.SpringEventRegistryConfigurator (priority:100000) +11:35:43.910 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.idm.spring.configurator.SpringIdmEngineConfigurator (priority:150000) +11:35:43.910 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.dmn.spring.configurator.SpringDmnEngineConfigurator (priority:200000) +11:35:43.910 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.form.spring.configurator.SpringFormEngineConfigurator (priority:300000) +11:35:43.910 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.content.spring.configurator.SpringContentEngineConfigurator (priority:400000) +11:35:43.910 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [initConfigurators,1075] - class org.flowable.cmmn.spring.configurator.SpringCmmnEngineConfigurator (priority:500000) +11:35:43.911 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.engine.spring.configurator.SpringProcessEngineConfigurator (priority:50000) +11:35:43.954 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.eventregistry.spring.configurator.SpringEventRegistryConfigurator (priority:100000) +11:35:43.973 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.idm.spring.configurator.SpringIdmEngineConfigurator (priority:150000) +11:35:43.975 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.dmn.spring.configurator.SpringDmnEngineConfigurator (priority:200000) +11:35:43.978 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.form.spring.configurator.SpringFormEngineConfigurator (priority:300000) +11:35:43.991 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.content.spring.configurator.SpringContentEngineConfigurator (priority:400000) +11:35:43.992 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsBeforeInit,1101] - Executing beforeInit() of class org.flowable.cmmn.spring.configurator.SpringCmmnEngineConfigurator (priority:500000) +11:35:44.764 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.engine.spring.configurator.SpringProcessEngineConfigurator (priority:50000) +11:35:45.089 [restartedMain] INFO o.f.e.i.ProcessEngineImpl - [<init>,89] - ProcessEngine default created +11:35:45.128 [restartedMain] INFO o.f.e.i.c.ValidateV5EntitiesCmd - [execute,43] - Total of v5 deployments found: 0 +11:35:45.238 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.eventregistry.spring.configurator.SpringEventRegistryConfigurator (priority:100000) +11:35:46.080 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.FLW_EV_DATABASECHANGELOG +11:35:46.149 [restartedMain] INFO o.f.e.i.EventRegistryEngineImpl - [<init>,53] - EventRegistryEngine default created +11:35:46.150 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.idm.spring.configurator.SpringIdmEngineConfigurator (priority:150000) +11:35:46.237 [restartedMain] INFO o.f.i.e.i.IdmEngineImpl - [<init>,52] - IdmEngine default created +11:35:46.238 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.dmn.spring.configurator.SpringDmnEngineConfigurator (priority:200000) +11:35:46.392 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_DMN_DATABASECHANGELOG +11:35:46.440 [restartedMain] INFO o.f.d.e.i.DmnEngineImpl - [<init>,55] - DmnEngine default created +11:35:46.442 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.form.spring.configurator.SpringFormEngineConfigurator (priority:300000) +11:35:46.576 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_FO_DATABASECHANGELOG +11:35:46.633 [restartedMain] INFO o.f.f.e.i.FormEngineImpl - [<init>,52] - FormEngine default created +11:35:46.634 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.content.spring.configurator.SpringContentEngineConfigurator (priority:400000) +11:35:46.638 [restartedMain] INFO o.f.c.s.SpringContentEngineConfiguration - [initContentStorage,196] - Content file system root : C:\Users\23082\content +11:35:46.957 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_CO_DATABASECHANGELOG +11:35:47.000 [restartedMain] INFO o.f.c.e.i.ContentEngineImpl - [<init>,48] - ContentEngine default created +11:35:47.002 [restartedMain] INFO o.f.a.s.SpringAppEngineConfiguration - [configuratorsAfterInit,1108] - Executing configure() of class org.flowable.cmmn.spring.configurator.SpringCmmnEngineConfigurator (priority:500000) +11:35:47.185 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_CMMN_DATABASECHANGELOG +11:35:47.259 [restartedMain] INFO o.f.c.e.i.CmmnEngineImpl - [<init>,72] - CmmnEngine default created +11:35:47.388 [restartedMain] INFO liquibase.changelog - [log,23] - Reading from ccwin.ACT_APP_DATABASECHANGELOG +11:35:47.453 [restartedMain] INFO o.f.a.e.i.AppEngineImpl - [<init>,48] - AppEngine default created +11:35:51.040 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Starting ProtocolHandler ["http-nio-8080"] +11:35:51.398 [restartedMain] INFO o.q.c.QuartzScheduler - [start,547] - Scheduler quartzScheduler_$_NON_CLUSTERED started. +11:35:51.409 [restartedMain] INFO c.w.w.WinApplication - [logStarted,61] - Started WinApplication in 17.244 seconds (JVM running for 17.823) +11:35:52.488 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +11:35:52.739 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +11:35:52.740 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +11:35:52.740 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +11:35:52.740 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +11:35:52.742 [SpringApplicationShutdownHook] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +11:35:52.745 [SpringApplicationShutdownHook] INFO c.a.d.p.DruidDataSource - [close,2138] - {dataSource-1} closing ... +11:35:52.747 [SpringApplicationShutdownHook] INFO c.a.d.p.DruidDataSource - [close,2211] - {dataSource-1} closed +11:41:24.019 [restartedMain] INFO c.w.w.WinApplication - [logStarting,55] - Starting WinApplication using Java 1.8.0_231 on LAPTOP-K8GOQEG9 with PID 20700 (D:\workspace\wenyin\win\win-admin\target\classes started by admin in D:\workspace\wenyin\win) +11:41:24.018 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +11:41:24.020 [restartedMain] INFO c.w.w.WinApplication - [logStartupProfileInfo,686] - The following 3 profiles are active: "druid", "mybatis", "dev" +11:41:26.633 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-8080"] +11:41:26.634 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +11:41:26.634 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +11:41:26.686 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +11:41:27.830 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,996] - {dataSource-1,ccwin} inited +11:41:27.833 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [ccwin] success +11:41:27.834 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +11:41:27.835 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [ccwin] +11:41:28.555 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +11:41:28.561 [restartedMain] INFO c.a.d.p.DruidDataSource - [close,2138] - {dataSource-1} closing ... +11:41:28.562 [restartedMain] INFO c.a.d.p.DruidDataSource - [close,2211] - {dataSource-1} closed +11:41:28.587 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Stopping service [Tomcat] +11:42:19.766 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +11:42:19.768 [restartedMain] INFO c.w.w.WinApplication - [logStarting,55] - Starting WinApplication using Java 1.8.0_231 on LAPTOP-K8GOQEG9 with PID 16192 (D:\workspace\wenyin\win\win-admin\target\classes started by admin in D:\workspace\wenyin\win) +11:42:19.769 [restartedMain] INFO c.w.w.WinApplication - [logStartupProfileInfo,686] - The following 3 profiles are active: "druid", "mybatis", "dev" +11:42:22.409 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-8080"] +11:42:22.409 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +11:42:22.410 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +11:42:22.459 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +11:42:23.716 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,996] - {dataSource-1,ccwin} inited +11:42:23.718 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [ccwin] success +11:42:23.720 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +11:42:23.720 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [ccwin] +11:42:25.242 [Druid-ConnectionPool-Create-159797312] INFO c.a.d.p.DruidAbstractDataSource - [setFailContinuous,1877] - {dataSource-1} failContinuous is true +11:42:41.411 [restartedMain] INFO c.w.w.WinApplication - [logStarting,55] - Starting WinApplication using Java 1.8.0_231 on LAPTOP-K8GOQEG9 with PID 3228 (D:\workspace\wenyin\win\win-admin\target\classes started by admin in D:\workspace\wenyin\win) +11:42:41.411 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +11:42:41.412 [restartedMain] INFO c.w.w.WinApplication - [logStartupProfileInfo,686] - The following 3 profiles are active: "druid", "mybatis", "dev" +11:42:44.148 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-8080"] +11:42:44.149 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +11:42:44.149 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +11:42:44.193 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +11:42:45.458 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,996] - {dataSource-1,ccwin} inited +11:42:45.460 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [ccwin] success +11:42:45.461 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +11:42:45.461 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [ccwin] +11:42:47.143 [Druid-ConnectionPool-Create-11548541] INFO c.a.d.p.DruidAbstractDataSource - [setFailContinuous,1877] - {dataSource-1} failContinuous is true +11:43:06.004 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +11:43:06.006 [restartedMain] INFO c.w.w.WinApplication - [logStarting,55] - Starting WinApplication using Java 1.8.0_231 on LAPTOP-K8GOQEG9 with PID 21740 (D:\workspace\wenyin\win\win-admin\target\classes started by admin in D:\workspace\wenyin\win) +11:43:06.007 [restartedMain] INFO c.w.w.WinApplication - [logStartupProfileInfo,686] - The following 3 profiles are active: "druid", "mybatis", "dev" +11:43:08.530 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-8080"] +11:43:08.530 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +11:43:08.530 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +11:43:08.579 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +11:43:09.660 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Stopping service [Tomcat] +11:43:36.384 [restartedMain] INFO c.w.w.WinApplication - [logStarting,55] - Starting WinApplication using Java 1.8.0_231 on LAPTOP-K8GOQEG9 with PID 23168 (D:\workspace\wenyin\win\win-admin\target\classes started by admin in D:\workspace\wenyin\win) +11:43:36.384 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +11:43:36.386 [restartedMain] INFO c.w.w.WinApplication - [logStartupProfileInfo,686] - The following 3 profiles are active: "druid", "mybatis", "dev" +11:43:38.908 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-8080"] +11:43:38.908 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +11:43:38.908 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +11:43:38.951 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +11:43:40.061 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,996] - {dataSource-1,ccwin} inited +11:43:40.062 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [ccwin] success +11:43:40.063 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +11:43:40.063 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [ccwin] +11:43:43.426 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +11:43:43.452 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +11:43:43.453 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +11:43:43.455 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +11:43:43.457 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +11:43:43.458 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +11:43:43.458 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +11:43:43.459 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@528b31d1 +11:43:45.148 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Starting ProtocolHandler ["http-nio-8080"] +11:43:45.326 [restartedMain] INFO o.q.c.QuartzScheduler - [start,547] - Scheduler quartzScheduler_$_NON_CLUSTERED started. +11:43:45.334 [restartedMain] INFO c.w.w.WinApplication - [logStarted,61] - Started WinApplication in 9.414 seconds (JVM running for 9.872) +11:43:49.675 [http-nio-8080-exec-1] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring DispatcherServlet 'dispatcherServlet' +11:43:53.797 [schedule-pool-1] INFO sys-user - [run,56] - [127.0.0.1]内网IP[admin][Success][登录成功] +11:45:17.014 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +11:45:17.167 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +11:45:17.168 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +11:45:17.168 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +11:45:17.168 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +11:45:17.170 [SpringApplicationShutdownHook] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +11:45:17.172 [SpringApplicationShutdownHook] INFO c.a.d.p.DruidDataSource - [close,2138] - {dataSource-1} closing ... +11:45:17.174 [SpringApplicationShutdownHook] INFO c.a.d.p.DruidDataSource - [close,2211] - {dataSource-1} closed +11:45:20.947 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +11:45:20.949 [restartedMain] INFO c.w.w.WinApplication - [logStarting,55] - Starting WinApplication using Java 1.8.0_231 on LAPTOP-K8GOQEG9 with PID 21724 (D:\workspace\wenyin\win\win-admin\target\classes started by admin in D:\workspace\wenyin\win) +11:45:20.949 [restartedMain] INFO c.w.w.WinApplication - [logStartupProfileInfo,686] - The following 3 profiles are active: "druid", "mybatis", "dev" +11:45:23.630 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-8080"] +11:45:23.630 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +11:45:23.631 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +11:45:23.675 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +11:45:24.863 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,996] - {dataSource-1,ccwin} inited +11:45:24.866 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [ccwin] success +11:45:24.869 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +11:45:24.870 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [ccwin] +11:45:28.555 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +11:45:28.577 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +11:45:28.578 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +11:45:28.580 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +11:45:28.582 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +11:45:28.583 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +11:45:28.583 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +11:45:28.583 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@65141c25 +11:45:30.588 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Starting ProtocolHandler ["http-nio-8080"] +11:45:30.816 [restartedMain] INFO o.q.c.QuartzScheduler - [start,547] - Scheduler quartzScheduler_$_NON_CLUSTERED started. +11:45:30.825 [restartedMain] INFO c.w.w.WinApplication - [logStarted,61] - Started WinApplication in 10.354 seconds (JVM running for 10.813) +11:45:34.351 [http-nio-8080-exec-2] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring DispatcherServlet 'dispatcherServlet' +11:45:36.711 [schedule-pool-1] INFO sys-user - [run,56] - [127.0.0.1]内网IP[admin][Success][登录成功] +11:45:44.755 [http-nio-8080-exec-15] INFO o.a.t.u.h.p.Cookie - [log,173] - A cookie header was received [Hm_lvt_931a8de1263e8fcdea855e1b3c00abff=1687155670,1687337520;] that contained an invalid cookie. That cookie will be ignored. + Note: further occurrences of this error will be logged at DEBUG level. +11:46:37.872 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +11:46:38.015 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +11:46:38.015 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +11:46:38.016 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +11:46:38.016 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +11:46:38.019 [SpringApplicationShutdownHook] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +11:46:38.020 [SpringApplicationShutdownHook] INFO c.a.d.p.DruidDataSource - [close,2138] - {dataSource-1} closing ... +11:46:38.023 [SpringApplicationShutdownHook] INFO c.a.d.p.DruidDataSource - [close,2211] - {dataSource-1} closed +13:35:13.278 [restartedMain] INFO c.w.w.WinApplication - [logStarting,55] - Starting WinApplication using Java 1.8.0_352 on 172-1-2-46.lightspeed.hstntx.sbcglobal.net with PID 68286 (/Users/longlongxiaogege/work/mengyin/code/lianmei/win/win-admin/target/classes started by longlongxiaogege in /Users/longlongxiaogege/work/mengyin/code/lianmei/win) +13:35:13.279 [restartedMain] INFO c.w.w.WinApplication - [logStartupProfileInfo,686] - The following 3 profiles are active: "druid", "mybatis", "dev" +13:35:13.280 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +13:35:14.285 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-8080"] +13:35:14.285 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +13:35:14.285 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +13:35:14.319 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +13:35:14.599 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,996] - {dataSource-1,ccwin} inited +13:35:14.600 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [ccwin] success +13:35:14.600 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +13:35:14.600 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [ccwin] +13:35:15.006 [Druid-ConnectionPool-Create-970337372] INFO c.a.d.p.DruidAbstractDataSource - [setFailContinuous,1877] - {dataSource-1} failContinuous is true +13:36:26.255 [restartedMain] INFO c.w.w.WinApplication - [logStarting,55] - Starting WinApplication using Java 1.8.0_352 on 172-1-2-46.lightspeed.hstntx.sbcglobal.net with PID 68376 (/Users/longlongxiaogege/work/mengyin/code/lianmei/win/win-admin/target/classes started by longlongxiaogege in /Users/longlongxiaogege/work/mengyin/code/lianmei/win) +13:36:26.256 [restartedMain] INFO c.w.w.WinApplication - [logStartupProfileInfo,686] - The following 3 profiles are active: "druid", "mybatis", "dev" +13:36:26.257 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +13:36:27.208 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-8080"] +13:36:27.208 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +13:36:27.208 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +13:36:27.249 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +13:36:27.505 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,996] - {dataSource-1,ccwin} inited +13:36:27.506 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [ccwin] success +13:36:27.506 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +13:36:27.506 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [ccwin] +13:36:29.517 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +13:36:29.522 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +13:36:29.522 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +13:36:29.522 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +13:36:29.523 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +13:36:29.523 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +13:36:29.523 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +13:36:29.523 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@5c966900 +13:36:30.779 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Starting ProtocolHandler ["http-nio-8080"] +13:36:30.855 [restartedMain] INFO o.q.c.QuartzScheduler - [start,547] - Scheduler quartzScheduler_$_NON_CLUSTERED started. +13:36:30.862 [restartedMain] INFO c.w.w.WinApplication - [logStarted,61] - Started WinApplication in 4.84 seconds (JVM running for 5.151) +13:46:50.870 [http-nio-8080-exec-1] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring DispatcherServlet 'dispatcherServlet' +13:48:04.267 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +13:48:04.283 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +13:48:04.284 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +13:48:04.284 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +13:48:04.284 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +13:48:04.287 [SpringApplicationShutdownHook] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +13:48:04.288 [SpringApplicationShutdownHook] INFO c.a.d.p.DruidDataSource - [close,2138] - {dataSource-1} closing ... +13:48:04.293 [SpringApplicationShutdownHook] INFO c.a.d.p.DruidDataSource - [close,2211] - {dataSource-1} closed +13:48:08.345 [restartedMain] INFO c.w.w.WinApplication - [logStarting,55] - Starting WinApplication using Java 1.8.0_352 on 172-1-2-46.lightspeed.hstntx.sbcglobal.net with PID 69831 (/Users/longlongxiaogege/work/mengyin/code/lianmei/win/win-admin/target/classes started by longlongxiaogege in /Users/longlongxiaogege/work/mengyin/code/lianmei/win) +13:48:08.345 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +13:48:08.345 [restartedMain] INFO c.w.w.WinApplication - [logStartupProfileInfo,686] - The following 3 profiles are active: "druid", "mybatis", "dev" +13:48:09.274 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-8080"] +13:48:09.274 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +13:48:09.275 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +13:48:09.304 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +13:48:09.561 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,996] - {dataSource-1,ccwin} inited +13:48:09.561 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [ccwin] success +13:48:09.561 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +13:48:09.562 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [ccwin] +13:48:10.398 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +13:48:10.399 [restartedMain] INFO c.a.d.p.DruidDataSource - [close,2138] - {dataSource-1} closing ... +13:48:10.404 [restartedMain] INFO c.a.d.p.DruidDataSource - [close,2211] - {dataSource-1} closed +13:48:10.519 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Stopping service [Tomcat] +13:48:35.991 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +13:48:35.993 [restartedMain] INFO c.w.w.WinApplication - [logStarting,55] - Starting WinApplication using Java 1.8.0_352 on 172-1-2-46.lightspeed.hstntx.sbcglobal.net with PID 69859 (/Users/longlongxiaogege/work/mengyin/code/lianmei/win/win-admin/target/classes started by longlongxiaogege in /Users/longlongxiaogege/work/mengyin/code/lianmei/win) +13:48:35.993 [restartedMain] INFO c.w.w.WinApplication - [logStartupProfileInfo,686] - The following 3 profiles are active: "druid", "mybatis", "dev" +13:48:37.003 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-8080"] +13:48:37.003 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +13:48:37.003 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +13:48:37.032 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +13:48:37.281 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,996] - {dataSource-1,ccwin} inited +13:48:37.282 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [ccwin] success +13:48:37.282 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +13:48:37.282 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [ccwin] +13:48:38.579 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +13:48:38.583 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +13:48:38.583 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +13:48:38.583 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +13:48:38.584 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +13:48:38.584 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +13:48:38.584 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +13:48:38.584 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@3a9b75ea +13:48:39.605 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Starting ProtocolHandler ["http-nio-8080"] +13:48:39.715 [restartedMain] INFO o.q.c.QuartzScheduler - [start,547] - Scheduler quartzScheduler_$_NON_CLUSTERED started. +13:48:39.720 [restartedMain] INFO c.w.w.WinApplication - [logStarted,61] - Started WinApplication in 4.006 seconds (JVM running for 4.396) +13:51:43.677 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +13:51:43.691 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +13:51:43.692 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +13:51:43.692 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +13:51:43.692 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +13:51:43.695 [SpringApplicationShutdownHook] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +13:51:43.696 [SpringApplicationShutdownHook] INFO c.a.d.p.DruidDataSource - [close,2138] - {dataSource-1} closing ... +13:51:43.704 [SpringApplicationShutdownHook] INFO c.a.d.p.DruidDataSource - [close,2211] - {dataSource-1} closed +13:51:50.219 [restartedMain] INFO c.w.w.WinApplication - [logStarting,55] - Starting WinApplication using Java 1.8.0_352 on 172-1-2-46.lightspeed.hstntx.sbcglobal.net with PID 70042 (/Users/longlongxiaogege/work/mengyin/code/lianmei/win/win-admin/target/classes started by longlongxiaogege in /Users/longlongxiaogege/work/mengyin/code/lianmei/win) +13:51:50.220 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +13:51:50.220 [restartedMain] INFO c.w.w.WinApplication - [logStartupProfileInfo,686] - The following 3 profiles are active: "druid", "mybatis", "dev" +13:51:51.154 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-8080"] +13:51:51.154 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +13:51:51.154 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +13:51:51.183 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +13:51:51.438 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,996] - {dataSource-1,ccwin} inited +13:51:51.439 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [ccwin] success +13:51:51.439 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +13:51:51.439 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [ccwin] +13:51:52.673 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +13:51:52.676 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +13:51:52.677 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +13:51:52.677 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +13:51:52.677 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +13:51:52.677 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +13:51:52.677 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +13:51:52.678 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@76536c3b +13:51:53.667 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Starting ProtocolHandler ["http-nio-8080"] +13:51:53.740 [restartedMain] INFO o.q.c.QuartzScheduler - [start,547] - Scheduler quartzScheduler_$_NON_CLUSTERED started. +13:51:53.746 [restartedMain] INFO c.w.w.WinApplication - [logStarted,61] - Started WinApplication in 3.81 seconds (JVM running for 4.249) +13:53:51.976 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +13:53:51.987 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +13:53:51.987 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +13:53:51.987 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +13:53:51.987 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +13:53:51.990 [SpringApplicationShutdownHook] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +13:53:51.991 [SpringApplicationShutdownHook] INFO c.a.d.p.DruidDataSource - [close,2138] - {dataSource-1} closing ... +13:53:51.996 [SpringApplicationShutdownHook] INFO c.a.d.p.DruidDataSource - [close,2211] - {dataSource-1} closed +13:54:39.242 [restartedMain] INFO c.w.w.WinApplication - [logStarting,55] - Starting WinApplication using Java 1.8.0_352 on 172-1-2-46.lightspeed.hstntx.sbcglobal.net with PID 70209 (/Users/longlongxiaogege/work/mengyin/code/lianmei/win/win-admin/target/classes started by longlongxiaogege in /Users/longlongxiaogege/work/mengyin/code/lianmei/win) +13:54:39.242 [restartedMain] INFO c.w.w.WinApplication - [logStartupProfileInfo,686] - The following 3 profiles are active: "druid", "mybatis", "dev" +13:54:39.243 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +13:54:40.283 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-8080"] +13:54:40.284 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +13:54:40.284 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +13:54:40.311 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +13:54:40.562 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,996] - {dataSource-1,ccwin} inited +13:54:40.562 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [ccwin] success +13:54:40.563 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +13:54:40.563 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [ccwin] +13:54:41.821 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +13:54:41.825 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +13:54:41.825 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +13:54:41.825 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +13:54:41.826 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +13:54:41.826 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +13:54:41.826 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +13:54:41.826 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@42dedc9e +13:54:42.880 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Starting ProtocolHandler ["http-nio-8080"] +13:54:42.955 [restartedMain] INFO o.q.c.QuartzScheduler - [start,547] - Scheduler quartzScheduler_$_NON_CLUSTERED started. +13:54:42.961 [restartedMain] INFO c.w.w.WinApplication - [logStarted,61] - Started WinApplication in 3.926 seconds (JVM running for 4.428) +13:55:23.791 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +13:55:23.802 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +13:55:23.802 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +13:55:23.803 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +13:55:23.803 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +13:55:23.805 [SpringApplicationShutdownHook] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +13:55:23.806 [SpringApplicationShutdownHook] INFO c.a.d.p.DruidDataSource - [close,2138] - {dataSource-1} closing ... +13:55:23.810 [SpringApplicationShutdownHook] INFO c.a.d.p.DruidDataSource - [close,2211] - {dataSource-1} closed +14:00:46.381 [restartedMain] INFO c.w.w.WinApplication - [logStarting,55] - Starting WinApplication using Java 1.8.0_352 on 172-1-2-46.lightspeed.hstntx.sbcglobal.net with PID 70598 (/Users/longlongxiaogege/work/mengyin/code/lianmei/win/win-admin/target/classes started by longlongxiaogege in /Users/longlongxiaogege/work/mengyin/code/lianmei/win) +14:00:46.382 [restartedMain] INFO c.w.w.WinApplication - [logStartupProfileInfo,686] - The following 3 profiles are active: "druid", "mybatis", "dev" +14:00:46.383 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +14:00:47.449 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-8080"] +14:00:47.449 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +14:00:47.450 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +14:00:47.479 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +14:00:47.776 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,996] - {dataSource-1,ccwin} inited +14:00:47.777 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [ccwin] success +14:00:47.777 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +14:00:47.777 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [ccwin] +14:00:49.238 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +14:00:49.242 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +14:00:49.242 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +14:00:49.243 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +14:00:49.243 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +14:00:49.243 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +14:00:49.243 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +14:00:49.243 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@5c966900 +14:00:50.271 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Starting ProtocolHandler ["http-nio-8080"] +14:00:50.349 [restartedMain] INFO o.q.c.QuartzScheduler - [start,547] - Scheduler quartzScheduler_$_NON_CLUSTERED started. +14:00:50.355 [restartedMain] INFO c.w.w.WinApplication - [logStarted,61] - Started WinApplication in 4.322 seconds (JVM running for 4.782) +14:01:10.394 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +14:01:10.409 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +14:01:10.409 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +14:01:10.409 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +14:01:10.409 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +14:01:10.412 [SpringApplicationShutdownHook] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +14:01:10.413 [SpringApplicationShutdownHook] INFO c.a.d.p.DruidDataSource - [close,2138] - {dataSource-1} closing ... +14:01:10.418 [SpringApplicationShutdownHook] INFO c.a.d.p.DruidDataSource - [close,2211] - {dataSource-1} closed +14:01:15.896 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +14:01:15.897 [restartedMain] INFO c.w.w.WinApplication - [logStarting,55] - Starting WinApplication using Java 1.8.0_352 on 172-1-2-46.lightspeed.hstntx.sbcglobal.net with PID 70642 (/Users/longlongxiaogege/work/mengyin/code/lianmei/win/win-admin/target/classes started by longlongxiaogege in /Users/longlongxiaogege/work/mengyin/code/lianmei/win) +14:01:15.898 [restartedMain] INFO c.w.w.WinApplication - [logStartupProfileInfo,686] - The following 3 profiles are active: "druid", "mybatis", "dev" +14:01:16.831 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-9000"] +14:01:16.831 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +14:01:16.831 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +14:01:16.861 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +14:01:17.114 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,996] - {dataSource-1,ccwin} inited +14:01:17.115 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [ccwin] success +14:01:17.115 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +14:01:17.115 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [ccwin] +14:01:18.554 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +14:01:18.558 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +14:01:18.558 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +14:01:18.558 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +14:01:18.559 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +14:01:18.559 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +14:01:18.559 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +14:01:18.559 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@76c71a4a +14:01:19.622 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Starting ProtocolHandler ["http-nio-9000"] +14:01:19.700 [restartedMain] INFO o.q.c.QuartzScheduler - [start,547] - Scheduler quartzScheduler_$_NON_CLUSTERED started. +14:01:19.718 [restartedMain] INFO c.w.w.WinApplication - [logStarted,61] - Started WinApplication in 4.106 seconds (JVM running for 4.51) +14:01:30.756 [http-nio-9000-exec-1] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring DispatcherServlet 'dispatcherServlet' +14:01:36.458 [schedule-pool-1] INFO sys-user - [run,56] - [127.0.0.1]内网IP[admin][Success][登录成功] +14:08:14.171 [schedule-pool-1] INFO sys-user - [run,56] - [127.0.0.1]内网IP[admin][Success][登录成功] +14:16:02.932 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +14:16:02.947 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +14:16:02.947 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +14:16:02.947 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +14:16:02.948 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +14:16:02.950 [SpringApplicationShutdownHook] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +14:16:02.951 [SpringApplicationShutdownHook] INFO c.a.d.p.DruidDataSource - [close,2138] - {dataSource-1} closing ... +14:16:02.965 [SpringApplicationShutdownHook] INFO c.a.d.p.DruidDataSource - [close,2211] - {dataSource-1} closed +14:18:59.827 [restartedMain] INFO c.w.w.WinApplication - [logStarting,55] - Starting WinApplication using Java 1.8.0_352 on 172-1-2-46.lightspeed.hstntx.sbcglobal.net with PID 71594 (/Users/longlongxiaogege/work/mengyin/code/lianmei/win/win-admin/target/classes started by longlongxiaogege in /Users/longlongxiaogege/work/mengyin/code/lianmei/win) +14:18:59.828 [restartedMain] INFO c.w.w.WinApplication - [logStartupProfileInfo,686] - The following 3 profiles are active: "druid", "mybatis", "dev" +14:18:59.829 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +14:19:00.773 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-9000"] +14:19:00.773 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +14:19:00.774 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +14:19:00.802 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +14:19:01.061 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,996] - {dataSource-1,ccwin} inited +14:19:01.062 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [ccwin] success +14:19:01.062 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +14:19:01.062 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [ccwin] +14:19:01.627 [Druid-ConnectionPool-Create-70427675] INFO c.a.d.p.DruidAbstractDataSource - [setFailContinuous,1877] - {dataSource-1} failContinuous is true +14:19:36.641 [restartedMain] INFO c.w.w.WinApplication - [logStarting,55] - Starting WinApplication using Java 1.8.0_352 on 172-1-2-46.lightspeed.hstntx.sbcglobal.net with PID 71633 (/Users/longlongxiaogege/work/mengyin/code/lianmei/win/win-admin/target/classes started by longlongxiaogege in /Users/longlongxiaogege/work/mengyin/code/lianmei/win) +14:19:36.642 [restartedMain] INFO c.w.w.WinApplication - [logStartupProfileInfo,686] - The following 3 profiles are active: "druid", "mybatis", "dev" +14:19:36.642 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +14:19:37.576 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-9000"] +14:19:37.577 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +14:19:37.577 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +14:19:37.605 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +14:19:37.862 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,996] - {dataSource-1,ccwin} inited +14:19:37.863 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [ccwin] success +14:19:37.863 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +14:19:37.863 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [ccwin] +14:19:39.190 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +14:19:39.195 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +14:19:39.195 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +14:19:39.195 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +14:19:39.196 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +14:19:39.196 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +14:19:39.196 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +14:19:39.196 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@52ee2512 +14:19:40.228 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Starting ProtocolHandler ["http-nio-9000"] +14:19:40.303 [restartedMain] INFO o.q.c.QuartzScheduler - [start,547] - Scheduler quartzScheduler_$_NON_CLUSTERED started. +14:19:40.308 [restartedMain] INFO c.w.w.WinApplication - [logStarted,61] - Started WinApplication in 3.908 seconds (JVM running for 4.252) +14:19:45.518 [http-nio-9000-exec-1] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring DispatcherServlet 'dispatcherServlet' +14:26:07.025 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +14:26:07.036 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +14:26:07.036 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +14:26:07.036 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +14:26:07.036 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +14:26:07.039 [SpringApplicationShutdownHook] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +14:26:07.040 [SpringApplicationShutdownHook] INFO c.a.d.p.DruidDataSource - [close,2138] - {dataSource-1} closing ... +14:26:07.046 [SpringApplicationShutdownHook] INFO c.a.d.p.DruidDataSource - [close,2211] - {dataSource-1} closed +14:26:11.469 [restartedMain] INFO c.w.w.WinApplication - [logStarting,55] - Starting WinApplication using Java 1.8.0_352 on 172-1-2-46.lightspeed.hstntx.sbcglobal.net with PID 71987 (/Users/longlongxiaogege/work/mengyin/code/lianmei/win/win-admin/target/classes started by longlongxiaogege in /Users/longlongxiaogege/work/mengyin/code/lianmei/win) +14:26:11.470 [restartedMain] INFO c.w.w.WinApplication - [logStartupProfileInfo,686] - The following 3 profiles are active: "druid", "mybatis", "dev" +14:26:11.470 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +14:26:12.417 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-9000"] +14:26:12.417 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +14:26:12.417 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +14:26:12.445 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +14:26:12.689 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,996] - {dataSource-1,ccwin} inited +14:26:12.689 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [ccwin] success +14:26:12.690 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +14:26:12.690 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [ccwin] +14:26:13.952 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +14:26:13.956 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +14:26:13.956 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +14:26:13.957 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +14:26:13.957 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +14:26:13.957 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +14:26:13.957 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +14:26:13.957 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@440d44ca +14:26:14.975 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Starting ProtocolHandler ["http-nio-9000"] +14:26:15.049 [restartedMain] INFO o.q.c.QuartzScheduler - [start,547] - Scheduler quartzScheduler_$_NON_CLUSTERED started. +14:26:15.055 [restartedMain] INFO c.w.w.WinApplication - [logStarted,61] - Started WinApplication in 3.851 seconds (JVM running for 4.321) +14:26:23.931 [http-nio-9000-exec-1] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring DispatcherServlet 'dispatcherServlet' +14:27:47.038 [schedule-pool-1] INFO sys-user - [run,56] - [127.0.0.1]内网IP[admin][Success][登录成功] +14:28:35.995 [schedule-pool-1] INFO sys-user - [run,56] - [127.0.0.1]内网IP[admin][Logout][退出成功] +14:28:52.459 [schedule-pool-2] INFO sys-user - [run,56] - [127.0.0.1]内网IP[admin][Success][登录成功] +14:47:07.206 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +14:47:07.220 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +14:47:07.220 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +14:47:07.220 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +14:47:07.220 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +14:47:07.222 [SpringApplicationShutdownHook] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +14:47:07.223 [SpringApplicationShutdownHook] INFO c.a.d.p.DruidDataSource - [close,2138] - {dataSource-1} closing ... +14:47:07.234 [SpringApplicationShutdownHook] INFO c.a.d.p.DruidDataSource - [close,2211] - {dataSource-1} closed +14:47:11.784 [restartedMain] INFO c.w.w.WinApplication - [logStarting,55] - Starting WinApplication using Java 1.8.0_352 on 172-1-2-46.lightspeed.hstntx.sbcglobal.net with PID 73091 (/Users/longlongxiaogege/work/mengyin/code/lianmei/win/win-admin/target/classes started by longlongxiaogege in /Users/longlongxiaogege/work/mengyin/code/lianmei/win) +14:47:11.785 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +14:47:11.785 [restartedMain] INFO c.w.w.WinApplication - [logStartupProfileInfo,686] - The following 3 profiles are active: "druid", "mybatis", "dev" +14:47:12.724 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-9000"] +14:47:12.724 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +14:47:12.724 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +14:47:12.752 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +14:47:13.007 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,996] - {dataSource-1,ccwin} inited +14:47:13.008 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [ccwin] success +14:47:13.008 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +14:47:13.008 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [ccwin] +14:47:14.397 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +14:47:14.401 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +14:47:14.403 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +14:47:14.404 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +14:47:14.404 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +14:47:14.405 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +14:47:14.405 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +14:47:14.405 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@1b154a3b +14:47:15.408 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Starting ProtocolHandler ["http-nio-9000"] +14:47:15.481 [restartedMain] INFO o.q.c.QuartzScheduler - [start,547] - Scheduler quartzScheduler_$_NON_CLUSTERED started. +14:47:15.486 [restartedMain] INFO c.w.w.WinApplication - [logStarted,61] - Started WinApplication in 3.946 seconds (JVM running for 4.295) +14:47:41.008 [http-nio-9000-exec-1] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring DispatcherServlet 'dispatcherServlet' +15:03:02.621 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +15:03:02.634 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +15:03:02.635 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +15:03:02.635 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +15:03:02.635 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +15:03:02.637 [SpringApplicationShutdownHook] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +15:03:02.639 [SpringApplicationShutdownHook] INFO c.a.d.p.DruidDataSource - [close,2138] - {dataSource-1} closing ... +15:03:02.646 [SpringApplicationShutdownHook] INFO c.a.d.p.DruidDataSource - [close,2211] - {dataSource-1} closed +15:30:17.547 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +15:30:18.553 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-9000"] +15:30:18.554 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +15:30:18.554 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +15:30:18.585 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +15:30:18.858 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,996] - {dataSource-1,ccwin} inited +15:30:18.858 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [ccwin] success +15:30:18.859 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +15:30:18.859 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [ccwin] +15:30:19.705 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +15:30:19.706 [restartedMain] INFO c.a.d.p.DruidDataSource - [close,2138] - {dataSource-1} closing ... +15:30:19.710 [restartedMain] INFO c.a.d.p.DruidDataSource - [close,2211] - {dataSource-1} closed +15:30:19.820 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Stopping service [Tomcat] +15:30:50.184 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +15:30:51.096 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-9000"] +15:30:51.097 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +15:30:51.097 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +15:30:51.125 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +15:30:51.378 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,996] - {dataSource-1,ccwin} inited +15:30:51.378 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [ccwin] success +15:30:51.379 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +15:30:51.379 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [ccwin] +15:30:52.628 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +15:30:52.633 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +15:30:52.633 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +15:30:52.633 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +15:30:52.633 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +15:30:52.634 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +15:30:52.634 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +15:30:52.634 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@7e39f8e5 +15:30:53.648 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Starting ProtocolHandler ["http-nio-9000"] +15:30:53.656 [restartedMain] INFO o.q.c.QuartzScheduler - [start,547] - Scheduler quartzScheduler_$_NON_CLUSTERED started. +15:31:38.595 [http-nio-9000-exec-1] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring DispatcherServlet 'dispatcherServlet' +15:31:46.280 [schedule-pool-1] INFO sys-user - [run,56] - [127.0.0.1]内网IP[admin][Success][登录成功] +15:31:57.814 [Thread-11] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +15:31:57.861 [Thread-11] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +15:31:57.861 [Thread-11] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +15:31:57.861 [Thread-11] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +15:31:57.862 [Thread-11] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +15:31:57.863 [Thread-11] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +15:31:57.865 [Thread-11] INFO c.a.d.p.DruidDataSource - [close,2138] - {dataSource-1} closing ... +15:31:57.873 [Thread-11] INFO c.a.d.p.DruidDataSource - [close,2211] - {dataSource-1} closed +15:31:58.458 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-9000"] +15:31:58.458 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +15:31:58.459 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +15:31:58.463 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +15:31:58.556 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,996] - {dataSource-2,ccwin} inited +15:31:58.556 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [ccwin] success +15:31:58.556 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +15:31:58.557 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [ccwin] +15:31:59.332 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +15:31:59.333 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +15:31:59.333 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +15:31:59.333 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +15:31:59.333 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +15:31:59.334 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +15:31:59.334 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +15:31:59.334 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@2ead02a2 +15:32:00.122 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Starting ProtocolHandler ["http-nio-9000"] +15:32:00.126 [restartedMain] INFO o.q.c.QuartzScheduler - [start,547] - Scheduler quartzScheduler_$_NON_CLUSTERED started. +16:03:19.270 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +16:03:19.282 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +16:03:19.282 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +16:03:19.283 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +16:03:19.283 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +16:03:19.284 [SpringApplicationShutdownHook] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +16:03:19.284 [SpringApplicationShutdownHook] INFO c.a.d.p.DruidDataSource - [close,2138] - {dataSource-2} closing ... +16:03:19.285 [SpringApplicationShutdownHook] INFO c.a.d.p.DruidDataSource - [close,2211] - {dataSource-2} closed +17:23:39.536 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +17:23:40.463 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-9000"] +17:23:40.464 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +17:23:40.464 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +17:23:40.494 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +17:23:40.746 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,996] - {dataSource-1,ccwin} inited +17:23:40.746 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [ccwin] success +17:23:40.747 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +17:23:40.747 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [ccwin] +17:23:41.997 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +17:23:42.001 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +17:23:42.001 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +17:23:42.001 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +17:23:42.001 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +17:23:42.002 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +17:23:42.002 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +17:23:42.002 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@45a9f86 +17:23:43.043 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Starting ProtocolHandler ["http-nio-9000"] +17:23:43.048 [restartedMain] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +17:23:43.048 [restartedMain] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +17:23:43.048 [restartedMain] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +17:23:43.048 [restartedMain] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +17:23:43.051 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +17:23:43.052 [restartedMain] INFO c.a.d.p.DruidDataSource - [close,2138] - {dataSource-1} closing ... +17:23:43.059 [restartedMain] INFO c.a.d.p.DruidDataSource - [close,2211] - {dataSource-1} closed +17:23:43.174 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Pausing ProtocolHandler ["http-nio-9000"] +17:23:43.174 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Stopping service [Tomcat] +17:23:43.176 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Stopping ProtocolHandler ["http-nio-9000"] +17:23:43.176 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Destroying ProtocolHandler ["http-nio-9000"] +17:25:27.290 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +17:25:28.218 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-9000"] +17:25:28.218 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +17:25:28.219 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +17:25:28.248 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +17:25:28.511 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,996] - {dataSource-1,ccwin} inited +17:25:28.511 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [ccwin] success +17:25:28.512 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +17:25:28.512 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [ccwin] +17:25:29.758 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +17:25:29.762 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +17:25:29.762 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +17:25:29.763 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +17:25:29.763 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +17:25:29.763 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +17:25:29.763 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +17:25:29.763 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@59bb3eff +17:25:30.795 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Starting ProtocolHandler ["http-nio-9000"] +17:25:30.803 [restartedMain] INFO o.q.c.QuartzScheduler - [start,547] - Scheduler quartzScheduler_$_NON_CLUSTERED started. +17:25:38.345 [Thread-11] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +17:25:38.357 [Thread-11] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +17:25:38.357 [Thread-11] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +17:25:38.357 [Thread-11] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +17:25:38.357 [Thread-11] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +17:25:38.359 [Thread-11] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +17:25:38.361 [Thread-11] INFO c.a.d.p.DruidDataSource - [close,2138] - {dataSource-1} closing ... +17:25:38.366 [Thread-11] INFO c.a.d.p.DruidDataSource - [close,2211] - {dataSource-1} closed diff --git a/logs/sys-info.2023-07-28.log b/logs/sys-info.2023-07-28.log new file mode 100644 index 0000000..4ea4326 --- /dev/null +++ b/logs/sys-info.2023-07-28.log @@ -0,0 +1,503 @@ +09:20:36.522 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +09:20:37.484 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-9000"] +09:20:37.485 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +09:20:37.485 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +09:20:37.516 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +09:20:37.789 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,996] - {dataSource-1,dcdata} inited +09:20:37.790 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +09:20:37.790 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [dcdata] success +09:20:37.790 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [dcdata] +09:20:39.041 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +09:20:39.045 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +09:20:39.045 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +09:20:39.045 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +09:20:39.046 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +09:20:39.046 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +09:20:39.046 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +09:20:39.046 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@3ce5c865 +09:20:40.041 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Starting ProtocolHandler ["http-nio-9000"] +09:20:40.049 [restartedMain] INFO o.q.c.QuartzScheduler - [start,547] - Scheduler quartzScheduler_$_NON_CLUSTERED started. +09:23:44.766 [Thread-11] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +09:23:44.777 [Thread-11] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +09:23:44.777 [Thread-11] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +09:23:44.777 [Thread-11] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +09:23:44.778 [Thread-11] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +09:23:44.780 [Thread-11] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +09:23:45.581 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-9000"] +09:23:45.581 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +09:23:45.581 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +09:23:45.586 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +09:23:45.687 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,996] - {dataSource-2,dcdata} inited +09:23:45.687 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +09:23:45.688 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [dcdata] success +09:23:45.688 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [dcdata] +09:23:46.466 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +09:23:46.467 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +09:23:46.467 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +09:23:46.467 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +09:23:46.467 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +09:23:46.467 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +09:23:46.467 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +09:23:46.468 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@2bd7f31a +09:23:47.242 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Starting ProtocolHandler ["http-nio-9000"] +09:23:47.246 [restartedMain] INFO o.q.c.QuartzScheduler - [start,547] - Scheduler quartzScheduler_$_NON_CLUSTERED started. +09:23:48.672 [Thread-19] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +09:23:48.693 [Thread-19] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +09:23:48.693 [Thread-19] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +09:23:48.694 [Thread-19] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +09:23:48.694 [Thread-19] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +09:23:48.696 [Thread-19] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +09:23:49.325 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-9000"] +09:23:49.325 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +09:23:49.325 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +09:23:49.330 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +09:23:49.423 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,996] - {dataSource-3,dcdata} inited +09:23:49.423 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +09:23:49.424 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [dcdata] success +09:23:49.424 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [dcdata] +09:23:50.043 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +09:23:50.044 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +09:23:50.044 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +09:23:50.044 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +09:23:50.044 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +09:23:50.044 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +09:23:50.045 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +09:23:50.045 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@37a8e5e3 +09:23:50.835 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Starting ProtocolHandler ["http-nio-9000"] +09:23:50.848 [restartedMain] INFO o.q.c.QuartzScheduler - [start,547] - Scheduler quartzScheduler_$_NON_CLUSTERED started. +09:24:46.081 [Thread-24] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +09:24:46.092 [Thread-24] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +09:24:46.092 [Thread-24] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +09:24:46.092 [Thread-24] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +09:24:46.092 [Thread-24] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +09:24:46.093 [Thread-24] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +09:24:46.798 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-9000"] +09:24:46.799 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +09:24:46.799 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +09:24:46.803 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +09:24:46.891 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,996] - {dataSource-4,dcdata} inited +09:24:46.891 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +09:24:46.891 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [dcdata] success +09:24:46.891 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [dcdata] +09:24:47.492 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +09:24:47.493 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +09:24:47.493 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +09:24:47.493 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +09:24:47.493 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +09:24:47.493 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +09:24:47.493 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +09:24:47.493 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@2bc6b839 +09:24:48.251 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Starting ProtocolHandler ["http-nio-9000"] +09:24:48.265 [restartedMain] INFO o.q.c.QuartzScheduler - [start,547] - Scheduler quartzScheduler_$_NON_CLUSTERED started. +09:26:53.849 [Thread-29] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +09:26:53.876 [Thread-29] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +09:26:53.877 [Thread-29] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +09:26:53.877 [Thread-29] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +09:26:53.877 [Thread-29] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +09:26:53.880 [Thread-29] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +09:26:54.614 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-9000"] +09:26:54.615 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +09:26:54.615 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +09:26:54.619 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +09:26:54.729 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,996] - {dataSource-5,dcdata} inited +09:26:54.730 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +09:26:54.730 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [dcdata] success +09:26:54.730 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [dcdata] +09:26:55.451 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +09:26:55.452 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +09:26:55.453 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +09:26:55.453 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +09:26:55.453 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +09:26:55.453 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +09:26:55.453 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +09:26:55.453 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@59225245 +09:26:56.253 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Starting ProtocolHandler ["http-nio-9000"] +09:26:56.257 [restartedMain] INFO o.q.c.QuartzScheduler - [start,547] - Scheduler quartzScheduler_$_NON_CLUSTERED started. +09:27:03.216 [Thread-34] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +09:27:03.229 [Thread-34] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +09:27:03.229 [Thread-34] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +09:27:03.229 [Thread-34] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +09:27:03.229 [Thread-34] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +09:27:03.230 [Thread-34] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +09:27:03.868 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-9000"] +09:27:03.868 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +09:27:03.868 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +09:27:03.873 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +09:27:03.961 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,996] - {dataSource-6,dcdata} inited +09:27:03.962 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +09:27:03.962 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [dcdata] success +09:27:03.962 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [dcdata] +09:27:04.569 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +09:27:04.569 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +09:27:04.569 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +09:27:04.569 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +09:27:04.570 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +09:27:04.570 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +09:27:04.570 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +09:27:04.570 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@1969c370 +09:27:05.311 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Starting ProtocolHandler ["http-nio-9000"] +09:27:05.314 [restartedMain] INFO o.q.c.QuartzScheduler - [start,547] - Scheduler quartzScheduler_$_NON_CLUSTERED started. +09:27:09.336 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +09:27:09.347 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +09:27:09.347 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +09:27:09.347 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +09:27:09.348 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +09:27:09.349 [SpringApplicationShutdownHook] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +09:27:12.496 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +09:27:13.414 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-9000"] +09:27:13.414 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +09:27:13.414 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +09:27:13.443 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +09:27:13.709 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,996] - {dataSource-1,dcdata} inited +09:27:13.710 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +09:27:13.710 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [dcdata] success +09:27:13.710 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [dcdata] +09:27:14.986 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +09:27:14.990 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +09:27:14.990 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +09:27:14.990 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +09:27:14.991 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +09:27:14.991 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +09:27:14.991 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +09:27:14.991 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@50a1d2d3 +09:27:16.008 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Starting ProtocolHandler ["http-nio-9000"] +09:27:16.018 [restartedMain] INFO o.q.c.QuartzScheduler - [start,547] - Scheduler quartzScheduler_$_NON_CLUSTERED started. +09:46:59.139 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +09:46:59.151 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +09:46:59.151 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +09:46:59.151 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +09:46:59.151 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +09:46:59.153 [SpringApplicationShutdownHook] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +09:47:18.956 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +09:47:19.879 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-9000"] +09:47:19.879 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +09:47:19.879 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +09:47:19.908 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +09:47:20.160 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,996] - {dataSource-1,dcdata} inited +09:47:20.161 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +09:47:20.161 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [dcdata] success +09:47:20.161 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [dcdata] +09:47:21.381 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +09:47:21.385 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +09:47:21.386 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +09:47:21.386 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +09:47:21.386 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +09:47:21.386 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +09:47:21.386 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +09:47:21.387 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@3d1c9362 +09:47:22.404 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Starting ProtocolHandler ["http-nio-9000"] +09:47:22.413 [restartedMain] INFO o.q.c.QuartzScheduler - [start,547] - Scheduler quartzScheduler_$_NON_CLUSTERED started. +09:50:06.466 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +09:50:06.477 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +09:50:06.478 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +09:50:06.478 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +09:50:06.478 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +09:50:06.480 [SpringApplicationShutdownHook] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +09:50:17.949 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +09:50:18.858 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-9000"] +09:50:18.859 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +09:50:18.859 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +09:50:18.888 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +09:50:19.146 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,996] - {dataSource-1,dcdata} inited +09:50:19.146 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +09:50:19.147 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [dcdata] success +09:50:19.147 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [dcdata] +09:50:20.365 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +09:50:20.369 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +09:50:20.369 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +09:50:20.369 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +09:50:20.370 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +09:50:20.370 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +09:50:20.370 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +09:50:20.370 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@1d35982a +09:50:21.433 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Starting ProtocolHandler ["http-nio-9000"] +09:50:21.442 [restartedMain] INFO o.q.c.QuartzScheduler - [start,547] - Scheduler quartzScheduler_$_NON_CLUSTERED started. +09:50:32.932 [http-nio-9000-exec-1] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring DispatcherServlet 'dispatcherServlet' +10:00:17.182 [Thread-11] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +10:00:17.197 [Thread-11] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +10:00:17.197 [Thread-11] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +10:00:17.197 [Thread-11] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +10:00:17.197 [Thread-11] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +10:00:17.200 [Thread-11] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +10:00:17.810 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-9000"] +10:00:17.810 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +10:00:17.810 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +10:00:17.815 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +10:00:17.993 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,996] - {dataSource-2,dcdata} inited +10:00:17.993 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +10:00:17.994 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [dcdata] success +10:00:17.994 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [dcdata] +10:00:18.671 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +10:00:18.672 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +10:00:18.672 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +10:00:18.672 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +10:00:18.672 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +10:00:18.673 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +10:00:18.673 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +10:00:18.673 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@19e1b439 +10:00:19.425 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Starting ProtocolHandler ["http-nio-9000"] +10:00:19.439 [restartedMain] INFO o.q.c.QuartzScheduler - [start,547] - Scheduler quartzScheduler_$_NON_CLUSTERED started. +10:08:57.679 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +10:08:57.692 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +10:08:57.692 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +10:08:57.692 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +10:08:57.692 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +10:08:57.694 [SpringApplicationShutdownHook] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +10:40:33.148 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +10:40:34.153 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-9000"] +10:40:34.154 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +10:40:34.154 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +10:40:34.184 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +10:40:34.462 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,996] - {dataSource-1,dcdata} inited +10:40:34.463 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +10:40:34.463 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [dcdata] success +10:40:34.463 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [dcdata] +10:40:35.842 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +10:40:35.847 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +10:40:35.847 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +10:40:35.848 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +10:40:35.848 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +10:40:35.848 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +10:40:35.848 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +10:40:35.848 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@50c3f758 +10:40:36.957 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Starting ProtocolHandler ["http-nio-9000"] +10:40:36.966 [restartedMain] INFO o.q.c.QuartzScheduler - [start,547] - Scheduler quartzScheduler_$_NON_CLUSTERED started. +10:43:24.359 [Thread-12] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +10:43:24.392 [Thread-12] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +10:43:24.392 [Thread-12] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +10:43:24.392 [Thread-12] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +10:43:24.392 [Thread-12] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +10:43:24.395 [Thread-12] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +11:09:00.871 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +11:09:00.872 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +11:09:00.876 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +11:09:00.998 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,996] - {dataSource-2,dcdata} inited +11:09:00.998 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +11:09:00.998 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [dcdata] success +11:09:00.998 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [dcdata] +11:09:01.789 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +11:09:01.791 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +11:09:01.792 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +11:09:01.792 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +11:09:01.792 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +11:09:01.792 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +11:09:01.792 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +11:09:01.792 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@2f95d6ee +11:09:02.579 [restartedMain] INFO o.q.c.QuartzScheduler - [start,547] - Scheduler quartzScheduler_$_NON_CLUSTERED started. +11:09:02.582 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +11:09:02.593 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +11:09:02.594 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +11:09:02.594 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +11:09:02.594 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +11:09:02.595 [SpringApplicationShutdownHook] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +11:09:04.906 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +11:09:05.860 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-9000"] +11:09:05.860 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +11:09:05.860 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +11:09:05.888 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +11:09:06.154 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,996] - {dataSource-1,dcdata} inited +11:09:06.154 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +11:09:06.155 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [dcdata] success +11:09:06.155 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [dcdata] +11:09:07.370 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +11:09:07.374 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +11:09:07.374 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +11:09:07.375 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +11:09:07.375 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +11:09:07.375 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +11:09:07.375 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +11:09:07.376 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@1d35982a +11:09:08.381 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Starting ProtocolHandler ["http-nio-9000"] +11:09:08.390 [restartedMain] INFO o.q.c.QuartzScheduler - [start,547] - Scheduler quartzScheduler_$_NON_CLUSTERED started. +11:09:16.591 [http-nio-9000-exec-1] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring DispatcherServlet 'dispatcherServlet' +11:17:48.635 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +11:17:48.653 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +11:17:48.653 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +11:17:48.653 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +11:17:48.654 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +11:17:48.656 [SpringApplicationShutdownHook] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +11:17:50.347 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +11:17:51.256 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-9000"] +11:17:51.256 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +11:17:51.256 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +11:17:51.284 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +11:17:51.537 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,996] - {dataSource-1,dcdata} inited +11:17:51.538 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +11:17:51.538 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [dcdata] success +11:17:51.538 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [dcdata] +11:17:52.750 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +11:17:52.754 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +11:17:52.754 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +11:17:52.755 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +11:17:52.755 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +11:17:52.755 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +11:17:52.755 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +11:17:52.755 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@42660110 +11:17:53.766 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Starting ProtocolHandler ["http-nio-9000"] +11:17:53.775 [restartedMain] INFO o.q.c.QuartzScheduler - [start,547] - Scheduler quartzScheduler_$_NON_CLUSTERED started. +11:18:02.789 [http-nio-9000-exec-1] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring DispatcherServlet 'dispatcherServlet' +11:22:31.291 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +11:22:31.302 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +11:22:31.302 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +11:22:31.302 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +11:22:31.302 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +11:22:31.304 [SpringApplicationShutdownHook] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +11:22:34.114 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +11:22:35.050 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-9000"] +11:22:35.050 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +11:22:35.050 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +11:22:35.078 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +11:22:35.336 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,996] - {dataSource-1,dcdata} inited +11:22:35.337 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +11:22:35.337 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [dcdata] success +11:22:35.337 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [dcdata] +11:22:36.578 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +11:22:36.582 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +11:22:36.582 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +11:22:36.583 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +11:22:36.583 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +11:22:36.583 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +11:22:36.583 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +11:22:36.583 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@50a1d2d3 +11:22:37.589 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Starting ProtocolHandler ["http-nio-9000"] +11:22:37.598 [restartedMain] INFO o.q.c.QuartzScheduler - [start,547] - Scheduler quartzScheduler_$_NON_CLUSTERED started. +11:24:27.120 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +11:24:27.140 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +11:24:27.141 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +11:24:27.141 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +11:24:27.141 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +11:24:27.143 [SpringApplicationShutdownHook] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +11:24:44.719 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +11:24:45.612 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-9000"] +11:24:45.612 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +11:24:45.612 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +11:24:45.639 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +11:24:45.892 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,996] - {dataSource-1,dcdata} inited +11:24:45.892 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +11:24:45.893 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [dcdata] success +11:24:45.893 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [dcdata] +11:24:47.105 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +11:24:47.109 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +11:24:47.109 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +11:24:47.109 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +11:24:47.110 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +11:24:47.110 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +11:24:47.110 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +11:24:47.110 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@73ac4566 +11:24:48.095 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Starting ProtocolHandler ["http-nio-9000"] +11:24:48.104 [restartedMain] INFO o.q.c.QuartzScheduler - [start,547] - Scheduler quartzScheduler_$_NON_CLUSTERED started. +11:24:56.094 [http-nio-9000-exec-1] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring DispatcherServlet 'dispatcherServlet' +11:25:02.144 [schedule-pool-1] INFO sys-user - [run,56] - [127.0.0.1]内网IP[admin][Success][登录成功] +11:28:05.709 [schedule-pool-1] INFO sys-user - [run,56] - [127.0.0.1]内网IP[admin][Logout][退出成功] diff --git a/logs/sys-info.2023-07-29.log b/logs/sys-info.2023-07-29.log new file mode 100644 index 0000000..90b7cc3 --- /dev/null +++ b/logs/sys-info.2023-07-29.log @@ -0,0 +1,6 @@ +13:43:21.458 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +13:43:21.475 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +13:43:21.475 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +13:43:21.475 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +13:43:21.476 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +13:43:21.478 [SpringApplicationShutdownHook] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... diff --git a/logs/sys-info.2023-07-31.log b/logs/sys-info.2023-07-31.log new file mode 100644 index 0000000..8b46366 --- /dev/null +++ b/logs/sys-info.2023-07-31.log @@ -0,0 +1,211 @@ +09:24:16.405 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +09:24:17.580 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-9000"] +09:24:17.581 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +09:24:17.581 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +09:24:17.615 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +09:24:17.921 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,996] - {dataSource-1,dcdata} inited +09:24:17.922 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +09:24:17.922 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [dcdata] success +09:24:17.922 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [dcdata] +09:24:19.284 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +09:24:19.288 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +09:24:19.288 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +09:24:19.289 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +09:24:19.289 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +09:24:19.289 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +09:24:19.289 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +09:24:19.290 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@76278c0b +09:24:20.425 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Starting ProtocolHandler ["http-nio-9000"] +09:24:20.433 [restartedMain] INFO o.q.c.QuartzScheduler - [start,547] - Scheduler quartzScheduler_$_NON_CLUSTERED started. +09:25:02.263 [http-nio-9000-exec-1] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring DispatcherServlet 'dispatcherServlet' +09:25:06.247 [schedule-pool-1] INFO sys-user - [run,56] - [127.0.0.1]内网IP[admin][Success][登录成功] +09:40:51.118 [lettuce-eventExecutorLoop-1-8] INFO i.l.c.p.ConnectionWatchdog - [log,171] - Reconnecting, last destination was /10.10.10.55:7000 +09:41:01.210 [lettuce-eventExecutorLoop-1-3] INFO i.l.c.p.ConnectionWatchdog - [log,171] - Reconnecting, last destination was 10.10.10.55:7000 +09:41:11.312 [lettuce-eventExecutorLoop-1-5] INFO i.l.c.p.ConnectionWatchdog - [log,171] - Reconnecting, last destination was 10.10.10.55:7000 +09:41:21.412 [lettuce-eventExecutorLoop-1-7] INFO i.l.c.p.ConnectionWatchdog - [log,171] - Reconnecting, last destination was 10.10.10.55:7000 +09:41:31.512 [lettuce-eventExecutorLoop-1-1] INFO i.l.c.p.ConnectionWatchdog - [log,171] - Reconnecting, last destination was 10.10.10.55:7000 +09:41:41.610 [lettuce-eventExecutorLoop-1-3] INFO i.l.c.p.ConnectionWatchdog - [log,171] - Reconnecting, last destination was 10.10.10.55:7000 +09:41:51.712 [lettuce-eventExecutorLoop-1-5] INFO i.l.c.p.ConnectionWatchdog - [log,171] - Reconnecting, last destination was 10.10.10.55:7000 +09:42:01.910 [lettuce-eventExecutorLoop-1-7] INFO i.l.c.p.ConnectionWatchdog - [log,171] - Reconnecting, last destination was 10.10.10.55:7000 +09:42:12.212 [lettuce-eventExecutorLoop-1-1] INFO i.l.c.p.ConnectionWatchdog - [log,171] - Reconnecting, last destination was 10.10.10.55:7000 +09:42:22.811 [lettuce-eventExecutorLoop-1-3] INFO i.l.c.p.ConnectionWatchdog - [log,171] - Reconnecting, last destination was 10.10.10.55:7000 +09:42:33.909 [lettuce-eventExecutorLoop-1-5] INFO i.l.c.p.ConnectionWatchdog - [log,171] - Reconnecting, last destination was 10.10.10.55:7000 +09:42:46.012 [lettuce-eventExecutorLoop-1-7] INFO i.l.c.p.ConnectionWatchdog - [log,171] - Reconnecting, last destination was 10.10.10.55:7000 +09:43:00.212 [lettuce-eventExecutorLoop-1-1] INFO i.l.c.p.ConnectionWatchdog - [log,171] - Reconnecting, last destination was 10.10.10.55:7000 +09:43:18.512 [lettuce-eventExecutorLoop-1-3] INFO i.l.c.p.ConnectionWatchdog - [log,171] - Reconnecting, last destination was 10.10.10.55:7000 +09:43:44.912 [lettuce-eventExecutorLoop-1-5] INFO i.l.c.p.ConnectionWatchdog - [log,171] - Reconnecting, last destination was 10.10.10.55:7000 +09:43:57.899 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +09:43:57.916 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +09:43:57.916 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +09:43:57.917 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +09:43:57.917 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +09:43:57.918 [SpringApplicationShutdownHook] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +09:44:02.339 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +09:44:03.271 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-9000"] +09:44:03.272 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +09:44:03.272 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +09:44:03.299 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +09:44:03.551 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,996] - {dataSource-1,dcdata} inited +09:44:03.552 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +09:44:03.552 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [dcdata] success +09:44:03.552 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [dcdata] +09:44:23.965 [Druid-ConnectionPool-Create-388032892] INFO c.a.d.p.DruidAbstractDataSource - [setFailContinuous,1877] - {dataSource-1} failContinuous is true +09:45:48.736 [Druid-ConnectionPool-Create-388032892] INFO c.a.d.p.DruidAbstractDataSource - [setFailContinuous,1882] - {dataSource-1} failContinuous is false +09:45:49.703 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +09:45:49.707 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +09:45:49.708 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +09:45:49.708 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +09:45:49.708 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +09:45:49.708 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +09:45:49.708 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +09:45:49.709 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@295e48a2 +09:45:50.745 [restartedMain] INFO o.q.c.QuartzScheduler - [start,547] - Scheduler quartzScheduler_$_NON_CLUSTERED started. +09:45:50.753 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +09:45:50.764 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +09:45:50.765 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +09:45:50.765 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +09:45:50.765 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +09:45:50.767 [SpringApplicationShutdownHook] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +09:45:52.660 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +09:45:53.595 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-9000"] +09:45:53.595 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +09:45:53.595 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +09:45:53.628 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +09:45:53.887 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,996] - {dataSource-1,dcdata} inited +09:45:53.887 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +09:45:53.888 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [dcdata] success +09:45:53.888 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [dcdata] +09:45:55.140 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +09:45:55.144 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +09:45:55.144 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +09:45:55.144 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +09:45:55.145 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +09:45:55.145 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +09:45:55.145 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +09:45:55.145 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@4319877e +09:45:56.130 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Starting ProtocolHandler ["http-nio-9000"] +09:45:56.139 [restartedMain] INFO o.q.c.QuartzScheduler - [start,547] - Scheduler quartzScheduler_$_NON_CLUSTERED started. +09:46:09.561 [http-nio-9000-exec-1] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring DispatcherServlet 'dispatcherServlet' +09:46:15.383 [schedule-pool-1] INFO sys-user - [run,56] - [127.0.0.1]内网IP[admin][Success][登录成功] +09:53:27.586 [schedule-pool-1] INFO sys-user - [run,56] - [127.0.0.1]内网IP[admin][Logout][退出成功] +09:53:35.971 [schedule-pool-2] INFO sys-user - [run,56] - [127.0.0.1]内网IP[ry][Success][登录成功] +10:04:38.064 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +10:04:38.085 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +10:04:38.085 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +10:04:38.086 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +10:04:38.086 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +10:04:38.087 [SpringApplicationShutdownHook] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +10:04:44.129 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +10:04:45.216 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-9000"] +10:04:45.216 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +10:04:45.216 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +10:04:45.248 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +10:04:45.545 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,996] - {dataSource-1,dcdata} inited +10:04:45.545 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +10:04:45.546 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [dcdata] success +10:04:45.546 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [dcdata] +10:04:49.955 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +10:04:49.960 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +10:04:49.960 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +10:04:49.960 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +10:04:49.961 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +10:04:49.961 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +10:04:49.961 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +10:04:49.961 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@8b0d903 +10:04:52.586 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Starting ProtocolHandler ["http-nio-9000"] +10:04:52.599 [restartedMain] INFO o.q.c.QuartzScheduler - [start,547] - Scheduler quartzScheduler_$_NON_CLUSTERED started. +10:05:06.622 [http-nio-9000-exec-1] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring DispatcherServlet 'dispatcherServlet' +10:28:15.312 [schedule-pool-1] INFO sys-user - [run,56] - [127.0.0.1]内网IP[admin][Success][登录成功] +10:29:22.309 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +10:29:22.344 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +10:29:22.344 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +10:29:22.344 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +10:29:22.345 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +10:29:22.347 [SpringApplicationShutdownHook] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +10:29:27.063 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +10:29:28.099 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-9000"] +10:29:28.099 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +10:29:28.099 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +10:29:28.132 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +10:29:28.422 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,996] - {dataSource-1,dcdata} inited +10:29:28.423 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +10:29:28.424 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [dcdata] success +10:29:28.424 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [dcdata] +10:29:29.770 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +10:29:29.775 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +10:29:29.775 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +10:29:29.775 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +10:29:29.776 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +10:29:29.776 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +10:29:29.776 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +10:29:29.776 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@58f5bb7b +10:29:30.879 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Starting ProtocolHandler ["http-nio-9000"] +10:29:30.890 [restartedMain] INFO o.q.c.QuartzScheduler - [start,547] - Scheduler quartzScheduler_$_NON_CLUSTERED started. +10:29:42.906 [http-nio-9000-exec-1] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring DispatcherServlet 'dispatcherServlet' +16:16:32.608 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +16:16:33.590 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-9000"] +16:16:33.591 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +16:16:33.591 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +16:16:33.631 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +16:16:33.917 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,996] - {dataSource-1,dcdata} inited +16:16:33.917 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +16:16:33.918 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [dcdata] success +16:16:33.918 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [dcdata] +16:16:35.072 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +16:16:35.077 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +16:16:35.077 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +16:16:35.078 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +16:16:35.078 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +16:16:35.078 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +16:16:35.078 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +16:16:35.078 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@21856edc +16:16:36.078 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Starting ProtocolHandler ["http-nio-9000"] +16:16:36.093 [restartedMain] INFO o.q.c.QuartzScheduler - [start,547] - Scheduler quartzScheduler_$_NON_CLUSTERED started. +16:17:38.175 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +16:17:38.197 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +16:17:38.197 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +16:17:38.197 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +16:17:38.198 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +16:17:38.200 [SpringApplicationShutdownHook] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... diff --git a/logs/sys-info.log b/logs/sys-info.log new file mode 100644 index 0000000..b2dec8f --- /dev/null +++ b/logs/sys-info.log @@ -0,0 +1,784 @@ +09:58:56.625 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +09:58:57.567 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-9000"] +09:58:57.568 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +09:58:57.568 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +09:58:57.607 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +09:58:57.888 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,996] - {dataSource-1,dcdata} inited +09:58:57.889 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +09:58:57.889 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [dcdata] success +09:58:57.889 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [dcdata] +09:58:59.000 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +09:58:59.004 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +09:58:59.004 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +09:58:59.005 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +09:58:59.005 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +09:58:59.005 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +09:58:59.005 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +09:58:59.005 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@1c8a0e4e +09:59:00.050 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Starting ProtocolHandler ["http-nio-9000"] +09:59:00.058 [restartedMain] INFO o.q.c.QuartzScheduler - [start,547] - Scheduler quartzScheduler_$_NON_CLUSTERED started. +10:03:27.123 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +10:03:27.146 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +10:03:27.147 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +10:03:27.147 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +10:03:27.147 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +10:03:27.150 [SpringApplicationShutdownHook] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +10:03:30.407 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +10:03:31.292 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-9000"] +10:03:31.292 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +10:03:31.292 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +10:03:31.321 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +10:03:31.574 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,996] - {dataSource-1,dcdata} inited +10:03:31.574 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +10:03:31.575 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [dcdata] success +10:03:31.575 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [dcdata] +10:03:32.739 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +10:03:32.743 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +10:03:32.743 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +10:03:32.744 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +10:03:32.744 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +10:03:32.744 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +10:03:32.744 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +10:03:32.744 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@2fccfcbd +10:03:33.745 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Starting ProtocolHandler ["http-nio-9000"] +10:03:33.753 [restartedMain] INFO o.q.c.QuartzScheduler - [start,547] - Scheduler quartzScheduler_$_NON_CLUSTERED started. +10:04:57.457 [http-nio-9000-exec-1] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring DispatcherServlet 'dispatcherServlet' +10:05:03.955 [schedule-pool-1] INFO sys-user - [run,56] - [127.0.0.1]内网IP[admin][Success][登录成功] +10:14:26.170 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +10:14:26.194 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +10:14:26.194 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +10:14:26.195 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +10:14:26.195 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +10:14:26.196 [SpringApplicationShutdownHook] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +10:14:27.899 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +10:14:28.783 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-9000"] +10:14:28.783 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +10:14:28.783 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +10:14:28.812 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +10:14:29.074 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,996] - {dataSource-1,dcdata} inited +10:14:29.075 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +10:14:29.076 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [dcdata] success +10:14:29.076 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [dcdata] +10:14:30.139 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +10:14:30.143 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +10:14:30.143 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +10:14:30.143 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +10:14:30.144 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +10:14:30.144 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +10:14:30.144 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +10:14:30.144 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@228d22a9 +10:14:31.080 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Starting ProtocolHandler ["http-nio-9000"] +10:14:31.089 [restartedMain] INFO o.q.c.QuartzScheduler - [start,547] - Scheduler quartzScheduler_$_NON_CLUSTERED started. +10:14:56.848 [http-nio-9000-exec-1] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring DispatcherServlet 'dispatcherServlet' +10:53:56.269 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +10:53:56.294 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +10:53:56.294 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +10:53:56.294 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +10:53:56.295 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +10:53:56.296 [SpringApplicationShutdownHook] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +10:53:58.310 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +10:53:59.197 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-9000"] +10:53:59.198 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +10:53:59.198 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +10:53:59.226 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +10:53:59.489 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,996] - {dataSource-1,dcdata} inited +10:53:59.489 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +10:53:59.489 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [dcdata] success +10:53:59.490 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [dcdata] +10:53:59.538 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +10:53:59.543 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Stopping service [Tomcat] +10:55:02.321 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +10:55:03.203 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-9000"] +10:55:03.203 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +10:55:03.203 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +10:55:03.232 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +10:55:03.490 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,996] - {dataSource-1,dcdata} inited +10:55:03.491 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +10:55:03.491 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [dcdata] success +10:55:03.491 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [dcdata] +10:55:03.539 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +10:55:03.544 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Stopping service [Tomcat] +10:58:46.467 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +10:58:47.356 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-9000"] +10:58:47.356 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +10:58:47.356 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +10:58:47.386 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +10:58:47.650 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,996] - {dataSource-1,dcdata} inited +10:58:47.651 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +10:58:47.651 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [dcdata] success +10:58:47.651 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [dcdata] +10:58:47.697 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +10:58:47.703 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Stopping service [Tomcat] +11:02:47.213 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +11:02:48.128 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-9000"] +11:02:48.129 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +11:02:48.129 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +11:02:48.159 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +11:02:48.428 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,996] - {dataSource-1,dcdata} inited +11:02:48.429 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +11:02:48.429 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [dcdata] success +11:02:48.429 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [dcdata] +11:02:48.474 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +11:02:48.479 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Stopping service [Tomcat] +11:04:18.878 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +11:04:19.909 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-9000"] +11:04:19.909 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +11:04:19.909 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +11:04:19.938 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +11:04:20.186 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,996] - {dataSource-1,dcdata} inited +11:04:20.187 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +11:04:20.188 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [dcdata] success +11:04:20.188 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [dcdata] +11:04:20.337 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +11:04:20.343 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Stopping service [Tomcat] +11:05:35.064 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +11:05:35.947 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-9000"] +11:05:35.947 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +11:05:35.947 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +11:05:35.975 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +11:05:36.241 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,996] - {dataSource-1,dcdata} inited +11:05:36.241 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +11:05:36.241 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [dcdata] success +11:05:36.241 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [dcdata] +11:05:36.385 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +11:05:36.390 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Stopping service [Tomcat] +11:13:27.166 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +11:13:28.108 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-9000"] +11:13:28.108 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +11:13:28.109 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +11:13:28.145 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +11:13:28.419 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,996] - {dataSource-1,dcdata} inited +11:13:28.420 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +11:13:28.420 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [dcdata] success +11:13:28.420 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [dcdata] +11:13:28.565 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +11:13:28.570 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Stopping service [Tomcat] +11:14:16.003 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +11:14:16.902 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-9000"] +11:14:16.903 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +11:14:16.903 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +11:14:16.932 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +11:14:17.194 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,996] - {dataSource-1,dcdata} inited +11:14:17.194 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +11:14:17.195 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [dcdata] success +11:14:17.195 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [dcdata] +11:14:18.293 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +11:14:18.297 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +11:14:18.298 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +11:14:18.298 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +11:14:18.298 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +11:14:18.298 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +11:14:18.298 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +11:14:18.298 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@6f27db75 +11:14:19.409 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Starting ProtocolHandler ["http-nio-9000"] +11:14:19.416 [restartedMain] INFO o.q.c.QuartzScheduler - [start,547] - Scheduler quartzScheduler_$_NON_CLUSTERED started. +11:15:02.187 [Thread-5] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +11:15:02.208 [Thread-5] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +11:15:02.208 [Thread-5] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +11:15:02.208 [Thread-5] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +11:15:02.208 [Thread-5] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +11:15:02.210 [Thread-5] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +11:15:02.757 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-9000"] +11:15:02.758 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +11:15:02.758 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +11:15:02.766 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +11:15:02.913 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,996] - {dataSource-2,dcdata} inited +11:15:02.913 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +11:15:02.913 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [dcdata] success +11:15:02.914 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [dcdata] +11:15:03.661 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +11:15:03.662 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +11:15:03.662 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +11:15:03.662 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +11:15:03.662 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +11:15:03.662 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +11:15:03.662 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +11:15:03.662 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@46283372 +11:15:04.447 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Starting ProtocolHandler ["http-nio-9000"] +11:15:04.451 [restartedMain] INFO o.q.c.QuartzScheduler - [start,547] - Scheduler quartzScheduler_$_NON_CLUSTERED started. +11:15:05.857 [Thread-8] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +11:15:05.879 [Thread-8] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +11:15:05.879 [Thread-8] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +11:15:05.879 [Thread-8] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +11:15:05.879 [Thread-8] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +11:15:05.880 [Thread-8] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +11:15:06.364 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-9000"] +11:15:06.364 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +11:15:06.364 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +11:15:06.371 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +11:15:06.448 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,996] - {dataSource-3,dcdata} inited +11:15:06.448 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +11:15:06.448 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [dcdata] success +11:15:06.448 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [dcdata] +11:15:07.086 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +11:15:07.086 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +11:15:07.086 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +11:15:07.086 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +11:15:07.087 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +11:15:07.087 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +11:15:07.087 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +11:15:07.087 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@2b5dc792 +11:15:07.944 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Starting ProtocolHandler ["http-nio-9000"] +11:15:07.949 [restartedMain] INFO o.q.c.QuartzScheduler - [start,547] - Scheduler quartzScheduler_$_NON_CLUSTERED started. +11:15:10.394 [Thread-12] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +11:15:10.404 [Thread-12] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +11:15:10.404 [Thread-12] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +11:15:10.404 [Thread-12] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +11:15:10.404 [Thread-12] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +11:15:10.406 [Thread-12] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +11:15:10.862 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-9000"] +11:15:10.863 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +11:15:10.863 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +11:15:10.870 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +11:15:10.946 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,996] - {dataSource-4,dcdata} inited +11:15:10.946 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +11:15:10.946 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [dcdata] success +11:15:10.946 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [dcdata] +11:15:11.521 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +11:15:11.522 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +11:15:11.522 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +11:15:11.522 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +11:15:11.522 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +11:15:11.522 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +11:15:11.522 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +11:15:11.522 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@56910b57 +11:15:12.236 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Starting ProtocolHandler ["http-nio-9000"] +11:15:12.239 [restartedMain] INFO o.q.c.QuartzScheduler - [start,547] - Scheduler quartzScheduler_$_NON_CLUSTERED started. +11:15:13.490 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +11:15:13.497 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +11:15:13.497 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +11:15:13.497 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +11:15:13.497 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +11:15:13.498 [SpringApplicationShutdownHook] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +11:15:15.683 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +11:15:16.579 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-9000"] +11:15:16.579 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +11:15:16.580 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +11:15:16.610 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +11:15:16.872 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,996] - {dataSource-1,dcdata} inited +11:15:16.873 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +11:15:16.873 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [dcdata] success +11:15:16.873 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [dcdata] +11:15:17.949 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +11:15:17.954 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +11:15:17.954 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +11:15:17.954 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +11:15:17.954 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +11:15:17.955 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +11:15:17.955 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +11:15:17.955 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@73d77d0c +11:15:18.904 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Starting ProtocolHandler ["http-nio-9000"] +11:15:18.912 [restartedMain] INFO o.q.c.QuartzScheduler - [start,547] - Scheduler quartzScheduler_$_NON_CLUSTERED started. +11:15:45.640 [http-nio-9000-exec-1] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring DispatcherServlet 'dispatcherServlet' +11:22:39.719 [Thread-5] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +11:22:39.768 [Thread-5] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +11:22:39.768 [Thread-5] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +11:22:39.768 [Thread-5] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +11:22:39.768 [Thread-5] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +11:22:39.771 [Thread-5] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +11:22:40.709 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-9000"] +11:22:40.709 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +11:22:40.709 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +11:22:40.718 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +11:22:40.839 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,996] - {dataSource-2,dcdata} inited +11:22:40.840 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +11:22:40.840 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [dcdata] success +11:22:40.840 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [dcdata] +11:22:41.018 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +11:22:41.021 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Stopping service [Tomcat] +11:22:43.834 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-9000"] +11:22:43.834 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +11:22:43.834 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +11:22:43.841 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +11:22:43.925 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,996] - {dataSource-3,dcdata} inited +11:22:43.925 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +11:22:43.925 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [dcdata] success +11:22:43.925 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [dcdata] +11:22:44.062 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +11:22:44.064 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Stopping service [Tomcat] +11:22:46.502 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +11:22:47.410 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-9000"] +11:22:47.410 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +11:22:47.410 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +11:22:47.441 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +11:22:47.703 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,996] - {dataSource-1,dcdata} inited +11:22:47.704 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +11:22:47.704 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [dcdata] success +11:22:47.704 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [dcdata] +11:22:47.963 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +11:22:47.971 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Stopping service [Tomcat] +11:23:47.027 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +11:23:47.939 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-9000"] +11:23:47.939 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +11:23:47.939 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +11:23:47.969 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +11:23:48.229 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,996] - {dataSource-1,dcdata} inited +11:23:48.230 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +11:23:48.230 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [dcdata] success +11:23:48.230 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [dcdata] +11:23:48.511 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +11:23:48.517 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Stopping service [Tomcat] +11:27:52.504 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +11:27:53.407 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-9000"] +11:27:53.407 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +11:27:53.407 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +11:27:53.437 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +11:27:53.699 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,996] - {dataSource-1,dcdata} inited +11:27:53.700 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +11:27:53.700 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [dcdata] success +11:27:53.700 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [dcdata] +11:27:54.783 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +11:27:54.787 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +11:27:54.787 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +11:27:54.788 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +11:27:54.788 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +11:27:54.788 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +11:27:54.788 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +11:27:54.788 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@156cc9b5 +11:27:55.743 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Starting ProtocolHandler ["http-nio-9000"] +11:27:55.754 [restartedMain] INFO o.q.c.QuartzScheduler - [start,547] - Scheduler quartzScheduler_$_NON_CLUSTERED started. +11:28:05.897 [http-nio-9000-exec-1] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring DispatcherServlet 'dispatcherServlet' +12:02:00.913 [Thread-5] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +12:02:00.942 [Thread-5] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +12:02:00.943 [Thread-5] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +12:02:00.943 [Thread-5] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +12:02:00.943 [Thread-5] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +12:02:00.945 [Thread-5] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +12:02:01.813 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-9000"] +12:02:01.813 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +12:02:01.814 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +12:02:01.822 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +12:02:01.948 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,996] - {dataSource-2,dcdata} inited +12:02:01.949 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +12:02:01.949 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [dcdata] success +12:02:01.950 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [dcdata] +12:02:01.984 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +12:02:01.993 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Stopping service [Tomcat] +12:06:01.774 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-9000"] +12:06:01.774 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +12:06:01.774 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +12:06:01.783 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +12:06:01.886 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,996] - {dataSource-3,dcdata} inited +12:06:01.887 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +12:06:01.887 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [dcdata] success +12:06:01.887 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [dcdata] +12:06:02.786 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +12:06:02.787 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +12:06:02.787 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +12:06:02.787 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +12:06:02.787 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +12:06:02.788 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +12:06:02.788 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +12:06:02.788 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@f6d725f +12:06:03.801 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Starting ProtocolHandler ["http-nio-9000"] +12:06:03.805 [restartedMain] INFO o.q.c.QuartzScheduler - [start,547] - Scheduler quartzScheduler_$_NON_CLUSTERED started. +12:07:01.837 [Thread-8] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +12:07:01.844 [Thread-8] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +12:07:01.844 [Thread-8] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +12:07:01.844 [Thread-8] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +12:07:01.844 [Thread-8] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +12:07:01.846 [Thread-8] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +12:07:02.315 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-9000"] +12:07:02.315 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +12:07:02.315 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +12:07:02.327 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +12:07:02.408 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,996] - {dataSource-4,dcdata} inited +12:07:02.408 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +12:07:02.408 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [dcdata] success +12:07:02.408 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [dcdata] +12:07:02.430 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +12:07:02.431 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Stopping service [Tomcat] +12:07:04.207 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-9000"] +12:07:04.207 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +12:07:04.207 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +12:07:04.214 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +12:07:04.290 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,996] - {dataSource-5,dcdata} inited +12:07:04.291 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +12:07:04.291 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [dcdata] success +12:07:04.291 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [dcdata] +12:07:04.319 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +12:07:04.320 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Stopping service [Tomcat] +12:07:25.696 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-9000"] +12:07:25.696 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +12:07:25.696 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +12:07:25.706 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +12:07:25.795 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,996] - {dataSource-6,dcdata} inited +12:07:25.795 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +12:07:25.795 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [dcdata] success +12:07:25.795 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [dcdata] +12:07:25.817 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +12:07:25.818 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Stopping service [Tomcat] +12:07:27.568 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-9000"] +12:07:27.568 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +12:07:27.568 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +12:07:27.576 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +12:07:27.658 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,996] - {dataSource-7,dcdata} inited +12:07:27.658 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +12:07:27.658 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [dcdata] success +12:07:27.658 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [dcdata] +12:07:27.678 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +12:07:27.679 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Stopping service [Tomcat] +12:12:52.160 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-9000"] +12:12:52.160 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +12:12:52.160 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +12:12:52.168 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +12:12:52.248 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,996] - {dataSource-8,dcdata} inited +12:12:52.248 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +12:12:52.248 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [dcdata] success +12:12:52.248 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [dcdata] +12:12:52.276 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +12:12:52.276 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Stopping service [Tomcat] +12:12:54.054 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-9000"] +12:12:54.054 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +12:12:54.054 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +12:12:54.062 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +12:12:54.150 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,996] - {dataSource-9,dcdata} inited +12:12:54.150 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +12:12:54.150 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [dcdata] success +12:12:54.151 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [dcdata] +12:12:54.176 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +12:12:54.177 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Stopping service [Tomcat] +12:13:16.490 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-9000"] +12:13:16.490 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +12:13:16.490 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +12:13:16.497 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +12:13:16.579 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,996] - {dataSource-10,dcdata} inited +12:13:16.580 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +12:13:16.580 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [dcdata] success +12:13:16.580 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [dcdata] +12:13:16.603 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +12:13:16.604 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Stopping service [Tomcat] +12:13:32.904 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-9000"] +12:13:32.904 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +12:13:32.904 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +12:13:32.911 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +12:13:32.997 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,996] - {dataSource-11,dcdata} inited +12:13:32.997 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +12:13:32.998 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [dcdata] success +12:13:32.998 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [dcdata] +12:13:33.685 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +12:13:33.686 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +12:13:33.686 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +12:13:33.686 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +12:13:33.686 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +12:13:33.686 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +12:13:33.686 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +12:13:33.686 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@7f8f2c86 +12:13:34.599 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Starting ProtocolHandler ["http-nio-9000"] +12:13:34.611 [restartedMain] INFO o.q.c.QuartzScheduler - [start,547] - Scheduler quartzScheduler_$_NON_CLUSTERED started. +12:15:07.988 [http-nio-9000-exec-1] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring DispatcherServlet 'dispatcherServlet' +13:29:42.368 [Thread-15] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +13:29:42.378 [Thread-15] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +13:29:42.378 [Thread-15] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +13:29:42.379 [Thread-15] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +13:29:42.379 [Thread-15] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +13:29:42.381 [Thread-15] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +13:29:43.238 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-9000"] +13:29:43.238 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +13:29:43.238 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +13:29:43.245 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +13:29:43.328 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,996] - {dataSource-12,dcdata} inited +13:29:43.328 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +13:29:43.328 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [dcdata] success +13:29:43.328 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [dcdata] +13:29:45.215 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +13:29:45.215 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +13:29:45.215 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +13:29:45.216 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +13:29:45.216 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +13:29:45.216 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +13:29:45.216 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +13:29:45.216 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@deb54e3 +13:29:46.731 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Starting ProtocolHandler ["http-nio-9000"] +13:29:46.735 [restartedMain] INFO o.q.c.QuartzScheduler - [start,547] - Scheduler quartzScheduler_$_NON_CLUSTERED started. +13:30:08.120 [Thread-40] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +13:30:08.142 [Thread-40] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +13:30:08.143 [Thread-40] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +13:30:08.143 [Thread-40] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +13:30:08.143 [Thread-40] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +13:30:08.144 [Thread-40] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +13:30:08.955 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-9000"] +13:30:08.955 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +13:30:08.955 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +13:30:08.962 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +13:30:09.083 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,996] - {dataSource-13,dcdata} inited +13:30:09.083 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +13:30:09.084 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [dcdata] success +13:30:09.084 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [dcdata] +13:30:09.947 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +13:30:09.948 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +13:30:09.948 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +13:30:09.948 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +13:30:09.948 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +13:30:09.948 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +13:30:09.948 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +13:30:09.948 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@6ee90756 +13:30:10.748 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Starting ProtocolHandler ["http-nio-9000"] +13:30:10.752 [restartedMain] INFO o.q.c.QuartzScheduler - [start,547] - Scheduler quartzScheduler_$_NON_CLUSTERED started. +13:30:11.125 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +13:30:11.132 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +13:30:11.132 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +13:30:11.132 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +13:30:11.132 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +13:30:11.133 [SpringApplicationShutdownHook] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +13:30:14.971 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +13:30:15.850 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-9000"] +13:30:15.850 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +13:30:15.850 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +13:30:15.879 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +13:30:16.140 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,996] - {dataSource-1,dcdata} inited +13:30:16.140 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +13:30:16.141 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [dcdata] success +13:30:16.141 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [dcdata] +13:30:17.466 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +13:30:17.470 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +13:30:17.471 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +13:30:17.471 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +13:30:17.471 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +13:30:17.471 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +13:30:17.471 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +13:30:17.471 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@68f7ce80 +13:30:18.485 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Starting ProtocolHandler ["http-nio-9000"] +13:30:18.493 [restartedMain] INFO o.q.c.QuartzScheduler - [start,547] - Scheduler quartzScheduler_$_NON_CLUSTERED started. +13:32:27.437 [http-nio-9000-exec-1] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring DispatcherServlet 'dispatcherServlet' +14:09:15.603 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +14:09:15.624 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +14:09:15.624 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +14:09:15.624 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +14:09:15.624 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +14:09:15.626 [SpringApplicationShutdownHook] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +14:09:22.605 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +14:09:23.537 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-9000"] +14:09:23.538 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +14:09:23.538 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +14:09:23.570 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +14:09:23.832 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,996] - {dataSource-1,dcdata} inited +14:09:23.833 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +14:09:23.833 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [dcdata] success +14:09:23.833 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [dcdata] +14:09:24.999 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +14:09:25.004 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +14:09:25.004 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +14:09:25.004 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +14:09:25.005 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +14:09:25.005 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +14:09:25.005 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +14:09:25.005 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@1447f9e +14:09:26.035 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Starting ProtocolHandler ["http-nio-9000"] +14:09:26.043 [restartedMain] INFO o.q.c.QuartzScheduler - [start,547] - Scheduler quartzScheduler_$_NON_CLUSTERED started. +14:09:30.317 [http-nio-9000-exec-1] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring DispatcherServlet 'dispatcherServlet' +14:27:28.143 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +14:27:28.174 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +14:27:28.175 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +14:27:28.175 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +14:27:28.175 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +14:27:28.177 [SpringApplicationShutdownHook] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +14:27:30.158 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +14:27:31.074 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-9000"] +14:27:31.075 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +14:27:31.075 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +14:27:31.104 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +14:27:31.357 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,996] - {dataSource-1,dcdata} inited +14:27:31.357 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +14:27:31.358 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [dcdata] success +14:27:31.358 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [dcdata] +14:27:32.445 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +14:27:32.450 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +14:27:32.450 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +14:27:32.450 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +14:27:32.450 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +14:27:32.450 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +14:27:32.450 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +14:27:32.451 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@3d83013e +14:27:33.459 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Starting ProtocolHandler ["http-nio-9000"] +14:27:33.467 [restartedMain] INFO o.q.c.QuartzScheduler - [start,547] - Scheduler quartzScheduler_$_NON_CLUSTERED started. +14:27:39.995 [http-nio-9000-exec-1] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring DispatcherServlet 'dispatcherServlet' +14:49:40.501 [Thread-5] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +14:49:40.528 [Thread-5] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +14:49:40.528 [Thread-5] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +14:49:40.528 [Thread-5] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +14:49:40.528 [Thread-5] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +14:49:40.530 [Thread-5] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +14:49:42.043 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-9000"] +14:49:42.043 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +14:49:42.043 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +14:49:42.053 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +14:49:42.186 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,996] - {dataSource-2,dcdata} inited +14:49:42.193 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +14:49:42.194 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [dcdata] success +14:49:42.194 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [dcdata] +14:49:42.245 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +14:49:42.248 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Stopping service [Tomcat] +14:51:28.222 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +14:51:28.222 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +14:51:28.230 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +14:51:28.381 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,996] - {dataSource-3,dcdata} inited +14:51:28.381 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +14:51:28.383 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [dcdata] success +14:51:28.383 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [dcdata] +14:51:29.595 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +14:51:29.595 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +14:51:29.596 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +14:51:29.596 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +14:51:29.596 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +14:51:29.596 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +14:51:29.596 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +14:51:29.596 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@13c875e0 +14:51:30.740 [restartedMain] INFO o.q.c.QuartzScheduler - [start,547] - Scheduler quartzScheduler_$_NON_CLUSTERED started. +14:59:28.550 [Thread-8] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +14:59:28.565 [Thread-8] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +14:59:28.566 [Thread-8] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +14:59:28.566 [Thread-8] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +14:59:28.566 [Thread-8] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +14:59:28.568 [Thread-8] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... +15:26:08.569 [background-preinit] INFO o.h.v.i.util.Version - [<clinit>,21] - HV000001: Hibernate Validator 6.2.3.Final +15:26:09.476 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Initializing ProtocolHandler ["http-nio-9000"] +15:26:09.476 [restartedMain] INFO o.a.c.c.StandardService - [log,173] - Starting service [Tomcat] +15:26:09.476 [restartedMain] INFO o.a.c.c.StandardEngine - [log,173] - Starting Servlet engine: [Apache Tomcat/9.0.63] +15:26:09.505 [restartedMain] INFO o.a.c.c.C.[.[.[/] - [log,173] - Initializing Spring embedded WebApplicationContext +15:26:09.768 [restartedMain] INFO c.a.d.p.DruidDataSource - [init,996] - {dataSource-1,dcdata} inited +15:26:09.769 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [sharding] success +15:26:09.769 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [addDataSource,144] - dynamic-datasource - add a datasource named [dcdata] success +15:26:09.769 [restartedMain] INFO c.b.d.d.DynamicRoutingDataSource - [afterPropertiesSet,235] - dynamic-datasource initial loaded [2] datasource,primary datasource named [dcdata] +15:26:11.160 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1220] - Using default implementation for ThreadExecutor +15:26:11.165 [restartedMain] INFO o.q.c.SchedulerSignalerImpl - [<init>,61] - Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl +15:26:11.165 [restartedMain] INFO o.q.c.QuartzScheduler - [<init>,229] - Quartz Scheduler v.2.3.2 created. +15:26:11.165 [restartedMain] INFO o.q.s.RAMJobStore - [initialize,155] - RAMJobStore initialized. +15:26:11.165 [restartedMain] INFO o.q.c.QuartzScheduler - [initialize,294] - Scheduler meta-data: Quartz Scheduler (v2.3.2) 'quartzScheduler' with instanceId 'NON_CLUSTERED' + Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally. + NOT STARTED. + Currently in standby mode. + Number of jobs executed: 0 + Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads. + Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered. + +15:26:11.165 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1374] - Quartz scheduler 'quartzScheduler' initialized from an externally provided properties instance. +15:26:11.166 [restartedMain] INFO o.q.i.StdSchedulerFactory - [instantiate,1378] - Quartz scheduler version: 2.3.2 +15:26:11.166 [restartedMain] INFO o.q.c.QuartzScheduler - [setJobFactory,2293] - JobFactory set to: org.springframework.scheduling.quartz.SpringBeanJobFactory@33651e85 +15:26:12.146 [restartedMain] INFO o.a.c.h.Http11NioProtocol - [log,173] - Starting ProtocolHandler ["http-nio-9000"] +15:26:12.153 [restartedMain] INFO o.q.c.QuartzScheduler - [start,547] - Scheduler quartzScheduler_$_NON_CLUSTERED started. +15:26:17.283 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +15:26:17.301 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,666] - Scheduler quartzScheduler_$_NON_CLUSTERED shutting down. +15:26:17.302 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [standby,585] - Scheduler quartzScheduler_$_NON_CLUSTERED paused. +15:26:17.302 [SpringApplicationShutdownHook] INFO o.q.c.QuartzScheduler - [shutdown,740] - Scheduler quartzScheduler_$_NON_CLUSTERED shutdown complete. +15:26:17.302 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +15:26:17.305 [SpringApplicationShutdownHook] INFO c.b.d.d.DynamicRoutingDataSource - [destroy,215] - dynamic-datasource start closing .... diff --git a/logs/sys-user.2023-03-08.log b/logs/sys-user.2023-03-08.log new file mode 100644 index 0000000..5381658 --- /dev/null +++ b/logs/sys-user.2023-03-08.log @@ -0,0 +1,6 @@ +11:24:10.928 [schedule-pool-1] INFO sys-user - [run,56] - [192.168.0.90]内网IP[admin][Success][登录成功] +11:32:13.637 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +11:50:37.906 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +12:53:15.683 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +12:57:17.086 [schedule-pool-1] INFO sys-user - [run,56] - [192.168.0.80]内网IP[admin][Success][登录成功] +13:21:36.069 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== diff --git a/logs/sys-user.2023-03-09.log b/logs/sys-user.2023-03-09.log new file mode 100644 index 0000000..bffb1b7 --- /dev/null +++ b/logs/sys-user.2023-03-09.log @@ -0,0 +1,4 @@ +08:41:19.006 [schedule-pool-1] INFO sys-user - [run,56] - [192.168.0.90]内网IP[admin][Success][登录成功] +13:07:27.222 [schedule-pool-1] INFO sys-user - [run,56] - [192.168.0.90]内网IP[admin][Error][验证码已失效] +13:07:32.302 [schedule-pool-2] INFO sys-user - [run,56] - [192.168.0.90]内网IP[admin][Success][登录成功] +16:50:23.469 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== diff --git a/logs/sys-user.2023-07-06.log b/logs/sys-user.2023-07-06.log new file mode 100644 index 0000000..83c7197 --- /dev/null +++ b/logs/sys-user.2023-07-06.log @@ -0,0 +1,8 @@ +08:56:24.549 [schedule-pool-1] INFO sys-user - [run,56] - [192.168.0.90]内网IP[admin][Success][登录成功] +11:03:00.526 [Thread-5] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +11:03:06.965 [Thread-9] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +11:03:11.770 [Thread-13] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +11:07:19.499 [Thread-17] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +11:44:32.446 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +09:05:53.871 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +09:05:53.931 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== diff --git a/logs/sys-user.2023-07-19.log b/logs/sys-user.2023-07-19.log new file mode 100644 index 0000000..10c3a41 --- /dev/null +++ b/logs/sys-user.2023-07-19.log @@ -0,0 +1,18 @@ +13:05:25.526 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +13:09:21.616 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +13:10:54.543 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +13:27:04.438 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +13:48:51.767 [schedule-pool-1] INFO sys-user - [run,56] - [127.0.0.1]内网IP[admin][Error][验证码错误] +13:48:54.866 [schedule-pool-1] INFO sys-user - [run,56] - [127.0.0.1]内网IP[admin][Success][登录成功] +13:49:16.231 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +13:50:13.238 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +13:51:29.333 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +14:01:13.869 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +14:04:32.894 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +14:04:46.013 [restartedMain] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +14:05:07.539 [restartedMain] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +14:05:56.973 [restartedMain] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +14:09:07.602 [restartedMain] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +14:10:46.506 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +14:12:49.372 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +14:53:01.614 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== diff --git a/logs/sys-user.2023-07-20.log b/logs/sys-user.2023-07-20.log new file mode 100644 index 0000000..14f0bb5 --- /dev/null +++ b/logs/sys-user.2023-07-20.log @@ -0,0 +1,10 @@ +10:06:32.541 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +12:42:57.635 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +12:45:00.101 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +12:47:16.361 [Thread-5] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +12:52:26.510 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +14:32:30.388 [schedule-pool-1] INFO sys-user - [run,56] - [127.0.0.1]内网IP[admin][Success][登录成功] +15:34:44.133 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +16:28:39.118 [Thread-5] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +16:52:51.353 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +17:39:56.501 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== diff --git a/logs/sys-user.2023-07-21.log b/logs/sys-user.2023-07-21.log new file mode 100644 index 0000000..5e05732 --- /dev/null +++ b/logs/sys-user.2023-07-21.log @@ -0,0 +1,3 @@ +09:44:40.713 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +10:56:11.452 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +11:08:05.666 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== diff --git a/logs/sys-user.2023-07-24.log b/logs/sys-user.2023-07-24.log new file mode 100644 index 0000000..b9f7ad3 --- /dev/null +++ b/logs/sys-user.2023-07-24.log @@ -0,0 +1,17 @@ +07:38:05.554 [schedule-pool-1] INFO sys-user - [run,56] - [127.0.0.1]内网IP[admin][Success][登录成功] +07:40:22.633 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +07:47:27.403 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +07:49:45.157 [Thread-5] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +07:50:32.821 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +08:43:19.080 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +08:45:29.626 [Thread-5] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +08:47:02.317 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +08:48:51.493 [Thread-5] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +08:54:29.889 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +09:29:16.988 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +09:52:33.784 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +13:23:01.626 [schedule-pool-1] INFO sys-user - [run,56] - [127.0.0.1]内网IP[admin][Error][验证码错误] +13:23:06.103 [schedule-pool-1] INFO sys-user - [run,56] - [127.0.0.1]内网IP[admin][Success][登录成功] +14:17:20.085 [schedule-pool-2] INFO sys-user - [run,56] - [127.0.0.1]内网IP[admin][Logout][退出成功] +15:53:44.326 [schedule-pool-1] INFO sys-user - [run,56] - [127.0.0.1]内网IP[admin][Success][登录成功] +15:54:03.693 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== diff --git a/logs/sys-user.2023-07-25.log b/logs/sys-user.2023-07-25.log new file mode 100644 index 0000000..a3448e8 --- /dev/null +++ b/logs/sys-user.2023-07-25.log @@ -0,0 +1,3 @@ +08:11:05.691 [schedule-pool-1] INFO sys-user - [run,56] - [127.0.0.1]内网IP[admin][Success][登录成功] +10:42:40.764 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +13:56:33.656 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== diff --git a/logs/sys-user.2023-07-27.log b/logs/sys-user.2023-07-27.log new file mode 100644 index 0000000..545d523 --- /dev/null +++ b/logs/sys-user.2023-07-27.log @@ -0,0 +1,26 @@ +10:54:20.580 [restartedMain] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +10:55:10.371 [restartedMain] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +11:35:52.740 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +11:43:53.797 [schedule-pool-1] INFO sys-user - [run,56] - [127.0.0.1]内网IP[admin][Success][登录成功] +11:45:17.168 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +11:45:36.711 [schedule-pool-1] INFO sys-user - [run,56] - [127.0.0.1]内网IP[admin][Success][登录成功] +11:46:38.016 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +13:48:04.284 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +13:51:43.692 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +13:53:51.987 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +13:55:23.803 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +14:01:10.409 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +14:01:36.458 [schedule-pool-1] INFO sys-user - [run,56] - [127.0.0.1]内网IP[admin][Success][登录成功] +14:08:14.171 [schedule-pool-1] INFO sys-user - [run,56] - [127.0.0.1]内网IP[admin][Success][登录成功] +14:16:02.948 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +14:26:07.036 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +14:27:47.038 [schedule-pool-1] INFO sys-user - [run,56] - [127.0.0.1]内网IP[admin][Success][登录成功] +14:28:35.995 [schedule-pool-1] INFO sys-user - [run,56] - [127.0.0.1]内网IP[admin][Logout][退出成功] +14:28:52.459 [schedule-pool-2] INFO sys-user - [run,56] - [127.0.0.1]内网IP[admin][Success][登录成功] +14:47:07.220 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +15:03:02.635 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +15:31:46.280 [schedule-pool-1] INFO sys-user - [run,56] - [127.0.0.1]内网IP[admin][Success][登录成功] +15:31:57.862 [Thread-11] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +16:03:19.283 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +17:23:43.048 [restartedMain] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +17:25:38.357 [Thread-11] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== diff --git a/logs/sys-user.2023-07-28.log b/logs/sys-user.2023-07-28.log new file mode 100644 index 0000000..25bc191 --- /dev/null +++ b/logs/sys-user.2023-07-28.log @@ -0,0 +1,17 @@ +09:23:44.778 [Thread-11] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +09:23:48.694 [Thread-19] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +09:24:46.092 [Thread-24] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +09:26:53.877 [Thread-29] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +09:27:03.229 [Thread-34] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +09:27:09.348 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +09:46:59.151 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +09:50:06.478 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +10:00:17.197 [Thread-11] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +10:08:57.692 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +10:43:24.392 [Thread-12] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +11:09:02.594 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +11:17:48.654 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +11:22:31.302 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +11:24:27.141 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +11:25:02.144 [schedule-pool-1] INFO sys-user - [run,56] - [127.0.0.1]内网IP[admin][Success][登录成功] +11:28:05.709 [schedule-pool-1] INFO sys-user - [run,56] - [127.0.0.1]内网IP[admin][Logout][退出成功] diff --git a/logs/sys-user.2023-07-29.log b/logs/sys-user.2023-07-29.log new file mode 100644 index 0000000..cd6b6c9 --- /dev/null +++ b/logs/sys-user.2023-07-29.log @@ -0,0 +1 @@ +13:43:21.476 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== diff --git a/logs/sys-user.2023-07-31.log b/logs/sys-user.2023-07-31.log new file mode 100644 index 0000000..3c08ad2 --- /dev/null +++ b/logs/sys-user.2023-07-31.log @@ -0,0 +1,10 @@ +09:25:06.247 [schedule-pool-1] INFO sys-user - [run,56] - [127.0.0.1]内网IP[admin][Success][登录成功] +09:43:57.917 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +09:45:50.765 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +09:46:15.383 [schedule-pool-1] INFO sys-user - [run,56] - [127.0.0.1]内网IP[admin][Success][登录成功] +09:53:27.586 [schedule-pool-1] INFO sys-user - [run,56] - [127.0.0.1]内网IP[admin][Logout][退出成功] +09:53:35.971 [schedule-pool-2] INFO sys-user - [run,56] - [127.0.0.1]内网IP[ry][Success][登录成功] +10:04:38.086 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +10:28:15.312 [schedule-pool-1] INFO sys-user - [run,56] - [127.0.0.1]内网IP[admin][Success][登录成功] +10:29:22.345 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +16:17:38.198 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== diff --git a/logs/sys-user.log b/logs/sys-user.log new file mode 100644 index 0000000..4eebf13 --- /dev/null +++ b/logs/sys-user.log @@ -0,0 +1,19 @@ +10:03:27.147 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +10:05:03.955 [schedule-pool-1] INFO sys-user - [run,56] - [127.0.0.1]内网IP[admin][Success][登录成功] +10:14:26.195 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +10:53:56.295 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +11:15:02.208 [Thread-5] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +11:15:05.879 [Thread-8] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +11:15:10.404 [Thread-12] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +11:15:13.497 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +11:22:39.768 [Thread-5] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +12:02:00.943 [Thread-5] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +12:07:01.844 [Thread-8] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +13:29:42.379 [Thread-15] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +13:30:08.143 [Thread-40] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +13:30:11.132 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +14:09:15.624 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +14:27:28.175 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +14:49:40.528 [Thread-5] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +14:59:28.566 [Thread-8] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== +15:26:17.302 [SpringApplicationShutdownHook] INFO sys-user - [shutdownAsyncManager,31] - ====关闭后台任务任务线程池==== diff --git a/mybatis-plus-mate.md b/mybatis-plus-mate.md new file mode 100644 index 0000000..fb4f80d --- /dev/null +++ b/mybatis-plus-mate.md @@ -0,0 +1,47 @@ +# mybatis-plus mate替代方案 + +[TOC] + +## 前请说明 +不是说mp-mate不好,首先这个是企业级收费框架,日常能用到的功能不多,即使买了授权也是没有源码的,对于学习没什么帮助,下面收录的文字可以帮你大概的了解这些过程是怎么实现的 + +## 数据敏感词过滤 +主要是一些文章的敏感词检测,这不应该封装到数据库来 +需要检测的地方调用方法就行了 + + +## 数据范围(数据权限) +若依自己的 @datascope + + +## 表结构自动维护 + +个人感觉用不上 + +## 字段数据绑定(字典回写) +[mybatis自定义插件处理数据字典](https://blog.csdn.net/qq_25863973/article/details/106183181) + +个人想法也不应该是mybatis层处理的东西 + + +## 字段加密解密 +[使用mybatis的BaseTypeHandler来给敏感字段进行AES加密](https://www.cnblogs.com/java-spring/p/14676670.html) + +[动态代理Mybatis Mapper类](https://blog.csdn.net/why_still_confused/article/details/113060605) + +[Spring Boot Mybatis 优雅解决敏感信息加解密问题](https://ld246.com/article/1587991687126) + +## 字段脱敏 + +[interceptor方式](https://blog.csdn.net/lemon_csdn/article/details/121627878) + +[Mybatis拦截器实现数据脱敏](https://blog.csdn.net/chengbinbbs/article/details/105879611) + +[mybatis-cipher](https://gitee.com/Jerry.hu/mybatis-cipher) + +[敏感数据加解密以及数据脱敏mybatis插件](https://github.com/chenhaiyangs/mybatis-encrypt-plugin) + +提供一些思路,跟加密其实很像 + +## 多数据源分库分表(读写分离) +[shardingsphere](https://gitee.com/zhangmrit/RuoYi-Vue/tree/shardingsphere/) \ No newline at end of file diff --git a/pom.xml b/pom.xml new file mode 100644 index 0000000..1222cdf --- /dev/null +++ b/pom.xml @@ -0,0 +1,306 @@ +<?xml version="1.0" encoding="UTF-8"?> +<project xmlns="http://maven.apache.org/POM/4.0.0" + xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" + xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> + <modelVersion>4.0.0</modelVersion> + + <artifactId>dc</artifactId> + <groupId>com.dc</groupId> + <version>1.0.0</version> + + <name>dc</name> + <description>闻音管理系统</description> + + <properties> + <dc.version>1.0.0</dc.version> + <spring-boot.version>2.5.14</spring-boot.version> + <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding> + <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding> + <java.version>1.8</java.version> + <maven-jar-plugin.version>3.1.1</maven-jar-plugin.version> + <druid.version>1.2.16</druid.version> + <bitwalker.version>1.21</bitwalker.version> + <swagger.version>3.0.0</swagger.version> + <kaptcha.version>2.3.3</kaptcha.version> + <pagehelper.boot.version>1.4.6</pagehelper.boot.version> + <fastjson.version>2.0.34</fastjson.version> + <oshi.version>6.4.3</oshi.version> + <commons.io.version>2.11.0</commons.io.version> + <commons.fileupload.version>1.4</commons.fileupload.version> + <commons.collections.version>3.2.2</commons.collections.version> + <poi.version>4.1.0</poi.version> + <velocity.version>2.3</velocity.version> + <jwt.version>0.9.1</jwt.version> + <mybatis-plus.version>3.5.3</mybatis-plus.version> + <shardingsphere.version>5.1.1</shardingsphere.version> + <dynamic-datasource.version>3.3.2</dynamic-datasource.version> + </properties> + + <!-- 依赖声明 --> + <dependencyManagement> + <dependencies> + + <!-- SpringBoot的依赖配置--> + <dependency> + <groupId>org.springframework.boot</groupId> + <artifactId>spring-boot-dependencies</artifactId> + <version>${spring-boot.version}</version> + <type>pom</type> + <scope>import</scope> + </dependency> + + <!-- SpringBoot Websocket --> + <dependency> + <groupId>org.springframework.boot</groupId> + <artifactId>spring-boot-starter-websocket</artifactId> + <version>${spring-boot.version}</version> + </dependency> + + <!-- 阿里数据库连接池 --> + <dependency> + <groupId>com.alibaba</groupId> + <artifactId>druid-spring-boot-starter</artifactId> + <version>${druid.version}</version> + </dependency> + + <!-- 解析客户端操作系统、浏览器等 --> + <dependency> + <groupId>eu.bitwalker</groupId> + <artifactId>UserAgentUtils</artifactId> + <version>${bitwalker.version}</version> + </dependency> + + <!-- pagehelper 分页插件 --> + <dependency> + <groupId>com.github.pagehelper</groupId> + <artifactId>pagehelper-spring-boot-starter</artifactId> + <version>${pagehelper.boot.version}</version> + </dependency> + + <!-- 获取系统信息 --> + <dependency> + <groupId>com.github.oshi</groupId> + <artifactId>oshi-core</artifactId> + <version>${oshi.version}</version> + </dependency> + + <!-- Swagger3依赖 --> + <dependency> + <groupId>io.springfox</groupId> + <artifactId>springfox-boot-starter</artifactId> + <version>${swagger.version}</version> + <exclusions> + <exclusion> + <groupId>io.swagger</groupId> + <artifactId>swagger-models</artifactId> + </exclusion> + </exclusions> + </dependency> + + <!-- 防止进入swagger页面报类型转换错误,排除3.0.0中的引用,手动增加1.6.2版本 --> + <dependency> + <groupId>io.swagger</groupId> + <artifactId>swagger-models</artifactId> + <version>1.6.2</version> + </dependency> + + <!-- io常用工具类 --> + <dependency> + <groupId>commons-io</groupId> + <artifactId>commons-io</artifactId> + <version>${commons.io.version}</version> + </dependency> + + <!-- 文件上传工具类 --> + <dependency> + <groupId>commons-fileupload</groupId> + <artifactId>commons-fileupload</artifactId> + <version>${commons.fileupload.version}</version> + </dependency> + + <!-- excel工具 --> + <dependency> + <groupId>org.apache.poi</groupId> + <artifactId>poi-ooxml</artifactId> + <version>${poi.version}</version> + </dependency> + <dependency> + <groupId>org.apache.poi</groupId> + <artifactId>poi</artifactId> + <version>${poi.version}</version> + </dependency> + <dependency> + <groupId>org.apache.poi</groupId> + <artifactId>poi-ooxml-schemas</artifactId> + <version>${poi.version}</version> + </dependency> + <dependency> + <groupId>org.apache.poi</groupId> + <artifactId>poi-scratchpad</artifactId> + <version>${poi.version}</version> + </dependency> + <dependency> + <groupId>org.apache.poi</groupId> + <artifactId>ooxml-schemas</artifactId> + <version>1.4</version> + </dependency> + + <!-- velocity代码生成使用模板 --> + <dependency> + <groupId>org.apache.velocity</groupId> + <artifactId>velocity-engine-core</artifactId> + <version>${velocity.version}</version> + </dependency> + + <!-- collections工具类 --> + <dependency> + <groupId>commons-collections</groupId> + <artifactId>commons-collections</artifactId> + <version>${commons.collections.version}</version> + </dependency> + + <!-- 阿里JSON解析器 --> + <dependency> + <groupId>com.alibaba.fastjson2</groupId> + <artifactId>fastjson2</artifactId> + <version>${fastjson.version}</version> + </dependency> + + <!-- Token生成与解析--> + <dependency> + <groupId>io.jsonwebtoken</groupId> + <artifactId>jjwt</artifactId> + <version>${jwt.version}</version> + </dependency> + + <!-- 验证码 --> + <dependency> + <groupId>pro.fessional</groupId> + <artifactId>kaptcha</artifactId> + <version>${kaptcha.version}</version> + </dependency> + + <dependency> + <groupId>com.baomidou</groupId> + <artifactId>mybatis-plus-boot-starter</artifactId> + <version>${mybatis-plus.version}</version> + </dependency> + + <dependency> + <groupId>com.baomidou</groupId> + <artifactId>mybatis-plus-extension</artifactId> + <version>${mybatis-plus.version}</version> + </dependency> + + <!-- shardingsphere --> + <dependency> + <groupId>org.apache.shardingsphere</groupId> + <artifactId>shardingsphere-jdbc-core-spring-boot-starter</artifactId> + <version>${shardingsphere.version}</version> + </dependency> + + <!-- 动态数据源 --> + <dependency> + <groupId>com.baomidou</groupId> + <artifactId>dynamic-datasource-spring-boot-starter</artifactId> + <version>${dynamic-datasource.version}</version> + </dependency> + + <!-- 定时任务--> + <dependency> + <groupId>com.dc</groupId> + <artifactId>dc-quartz</artifactId> + <version>${dc.version}</version> + </dependency> + + <!-- 代码生成--> + <dependency> + <groupId>com.dc</groupId> + <artifactId>dc-generator</artifactId> + <version>${dc.version}</version> + </dependency> + + <!-- 核心模块--> + <dependency> + <groupId>com.dc</groupId> + <artifactId>dc-framework</artifactId> + <version>${dc.version}</version> + </dependency> + + <!-- 系统模块--> + <dependency> + <groupId>com.dc</groupId> + <artifactId>dc-system</artifactId> + <version>${dc.version}</version> + </dependency> + + <!-- 通用工具--> + <dependency> + <groupId>com.dc</groupId> + <artifactId>dc-common</artifactId> + <version>${dc.version}</version> + </dependency> + + </dependencies> + </dependencyManagement> + + <modules> + <module>dc-admin</module> + <module>dc-app</module> + <module>dc-framework</module> + <module>dc-system</module> + <module>dc-quartz</module> + <module>dc-generator</module> + <module>dc-common</module> + </modules> + <packaging>pom</packaging> + + <dependencies> + <dependency> + <groupId>org.projectlombok</groupId> + <artifactId>lombok</artifactId> + <scope>provided</scope> + </dependency> + </dependencies> + + <build> + <plugins> + <plugin> + <groupId>org.apache.maven.plugins</groupId> + <artifactId>maven-compiler-plugin</artifactId> + <version>3.1</version> + <configuration> + <source>${java.version}</source> + <target>${java.version}</target> + <encoding>${project.build.sourceEncoding}</encoding> + </configuration> + </plugin> + </plugins> + </build> + + <repositories> + <repository> + <id>public</id> + <name>aliyun nexus</name> + <url>https://maven.aliyun.com/repository/public</url> + <releases> + <enabled>true</enabled> + </releases> + </repository> + </repositories> + + <pluginRepositories> + <pluginRepository> + <id>public</id> + <name>aliyun nexus</name> + <url>https://maven.aliyun.com/repository/public</url> + <releases> + <enabled>true</enabled> + </releases> + <snapshots> + <enabled>false</enabled> + </snapshots> + </pluginRepository> + </pluginRepositories> + +</project> \ No newline at end of file diff --git a/sql/quartz.sql b/sql/quartz.sql new file mode 100644 index 0000000..5c24dd6 --- /dev/null +++ b/sql/quartz.sql @@ -0,0 +1,174 @@ +DROP TABLE IF EXISTS qrtz_fired_triggers; +DROP TABLE IF EXISTS qrtz_paused_trigger_grps; +DROP TABLE IF EXISTS qrtz_scheduler_state; +DROP TABLE IF EXISTS qrtz_locks; +DROP TABLE IF EXISTS qrtz_simple_triggers; +DROP TABLE IF EXISTS qrtz_simprop_triggers; +DROP TABLE IF EXISTS qrtz_cron_triggers; +DROP TABLE IF EXISTS qrtz_blob_triggers; +DROP TABLE IF EXISTS qrtz_triggers; +DROP TABLE IF EXISTS qrtz_job_details; +DROP TABLE IF EXISTS qrtz_calendars; + +-- ---------------------------- +-- 1、存储每一个已配置的 jobDetail 的详细信息 +-- ---------------------------- +create table qrtz_job_details ( + sched_name varchar(120) not null comment '调度名称', + job_name varchar(200) not null comment '任务名称', + job_group varchar(200) not null comment '任务组名', + description varchar(250) null comment '相关介绍', + job_class_name varchar(250) not null comment '执行任务类名称', + is_durable varchar(1) not null comment '是否持久化', + is_nonconcurrent varchar(1) not null comment '是否并发', + is_update_data varchar(1) not null comment '是否更新数据', + requests_recovery varchar(1) not null comment '是否接受恢复执行', + job_data blob null comment '存放持久化job对象', + primary key (sched_name, job_name, job_group) +) engine=innodb comment = '任务详细信息表'; + +-- ---------------------------- +-- 2、 存储已配置的 Trigger 的信息 +-- ---------------------------- +create table qrtz_triggers ( + sched_name varchar(120) not null comment '调度名称', + trigger_name varchar(200) not null comment '触发器的名字', + trigger_group varchar(200) not null comment '触发器所属组的名字', + job_name varchar(200) not null comment 'qrtz_job_details表job_name的外键', + job_group varchar(200) not null comment 'qrtz_job_details表job_group的外键', + description varchar(250) null comment '相关介绍', + next_fire_time bigint(13) null comment '上一次触发时间(毫秒)', + prev_fire_time bigint(13) null comment '下一次触发时间(默认为-1表示不触发)', + priority integer null comment '优先级', + trigger_state varchar(16) not null comment '触发器状态', + trigger_type varchar(8) not null comment '触发器的类型', + start_time bigint(13) not null comment '开始时间', + end_time bigint(13) null comment '结束时间', + calendar_name varchar(200) null comment '日程表名称', + misfire_instr smallint(2) null comment '补偿执行的策略', + job_data blob null comment '存放持久化job对象', + primary key (sched_name, trigger_name, trigger_group), + foreign key (sched_name, job_name, job_group) references qrtz_job_details(sched_name, job_name, job_group) +) engine=innodb comment = '触发器详细信息表'; + +-- ---------------------------- +-- 3、 存储简单的 Trigger,包括重复次数,间隔,以及已触发的次数 +-- ---------------------------- +create table qrtz_simple_triggers ( + sched_name varchar(120) not null comment '调度名称', + trigger_name varchar(200) not null comment 'qrtz_triggers表trigger_name的外键', + trigger_group varchar(200) not null comment 'qrtz_triggers表trigger_group的外键', + repeat_count bigint(7) not null comment '重复的次数统计', + repeat_interval bigint(12) not null comment '重复的间隔时间', + times_triggered bigint(10) not null comment '已经触发的次数', + primary key (sched_name, trigger_name, trigger_group), + foreign key (sched_name, trigger_name, trigger_group) references qrtz_triggers(sched_name, trigger_name, trigger_group) +) engine=innodb comment = '简单触发器的信息表'; + +-- ---------------------------- +-- 4、 存储 Cron Trigger,包括 Cron 表达式和时区信息 +-- ---------------------------- +create table qrtz_cron_triggers ( + sched_name varchar(120) not null comment '调度名称', + trigger_name varchar(200) not null comment 'qrtz_triggers表trigger_name的外键', + trigger_group varchar(200) not null comment 'qrtz_triggers表trigger_group的外键', + cron_expression varchar(200) not null comment 'cron表达式', + time_zone_id varchar(80) comment '时区', + primary key (sched_name, trigger_name, trigger_group), + foreign key (sched_name, trigger_name, trigger_group) references qrtz_triggers(sched_name, trigger_name, trigger_group) +) engine=innodb comment = 'Cron类型的触发器表'; + +-- ---------------------------- +-- 5、 Trigger 作为 Blob 类型存储(用于 Quartz 用户用 JDBC 创建他们自己定制的 Trigger 类型,JobStore 并不知道如何存储实例的时候) +-- ---------------------------- +create table qrtz_blob_triggers ( + sched_name varchar(120) not null comment '调度名称', + trigger_name varchar(200) not null comment 'qrtz_triggers表trigger_name的外键', + trigger_group varchar(200) not null comment 'qrtz_triggers表trigger_group的外键', + blob_data blob null comment '存放持久化Trigger对象', + primary key (sched_name, trigger_name, trigger_group), + foreign key (sched_name, trigger_name, trigger_group) references qrtz_triggers(sched_name, trigger_name, trigger_group) +) engine=innodb comment = 'Blob类型的触发器表'; + +-- ---------------------------- +-- 6、 以 Blob 类型存储存放日历信息, quartz可配置一个日历来指定一个时间范围 +-- ---------------------------- +create table qrtz_calendars ( + sched_name varchar(120) not null comment '调度名称', + calendar_name varchar(200) not null comment '日历名称', + calendar blob not null comment '存放持久化calendar对象', + primary key (sched_name, calendar_name) +) engine=innodb comment = '日历信息表'; + +-- ---------------------------- +-- 7、 存储已暂停的 Trigger 组的信息 +-- ---------------------------- +create table qrtz_paused_trigger_grps ( + sched_name varchar(120) not null comment '调度名称', + trigger_group varchar(200) not null comment 'qrtz_triggers表trigger_group的外键', + primary key (sched_name, trigger_group) +) engine=innodb comment = '暂停的触发器表'; + +-- ---------------------------- +-- 8、 存储与已触发的 Trigger 相关的状态信息,以及相联 Job 的执行信息 +-- ---------------------------- +create table qrtz_fired_triggers ( + sched_name varchar(120) not null comment '调度名称', + entry_id varchar(95) not null comment '调度器实例id', + trigger_name varchar(200) not null comment 'qrtz_triggers表trigger_name的外键', + trigger_group varchar(200) not null comment 'qrtz_triggers表trigger_group的外键', + instance_name varchar(200) not null comment '调度器实例名', + fired_time bigint(13) not null comment '触发的时间', + sched_time bigint(13) not null comment '定时器制定的时间', + priority integer not null comment '优先级', + state varchar(16) not null comment '状态', + job_name varchar(200) null comment '任务名称', + job_group varchar(200) null comment '任务组名', + is_nonconcurrent varchar(1) null comment '是否并发', + requests_recovery varchar(1) null comment '是否接受恢复执行', + primary key (sched_name, entry_id) +) engine=innodb comment = '已触发的触发器表'; + +-- ---------------------------- +-- 9、 存储少量的有关 Scheduler 的状态信息,假如是用于集群中,可以看到其他的 Scheduler 实例 +-- ---------------------------- +create table qrtz_scheduler_state ( + sched_name varchar(120) not null comment '调度名称', + instance_name varchar(200) not null comment '实例名称', + last_checkin_time bigint(13) not null comment '上次检查时间', + checkin_interval bigint(13) not null comment '检查间隔时间', + primary key (sched_name, instance_name) +) engine=innodb comment = '调度器状态表'; + +-- ---------------------------- +-- 10、 存储程序的悲观锁的信息(假如使用了悲观锁) +-- ---------------------------- +create table qrtz_locks ( + sched_name varchar(120) not null comment '调度名称', + lock_name varchar(40) not null comment '悲观锁名称', + primary key (sched_name, lock_name) +) engine=innodb comment = '存储的悲观锁信息表'; + +-- ---------------------------- +-- 11、 Quartz集群实现同步机制的行锁表 +-- ---------------------------- +create table qrtz_simprop_triggers ( + sched_name varchar(120) not null comment '调度名称', + trigger_name varchar(200) not null comment 'qrtz_triggers表trigger_name的外键', + trigger_group varchar(200) not null comment 'qrtz_triggers表trigger_group的外键', + str_prop_1 varchar(512) null comment 'String类型的trigger的第一个参数', + str_prop_2 varchar(512) null comment 'String类型的trigger的第二个参数', + str_prop_3 varchar(512) null comment 'String类型的trigger的第三个参数', + int_prop_1 int null comment 'int类型的trigger的第一个参数', + int_prop_2 int null comment 'int类型的trigger的第二个参数', + long_prop_1 bigint null comment 'long类型的trigger的第一个参数', + long_prop_2 bigint null comment 'long类型的trigger的第二个参数', + dec_prop_1 numeric(13,4) null comment 'decimal类型的trigger的第一个参数', + dec_prop_2 numeric(13,4) null comment 'decimal类型的trigger的第二个参数', + bool_prop_1 varchar(1) null comment 'Boolean类型的trigger的第一个参数', + bool_prop_2 varchar(1) null comment 'Boolean类型的trigger的第二个参数', + primary key (sched_name, trigger_name, trigger_group), + foreign key (sched_name, trigger_name, trigger_group) references qrtz_triggers(sched_name, trigger_name, trigger_group) +) engine=innodb comment = '同步机制的行锁表'; + +commit; \ No newline at end of file diff --git a/sql/ry_20220822.sql b/sql/ry_20220822.sql new file mode 100644 index 0000000..8d5e65f --- /dev/null +++ b/sql/ry_20220822.sql @@ -0,0 +1,692 @@ +-- ---------------------------- +-- 1、部门表 +-- ---------------------------- +drop table if exists sys_dept; +create table sys_dept ( + dept_id bigint(20) not null auto_increment comment '部门id', + parent_id bigint(20) default 0 comment '父部门id', + ancestors varchar(50) default '' comment '祖级列表', + dept_name varchar(30) default '' comment '部门名称', + order_num int(4) default 0 comment '显示顺序', + leader varchar(20) default null comment '负责人', + phone varchar(11) default null comment '联系电话', + email varchar(50) default null comment '邮箱', + status char(1) default '0' comment '部门状态(0正常 1停用)', + del_flag char(1) default '0' comment '删除标志(0代表存在 2代表删除)', + create_by varchar(64) default '' comment '创建者', + create_time datetime comment '创建时间', + update_by varchar(64) default '' comment '更新者', + update_time datetime comment '更新时间', + primary key (dept_id) +) engine=innodb auto_increment=200 comment = '部门表'; + +-- ---------------------------- +-- 初始化-部门表数据 +-- ---------------------------- +insert into sys_dept values(100, 0, '0', '闻音科技', 0, '闻音', '15888888888', 'ry@qq.com', '0', '0', 'admin', sysdate(), '', null); +insert into sys_dept values(101, 100, '0,100', '深圳总公司', 1, '闻音', '15888888888', 'ry@qq.com', '0', '0', 'admin', sysdate(), '', null); +insert into sys_dept values(102, 100, '0,100', '长沙分公司', 2, '闻音', '15888888888', 'ry@qq.com', '0', '0', 'admin', sysdate(), '', null); +insert into sys_dept values(103, 101, '0,100,101', '研发部门', 1, '闻音', '15888888888', 'ry@qq.com', '0', '0', 'admin', sysdate(), '', null); +insert into sys_dept values(104, 101, '0,100,101', '市场部门', 2, '闻音', '15888888888', 'ry@qq.com', '0', '0', 'admin', sysdate(), '', null); +insert into sys_dept values(105, 101, '0,100,101', '测试部门', 3, '闻音', '15888888888', 'ry@qq.com', '0', '0', 'admin', sysdate(), '', null); +insert into sys_dept values(106, 101, '0,100,101', '财务部门', 4, '闻音', '15888888888', 'ry@qq.com', '0', '0', 'admin', sysdate(), '', null); +insert into sys_dept values(107, 101, '0,100,101', '运维部门', 5, '闻音', '15888888888', 'ry@qq.com', '0', '0', 'admin', sysdate(), '', null); +insert into sys_dept values(108, 102, '0,100,102', '市场部门', 1, '闻音', '15888888888', 'ry@qq.com', '0', '0', 'admin', sysdate(), '', null); +insert into sys_dept values(109, 102, '0,100,102', '财务部门', 2, '闻音', '15888888888', 'ry@qq.com', '0', '0', 'admin', sysdate(), '', null); + + +-- ---------------------------- +-- 2、用户信息表 +-- ---------------------------- +drop table if exists sys_user; +create table sys_user ( + user_id bigint(20) not null auto_increment comment '用户ID', + dept_id bigint(20) default null comment '部门ID', + user_name varchar(30) not null comment '用户账号', + nick_name varchar(30) not null comment '用户昵称', + user_type varchar(2) default '00' comment '用户类型(00系统用户)', + email varchar(50) default '' comment '用户邮箱', + phonenumber varchar(11) default '' comment '手机号码', + sex char(1) default '0' comment '用户性别(0男 1女 2未知)', + avatar varchar(100) default '' comment '头像地址', + password varchar(100) default '' comment '密码', + status char(1) default '0' comment '帐号状态(0正常 1停用)', + del_flag char(1) default '0' comment '删除标志(0代表存在 2代表删除)', + login_ip varchar(128) default '' comment '最后登录IP', + login_date datetime comment '最后登录时间', + create_by varchar(64) default '' comment '创建者', + create_time datetime comment '创建时间', + update_by varchar(64) default '' comment '更新者', + update_time datetime comment '更新时间', + remark varchar(500) default null comment '备注', + primary key (user_id) +) engine=innodb auto_increment=100 comment = '用户信息表'; + +-- ---------------------------- +-- 初始化-用户信息表数据 +-- ---------------------------- +insert into sys_user values(1, 103, 'admin', '闻音', '00', 'win@163.com', '15888888888', '1', '', '$2a$10$7JB720yubVSZvUI0rEqK/.VqGOZTH.ulu33dHOiBE8ByOhJIrdAu2', '0', '0', '127.0.0.1', sysdate(), 'admin', sysdate(), '', null, '管理员'); +insert into sys_user values(2, 105, 'win', '闻音', '00', 'win@qq.com', '15666666666', '1', '', '$2a$10$7JB720yubVSZvUI0rEqK/.VqGOZTH.ulu33dHOiBE8ByOhJIrdAu2', '0', '0', '127.0.0.1', sysdate(), 'admin', sysdate(), '', null, '测试员'); + + +-- ---------------------------- +-- 3、岗位信息表 +-- ---------------------------- +drop table if exists sys_post; +create table sys_post +( + post_id bigint(20) not null auto_increment comment '岗位ID', + post_code varchar(64) not null comment '岗位编码', + post_name varchar(50) not null comment '岗位名称', + post_sort int(4) not null comment '显示顺序', + status char(1) not null comment '状态(0正常 1停用)', + create_by varchar(64) default '' comment '创建者', + create_time datetime comment '创建时间', + update_by varchar(64) default '' comment '更新者', + update_time datetime comment '更新时间', + remark varchar(500) default null comment '备注', + primary key (post_id) +) engine=innodb comment = '岗位信息表'; + +-- ---------------------------- +-- 初始化-岗位信息表数据 +-- ---------------------------- +insert into sys_post values(1, 'ceo', '董事长', 1, '0', 'admin', sysdate(), '', null, ''); +insert into sys_post values(2, 'se', '项目经理', 2, '0', 'admin', sysdate(), '', null, ''); +insert into sys_post values(3, 'hr', '人力资源', 3, '0', 'admin', sysdate(), '', null, ''); +insert into sys_post values(4, 'user', '普通员工', 4, '0', 'admin', sysdate(), '', null, ''); + + +-- ---------------------------- +-- 4、角色信息表 +-- ---------------------------- +drop table if exists sys_role; +create table sys_role ( + role_id bigint(20) not null auto_increment comment '角色ID', + role_name varchar(30) not null comment '角色名称', + role_key varchar(100) not null comment '角色权限字符串', + role_sort int(4) not null comment '显示顺序', + data_scope char(1) default '1' comment '数据范围(1:全部数据权限 2:自定数据权限 3:本部门数据权限 4:本部门及以下数据权限)', + menu_check_strictly tinyint(1) default 1 comment '菜单树选择项是否关联显示', + dept_check_strictly tinyint(1) default 1 comment '部门树选择项是否关联显示', + status char(1) not null comment '角色状态(0正常 1停用)', + del_flag char(1) default '0' comment '删除标志(0代表存在 2代表删除)', + create_by varchar(64) default '' comment '创建者', + create_time datetime comment '创建时间', + update_by varchar(64) default '' comment '更新者', + update_time datetime comment '更新时间', + remark varchar(500) default null comment '备注', + primary key (role_id) +) engine=innodb auto_increment=100 comment = '角色信息表'; + +-- ---------------------------- +-- 初始化-角色信息表数据 +-- ---------------------------- +insert into sys_role values('1', '超级管理员', 'admin', 1, 1, 1, 1, '0', '0', 'admin', sysdate(), '', null, '超级管理员'); +insert into sys_role values('2', '普通角色', 'common', 2, 2, 1, 1, '0', '0', 'admin', sysdate(), '', null, '普通角色'); + + +-- ---------------------------- +-- 5、菜单权限表 +-- ---------------------------- +drop table if exists sys_menu; +create table sys_menu ( + menu_id bigint(20) not null auto_increment comment '菜单ID', + menu_name varchar(50) not null comment '菜单名称', + parent_id bigint(20) default 0 comment '父菜单ID', + order_num int(4) default 0 comment '显示顺序', + path varchar(200) default '' comment '路由地址', + component varchar(255) default null comment '组件路径', + query varchar(255) default null comment '路由参数', + is_frame int(1) default 1 comment '是否为外链(0是 1否)', + is_cache int(1) default 0 comment '是否缓存(0缓存 1不缓存)', + menu_type char(1) default '' comment '菜单类型(M目录 C菜单 F按钮)', + visible char(1) default 0 comment '菜单状态(0显示 1隐藏)', + status char(1) default 0 comment '菜单状态(0正常 1停用)', + perms varchar(100) default null comment '权限标识', + icon varchar(100) default '#' comment '菜单图标', + create_by varchar(64) default '' comment '创建者', + create_time datetime comment '创建时间', + update_by varchar(64) default '' comment '更新者', + update_time datetime comment '更新时间', + remark varchar(500) default '' comment '备注', + primary key (menu_id) +) engine=innodb auto_increment=2000 comment = '菜单权限表'; + +-- ---------------------------- +-- 初始化-菜单信息表数据 +-- ---------------------------- +-- 一级菜单 +insert into sys_menu values('1', '系统管理', '0', '1', 'system', null, '', 1, 0, 'M', '0', '0', '', 'system', 'admin', sysdate(), '', null, '系统管理目录'); +insert into sys_menu values('2', '系统监控', '0', '2', 'monitor', null, '', 1, 0, 'M', '0', '0', '', 'monitor', 'admin', sysdate(), '', null, '系统监控目录'); +insert into sys_menu values('3', '系统工具', '0', '3', 'tool', null, '', 1, 0, 'M', '0', '0', '', 'tool', 'admin', sysdate(), '', null, '系统工具目录'); +insert into sys_menu values('4', '闻音官网', '0', '4', 'http://www.ccwin-in.com/', null, '', 0, 0, 'M', '0', '0', '', 'guide', 'admin', sysdate(), '', null, '闻音官网地址'); +-- 二级菜单 +insert into sys_menu values('100', '用户管理', '1', '1', 'user', 'system/user/index', '', 1, 0, 'C', '0', '0', 'system:user:list', 'user', 'admin', sysdate(), '', null, '用户管理菜单'); +insert into sys_menu values('101', '角色管理', '1', '2', 'role', 'system/role/index', '', 1, 0, 'C', '0', '0', 'system:role:list', 'peoples', 'admin', sysdate(), '', null, '角色管理菜单'); +insert into sys_menu values('102', '菜单管理', '1', '3', 'menu', 'system/menu/index', '', 1, 0, 'C', '0', '0', 'system:menu:list', 'tree-table', 'admin', sysdate(), '', null, '菜单管理菜单'); +insert into sys_menu values('103', '部门管理', '1', '4', 'dept', 'system/dept/index', '', 1, 0, 'C', '0', '0', 'system:dept:list', 'tree', 'admin', sysdate(), '', null, '部门管理菜单'); +insert into sys_menu values('104', '岗位管理', '1', '5', 'post', 'system/post/index', '', 1, 0, 'C', '0', '0', 'system:post:list', 'post', 'admin', sysdate(), '', null, '岗位管理菜单'); +insert into sys_menu values('105', '字典管理', '1', '6', 'dict', 'system/dict/index', '', 1, 0, 'C', '0', '0', 'system:dict:list', 'dict', 'admin', sysdate(), '', null, '字典管理菜单'); +insert into sys_menu values('106', '参数设置', '1', '7', 'config', 'system/config/index', '', 1, 0, 'C', '0', '0', 'system:config:list', 'edit', 'admin', sysdate(), '', null, '参数设置菜单'); +insert into sys_menu values('107', '通知公告', '1', '8', 'notice', 'system/notice/index', '', 1, 0, 'C', '0', '0', 'system:notice:list', 'message', 'admin', sysdate(), '', null, '通知公告菜单'); +insert into sys_menu values('108', '日志管理', '1', '9', 'log', '', '', 1, 0, 'M', '0', '0', '', 'log', 'admin', sysdate(), '', null, '日志管理菜单'); +insert into sys_menu values('109', '在线用户', '2', '1', 'online', 'monitor/online/index', '', 1, 0, 'C', '0', '0', 'monitor:online:list', 'online', 'admin', sysdate(), '', null, '在线用户菜单'); +insert into sys_menu values('110', '定时任务', '2', '2', 'job', 'monitor/job/index', '', 1, 0, 'C', '0', '0', 'monitor:job:list', 'job', 'admin', sysdate(), '', null, '定时任务菜单'); +insert into sys_menu values('111', '数据监控', '2', '3', 'druid', 'monitor/druid/index', '', 1, 0, 'C', '0', '0', 'monitor:druid:list', 'druid', 'admin', sysdate(), '', null, '数据监控菜单'); +insert into sys_menu values('112', '服务监控', '2', '4', 'server', 'monitor/server/index', '', 1, 0, 'C', '0', '0', 'monitor:server:list', 'server', 'admin', sysdate(), '', null, '服务监控菜单'); +insert into sys_menu values('113', '缓存监控', '2', '5', 'cache', 'monitor/cache/index', '', 1, 0, 'C', '0', '0', 'monitor:cache:list', 'redis', 'admin', sysdate(), '', null, '缓存监控菜单'); +insert into sys_menu values('114', '缓存列表', '2', '6', 'cacheList', 'monitor/cache/list', '', 1, 0, 'C', '0', '0', 'monitor:cache:list', 'redis-list', 'admin', sysdate(), '', null, '缓存列表菜单'); +insert into sys_menu values('115', '表单构建', '3', '1', 'build', 'tool/build/index', '', 1, 0, 'C', '0', '0', 'tool:build:list', 'build', 'admin', sysdate(), '', null, '表单构建菜单'); +insert into sys_menu values('116', '代码生成', '3', '2', 'gen', 'tool/gen/index', '', 1, 0, 'C', '0', '0', 'tool:gen:list', 'code', 'admin', sysdate(), '', null, '代码生成菜单'); +insert into sys_menu values('117', '系统接口', '3', '3', 'swagger', 'tool/swagger/index', '', 1, 0, 'C', '0', '0', 'tool:swagger:list', 'swagger', 'admin', sysdate(), '', null, '系统接口菜单'); +-- 三级菜单 +insert into sys_menu values('500', '操作日志', '108', '1', 'operlog', 'monitor/operlog/index', '', 1, 0, 'C', '0', '0', 'monitor:operlog:list', 'form', 'admin', sysdate(), '', null, '操作日志菜单'); +insert into sys_menu values('501', '登录日志', '108', '2', 'logininfor', 'monitor/logininfor/index', '', 1, 0, 'C', '0', '0', 'monitor:logininfor:list', 'logininfor', 'admin', sysdate(), '', null, '登录日志菜单'); +-- 用户管理按钮 +insert into sys_menu values('1000', '用户查询', '100', '1', '', '', '', 1, 0, 'F', '0', '0', 'system:user:query', '#', 'admin', sysdate(), '', null, ''); +insert into sys_menu values('1001', '用户新增', '100', '2', '', '', '', 1, 0, 'F', '0', '0', 'system:user:add', '#', 'admin', sysdate(), '', null, ''); +insert into sys_menu values('1002', '用户修改', '100', '3', '', '', '', 1, 0, 'F', '0', '0', 'system:user:edit', '#', 'admin', sysdate(), '', null, ''); +insert into sys_menu values('1003', '用户删除', '100', '4', '', '', '', 1, 0, 'F', '0', '0', 'system:user:remove', '#', 'admin', sysdate(), '', null, ''); +insert into sys_menu values('1004', '用户导出', '100', '5', '', '', '', 1, 0, 'F', '0', '0', 'system:user:export', '#', 'admin', sysdate(), '', null, ''); +insert into sys_menu values('1005', '用户导入', '100', '6', '', '', '', 1, 0, 'F', '0', '0', 'system:user:import', '#', 'admin', sysdate(), '', null, ''); +insert into sys_menu values('1006', '重置密码', '100', '7', '', '', '', 1, 0, 'F', '0', '0', 'system:user:resetPwd', '#', 'admin', sysdate(), '', null, ''); +-- 角色管理按钮 +insert into sys_menu values('1007', '角色查询', '101', '1', '', '', '', 1, 0, 'F', '0', '0', 'system:role:query', '#', 'admin', sysdate(), '', null, ''); +insert into sys_menu values('1008', '角色新增', '101', '2', '', '', '', 1, 0, 'F', '0', '0', 'system:role:add', '#', 'admin', sysdate(), '', null, ''); +insert into sys_menu values('1009', '角色修改', '101', '3', '', '', '', 1, 0, 'F', '0', '0', 'system:role:edit', '#', 'admin', sysdate(), '', null, ''); +insert into sys_menu values('1010', '角色删除', '101', '4', '', '', '', 1, 0, 'F', '0', '0', 'system:role:remove', '#', 'admin', sysdate(), '', null, ''); +insert into sys_menu values('1011', '角色导出', '101', '5', '', '', '', 1, 0, 'F', '0', '0', 'system:role:export', '#', 'admin', sysdate(), '', null, ''); +-- 菜单管理按钮 +insert into sys_menu values('1012', '菜单查询', '102', '1', '', '', '', 1, 0, 'F', '0', '0', 'system:menu:query', '#', 'admin', sysdate(), '', null, ''); +insert into sys_menu values('1013', '菜单新增', '102', '2', '', '', '', 1, 0, 'F', '0', '0', 'system:menu:add', '#', 'admin', sysdate(), '', null, ''); +insert into sys_menu values('1014', '菜单修改', '102', '3', '', '', '', 1, 0, 'F', '0', '0', 'system:menu:edit', '#', 'admin', sysdate(), '', null, ''); +insert into sys_menu values('1015', '菜单删除', '102', '4', '', '', '', 1, 0, 'F', '0', '0', 'system:menu:remove', '#', 'admin', sysdate(), '', null, ''); +-- 部门管理按钮 +insert into sys_menu values('1016', '部门查询', '103', '1', '', '', '', 1, 0, 'F', '0', '0', 'system:dept:query', '#', 'admin', sysdate(), '', null, ''); +insert into sys_menu values('1017', '部门新增', '103', '2', '', '', '', 1, 0, 'F', '0', '0', 'system:dept:add', '#', 'admin', sysdate(), '', null, ''); +insert into sys_menu values('1018', '部门修改', '103', '3', '', '', '', 1, 0, 'F', '0', '0', 'system:dept:edit', '#', 'admin', sysdate(), '', null, ''); +insert into sys_menu values('1019', '部门删除', '103', '4', '', '', '', 1, 0, 'F', '0', '0', 'system:dept:remove', '#', 'admin', sysdate(), '', null, ''); +-- 岗位管理按钮 +insert into sys_menu values('1020', '岗位查询', '104', '1', '', '', '', 1, 0, 'F', '0', '0', 'system:post:query', '#', 'admin', sysdate(), '', null, ''); +insert into sys_menu values('1021', '岗位新增', '104', '2', '', '', '', 1, 0, 'F', '0', '0', 'system:post:add', '#', 'admin', sysdate(), '', null, ''); +insert into sys_menu values('1022', '岗位修改', '104', '3', '', '', '', 1, 0, 'F', '0', '0', 'system:post:edit', '#', 'admin', sysdate(), '', null, ''); +insert into sys_menu values('1023', '岗位删除', '104', '4', '', '', '', 1, 0, 'F', '0', '0', 'system:post:remove', '#', 'admin', sysdate(), '', null, ''); +insert into sys_menu values('1024', '岗位导出', '104', '5', '', '', '', 1, 0, 'F', '0', '0', 'system:post:export', '#', 'admin', sysdate(), '', null, ''); +-- 字典管理按钮 +insert into sys_menu values('1025', '字典查询', '105', '1', '#', '', '', 1, 0, 'F', '0', '0', 'system:dict:query', '#', 'admin', sysdate(), '', null, ''); +insert into sys_menu values('1026', '字典新增', '105', '2', '#', '', '', 1, 0, 'F', '0', '0', 'system:dict:add', '#', 'admin', sysdate(), '', null, ''); +insert into sys_menu values('1027', '字典修改', '105', '3', '#', '', '', 1, 0, 'F', '0', '0', 'system:dict:edit', '#', 'admin', sysdate(), '', null, ''); +insert into sys_menu values('1028', '字典删除', '105', '4', '#', '', '', 1, 0, 'F', '0', '0', 'system:dict:remove', '#', 'admin', sysdate(), '', null, ''); +insert into sys_menu values('1029', '字典导出', '105', '5', '#', '', '', 1, 0, 'F', '0', '0', 'system:dict:export', '#', 'admin', sysdate(), '', null, ''); +-- 参数设置按钮 +insert into sys_menu values('1030', '参数查询', '106', '1', '#', '', '', 1, 0, 'F', '0', '0', 'system:config:query', '#', 'admin', sysdate(), '', null, ''); +insert into sys_menu values('1031', '参数新增', '106', '2', '#', '', '', 1, 0, 'F', '0', '0', 'system:config:add', '#', 'admin', sysdate(), '', null, ''); +insert into sys_menu values('1032', '参数修改', '106', '3', '#', '', '', 1, 0, 'F', '0', '0', 'system:config:edit', '#', 'admin', sysdate(), '', null, ''); +insert into sys_menu values('1033', '参数删除', '106', '4', '#', '', '', 1, 0, 'F', '0', '0', 'system:config:remove', '#', 'admin', sysdate(), '', null, ''); +insert into sys_menu values('1034', '参数导出', '106', '5', '#', '', '', 1, 0, 'F', '0', '0', 'system:config:export', '#', 'admin', sysdate(), '', null, ''); +-- 通知公告按钮 +insert into sys_menu values('1035', '公告查询', '107', '1', '#', '', '', 1, 0, 'F', '0', '0', 'system:notice:query', '#', 'admin', sysdate(), '', null, ''); +insert into sys_menu values('1036', '公告新增', '107', '2', '#', '', '', 1, 0, 'F', '0', '0', 'system:notice:add', '#', 'admin', sysdate(), '', null, ''); +insert into sys_menu values('1037', '公告修改', '107', '3', '#', '', '', 1, 0, 'F', '0', '0', 'system:notice:edit', '#', 'admin', sysdate(), '', null, ''); +insert into sys_menu values('1038', '公告删除', '107', '4', '#', '', '', 1, 0, 'F', '0', '0', 'system:notice:remove', '#', 'admin', sysdate(), '', null, ''); +-- 操作日志按钮 +insert into sys_menu values('1039', '操作查询', '500', '1', '#', '', '', 1, 0, 'F', '0', '0', 'monitor:operlog:query', '#', 'admin', sysdate(), '', null, ''); +insert into sys_menu values('1040', '操作删除', '500', '2', '#', '', '', 1, 0, 'F', '0', '0', 'monitor:operlog:remove', '#', 'admin', sysdate(), '', null, ''); +insert into sys_menu values('1041', '日志导出', '500', '3', '#', '', '', 1, 0, 'F', '0', '0', 'monitor:operlog:export', '#', 'admin', sysdate(), '', null, ''); +-- 登录日志按钮 +insert into sys_menu values('1042', '登录查询', '501', '1', '#', '', '', 1, 0, 'F', '0', '0', 'monitor:logininfor:query', '#', 'admin', sysdate(), '', null, ''); +insert into sys_menu values('1043', '登录删除', '501', '2', '#', '', '', 1, 0, 'F', '0', '0', 'monitor:logininfor:remove', '#', 'admin', sysdate(), '', null, ''); +insert into sys_menu values('1044', '日志导出', '501', '3', '#', '', '', 1, 0, 'F', '0', '0', 'monitor:logininfor:export', '#', 'admin', sysdate(), '', null, ''); +insert into sys_menu values('1045', '账户解锁', '501', '4', '#', '', '', 1, 0, 'F', '0', '0', 'monitor:logininfor:unlock', '#', 'admin', sysdate(), '', null, ''); +-- 在线用户按钮 +insert into sys_menu values('1046', '在线查询', '109', '1', '#', '', '', 1, 0, 'F', '0', '0', 'monitor:online:query', '#', 'admin', sysdate(), '', null, ''); +insert into sys_menu values('1047', '批量强退', '109', '2', '#', '', '', 1, 0, 'F', '0', '0', 'monitor:online:batchLogout', '#', 'admin', sysdate(), '', null, ''); +insert into sys_menu values('1048', '单条强退', '109', '3', '#', '', '', 1, 0, 'F', '0', '0', 'monitor:online:forceLogout', '#', 'admin', sysdate(), '', null, ''); +-- 定时任务按钮 +insert into sys_menu values('1049', '任务查询', '110', '1', '#', '', '', 1, 0, 'F', '0', '0', 'monitor:job:query', '#', 'admin', sysdate(), '', null, ''); +insert into sys_menu values('1050', '任务新增', '110', '2', '#', '', '', 1, 0, 'F', '0', '0', 'monitor:job:add', '#', 'admin', sysdate(), '', null, ''); +insert into sys_menu values('1051', '任务修改', '110', '3', '#', '', '', 1, 0, 'F', '0', '0', 'monitor:job:edit', '#', 'admin', sysdate(), '', null, ''); +insert into sys_menu values('1052', '任务删除', '110', '4', '#', '', '', 1, 0, 'F', '0', '0', 'monitor:job:remove', '#', 'admin', sysdate(), '', null, ''); +insert into sys_menu values('1053', '状态修改', '110', '5', '#', '', '', 1, 0, 'F', '0', '0', 'monitor:job:changeStatus', '#', 'admin', sysdate(), '', null, ''); +insert into sys_menu values('1054', '任务导出', '110', '6', '#', '', '', 1, 0, 'F', '0', '0', 'monitor:job:export', '#', 'admin', sysdate(), '', null, ''); +-- 代码生成按钮 +insert into sys_menu values('1055', '生成查询', '116', '1', '#', '', '', 1, 0, 'F', '0', '0', 'tool:gen:query', '#', 'admin', sysdate(), '', null, ''); +insert into sys_menu values('1056', '生成修改', '116', '2', '#', '', '', 1, 0, 'F', '0', '0', 'tool:gen:edit', '#', 'admin', sysdate(), '', null, ''); +insert into sys_menu values('1057', '生成删除', '116', '3', '#', '', '', 1, 0, 'F', '0', '0', 'tool:gen:remove', '#', 'admin', sysdate(), '', null, ''); +insert into sys_menu values('1058', '导入代码', '116', '4', '#', '', '', 1, 0, 'F', '0', '0', 'tool:gen:import', '#', 'admin', sysdate(), '', null, ''); +insert into sys_menu values('1059', '预览代码', '116', '5', '#', '', '', 1, 0, 'F', '0', '0', 'tool:gen:preview', '#', 'admin', sysdate(), '', null, ''); +insert into sys_menu values('1060', '生成代码', '116', '6', '#', '', '', 1, 0, 'F', '0', '0', 'tool:gen:code', '#', 'admin', sysdate(), '', null, ''); + + +-- ---------------------------- +-- 6、用户和角色关联表 用户N-1角色 +-- ---------------------------- +drop table if exists sys_user_role; +create table sys_user_role ( + user_id bigint(20) not null comment '用户ID', + role_id bigint(20) not null comment '角色ID', + primary key(user_id, role_id) +) engine=innodb comment = '用户和角色关联表'; + +-- ---------------------------- +-- 初始化-用户和角色关联表数据 +-- ---------------------------- +insert into sys_user_role values ('1', '1'); +insert into sys_user_role values ('2', '2'); + + +-- ---------------------------- +-- 7、角色和菜单关联表 角色1-N菜单 +-- ---------------------------- +drop table if exists sys_role_menu; +create table sys_role_menu ( + role_id bigint(20) not null comment '角色ID', + menu_id bigint(20) not null comment '菜单ID', + primary key(role_id, menu_id) +) engine=innodb comment = '角色和菜单关联表'; + +-- ---------------------------- +-- 初始化-角色和菜单关联表数据 +-- ---------------------------- +insert into sys_role_menu values ('2', '1'); +insert into sys_role_menu values ('2', '2'); +insert into sys_role_menu values ('2', '3'); +insert into sys_role_menu values ('2', '4'); +insert into sys_role_menu values ('2', '100'); +insert into sys_role_menu values ('2', '101'); +insert into sys_role_menu values ('2', '102'); +insert into sys_role_menu values ('2', '103'); +insert into sys_role_menu values ('2', '104'); +insert into sys_role_menu values ('2', '105'); +insert into sys_role_menu values ('2', '106'); +insert into sys_role_menu values ('2', '107'); +insert into sys_role_menu values ('2', '108'); +insert into sys_role_menu values ('2', '109'); +insert into sys_role_menu values ('2', '110'); +insert into sys_role_menu values ('2', '111'); +insert into sys_role_menu values ('2', '112'); +insert into sys_role_menu values ('2', '113'); +insert into sys_role_menu values ('2', '114'); +insert into sys_role_menu values ('2', '115'); +insert into sys_role_menu values ('2', '116'); +insert into sys_role_menu values ('2', '117'); +insert into sys_role_menu values ('2', '500'); +insert into sys_role_menu values ('2', '501'); +insert into sys_role_menu values ('2', '1000'); +insert into sys_role_menu values ('2', '1001'); +insert into sys_role_menu values ('2', '1002'); +insert into sys_role_menu values ('2', '1003'); +insert into sys_role_menu values ('2', '1004'); +insert into sys_role_menu values ('2', '1005'); +insert into sys_role_menu values ('2', '1006'); +insert into sys_role_menu values ('2', '1007'); +insert into sys_role_menu values ('2', '1008'); +insert into sys_role_menu values ('2', '1009'); +insert into sys_role_menu values ('2', '1010'); +insert into sys_role_menu values ('2', '1011'); +insert into sys_role_menu values ('2', '1012'); +insert into sys_role_menu values ('2', '1013'); +insert into sys_role_menu values ('2', '1014'); +insert into sys_role_menu values ('2', '1015'); +insert into sys_role_menu values ('2', '1016'); +insert into sys_role_menu values ('2', '1017'); +insert into sys_role_menu values ('2', '1018'); +insert into sys_role_menu values ('2', '1019'); +insert into sys_role_menu values ('2', '1020'); +insert into sys_role_menu values ('2', '1021'); +insert into sys_role_menu values ('2', '1022'); +insert into sys_role_menu values ('2', '1023'); +insert into sys_role_menu values ('2', '1024'); +insert into sys_role_menu values ('2', '1025'); +insert into sys_role_menu values ('2', '1026'); +insert into sys_role_menu values ('2', '1027'); +insert into sys_role_menu values ('2', '1028'); +insert into sys_role_menu values ('2', '1029'); +insert into sys_role_menu values ('2', '1030'); +insert into sys_role_menu values ('2', '1031'); +insert into sys_role_menu values ('2', '1032'); +insert into sys_role_menu values ('2', '1033'); +insert into sys_role_menu values ('2', '1034'); +insert into sys_role_menu values ('2', '1035'); +insert into sys_role_menu values ('2', '1036'); +insert into sys_role_menu values ('2', '1037'); +insert into sys_role_menu values ('2', '1038'); +insert into sys_role_menu values ('2', '1039'); +insert into sys_role_menu values ('2', '1040'); +insert into sys_role_menu values ('2', '1041'); +insert into sys_role_menu values ('2', '1042'); +insert into sys_role_menu values ('2', '1043'); +insert into sys_role_menu values ('2', '1044'); +insert into sys_role_menu values ('2', '1045'); +insert into sys_role_menu values ('2', '1046'); +insert into sys_role_menu values ('2', '1047'); +insert into sys_role_menu values ('2', '1048'); +insert into sys_role_menu values ('2', '1049'); +insert into sys_role_menu values ('2', '1050'); +insert into sys_role_menu values ('2', '1051'); +insert into sys_role_menu values ('2', '1052'); +insert into sys_role_menu values ('2', '1053'); +insert into sys_role_menu values ('2', '1054'); +insert into sys_role_menu values ('2', '1055'); +insert into sys_role_menu values ('2', '1056'); +insert into sys_role_menu values ('2', '1057'); +insert into sys_role_menu values ('2', '1058'); +insert into sys_role_menu values ('2', '1059'); +insert into sys_role_menu values ('2', '1060'); + +-- ---------------------------- +-- 8、角色和部门关联表 角色1-N部门 +-- ---------------------------- +drop table if exists sys_role_dept; +create table sys_role_dept ( + role_id bigint(20) not null comment '角色ID', + dept_id bigint(20) not null comment '部门ID', + primary key(role_id, dept_id) +) engine=innodb comment = '角色和部门关联表'; + +-- ---------------------------- +-- 初始化-角色和部门关联表数据 +-- ---------------------------- +insert into sys_role_dept values ('2', '100'); +insert into sys_role_dept values ('2', '101'); +insert into sys_role_dept values ('2', '105'); + + +-- ---------------------------- +-- 9、用户与岗位关联表 用户1-N岗位 +-- ---------------------------- +drop table if exists sys_user_post; +create table sys_user_post +( + user_id bigint(20) not null comment '用户ID', + post_id bigint(20) not null comment '岗位ID', + primary key (user_id, post_id) +) engine=innodb comment = '用户与岗位关联表'; + +-- ---------------------------- +-- 初始化-用户与岗位关联表数据 +-- ---------------------------- +insert into sys_user_post values ('1', '1'); +insert into sys_user_post values ('2', '2'); + + +-- ---------------------------- +-- 10、操作日志记录 +-- ---------------------------- +drop table if exists sys_oper_log; +create table sys_oper_log ( + oper_id bigint(20) not null auto_increment comment '日志主键', + title varchar(50) default '' comment '模块标题', + business_type int(2) default 0 comment '业务类型(0其它 1新增 2修改 3删除)', + method varchar(100) default '' comment '方法名称', + request_method varchar(10) default '' comment '请求方式', + operator_type int(1) default 0 comment '操作类别(0其它 1后台用户 2手机端用户)', + oper_name varchar(50) default '' comment '操作人员', + dept_name varchar(50) default '' comment '部门名称', + oper_url varchar(255) default '' comment '请求URL', + oper_ip varchar(128) default '' comment '主机地址', + oper_location varchar(255) default '' comment '操作地点', + oper_param varchar(2000) default '' comment '请求参数', + json_result varchar(2000) default '' comment '返回参数', + status int(1) default 0 comment '操作状态(0正常 1异常)', + error_msg varchar(2000) default '' comment '错误消息', + oper_time datetime comment '操作时间', + primary key (oper_id) +) engine=innodb auto_increment=100 comment = '操作日志记录'; + + +-- ---------------------------- +-- 11、字典类型表 +-- ---------------------------- +drop table if exists sys_dict_type; +create table sys_dict_type +( + dict_id bigint(20) not null auto_increment comment '字典主键', + dict_name varchar(100) default '' comment '字典名称', + dict_type varchar(100) default '' comment '字典类型', + status char(1) default '0' comment '状态(0正常 1停用)', + create_by varchar(64) default '' comment '创建者', + create_time datetime comment '创建时间', + update_by varchar(64) default '' comment '更新者', + update_time datetime comment '更新时间', + remark varchar(500) default null comment '备注', + primary key (dict_id), + unique (dict_type) +) engine=innodb auto_increment=100 comment = '字典类型表'; + +insert into sys_dict_type values(1, '用户性别', 'sys_user_sex', '0', 'admin', sysdate(), '', null, '用户性别列表'); +insert into sys_dict_type values(2, '菜单状态', 'sys_show_hide', '0', 'admin', sysdate(), '', null, '菜单状态列表'); +insert into sys_dict_type values(3, '系统开关', 'sys_normal_disable', '0', 'admin', sysdate(), '', null, '系统开关列表'); +insert into sys_dict_type values(4, '任务状态', 'sys_job_status', '0', 'admin', sysdate(), '', null, '任务状态列表'); +insert into sys_dict_type values(5, '任务分组', 'sys_job_group', '0', 'admin', sysdate(), '', null, '任务分组列表'); +insert into sys_dict_type values(6, '系统是否', 'sys_yes_no', '0', 'admin', sysdate(), '', null, '系统是否列表'); +insert into sys_dict_type values(7, '通知类型', 'sys_notice_type', '0', 'admin', sysdate(), '', null, '通知类型列表'); +insert into sys_dict_type values(8, '通知状态', 'sys_notice_status', '0', 'admin', sysdate(), '', null, '通知状态列表'); +insert into sys_dict_type values(9, '操作类型', 'sys_oper_type', '0', 'admin', sysdate(), '', null, '操作类型列表'); +insert into sys_dict_type values(10, '系统状态', 'sys_common_status', '0', 'admin', sysdate(), '', null, '登录状态列表'); + + +-- ---------------------------- +-- 12、字典数据表 +-- ---------------------------- +drop table if exists sys_dict_data; +create table sys_dict_data +( + dict_code bigint(20) not null auto_increment comment '字典编码', + dict_sort int(4) default 0 comment '字典排序', + dict_label varchar(100) default '' comment '字典标签', + dict_value varchar(100) default '' comment '字典键值', + dict_type varchar(100) default '' comment '字典类型', + css_class varchar(100) default null comment '样式属性(其他样式扩展)', + list_class varchar(100) default null comment '表格回显样式', + is_default char(1) default 'N' comment '是否默认(Y是 N否)', + status char(1) default '0' comment '状态(0正常 1停用)', + create_by varchar(64) default '' comment '创建者', + create_time datetime comment '创建时间', + update_by varchar(64) default '' comment '更新者', + update_time datetime comment '更新时间', + remark varchar(500) default null comment '备注', + primary key (dict_code) +) engine=innodb auto_increment=100 comment = '字典数据表'; + +insert into sys_dict_data values(1, 1, '男', '0', 'sys_user_sex', '', '', 'Y', '0', 'admin', sysdate(), '', null, '性别男'); +insert into sys_dict_data values(2, 2, '女', '1', 'sys_user_sex', '', '', 'N', '0', 'admin', sysdate(), '', null, '性别女'); +insert into sys_dict_data values(3, 3, '未知', '2', 'sys_user_sex', '', '', 'N', '0', 'admin', sysdate(), '', null, '性别未知'); +insert into sys_dict_data values(4, 1, '显示', '0', 'sys_show_hide', '', 'primary', 'Y', '0', 'admin', sysdate(), '', null, '显示菜单'); +insert into sys_dict_data values(5, 2, '隐藏', '1', 'sys_show_hide', '', 'danger', 'N', '0', 'admin', sysdate(), '', null, '隐藏菜单'); +insert into sys_dict_data values(6, 1, '正常', '0', 'sys_normal_disable', '', 'primary', 'Y', '0', 'admin', sysdate(), '', null, '正常状态'); +insert into sys_dict_data values(7, 2, '停用', '1', 'sys_normal_disable', '', 'danger', 'N', '0', 'admin', sysdate(), '', null, '停用状态'); +insert into sys_dict_data values(8, 1, '正常', '0', 'sys_job_status', '', 'primary', 'Y', '0', 'admin', sysdate(), '', null, '正常状态'); +insert into sys_dict_data values(9, 2, '暂停', '1', 'sys_job_status', '', 'danger', 'N', '0', 'admin', sysdate(), '', null, '停用状态'); +insert into sys_dict_data values(10, 1, '默认', 'DEFAULT', 'sys_job_group', '', '', 'Y', '0', 'admin', sysdate(), '', null, '默认分组'); +insert into sys_dict_data values(11, 2, '系统', 'SYSTEM', 'sys_job_group', '', '', 'N', '0', 'admin', sysdate(), '', null, '系统分组'); +insert into sys_dict_data values(12, 1, '是', 'Y', 'sys_yes_no', '', 'primary', 'Y', '0', 'admin', sysdate(), '', null, '系统默认是'); +insert into sys_dict_data values(13, 2, '否', 'N', 'sys_yes_no', '', 'danger', 'N', '0', 'admin', sysdate(), '', null, '系统默认否'); +insert into sys_dict_data values(14, 1, '通知', '1', 'sys_notice_type', '', 'warning', 'Y', '0', 'admin', sysdate(), '', null, '通知'); +insert into sys_dict_data values(15, 2, '公告', '2', 'sys_notice_type', '', 'success', 'N', '0', 'admin', sysdate(), '', null, '公告'); +insert into sys_dict_data values(16, 1, '正常', '0', 'sys_notice_status', '', 'primary', 'Y', '0', 'admin', sysdate(), '', null, '正常状态'); +insert into sys_dict_data values(17, 2, '关闭', '1', 'sys_notice_status', '', 'danger', 'N', '0', 'admin', sysdate(), '', null, '关闭状态'); +insert into sys_dict_data values(18, 99, '其他', '0', 'sys_oper_type', '', 'info', 'N', '0', 'admin', sysdate(), '', null, '其他操作'); +insert into sys_dict_data values(19, 1, '新增', '1', 'sys_oper_type', '', 'info', 'N', '0', 'admin', sysdate(), '', null, '新增操作'); +insert into sys_dict_data values(20, 2, '修改', '2', 'sys_oper_type', '', 'info', 'N', '0', 'admin', sysdate(), '', null, '修改操作'); +insert into sys_dict_data values(21, 3, '删除', '3', 'sys_oper_type', '', 'danger', 'N', '0', 'admin', sysdate(), '', null, '删除操作'); +insert into sys_dict_data values(22, 4, '授权', '4', 'sys_oper_type', '', 'primary', 'N', '0', 'admin', sysdate(), '', null, '授权操作'); +insert into sys_dict_data values(23, 5, '导出', '5', 'sys_oper_type', '', 'warning', 'N', '0', 'admin', sysdate(), '', null, '导出操作'); +insert into sys_dict_data values(24, 6, '导入', '6', 'sys_oper_type', '', 'warning', 'N', '0', 'admin', sysdate(), '', null, '导入操作'); +insert into sys_dict_data values(25, 7, '强退', '7', 'sys_oper_type', '', 'danger', 'N', '0', 'admin', sysdate(), '', null, '强退操作'); +insert into sys_dict_data values(26, 8, '生成代码', '8', 'sys_oper_type', '', 'warning', 'N', '0', 'admin', sysdate(), '', null, '生成操作'); +insert into sys_dict_data values(27, 9, '清空数据', '9', 'sys_oper_type', '', 'danger', 'N', '0', 'admin', sysdate(), '', null, '清空操作'); +insert into sys_dict_data values(28, 1, '成功', '0', 'sys_common_status', '', 'primary', 'N', '0', 'admin', sysdate(), '', null, '正常状态'); +insert into sys_dict_data values(29, 2, '失败', '1', 'sys_common_status', '', 'danger', 'N', '0', 'admin', sysdate(), '', null, '停用状态'); + + +-- ---------------------------- +-- 13、参数配置表 +-- ---------------------------- +drop table if exists sys_config; +create table sys_config ( + config_id int(5) not null auto_increment comment '参数主键', + config_name varchar(100) default '' comment '参数名称', + config_key varchar(100) default '' comment '参数键名', + config_value varchar(500) default '' comment '参数键值', + config_type char(1) default 'N' comment '系统内置(Y是 N否)', + create_by varchar(64) default '' comment '创建者', + create_time datetime comment '创建时间', + update_by varchar(64) default '' comment '更新者', + update_time datetime comment '更新时间', + remark varchar(500) default null comment '备注', + primary key (config_id) +) engine=innodb auto_increment=100 comment = '参数配置表'; + +insert into sys_config values(1, '主框架页-默认皮肤样式名称', 'sys.index.skinName', 'skin-blue', 'Y', 'admin', sysdate(), '', null, '蓝色 skin-blue、绿色 skin-green、紫色 skin-purple、红色 skin-red、黄色 skin-yellow' ); +insert into sys_config values(2, '用户管理-账号初始密码', 'sys.user.initPassword', '123456', 'Y', 'admin', sysdate(), '', null, '初始化密码 123456' ); +insert into sys_config values(3, '主框架页-侧边栏主题', 'sys.index.sideTheme', 'theme-dark', 'Y', 'admin', sysdate(), '', null, '深色主题theme-dark,浅色主题theme-light' ); +insert into sys_config values(4, '账号自助-验证码开关', 'sys.account.captchaEnabled', 'true', 'Y', 'admin', sysdate(), '', null, '是否开启验证码功能(true开启,false关闭)'); +insert into sys_config values(5, '账号自助-是否开启用户注册功能', 'sys.account.registerUser', 'false', 'Y', 'admin', sysdate(), '', null, '是否开启注册用户功能(true开启,false关闭)'); + + +-- ---------------------------- +-- 14、系统访问记录 +-- ---------------------------- +drop table if exists sys_logininfor; +create table sys_logininfor ( + info_id bigint(20) not null auto_increment comment '访问ID', + user_name varchar(50) default '' comment '用户账号', + ipaddr varchar(128) default '' comment '登录IP地址', + login_location varchar(255) default '' comment '登录地点', + browser varchar(50) default '' comment '浏览器类型', + os varchar(50) default '' comment '操作系统', + status char(1) default '0' comment '登录状态(0成功 1失败)', + msg varchar(255) default '' comment '提示消息', + login_time datetime comment '访问时间', + primary key (info_id) +) engine=innodb auto_increment=100 comment = '系统访问记录'; + + +-- ---------------------------- +-- 15、定时任务调度表 +-- ---------------------------- +drop table if exists sys_job; +create table sys_job ( + job_id bigint(20) not null auto_increment comment '任务ID', + job_name varchar(64) default '' comment '任务名称', + job_group varchar(64) default 'DEFAULT' comment '任务组名', + invoke_target varchar(500) not null comment '调用目标字符串', + cron_expression varchar(255) default '' comment 'cron执行表达式', + misfire_policy varchar(20) default '3' comment '计划执行错误策略(1立即执行 2执行一次 3放弃执行)', + concurrent char(1) default '1' comment '是否并发执行(0允许 1禁止)', + status char(1) default '0' comment '状态(0正常 1暂停)', + create_by varchar(64) default '' comment '创建者', + create_time datetime comment '创建时间', + update_by varchar(64) default '' comment '更新者', + update_time datetime comment '更新时间', + remark varchar(500) default '' comment '备注信息', + primary key (job_id, job_name, job_group) +) engine=innodb auto_increment=100 comment = '定时任务调度表'; + +insert into sys_job values(1, '系统默认(无参)', 'DEFAULT', 'ryTask.ryNoParams', '0/10 * * * * ?', '3', '1', '1', 'admin', sysdate(), '', null, ''); +insert into sys_job values(2, '系统默认(有参)', 'DEFAULT', 'ryTask.ryParams(\'ry\')', '0/15 * * * * ?', '3', '1', '1', 'admin', sysdate(), '', null, ''); +insert into sys_job values(3, '系统默认(多参)', 'DEFAULT', 'ryTask.ryMultipleParams(\'ry\', true, 2000L, 316.50D, 100)', '0/20 * * * * ?', '3', '1', '1', 'admin', sysdate(), '', null, ''); + + +-- ---------------------------- +-- 16、定时任务调度日志表 +-- ---------------------------- +drop table if exists sys_job_log; +create table sys_job_log ( + job_log_id bigint(20) not null auto_increment comment '任务日志ID', + job_name varchar(64) not null comment '任务名称', + job_group varchar(64) not null comment '任务组名', + invoke_target varchar(500) not null comment '调用目标字符串', + job_message varchar(500) comment '日志信息', + status char(1) default '0' comment '执行状态(0正常 1失败)', + exception_info varchar(2000) default '' comment '异常信息', + create_time datetime comment '创建时间', + primary key (job_log_id) +) engine=innodb comment = '定时任务调度日志表'; + + +-- ---------------------------- +-- 17、通知公告表 +-- ---------------------------- +drop table if exists sys_notice; +create table sys_notice ( + notice_id int(4) not null auto_increment comment '公告ID', + notice_title varchar(50) not null comment '公告标题', + notice_type char(1) not null comment '公告类型(1通知 2公告)', + notice_content longblob default null comment '公告内容', + status char(1) default '0' comment '公告状态(0正常 1关闭)', + create_by varchar(64) default '' comment '创建者', + create_time datetime comment '创建时间', + update_by varchar(64) default '' comment '更新者', + update_time datetime comment '更新时间', + remark varchar(255) default null comment '备注', + primary key (notice_id) +) engine=innodb auto_increment=10 comment = '通知公告表'; + +-- ---------------------------- +-- 初始化-公告信息表数据 +-- ---------------------------- +insert into sys_notice values('1', '温馨提醒:2018-07-01 闻音新版本发布啦', '2', '新版本内容', '0', 'admin', sysdate(), '', null, '管理员'); +insert into sys_notice values('2', '维护通知:2018-07-01 闻音系统凌晨维护', '1', '维护内容', '0', 'admin', sysdate(), '', null, '管理员'); + + +-- ---------------------------- +-- 18、代码生成业务表 +-- ---------------------------- +drop table if exists gen_table; +create table gen_table ( + table_id bigint(20) not null auto_increment comment '编号', + table_name varchar(200) default '' comment '表名称', + table_comment varchar(500) default '' comment '表描述', + sub_table_name varchar(64) default null comment '关联子表的表名', + sub_table_fk_name varchar(64) default null comment '子表关联的外键名', + class_name varchar(100) default '' comment '实体类名称', + tpl_category varchar(200) default 'crud' comment '使用的模板(crud单表操作 tree树表操作)', + package_name varchar(100) comment '生成包路径', + module_name varchar(30) comment '生成模块名', + business_name varchar(30) comment '生成业务名', + function_name varchar(50) comment '生成功能名', + function_author varchar(50) comment '生成功能作者', + gen_type char(1) default '0' comment '生成代码方式(0zip压缩包 1自定义路径)', + gen_path varchar(200) default '/' comment '生成路径(不填默认项目路径)', + options varchar(1000) comment '其它生成选项', + create_by varchar(64) default '' comment '创建者', + create_time datetime comment '创建时间', + update_by varchar(64) default '' comment '更新者', + update_time datetime comment '更新时间', + remark varchar(500) default null comment '备注', + primary key (table_id) +) engine=innodb auto_increment=1 comment = '代码生成业务表'; + + +-- ---------------------------- +-- 19、代码生成业务表字段 +-- ---------------------------- +drop table if exists gen_table_column; +create table gen_table_column ( + column_id bigint(20) not null auto_increment comment '编号', + table_id varchar(64) comment '归属表编号', + column_name varchar(200) comment '列名称', + column_comment varchar(500) comment '列描述', + column_type varchar(100) comment '列类型', + java_type varchar(500) comment 'JAVA类型', + java_field varchar(200) comment 'JAVA字段名', + is_pk char(1) comment '是否主键(1是)', + is_increment char(1) comment '是否自增(1是)', + is_required char(1) comment '是否必填(1是)', + is_insert char(1) comment '是否为插入字段(1是)', + is_edit char(1) comment '是否编辑字段(1是)', + is_list char(1) comment '是否列表字段(1是)', + is_query char(1) comment '是否查询字段(1是)', + query_type varchar(200) default 'EQ' comment '查询方式(等于、不等于、大于、小于、范围)', + html_type varchar(200) comment '显示类型(文本框、文本域、下拉框、复选框、单选框、日期控件)', + dict_type varchar(200) default '' comment '字典类型', + sort int comment '排序', + create_by varchar(64) default '' comment '创建者', + create_time datetime comment '创建时间', + update_by varchar(64) default '' comment '更新者', + update_time datetime comment '更新时间', + primary key (column_id) +) engine=innodb auto_increment=1 comment = '代码生成业务表字段'; \ No newline at end of file diff --git a/src/main/resources/META-INF/maven/archetype.xml b/src/main/resources/META-INF/maven/archetype.xml new file mode 100644 index 0000000..245aae0 --- /dev/null +++ b/src/main/resources/META-INF/maven/archetype.xml @@ -0,0 +1,9 @@ +<archetype> + <id>dc-master</id> + <sources> + <source>src/main/java/App.java</source> + </sources> + <testSources> + <source>src/test/java/AppTest.java</source> + </testSources> +</archetype> diff --git a/src/main/resources/archetype-resources/pom.xml b/src/main/resources/archetype-resources/pom.xml new file mode 100644 index 0000000..08f7be1 --- /dev/null +++ b/src/main/resources/archetype-resources/pom.xml @@ -0,0 +1,15 @@ +<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" + xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd"> + <modelVersion>4.0.0</modelVersion> + <groupId>$org.example</groupId> + <artifactId>$dc-master</artifactId> + <version>$1.0-SNAPSHOT</version> + <dependencies> + <dependency> + <groupId>junit</groupId> + <artifactId>junit</artifactId> + <version>3.8.1</version> + <scope>test</scope> + </dependency> + </dependencies> +</project> diff --git a/src/main/resources/archetype-resources/src/main/java/App.java b/src/main/resources/archetype-resources/src/main/java/App.java new file mode 100644 index 0000000..1fa6a95 --- /dev/null +++ b/src/main/resources/archetype-resources/src/main/java/App.java @@ -0,0 +1,13 @@ +package $org.example; + +/** + * Hello world! + * + */ +public class App +{ + public static void main( String[] args ) + { + System.out.println( "Hello World!" ); + } +} diff --git a/src/main/resources/archetype-resources/src/test/java/AppTest.java b/src/main/resources/archetype-resources/src/test/java/AppTest.java new file mode 100644 index 0000000..65be417 --- /dev/null +++ b/src/main/resources/archetype-resources/src/test/java/AppTest.java @@ -0,0 +1,38 @@ +package $org.example; + +import junit.framework.Test; +import junit.framework.TestCase; +import junit.framework.TestSuite; + +/** + * Unit test for simple App. + */ +public class AppTest + extends TestCase +{ + /** + * Create the test case + * + * @param testName name of the test case + */ + public AppTest( String testName ) + { + super( testName ); + } + + /** + * @return the suite of tests being tested + */ + public static Test suite() + { + return new TestSuite( AppTest.class ); + } + + /** + * Rigourous Test :-) + */ + public void testApp() + { + assertTrue( true ); + } +}