andy 1 year ago
commit
16fbd0b6a6
43 changed files with 2383 additions and 0 deletions
  1. 33 0
      .gitignore
  2. BIN
      .mvn/wrapper/maven-wrapper.jar
  3. 2 0
      .mvn/wrapper/maven-wrapper.properties
  4. BIN
      center.h2.mv.db
  5. 523 0
      center.h2.trace.db
  6. 308 0
      mvnw
  7. 205 0
      mvnw.cmd
  8. 112 0
      pom.xml
  9. 13 0
      src/main/java/com/scbfkj/uni/UniApplication.java
  10. 7 0
      src/main/java/com/scbfkj/uni/api/ControlApi.java
  11. 7 0
      src/main/java/com/scbfkj/uni/api/DataProcessApi.java
  12. 7 0
      src/main/java/com/scbfkj/uni/api/GenericApi.java
  13. 26 0
      src/main/java/com/scbfkj/uni/api/LogAop.java
  14. 136 0
      src/main/java/com/scbfkj/uni/api/SecurityApi.java
  15. 18 0
      src/main/java/com/scbfkj/uni/config/CorsConfig.java
  16. 41 0
      src/main/java/com/scbfkj/uni/config/InitBeanConfig.java
  17. 17 0
      src/main/java/com/scbfkj/uni/library/CodeUtil.java
  18. 4 0
      src/main/java/com/scbfkj/uni/library/DataAliasGetUtil.java
  19. 402 0
      src/main/java/com/scbfkj/uni/library/DataEncryptionUtil.java
  20. 4 0
      src/main/java/com/scbfkj/uni/library/DataFormatUtil.java
  21. 4 0
      src/main/java/com/scbfkj/uni/library/FileUtil.java
  22. 76 0
      src/main/java/com/scbfkj/uni/library/ImageUtil.java
  23. 4 0
      src/main/java/com/scbfkj/uni/library/ScriptEngineUtil.java
  24. 53 0
      src/main/java/com/scbfkj/uni/library/UniReturnUtil.java
  25. 22 0
      src/main/java/com/scbfkj/uni/process/DataBase.java
  26. 4 0
      src/main/java/com/scbfkj/uni/process/Elasticsearch.java
  27. 4 0
      src/main/java/com/scbfkj/uni/process/FTP.java
  28. 4 0
      src/main/java/com/scbfkj/uni/process/IBMMQ.java
  29. 4 0
      src/main/java/com/scbfkj/uni/process/Kafka.java
  30. 4 0
      src/main/java/com/scbfkj/uni/process/RabbitMq.java
  31. 4 0
      src/main/java/com/scbfkj/uni/process/Web.java
  32. 4 0
      src/main/java/com/scbfkj/uni/service/ControlService.java
  33. 4 0
      src/main/java/com/scbfkj/uni/service/DataProcessService.java
  34. 4 0
      src/main/java/com/scbfkj/uni/service/LoggerService.java
  35. 4 0
      src/main/java/com/scbfkj/uni/service/SecurityService.java
  36. 4 0
      src/main/java/com/scbfkj/uni/system/Config.java
  37. 4 0
      src/main/java/com/scbfkj/uni/system/ScheduleTask.java
  38. 4 0
      src/main/java/com/scbfkj/uni/system/ScheduleUtil.java
  39. 51 0
      src/main/java/com/scbfkj/uni/system/SpringContextApplication.java
  40. 16 0
      src/main/java/com/scbfkj/uni/system/SystemInit.java
  41. 4 0
      src/main/resources/application.properties
  42. 223 0
      src/main/resources/schema/V1__init.sql
  43. 13 0
      src/test/java/com/scbfkj/uni/UniApplicationTests.java

+ 33 - 0
.gitignore

@@ -0,0 +1,33 @@
+HELP.md
+target/
+!.mvn/wrapper/maven-wrapper.jar
+!**/src/main/**/target/
+!**/src/test/**/target/
+
+### STS ###
+.apt_generated
+.classpath
+.factorypath
+.project
+.settings
+.springBeans
+.sts4-cache
+
+### IntelliJ IDEA ###
+.idea
+*.iws
+*.iml
+*.ipr
+
+### NetBeans ###
+/nbproject/private/
+/nbbuild/
+/dist/
+/nbdist/
+/.nb-gradle/
+build/
+!**/src/main/**/build/
+!**/src/test/**/build/
+
+### VS Code ###
+.vscode/

BIN
.mvn/wrapper/maven-wrapper.jar


+ 2 - 0
.mvn/wrapper/maven-wrapper.properties

@@ -0,0 +1,2 @@
+distributionUrl=https://repo.maven.apache.org/maven2/org/apache/maven/apache-maven/3.9.5/apache-maven-3.9.5-bin.zip
+wrapperUrl=https://repo.maven.apache.org/maven2/org/apache/maven/wrapper/maven-wrapper/3.2.0/maven-wrapper-3.2.0.jar

BIN
center.h2.mv.db


+ 523 - 0
center.h2.trace.db

@@ -0,0 +1,523 @@
+2023-10-18 06:08:15 jdbc[3]: exception
+java.sql.SQLClientInfoException: Client info name 'ApplicationName' not supported.
+	at org.h2.jdbc.JdbcConnection.setClientInfo(JdbcConnection.java:1573)
+	at com.intellij.database.remote.jdbc.impl.RemoteConnectionImpl.setClientInfo(RemoteConnectionImpl.java:469)
+	at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
+	at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:77)
+	at java.base/jdk.internal.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
+	at java.base/java.lang.reflect.Method.invoke(Method.java:568)
+	at java.rmi/sun.rmi.server.UnicastServerRef.dispatch(UnicastServerRef.java:360)
+	at java.rmi/sun.rmi.transport.Transport$1.run(Transport.java:200)
+	at java.rmi/sun.rmi.transport.Transport$1.run(Transport.java:197)
+	at java.base/java.security.AccessController.doPrivileged(AccessController.java:712)
+	at java.rmi/sun.rmi.transport.Transport.serviceCall(Transport.java:196)
+	at java.rmi/sun.rmi.transport.tcp.TCPTransport.handleMessages(TCPTransport.java:587)
+	at java.rmi/sun.rmi.transport.tcp.TCPTransport$ConnectionHandler.run0(TCPTransport.java:828)
+	at java.rmi/sun.rmi.transport.tcp.TCPTransport$ConnectionHandler.lambda$run$0(TCPTransport.java:705)
+	at java.base/java.security.AccessController.doPrivileged(AccessController.java:399)
+	at java.rmi/sun.rmi.transport.tcp.TCPTransport$ConnectionHandler.run(TCPTransport.java:704)
+	at java.base/java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1136)
+	at java.base/java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:635)
+	at java.base/java.lang.Thread.run(Thread.java:833)
+2023-10-18 06:08:16 jdbc[3]: exception
+java.sql.SQLClientInfoException: Client info name 'ApplicationName' not supported.
+	at org.h2.jdbc.JdbcConnection.setClientInfo(JdbcConnection.java:1573)
+	at com.intellij.database.remote.jdbc.impl.RemoteConnectionImpl.setClientInfo(RemoteConnectionImpl.java:469)
+	at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
+	at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:77)
+	at java.base/jdk.internal.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
+	at java.base/java.lang.reflect.Method.invoke(Method.java:568)
+	at java.rmi/sun.rmi.server.UnicastServerRef.dispatch(UnicastServerRef.java:360)
+	at java.rmi/sun.rmi.transport.Transport$1.run(Transport.java:200)
+	at java.rmi/sun.rmi.transport.Transport$1.run(Transport.java:197)
+	at java.base/java.security.AccessController.doPrivileged(AccessController.java:712)
+	at java.rmi/sun.rmi.transport.Transport.serviceCall(Transport.java:196)
+	at java.rmi/sun.rmi.transport.tcp.TCPTransport.handleMessages(TCPTransport.java:587)
+	at java.rmi/sun.rmi.transport.tcp.TCPTransport$ConnectionHandler.run0(TCPTransport.java:828)
+	at java.rmi/sun.rmi.transport.tcp.TCPTransport$ConnectionHandler.lambda$run$0(TCPTransport.java:705)
+	at java.base/java.security.AccessController.doPrivileged(AccessController.java:399)
+	at java.rmi/sun.rmi.transport.tcp.TCPTransport$ConnectionHandler.run(TCPTransport.java:704)
+	at java.base/java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1136)
+	at java.base/java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:635)
+	at java.base/java.lang.Thread.run(Thread.java:833)
+2023-10-18 06:12:54 jdbc[3]: exception
+java.sql.SQLClientInfoException: Client info name 'ApplicationName' not supported.
+	at org.h2.jdbc.JdbcConnection.setClientInfo(JdbcConnection.java:1573)
+	at com.intellij.database.remote.jdbc.impl.RemoteConnectionImpl.setClientInfo(RemoteConnectionImpl.java:469)
+	at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
+	at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:77)
+	at java.base/jdk.internal.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
+	at java.base/java.lang.reflect.Method.invoke(Method.java:568)
+	at java.rmi/sun.rmi.server.UnicastServerRef.dispatch(UnicastServerRef.java:360)
+	at java.rmi/sun.rmi.transport.Transport$1.run(Transport.java:200)
+	at java.rmi/sun.rmi.transport.Transport$1.run(Transport.java:197)
+	at java.base/java.security.AccessController.doPrivileged(AccessController.java:712)
+	at java.rmi/sun.rmi.transport.Transport.serviceCall(Transport.java:196)
+	at java.rmi/sun.rmi.transport.tcp.TCPTransport.handleMessages(TCPTransport.java:587)
+	at java.rmi/sun.rmi.transport.tcp.TCPTransport$ConnectionHandler.run0(TCPTransport.java:828)
+	at java.rmi/sun.rmi.transport.tcp.TCPTransport$ConnectionHandler.lambda$run$0(TCPTransport.java:705)
+	at java.base/java.security.AccessController.doPrivileged(AccessController.java:399)
+	at java.rmi/sun.rmi.transport.tcp.TCPTransport$ConnectionHandler.run(TCPTransport.java:704)
+	at java.base/java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1136)
+	at java.base/java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:635)
+	at java.base/java.lang.Thread.run(Thread.java:833)
+2023-10-18 06:12:54 jdbc[3]: exception
+org.h2.jdbc.JdbcSQLSyntaxErrorException: Syntax error in SQL statement "create table tableconfiguration\000d\000a(\000d\000a    tableconfigurationid int auto_increment comment '自增长主键表格配置编号'\000d\000a        primary key,\000d\000a    pagecode             varchar(50)  null,\000d\000a    columnname           varchar(50)  null comment '列名',\000d\000a    columncode           varchar(50)  null comment '列标识',\000d\000a    groupname            varchar(50)  null comment '上级分组名称',\000d\000a    columndescribe       varchar(200) null comment '列描述',\000d\000a    datatype             varchar(50)  null comment '数据类型',\000d\000a    datalength           int          null comment '数据长度',\000d\000a    isdisplay            tinyint[*](1)   null,\000d\000a    displaynumber        int          null comment '显示顺序',\000d\000a    displaywidth         int          null comment '显示宽度',\000d\000a    enablesort           tinyint(1)   null,\000d\000a    enablefilter         tinyint(1)   null,\000d\000a    enablegroup          tinyint(1)   null,\000d\000a    enablecount          tinyint(1)   null,\000d\000a    isfiltercolumn       tinyint(1)   null,\000d\000a    isprimarykey         tinyint(1)   null,\000d\000a    defaultparameters    varchar(200) null comment '默认查询参数'\000d\000a)"; expected "ARRAY, INVISIBLE, VISIBLE, NOT, NULL, AS, DEFAULT, GENERATED, ON, NOT, NULL, AUTO_INCREMENT, DEFAULT, NULL_TO_DEFAULT, SEQUENCE, SELECTIVITY, COMMENT, CONSTRAINT, COMMENT, PRIMARY, UNIQUE, NOT, NULL, CHECK, REFERENCES, AUTO_INCREMENT, ,, )"; SQL statement:
+create table tableconfiguration
+(
+    tableconfigurationid int auto_increment comment '自增长主键表格配置编号'
+        primary key,
+    pagecode             varchar(50)  null,
+    columnname           varchar(50)  null comment '列名',
+    columncode           varchar(50)  null comment '列标识',
+    groupname            varchar(50)  null comment '上级分组名称',
+    columndescribe       varchar(200) null comment '列描述',
+    datatype             varchar(50)  null comment '数据类型',
+    datalength           int          null comment '数据长度',
+    isdisplay            tinyint(1)   null,
+    displaynumber        int          null comment '显示顺序',
+    displaywidth         int          null comment '显示宽度',
+    enablesort           tinyint(1)   null,
+    enablefilter         tinyint(1)   null,
+    enablegroup          tinyint(1)   null,
+    enablecount          tinyint(1)   null,
+    isfiltercolumn       tinyint(1)   null,
+    isprimarykey         tinyint(1)   null,
+    defaultparameters    varchar(200) null comment '默认查询参数'
+) [42001-210]
+2023-10-18 06:12:54 jdbc[4]: exception
+java.sql.SQLClientInfoException: Client info name 'ApplicationName' not supported.
+	at org.h2.jdbc.JdbcConnection.setClientInfo(JdbcConnection.java:1573)
+	at com.intellij.database.remote.jdbc.impl.RemoteConnectionImpl.setClientInfo(RemoteConnectionImpl.java:469)
+	at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
+	at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:77)
+	at java.base/jdk.internal.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
+	at java.base/java.lang.reflect.Method.invoke(Method.java:568)
+	at java.rmi/sun.rmi.server.UnicastServerRef.dispatch(UnicastServerRef.java:360)
+	at java.rmi/sun.rmi.transport.Transport$1.run(Transport.java:200)
+	at java.rmi/sun.rmi.transport.Transport$1.run(Transport.java:197)
+	at java.base/java.security.AccessController.doPrivileged(AccessController.java:712)
+	at java.rmi/sun.rmi.transport.Transport.serviceCall(Transport.java:196)
+	at java.rmi/sun.rmi.transport.tcp.TCPTransport.handleMessages(TCPTransport.java:587)
+	at java.rmi/sun.rmi.transport.tcp.TCPTransport$ConnectionHandler.run0(TCPTransport.java:828)
+	at java.rmi/sun.rmi.transport.tcp.TCPTransport$ConnectionHandler.lambda$run$0(TCPTransport.java:705)
+	at java.base/java.security.AccessController.doPrivileged(AccessController.java:399)
+	at java.rmi/sun.rmi.transport.tcp.TCPTransport$ConnectionHandler.run(TCPTransport.java:704)
+	at java.base/java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1136)
+	at java.base/java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:635)
+	at java.base/java.lang.Thread.run(Thread.java:833)
+2023-10-18 06:13:43 jdbc[3]: exception
+org.h2.jdbc.JdbcSQLSyntaxErrorException: Syntax error in SQL statement "create table userinfo\000d\000a(\000d\000a    userid                    int auto_increment comment '自增长主键用户编号'\000d\000a        primary key,\000d\000a    usergroupid               int          null,\000d\000a    username                  varchar(50)  null comment '用户名',\000d\000a    account                   varchar(50)  null comment '账号',\000d\000a    userpassword              varchar(50)  null comment '密码',\000d\000a    userdescribe              varchar(200) null comment '描述',\000d\000a    isenable                  tinyint[*](1)   null,\000d\000a    secondarypassword         varchar(50)  null,\000d\000a    lastestchangepasswordtime datetime     null\000d\000a)"; expected "ARRAY, INVISIBLE, VISIBLE, NOT, NULL, AS, DEFAULT, GENERATED, ON, NOT, NULL, AUTO_INCREMENT, DEFAULT, NULL_TO_DEFAULT, SEQUENCE, SELECTIVITY, COMMENT, CONSTRAINT, COMMENT, PRIMARY, UNIQUE, NOT, NULL, CHECK, REFERENCES, AUTO_INCREMENT, ,, )"; SQL statement:
+create table userinfo
+(
+    userid                    int auto_increment comment '自增长主键用户编号'
+        primary key,
+    usergroupid               int          null,
+    username                  varchar(50)  null comment '用户名',
+    account                   varchar(50)  null comment '账号',
+    userpassword              varchar(50)  null comment '密码',
+    userdescribe              varchar(200) null comment '描述',
+    isenable                  tinyint(1)   null,
+    secondarypassword         varchar(50)  null,
+    lastestchangepasswordtime datetime     null
+) [42001-210]
+2023-10-18 06:13:43 jdbc[5]: exception
+java.sql.SQLClientInfoException: Client info name 'ApplicationName' not supported.
+	at org.h2.jdbc.JdbcConnection.setClientInfo(JdbcConnection.java:1573)
+	at com.intellij.database.remote.jdbc.impl.RemoteConnectionImpl.setClientInfo(RemoteConnectionImpl.java:469)
+	at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
+	at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:77)
+	at java.base/jdk.internal.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
+	at java.base/java.lang.reflect.Method.invoke(Method.java:568)
+	at java.rmi/sun.rmi.server.UnicastServerRef.dispatch(UnicastServerRef.java:360)
+	at java.rmi/sun.rmi.transport.Transport$1.run(Transport.java:200)
+	at java.rmi/sun.rmi.transport.Transport$1.run(Transport.java:197)
+	at java.base/java.security.AccessController.doPrivileged(AccessController.java:712)
+	at java.rmi/sun.rmi.transport.Transport.serviceCall(Transport.java:196)
+	at java.rmi/sun.rmi.transport.tcp.TCPTransport.handleMessages(TCPTransport.java:587)
+	at java.rmi/sun.rmi.transport.tcp.TCPTransport$ConnectionHandler.run0(TCPTransport.java:828)
+	at java.rmi/sun.rmi.transport.tcp.TCPTransport$ConnectionHandler.lambda$run$0(TCPTransport.java:705)
+	at java.base/java.security.AccessController.doPrivileged(AccessController.java:399)
+	at java.rmi/sun.rmi.transport.tcp.TCPTransport$ConnectionHandler.run(TCPTransport.java:704)
+	at java.base/java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1136)
+	at java.base/java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:635)
+	at java.base/java.lang.Thread.run(Thread.java:833)
+2023-10-18 06:13:57 jdbc[3]: exception
+org.h2.jdbc.JdbcSQLSyntaxErrorException: Syntax error in SQL statement "create table userloginlog\000d\000a(\000d\000a    loginid       int auto_increment comment '自增长主键登录编号'\000d\000a        primary key,\000d\000a    userid        int          null,\000d\000a    requestip     varchar(50)  null comment '请求地址',\000d\000a    sessionid     varchar(50)  null comment '请求编号',\000d\000a    logintime     datetime     null comment '登录时间',\000d\000a    usertoken     varchar(100) null,\000d\000a    lasttime      datetime     null comment '最后活跃时间',\000d\000a    lastheartbeat datetime     null,\000d\000a    logouttime    datetime     null,\000d\000a    apptoken      varchar(128) null comment '连接令牌',\000d\000a    isexpires     tinyint[*](1)   null,\000d\000a    appid         varchar(16)  null,\000d\000a    expirestime   datetime     null\000d\000a)"; expected "ARRAY, INVISIBLE, VISIBLE, NOT, NULL, AS, DEFAULT, GENERATED, ON, NOT, NULL, AUTO_INCREMENT, DEFAULT, NULL_TO_DEFAULT, SEQUENCE, SELECTIVITY, COMMENT, CONSTRAINT, COMMENT, PRIMARY, UNIQUE, NOT, NULL, CHECK, REFERENCES, AUTO_INCREMENT, ,, )"; SQL statement:
+create table userloginlog
+(
+    loginid       int auto_increment comment '自增长主键登录编号'
+        primary key,
+    userid        int          null,
+    requestip     varchar(50)  null comment '请求地址',
+    sessionid     varchar(50)  null comment '请求编号',
+    logintime     datetime     null comment '登录时间',
+    usertoken     varchar(100) null,
+    lasttime      datetime     null comment '最后活跃时间',
+    lastheartbeat datetime     null,
+    logouttime    datetime     null,
+    apptoken      varchar(128) null comment '连接令牌',
+    isexpires     tinyint(1)   null,
+    appid         varchar(16)  null,
+    expirestime   datetime     null
+) [42001-210]
+2023-10-18 06:13:57 jdbc[6]: exception
+java.sql.SQLClientInfoException: Client info name 'ApplicationName' not supported.
+	at org.h2.jdbc.JdbcConnection.setClientInfo(JdbcConnection.java:1573)
+	at com.intellij.database.remote.jdbc.impl.RemoteConnectionImpl.setClientInfo(RemoteConnectionImpl.java:469)
+	at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
+	at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:77)
+	at java.base/jdk.internal.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
+	at java.base/java.lang.reflect.Method.invoke(Method.java:568)
+	at java.rmi/sun.rmi.server.UnicastServerRef.dispatch(UnicastServerRef.java:360)
+	at java.rmi/sun.rmi.transport.Transport$1.run(Transport.java:200)
+	at java.rmi/sun.rmi.transport.Transport$1.run(Transport.java:197)
+	at java.base/java.security.AccessController.doPrivileged(AccessController.java:712)
+	at java.rmi/sun.rmi.transport.Transport.serviceCall(Transport.java:196)
+	at java.rmi/sun.rmi.transport.tcp.TCPTransport.handleMessages(TCPTransport.java:587)
+	at java.rmi/sun.rmi.transport.tcp.TCPTransport$ConnectionHandler.run0(TCPTransport.java:828)
+	at java.rmi/sun.rmi.transport.tcp.TCPTransport$ConnectionHandler.lambda$run$0(TCPTransport.java:705)
+	at java.base/java.security.AccessController.doPrivileged(AccessController.java:399)
+	at java.rmi/sun.rmi.transport.tcp.TCPTransport$ConnectionHandler.run(TCPTransport.java:704)
+	at java.base/java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1136)
+	at java.base/java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:635)
+	at java.base/java.lang.Thread.run(Thread.java:833)
+2023-10-18 06:14:08 jdbc[7]: exception
+java.sql.SQLClientInfoException: Client info name 'ApplicationName' not supported.
+	at org.h2.jdbc.JdbcConnection.setClientInfo(JdbcConnection.java:1573)
+	at com.intellij.database.remote.jdbc.impl.RemoteConnectionImpl.setClientInfo(RemoteConnectionImpl.java:469)
+	at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
+	at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:77)
+	at java.base/jdk.internal.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
+	at java.base/java.lang.reflect.Method.invoke(Method.java:568)
+	at java.rmi/sun.rmi.server.UnicastServerRef.dispatch(UnicastServerRef.java:360)
+	at java.rmi/sun.rmi.transport.Transport$1.run(Transport.java:200)
+	at java.rmi/sun.rmi.transport.Transport$1.run(Transport.java:197)
+	at java.base/java.security.AccessController.doPrivileged(AccessController.java:712)
+	at java.rmi/sun.rmi.transport.Transport.serviceCall(Transport.java:196)
+	at java.rmi/sun.rmi.transport.tcp.TCPTransport.handleMessages(TCPTransport.java:587)
+	at java.rmi/sun.rmi.transport.tcp.TCPTransport$ConnectionHandler.run0(TCPTransport.java:828)
+	at java.rmi/sun.rmi.transport.tcp.TCPTransport$ConnectionHandler.lambda$run$0(TCPTransport.java:705)
+	at java.base/java.security.AccessController.doPrivileged(AccessController.java:399)
+	at java.rmi/sun.rmi.transport.tcp.TCPTransport$ConnectionHandler.run(TCPTransport.java:704)
+	at java.base/java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1136)
+	at java.base/java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:635)
+	at java.base/java.lang.Thread.run(Thread.java:833)
+2023-10-18 06:14:12 jdbc[3]: exception
+org.h2.jdbc.JdbcSQLSyntaxErrorException: Syntax error in SQL statement "create table userloginlog\000d\000a(\000d\000a    loginid       int auto_increment comment '自增长主键登录编号'\000d\000a        primary key,\000d\000a    userid        int          null,\000d\000a    requestip     varchar(50)  null comment '请求地址',\000d\000a    sessionid     varchar(50)  null comment '请求编号',\000d\000a    logintime     datetime     null comment '登录时间',\000d\000a    usertoken     varchar(100) null,\000d\000a    lasttime      datetime     null comment '最后活跃时间',\000d\000a    lastheartbeat datetime     null,\000d\000a    logouttime    datetime     null,\000d\000a    apptoken      varchar(128) null comment '连接令牌',\000d\000a    isexpires     tinyint[*](1)   null,\000d\000a    appid         varchar(16)  null,\000d\000a    expirestime   datetime     null\000d\000a)"; expected "ARRAY, INVISIBLE, VISIBLE, NOT, NULL, AS, DEFAULT, GENERATED, ON, NOT, NULL, AUTO_INCREMENT, DEFAULT, NULL_TO_DEFAULT, SEQUENCE, SELECTIVITY, COMMENT, CONSTRAINT, COMMENT, PRIMARY, UNIQUE, NOT, NULL, CHECK, REFERENCES, AUTO_INCREMENT, ,, )"; SQL statement:
+create table userloginlog
+(
+    loginid       int auto_increment comment '自增长主键登录编号'
+        primary key,
+    userid        int          null,
+    requestip     varchar(50)  null comment '请求地址',
+    sessionid     varchar(50)  null comment '请求编号',
+    logintime     datetime     null comment '登录时间',
+    usertoken     varchar(100) null,
+    lasttime      datetime     null comment '最后活跃时间',
+    lastheartbeat datetime     null,
+    logouttime    datetime     null,
+    apptoken      varchar(128) null comment '连接令牌',
+    isexpires     tinyint(1)   null,
+    appid         varchar(16)  null,
+    expirestime   datetime     null
+) [42001-210]
+2023-10-18 06:14:12 jdbc[8]: exception
+java.sql.SQLClientInfoException: Client info name 'ApplicationName' not supported.
+	at org.h2.jdbc.JdbcConnection.setClientInfo(JdbcConnection.java:1573)
+	at com.intellij.database.remote.jdbc.impl.RemoteConnectionImpl.setClientInfo(RemoteConnectionImpl.java:469)
+	at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
+	at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:77)
+	at java.base/jdk.internal.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
+	at java.base/java.lang.reflect.Method.invoke(Method.java:568)
+	at java.rmi/sun.rmi.server.UnicastServerRef.dispatch(UnicastServerRef.java:360)
+	at java.rmi/sun.rmi.transport.Transport$1.run(Transport.java:200)
+	at java.rmi/sun.rmi.transport.Transport$1.run(Transport.java:197)
+	at java.base/java.security.AccessController.doPrivileged(AccessController.java:712)
+	at java.rmi/sun.rmi.transport.Transport.serviceCall(Transport.java:196)
+	at java.rmi/sun.rmi.transport.tcp.TCPTransport.handleMessages(TCPTransport.java:587)
+	at java.rmi/sun.rmi.transport.tcp.TCPTransport$ConnectionHandler.run0(TCPTransport.java:828)
+	at java.rmi/sun.rmi.transport.tcp.TCPTransport$ConnectionHandler.lambda$run$0(TCPTransport.java:705)
+	at java.base/java.security.AccessController.doPrivileged(AccessController.java:399)
+	at java.rmi/sun.rmi.transport.tcp.TCPTransport$ConnectionHandler.run(TCPTransport.java:704)
+	at java.base/java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1136)
+	at java.base/java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:635)
+	at java.base/java.lang.Thread.run(Thread.java:833)
+2023-10-18 06:14:17 jdbc[3]: exception
+org.h2.jdbc.JdbcSQLSyntaxErrorException: Syntax error in SQL statement "create table userinfo\000d\000a(\000d\000a    userid                    int auto_increment comment '自增长主键用户编号'\000d\000a        primary key,\000d\000a    usergroupid               int          null,\000d\000a    username                  varchar(50)  null comment '用户名',\000d\000a    account                   varchar(50)  null comment '账号',\000d\000a    userpassword              varchar(50)  null comment '密码',\000d\000a    userdescribe              varchar(200) null comment '描述',\000d\000a    isenable                  tinyint[*](1)   null,\000d\000a    secondarypassword         varchar(50)  null,\000d\000a    lastestchangepasswordtime datetime     null\000d\000a)"; expected "ARRAY, INVISIBLE, VISIBLE, NOT, NULL, AS, DEFAULT, GENERATED, ON, NOT, NULL, AUTO_INCREMENT, DEFAULT, NULL_TO_DEFAULT, SEQUENCE, SELECTIVITY, COMMENT, CONSTRAINT, COMMENT, PRIMARY, UNIQUE, NOT, NULL, CHECK, REFERENCES, AUTO_INCREMENT, ,, )"; SQL statement:
+create table userinfo
+(
+    userid                    int auto_increment comment '自增长主键用户编号'
+        primary key,
+    usergroupid               int          null,
+    username                  varchar(50)  null comment '用户名',
+    account                   varchar(50)  null comment '账号',
+    userpassword              varchar(50)  null comment '密码',
+    userdescribe              varchar(200) null comment '描述',
+    isenable                  tinyint(1)   null,
+    secondarypassword         varchar(50)  null,
+    lastestchangepasswordtime datetime     null
+) [42001-210]
+2023-10-18 06:14:17 jdbc[9]: exception
+java.sql.SQLClientInfoException: Client info name 'ApplicationName' not supported.
+	at org.h2.jdbc.JdbcConnection.setClientInfo(JdbcConnection.java:1573)
+	at com.intellij.database.remote.jdbc.impl.RemoteConnectionImpl.setClientInfo(RemoteConnectionImpl.java:469)
+	at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
+	at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:77)
+	at java.base/jdk.internal.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
+	at java.base/java.lang.reflect.Method.invoke(Method.java:568)
+	at java.rmi/sun.rmi.server.UnicastServerRef.dispatch(UnicastServerRef.java:360)
+	at java.rmi/sun.rmi.transport.Transport$1.run(Transport.java:200)
+	at java.rmi/sun.rmi.transport.Transport$1.run(Transport.java:197)
+	at java.base/java.security.AccessController.doPrivileged(AccessController.java:712)
+	at java.rmi/sun.rmi.transport.Transport.serviceCall(Transport.java:196)
+	at java.rmi/sun.rmi.transport.tcp.TCPTransport.handleMessages(TCPTransport.java:587)
+	at java.rmi/sun.rmi.transport.tcp.TCPTransport$ConnectionHandler.run0(TCPTransport.java:828)
+	at java.rmi/sun.rmi.transport.tcp.TCPTransport$ConnectionHandler.lambda$run$0(TCPTransport.java:705)
+	at java.base/java.security.AccessController.doPrivileged(AccessController.java:399)
+	at java.rmi/sun.rmi.transport.tcp.TCPTransport$ConnectionHandler.run(TCPTransport.java:704)
+	at java.base/java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1136)
+	at java.base/java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:635)
+	at java.base/java.lang.Thread.run(Thread.java:833)
+2023-10-18 06:14:33 jdbc[3]: exception
+org.h2.jdbc.JdbcSQLSyntaxErrorException: Syntax error in SQL statement "create table userinfo\000d\000a(\000d\000a    userid                    int auto_increment comment '自增长主键用户编号'\000d\000a        primary key,\000d\000a    usergroupid               int          null,\000d\000a    username                  varchar(50)  null comment '用户名',\000d\000a    account                   varchar(50)  null comment '账号',\000d\000a    userpassword              varchar(50)  null comment '密码',\000d\000a    userdescribe              varchar(200) null comment '描述',\000d\000a    isenable                  int[*](1)   null,\000d\000a    secondarypassword         varchar(50)  null,\000d\000a    lastestchangepasswordtime datetime     null\000d\000a)"; expected "ARRAY, INVISIBLE, VISIBLE, NOT, NULL, AS, DEFAULT, GENERATED, ON, NOT, NULL, AUTO_INCREMENT, DEFAULT, NULL_TO_DEFAULT, SEQUENCE, SELECTIVITY, COMMENT, CONSTRAINT, COMMENT, PRIMARY, UNIQUE, NOT, NULL, CHECK, REFERENCES, AUTO_INCREMENT, ,, )"; SQL statement:
+create table userinfo
+(
+    userid                    int auto_increment comment '自增长主键用户编号'
+        primary key,
+    usergroupid               int          null,
+    username                  varchar(50)  null comment '用户名',
+    account                   varchar(50)  null comment '账号',
+    userpassword              varchar(50)  null comment '密码',
+    userdescribe              varchar(200) null comment '描述',
+    isenable                  int(1)   null,
+    secondarypassword         varchar(50)  null,
+    lastestchangepasswordtime datetime     null
+) [42001-210]
+2023-10-18 06:14:33 jdbc[10]: exception
+java.sql.SQLClientInfoException: Client info name 'ApplicationName' not supported.
+	at org.h2.jdbc.JdbcConnection.setClientInfo(JdbcConnection.java:1573)
+	at com.intellij.database.remote.jdbc.impl.RemoteConnectionImpl.setClientInfo(RemoteConnectionImpl.java:469)
+	at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
+	at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:77)
+	at java.base/jdk.internal.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
+	at java.base/java.lang.reflect.Method.invoke(Method.java:568)
+	at java.rmi/sun.rmi.server.UnicastServerRef.dispatch(UnicastServerRef.java:360)
+	at java.rmi/sun.rmi.transport.Transport$1.run(Transport.java:200)
+	at java.rmi/sun.rmi.transport.Transport$1.run(Transport.java:197)
+	at java.base/java.security.AccessController.doPrivileged(AccessController.java:712)
+	at java.rmi/sun.rmi.transport.Transport.serviceCall(Transport.java:196)
+	at java.rmi/sun.rmi.transport.tcp.TCPTransport.handleMessages(TCPTransport.java:587)
+	at java.rmi/sun.rmi.transport.tcp.TCPTransport$ConnectionHandler.run0(TCPTransport.java:828)
+	at java.rmi/sun.rmi.transport.tcp.TCPTransport$ConnectionHandler.lambda$run$0(TCPTransport.java:705)
+	at java.base/java.security.AccessController.doPrivileged(AccessController.java:399)
+	at java.rmi/sun.rmi.transport.tcp.TCPTransport$ConnectionHandler.run(TCPTransport.java:704)
+	at java.base/java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1136)
+	at java.base/java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:635)
+	at java.base/java.lang.Thread.run(Thread.java:833)
+2023-10-18 06:15:26 jdbc[3]: exception
+org.h2.jdbc.JdbcSQLSyntaxErrorException: Syntax error in SQL statement "create table userinfo\000d\000a(\000d\000a    userid                    int auto_increment comment '自增长主键用户编号'\000d\000a        primary key,\000d\000a    usergroupid               int          null,\000d\000a    username                  varchar(50)  null comment '用户名',\000d\000a    account                   varchar(50)  null comment '账号',\000d\000a    userpassword              varchar(50)  null comment '密码',\000d\000a    userdescribe              varchar(200) null comment '描述',\000d\000a    isenable                  int[*](1)   null,\000d\000a    secondarypassword         varchar(50)  null,\000d\000a    lastestchangepasswordtime datetime     null\000d\000a)"; expected "ARRAY, INVISIBLE, VISIBLE, NOT, NULL, AS, DEFAULT, GENERATED, ON, NOT, NULL, AUTO_INCREMENT, DEFAULT, NULL_TO_DEFAULT, SEQUENCE, SELECTIVITY, COMMENT, CONSTRAINT, COMMENT, PRIMARY, UNIQUE, NOT, NULL, CHECK, REFERENCES, AUTO_INCREMENT, ,, )"; SQL statement:
+create table userinfo
+(
+    userid                    int auto_increment comment '自增长主键用户编号'
+        primary key,
+    usergroupid               int          null,
+    username                  varchar(50)  null comment '用户名',
+    account                   varchar(50)  null comment '账号',
+    userpassword              varchar(50)  null comment '密码',
+    userdescribe              varchar(200) null comment '描述',
+    isenable                  int(1)   null,
+    secondarypassword         varchar(50)  null,
+    lastestchangepasswordtime datetime     null
+) [42001-210]
+2023-10-18 06:15:26 jdbc[11]: exception
+java.sql.SQLClientInfoException: Client info name 'ApplicationName' not supported.
+	at org.h2.jdbc.JdbcConnection.setClientInfo(JdbcConnection.java:1573)
+	at com.intellij.database.remote.jdbc.impl.RemoteConnectionImpl.setClientInfo(RemoteConnectionImpl.java:469)
+	at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
+	at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:77)
+	at java.base/jdk.internal.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
+	at java.base/java.lang.reflect.Method.invoke(Method.java:568)
+	at java.rmi/sun.rmi.server.UnicastServerRef.dispatch(UnicastServerRef.java:360)
+	at java.rmi/sun.rmi.transport.Transport$1.run(Transport.java:200)
+	at java.rmi/sun.rmi.transport.Transport$1.run(Transport.java:197)
+	at java.base/java.security.AccessController.doPrivileged(AccessController.java:712)
+	at java.rmi/sun.rmi.transport.Transport.serviceCall(Transport.java:196)
+	at java.rmi/sun.rmi.transport.tcp.TCPTransport.handleMessages(TCPTransport.java:587)
+	at java.rmi/sun.rmi.transport.tcp.TCPTransport$ConnectionHandler.run0(TCPTransport.java:828)
+	at java.rmi/sun.rmi.transport.tcp.TCPTransport$ConnectionHandler.lambda$run$0(TCPTransport.java:705)
+	at java.base/java.security.AccessController.doPrivileged(AccessController.java:399)
+	at java.rmi/sun.rmi.transport.tcp.TCPTransport$ConnectionHandler.run(TCPTransport.java:704)
+	at java.base/java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1136)
+	at java.base/java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:635)
+	at java.base/java.lang.Thread.run(Thread.java:833)
+2023-10-18 06:15:37 jdbc[3]: exception
+org.h2.jdbc.JdbcSQLSyntaxErrorException: Syntax error in SQL statement "create table userinfo\000d\000a(\000d\000a    userid                    int auto_increment comment '自增长主键用户编号'\000d\000a        primary key,\000d\000a    usergroupid               int          null,\000d\000a    username                  varchar(50)  null comment '用户名',\000d\000a    account                   varchar(50)  null comment '账号',\000d\000a    userpassword              varchar(50)  null comment '密码',\000d\000a    userdescribe              varchar(200) null comment '描述',\000d\000a    isenable                  int[*](1)   null,\000d\000a    secondarypassword         varchar(50)  null,\000d\000a--     lastestchangepasswordtime datetime     null\000d\000a)"; expected "ARRAY, INVISIBLE, VISIBLE, NOT, NULL, AS, DEFAULT, GENERATED, ON, NOT, NULL, AUTO_INCREMENT, DEFAULT, NULL_TO_DEFAULT, SEQUENCE, SELECTIVITY, COMMENT, CONSTRAINT, COMMENT, PRIMARY, UNIQUE, NOT, NULL, CHECK, REFERENCES, AUTO_INCREMENT, ,, )"; SQL statement:
+create table userinfo
+(
+    userid                    int auto_increment comment '自增长主键用户编号'
+        primary key,
+    usergroupid               int          null,
+    username                  varchar(50)  null comment '用户名',
+    account                   varchar(50)  null comment '账号',
+    userpassword              varchar(50)  null comment '密码',
+    userdescribe              varchar(200) null comment '描述',
+    isenable                  int(1)   null,
+    secondarypassword         varchar(50)  null,
+--     lastestchangepasswordtime datetime     null
+) [42001-210]
+2023-10-18 06:15:37 jdbc[12]: exception
+java.sql.SQLClientInfoException: Client info name 'ApplicationName' not supported.
+	at org.h2.jdbc.JdbcConnection.setClientInfo(JdbcConnection.java:1573)
+	at com.intellij.database.remote.jdbc.impl.RemoteConnectionImpl.setClientInfo(RemoteConnectionImpl.java:469)
+	at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
+	at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:77)
+	at java.base/jdk.internal.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
+	at java.base/java.lang.reflect.Method.invoke(Method.java:568)
+	at java.rmi/sun.rmi.server.UnicastServerRef.dispatch(UnicastServerRef.java:360)
+	at java.rmi/sun.rmi.transport.Transport$1.run(Transport.java:200)
+	at java.rmi/sun.rmi.transport.Transport$1.run(Transport.java:197)
+	at java.base/java.security.AccessController.doPrivileged(AccessController.java:712)
+	at java.rmi/sun.rmi.transport.Transport.serviceCall(Transport.java:196)
+	at java.rmi/sun.rmi.transport.tcp.TCPTransport.handleMessages(TCPTransport.java:587)
+	at java.rmi/sun.rmi.transport.tcp.TCPTransport$ConnectionHandler.run0(TCPTransport.java:828)
+	at java.rmi/sun.rmi.transport.tcp.TCPTransport$ConnectionHandler.lambda$run$0(TCPTransport.java:705)
+	at java.base/java.security.AccessController.doPrivileged(AccessController.java:399)
+	at java.rmi/sun.rmi.transport.tcp.TCPTransport$ConnectionHandler.run(TCPTransport.java:704)
+	at java.base/java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1136)
+	at java.base/java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:635)
+	at java.base/java.lang.Thread.run(Thread.java:833)
+2023-10-18 06:17:33 jdbc[3]: exception
+org.h2.jdbc.JdbcSQLSyntaxErrorException: Syntax error in SQL statement "create table userinfo\000d\000a(\000d\000a    userid                    int auto_increment comment '自增长主键用户编号'\000d\000a        primary key,\000d\000a    usergroupid               int          null comment  '用户组编号',\000d\000a    username                  varchar(50)  null comment '用户名',\000d\000a    account                   varchar(50)  null comment '账号',\000d\000a    userpassword              varchar(50)  null comment '密码',\000d\000a    userdescribe              varchar(200) null comment '描述',\000d\000a    isenable                  int[*](1)   null comment '是否启用账号',\000d\000a    secondarypassword         varchar(50)  null comment '二级安全密码',\000d\000a    lastestchangepasswordtime datetime     null comment '最后修改密码时间'\000d\000a)"; expected "ARRAY, INVISIBLE, VISIBLE, NOT, NULL, AS, DEFAULT, GENERATED, ON, NOT, NULL, AUTO_INCREMENT, DEFAULT, NULL_TO_DEFAULT, SEQUENCE, SELECTIVITY, COMMENT, CONSTRAINT, COMMENT, PRIMARY, UNIQUE, NOT, NULL, CHECK, REFERENCES, AUTO_INCREMENT, ,, )"; SQL statement:
+create table userinfo
+(
+    userid                    int auto_increment comment '自增长主键用户编号'
+        primary key,
+    usergroupid               int          null comment  '用户组编号',
+    username                  varchar(50)  null comment '用户名',
+    account                   varchar(50)  null comment '账号',
+    userpassword              varchar(50)  null comment '密码',
+    userdescribe              varchar(200) null comment '描述',
+    isenable                  int(1)   null comment '是否启用账号',
+    secondarypassword         varchar(50)  null comment '二级安全密码',
+    lastestchangepasswordtime datetime     null comment '最后修改密码时间'
+) [42001-210]
+2023-10-18 06:17:33 jdbc[13]: exception
+java.sql.SQLClientInfoException: Client info name 'ApplicationName' not supported.
+	at org.h2.jdbc.JdbcConnection.setClientInfo(JdbcConnection.java:1573)
+	at com.intellij.database.remote.jdbc.impl.RemoteConnectionImpl.setClientInfo(RemoteConnectionImpl.java:469)
+	at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
+	at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:77)
+	at java.base/jdk.internal.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
+	at java.base/java.lang.reflect.Method.invoke(Method.java:568)
+	at java.rmi/sun.rmi.server.UnicastServerRef.dispatch(UnicastServerRef.java:360)
+	at java.rmi/sun.rmi.transport.Transport$1.run(Transport.java:200)
+	at java.rmi/sun.rmi.transport.Transport$1.run(Transport.java:197)
+	at java.base/java.security.AccessController.doPrivileged(AccessController.java:712)
+	at java.rmi/sun.rmi.transport.Transport.serviceCall(Transport.java:196)
+	at java.rmi/sun.rmi.transport.tcp.TCPTransport.handleMessages(TCPTransport.java:587)
+	at java.rmi/sun.rmi.transport.tcp.TCPTransport$ConnectionHandler.run0(TCPTransport.java:828)
+	at java.rmi/sun.rmi.transport.tcp.TCPTransport$ConnectionHandler.lambda$run$0(TCPTransport.java:705)
+	at java.base/java.security.AccessController.doPrivileged(AccessController.java:399)
+	at java.rmi/sun.rmi.transport.tcp.TCPTransport$ConnectionHandler.run(TCPTransport.java:704)
+	at java.base/java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1136)
+	at java.base/java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:635)
+	at java.base/java.lang.Thread.run(Thread.java:833)
+2023-10-18 06:17:41 jdbc[3]: exception
+org.h2.jdbc.JdbcSQLSyntaxErrorException: Syntax error in SQL statement "create table userinfo\000d\000a(\000d\000a    userid                    int auto_increment comment '自增长主键用户编号'\000d\000a        primary key,\000d\000a    usergroupid               int          null comment  '用户组编号',\000d\000a    username                  varchar(50)  null comment '用户名',\000d\000a    account                   varchar(50)  null comment '账号',\000d\000a    userpassword              varchar(50)  null comment '密码',\000d\000a    userdescribe              varchar(200) null comment '描述',\000d\000a    isenable                  int[*](1)   null comment '是否启用账号',\000d\000a    secondarypassword         varchar(50)  null comment '二级安全密码',\000d\000a    lastestchangepasswordtime datetime     null comment '最后修改密码时间'\000d\000a)"; expected "ARRAY, INVISIBLE, VISIBLE, NOT, NULL, AS, DEFAULT, GENERATED, ON, NOT, NULL, AUTO_INCREMENT, DEFAULT, NULL_TO_DEFAULT, SEQUENCE, SELECTIVITY, COMMENT, CONSTRAINT, COMMENT, PRIMARY, UNIQUE, NOT, NULL, CHECK, REFERENCES, AUTO_INCREMENT, ,, )"; SQL statement:
+create table userinfo
+(
+    userid                    int auto_increment comment '自增长主键用户编号'
+        primary key,
+    usergroupid               int          null comment  '用户组编号',
+    username                  varchar(50)  null comment '用户名',
+    account                   varchar(50)  null comment '账号',
+    userpassword              varchar(50)  null comment '密码',
+    userdescribe              varchar(200) null comment '描述',
+    isenable                  int(1)   null comment '是否启用账号',
+    secondarypassword         varchar(50)  null comment '二级安全密码',
+    lastestchangepasswordtime datetime     null comment '最后修改密码时间'
+) [42001-210]
+2023-10-18 06:17:41 jdbc[14]: exception
+java.sql.SQLClientInfoException: Client info name 'ApplicationName' not supported.
+	at org.h2.jdbc.JdbcConnection.setClientInfo(JdbcConnection.java:1573)
+	at com.intellij.database.remote.jdbc.impl.RemoteConnectionImpl.setClientInfo(RemoteConnectionImpl.java:469)
+	at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
+	at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:77)
+	at java.base/jdk.internal.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
+	at java.base/java.lang.reflect.Method.invoke(Method.java:568)
+	at java.rmi/sun.rmi.server.UnicastServerRef.dispatch(UnicastServerRef.java:360)
+	at java.rmi/sun.rmi.transport.Transport$1.run(Transport.java:200)
+	at java.rmi/sun.rmi.transport.Transport$1.run(Transport.java:197)
+	at java.base/java.security.AccessController.doPrivileged(AccessController.java:712)
+	at java.rmi/sun.rmi.transport.Transport.serviceCall(Transport.java:196)
+	at java.rmi/sun.rmi.transport.tcp.TCPTransport.handleMessages(TCPTransport.java:587)
+	at java.rmi/sun.rmi.transport.tcp.TCPTransport$ConnectionHandler.run0(TCPTransport.java:828)
+	at java.rmi/sun.rmi.transport.tcp.TCPTransport$ConnectionHandler.lambda$run$0(TCPTransport.java:705)
+	at java.base/java.security.AccessController.doPrivileged(AccessController.java:399)
+	at java.rmi/sun.rmi.transport.tcp.TCPTransport$ConnectionHandler.run(TCPTransport.java:704)
+	at java.base/java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1136)
+	at java.base/java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:635)
+	at java.base/java.lang.Thread.run(Thread.java:833)
+2023-10-18 06:27:12 jdbc[15]: exception
+java.sql.SQLClientInfoException: Client info name 'ApplicationName' not supported.
+	at org.h2.jdbc.JdbcConnection.setClientInfo(JdbcConnection.java:1573)
+	at com.intellij.database.remote.jdbc.impl.RemoteConnectionImpl.setClientInfo(RemoteConnectionImpl.java:469)
+	at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
+	at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:77)
+	at java.base/jdk.internal.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
+	at java.base/java.lang.reflect.Method.invoke(Method.java:568)
+	at java.rmi/sun.rmi.server.UnicastServerRef.dispatch(UnicastServerRef.java:360)
+	at java.rmi/sun.rmi.transport.Transport$1.run(Transport.java:200)
+	at java.rmi/sun.rmi.transport.Transport$1.run(Transport.java:197)
+	at java.base/java.security.AccessController.doPrivileged(AccessController.java:712)
+	at java.rmi/sun.rmi.transport.Transport.serviceCall(Transport.java:196)
+	at java.rmi/sun.rmi.transport.tcp.TCPTransport.handleMessages(TCPTransport.java:587)
+	at java.rmi/sun.rmi.transport.tcp.TCPTransport$ConnectionHandler.run0(TCPTransport.java:828)
+	at java.rmi/sun.rmi.transport.tcp.TCPTransport$ConnectionHandler.lambda$run$0(TCPTransport.java:705)
+	at java.base/java.security.AccessController.doPrivileged(AccessController.java:399)
+	at java.rmi/sun.rmi.transport.tcp.TCPTransport$ConnectionHandler.run(TCPTransport.java:704)
+	at java.base/java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1136)
+	at java.base/java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:635)
+	at java.base/java.lang.Thread.run(Thread.java:833)
+2023-10-18 06:27:12 jdbc[16]: exception
+java.sql.SQLClientInfoException: Client info name 'ApplicationName' not supported.
+	at org.h2.jdbc.JdbcConnection.setClientInfo(JdbcConnection.java:1573)
+	at com.intellij.database.remote.jdbc.impl.RemoteConnectionImpl.setClientInfo(RemoteConnectionImpl.java:469)
+	at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
+	at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:77)
+	at java.base/jdk.internal.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
+	at java.base/java.lang.reflect.Method.invoke(Method.java:568)
+	at java.rmi/sun.rmi.server.UnicastServerRef.dispatch(UnicastServerRef.java:360)
+	at java.rmi/sun.rmi.transport.Transport$1.run(Transport.java:200)
+	at java.rmi/sun.rmi.transport.Transport$1.run(Transport.java:197)
+	at java.base/java.security.AccessController.doPrivileged(AccessController.java:712)
+	at java.rmi/sun.rmi.transport.Transport.serviceCall(Transport.java:196)
+	at java.rmi/sun.rmi.transport.tcp.TCPTransport.handleMessages(TCPTransport.java:587)
+	at java.rmi/sun.rmi.transport.tcp.TCPTransport$ConnectionHandler.run0(TCPTransport.java:828)
+	at java.rmi/sun.rmi.transport.tcp.TCPTransport$ConnectionHandler.lambda$run$0(TCPTransport.java:705)
+	at java.base/java.security.AccessController.doPrivileged(AccessController.java:399)
+	at java.rmi/sun.rmi.transport.tcp.TCPTransport$ConnectionHandler.run(TCPTransport.java:704)
+	at java.base/java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1136)
+	at java.base/java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:635)
+	at java.base/java.lang.Thread.run(Thread.java:833)
+2023-10-18 06:27:22 jdbc[17]: exception
+java.sql.SQLClientInfoException: Client info name 'ApplicationName' not supported.
+	at org.h2.jdbc.JdbcConnection.setClientInfo(JdbcConnection.java:1573)
+	at com.intellij.database.remote.jdbc.impl.RemoteConnectionImpl.setClientInfo(RemoteConnectionImpl.java:469)
+	at jdk.internal.reflect.GeneratedMethodAccessor56.invoke(Unknown Source)
+	at java.base/jdk.internal.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
+	at java.base/java.lang.reflect.Method.invoke(Method.java:568)
+	at java.rmi/sun.rmi.server.UnicastServerRef.dispatch(UnicastServerRef.java:360)
+	at java.rmi/sun.rmi.transport.Transport$1.run(Transport.java:200)
+	at java.rmi/sun.rmi.transport.Transport$1.run(Transport.java:197)
+	at java.base/java.security.AccessController.doPrivileged(AccessController.java:712)
+	at java.rmi/sun.rmi.transport.Transport.serviceCall(Transport.java:196)
+	at java.rmi/sun.rmi.transport.tcp.TCPTransport.handleMessages(TCPTransport.java:587)
+	at java.rmi/sun.rmi.transport.tcp.TCPTransport$ConnectionHandler.run0(TCPTransport.java:828)
+	at java.rmi/sun.rmi.transport.tcp.TCPTransport$ConnectionHandler.lambda$run$0(TCPTransport.java:705)
+	at java.base/java.security.AccessController.doPrivileged(AccessController.java:399)
+	at java.rmi/sun.rmi.transport.tcp.TCPTransport$ConnectionHandler.run(TCPTransport.java:704)
+	at java.base/java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1136)
+	at java.base/java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:635)
+	at java.base/java.lang.Thread.run(Thread.java:833)

+ 308 - 0
mvnw

@@ -0,0 +1,308 @@
+#!/bin/sh
+# ----------------------------------------------------------------------------
+# Licensed to the Apache Software Foundation (ASF) under one
+# or more contributor license agreements.  See the NOTICE file
+# distributed with this work for additional information
+# regarding copyright ownership.  The ASF licenses this file
+# to you under the Apache License, Version 2.0 (the
+# "License"); you may not use this file except in compliance
+# with the License.  You may obtain a copy of the License at
+#
+#    https://www.apache.org/licenses/LICENSE-2.0
+#
+# Unless required by applicable law or agreed to in writing,
+# software distributed under the License is distributed on an
+# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
+# KIND, either express or implied.  See the License for the
+# specific language governing permissions and limitations
+# under the License.
+# ----------------------------------------------------------------------------
+
+# ----------------------------------------------------------------------------
+# Apache Maven Wrapper startup batch script, version 3.2.0
+#
+# Required ENV vars:
+# ------------------
+#   JAVA_HOME - location of a JDK home dir
+#
+# Optional ENV vars
+# -----------------
+#   MAVEN_OPTS - parameters passed to the Java VM when running Maven
+#     e.g. to debug Maven itself, use
+#       set MAVEN_OPTS=-Xdebug -Xrunjdwp:transport=dt_socket,server=y,suspend=y,address=8000
+#   MAVEN_SKIP_RC - flag to disable loading of mavenrc files
+# ----------------------------------------------------------------------------
+
+if [ -z "$MAVEN_SKIP_RC" ] ; then
+
+  if [ -f /usr/local/etc/mavenrc ] ; then
+    . /usr/local/etc/mavenrc
+  fi
+
+  if [ -f /etc/mavenrc ] ; then
+    . /etc/mavenrc
+  fi
+
+  if [ -f "$HOME/.mavenrc" ] ; then
+    . "$HOME/.mavenrc"
+  fi
+
+fi
+
+# OS specific support.  $var _must_ be set to either true or false.
+cygwin=false;
+darwin=false;
+mingw=false
+case "$(uname)" in
+  CYGWIN*) cygwin=true ;;
+  MINGW*) mingw=true;;
+  Darwin*) darwin=true
+    # Use /usr/libexec/java_home if available, otherwise fall back to /Library/Java/Home
+    # See https://developer.apple.com/library/mac/qa/qa1170/_index.html
+    if [ -z "$JAVA_HOME" ]; then
+      if [ -x "/usr/libexec/java_home" ]; then
+        JAVA_HOME="$(/usr/libexec/java_home)"; export JAVA_HOME
+      else
+        JAVA_HOME="/Library/Java/Home"; export JAVA_HOME
+      fi
+    fi
+    ;;
+esac
+
+if [ -z "$JAVA_HOME" ] ; then
+  if [ -r /etc/gentoo-release ] ; then
+    JAVA_HOME=$(java-config --jre-home)
+  fi
+fi
+
+# For Cygwin, ensure paths are in UNIX format before anything is touched
+if $cygwin ; then
+  [ -n "$JAVA_HOME" ] &&
+    JAVA_HOME=$(cygpath --unix "$JAVA_HOME")
+  [ -n "$CLASSPATH" ] &&
+    CLASSPATH=$(cygpath --path --unix "$CLASSPATH")
+fi
+
+# For Mingw, ensure paths are in UNIX format before anything is touched
+if $mingw ; then
+  [ -n "$JAVA_HOME" ] && [ -d "$JAVA_HOME" ] &&
+    JAVA_HOME="$(cd "$JAVA_HOME" || (echo "cannot cd into $JAVA_HOME."; exit 1); pwd)"
+fi
+
+if [ -z "$JAVA_HOME" ]; then
+  javaExecutable="$(which javac)"
+  if [ -n "$javaExecutable" ] && ! [ "$(expr "\"$javaExecutable\"" : '\([^ ]*\)')" = "no" ]; then
+    # readlink(1) is not available as standard on Solaris 10.
+    readLink=$(which readlink)
+    if [ ! "$(expr "$readLink" : '\([^ ]*\)')" = "no" ]; then
+      if $darwin ; then
+        javaHome="$(dirname "\"$javaExecutable\"")"
+        javaExecutable="$(cd "\"$javaHome\"" && pwd -P)/javac"
+      else
+        javaExecutable="$(readlink -f "\"$javaExecutable\"")"
+      fi
+      javaHome="$(dirname "\"$javaExecutable\"")"
+      javaHome=$(expr "$javaHome" : '\(.*\)/bin')
+      JAVA_HOME="$javaHome"
+      export JAVA_HOME
+    fi
+  fi
+fi
+
+if [ -z "$JAVACMD" ] ; then
+  if [ -n "$JAVA_HOME"  ] ; then
+    if [ -x "$JAVA_HOME/jre/sh/java" ] ; then
+      # IBM's JDK on AIX uses strange locations for the executables
+      JAVACMD="$JAVA_HOME/jre/sh/java"
+    else
+      JAVACMD="$JAVA_HOME/bin/java"
+    fi
+  else
+    JAVACMD="$(\unset -f command 2>/dev/null; \command -v java)"
+  fi
+fi
+
+if [ ! -x "$JAVACMD" ] ; then
+  echo "Error: JAVA_HOME is not defined correctly." >&2
+  echo "  We cannot execute $JAVACMD" >&2
+  exit 1
+fi
+
+if [ -z "$JAVA_HOME" ] ; then
+  echo "Warning: JAVA_HOME environment variable is not set."
+fi
+
+# traverses directory structure from process work directory to filesystem root
+# first directory with .mvn subdirectory is considered project base directory
+find_maven_basedir() {
+  if [ -z "$1" ]
+  then
+    echo "Path not specified to find_maven_basedir"
+    return 1
+  fi
+
+  basedir="$1"
+  wdir="$1"
+  while [ "$wdir" != '/' ] ; do
+    if [ -d "$wdir"/.mvn ] ; then
+      basedir=$wdir
+      break
+    fi
+    # workaround for JBEAP-8937 (on Solaris 10/Sparc)
+    if [ -d "${wdir}" ]; then
+      wdir=$(cd "$wdir/.." || exit 1; pwd)
+    fi
+    # end of workaround
+  done
+  printf '%s' "$(cd "$basedir" || exit 1; pwd)"
+}
+
+# concatenates all lines of a file
+concat_lines() {
+  if [ -f "$1" ]; then
+    # Remove \r in case we run on Windows within Git Bash
+    # and check out the repository with auto CRLF management
+    # enabled. Otherwise, we may read lines that are delimited with
+    # \r\n and produce $'-Xarg\r' rather than -Xarg due to word
+    # splitting rules.
+    tr -s '\r\n' ' ' < "$1"
+  fi
+}
+
+log() {
+  if [ "$MVNW_VERBOSE" = true ]; then
+    printf '%s\n' "$1"
+  fi
+}
+
+BASE_DIR=$(find_maven_basedir "$(dirname "$0")")
+if [ -z "$BASE_DIR" ]; then
+  exit 1;
+fi
+
+MAVEN_PROJECTBASEDIR=${MAVEN_BASEDIR:-"$BASE_DIR"}; export MAVEN_PROJECTBASEDIR
+log "$MAVEN_PROJECTBASEDIR"
+
+##########################################################################################
+# Extension to allow automatically downloading the maven-wrapper.jar from Maven-central
+# This allows using the maven wrapper in projects that prohibit checking in binary data.
+##########################################################################################
+wrapperJarPath="$MAVEN_PROJECTBASEDIR/.mvn/wrapper/maven-wrapper.jar"
+if [ -r "$wrapperJarPath" ]; then
+    log "Found $wrapperJarPath"
+else
+    log "Couldn't find $wrapperJarPath, downloading it ..."
+
+    if [ -n "$MVNW_REPOURL" ]; then
+      wrapperUrl="$MVNW_REPOURL/org/apache/maven/wrapper/maven-wrapper/3.2.0/maven-wrapper-3.2.0.jar"
+    else
+      wrapperUrl="https://repo.maven.apache.org/maven2/org/apache/maven/wrapper/maven-wrapper/3.2.0/maven-wrapper-3.2.0.jar"
+    fi
+    while IFS="=" read -r key value; do
+      # Remove '\r' from value to allow usage on windows as IFS does not consider '\r' as a separator ( considers space, tab, new line ('\n'), and custom '=' )
+      safeValue=$(echo "$value" | tr -d '\r')
+      case "$key" in (wrapperUrl) wrapperUrl="$safeValue"; break ;;
+      esac
+    done < "$MAVEN_PROJECTBASEDIR/.mvn/wrapper/maven-wrapper.properties"
+    log "Downloading from: $wrapperUrl"
+
+    if $cygwin; then
+      wrapperJarPath=$(cygpath --path --windows "$wrapperJarPath")
+    fi
+
+    if command -v wget > /dev/null; then
+        log "Found wget ... using wget"
+        [ "$MVNW_VERBOSE" = true ] && QUIET="" || QUIET="--quiet"
+        if [ -z "$MVNW_USERNAME" ] || [ -z "$MVNW_PASSWORD" ]; then
+            wget $QUIET "$wrapperUrl" -O "$wrapperJarPath" || rm -f "$wrapperJarPath"
+        else
+            wget $QUIET --http-user="$MVNW_USERNAME" --http-password="$MVNW_PASSWORD" "$wrapperUrl" -O "$wrapperJarPath" || rm -f "$wrapperJarPath"
+        fi
+    elif command -v curl > /dev/null; then
+        log "Found curl ... using curl"
+        [ "$MVNW_VERBOSE" = true ] && QUIET="" || QUIET="--silent"
+        if [ -z "$MVNW_USERNAME" ] || [ -z "$MVNW_PASSWORD" ]; then
+            curl $QUIET -o "$wrapperJarPath" "$wrapperUrl" -f -L || rm -f "$wrapperJarPath"
+        else
+            curl $QUIET --user "$MVNW_USERNAME:$MVNW_PASSWORD" -o "$wrapperJarPath" "$wrapperUrl" -f -L || rm -f "$wrapperJarPath"
+        fi
+    else
+        log "Falling back to using Java to download"
+        javaSource="$MAVEN_PROJECTBASEDIR/.mvn/wrapper/MavenWrapperDownloader.java"
+        javaClass="$MAVEN_PROJECTBASEDIR/.mvn/wrapper/MavenWrapperDownloader.class"
+        # For Cygwin, switch paths to Windows format before running javac
+        if $cygwin; then
+          javaSource=$(cygpath --path --windows "$javaSource")
+          javaClass=$(cygpath --path --windows "$javaClass")
+        fi
+        if [ -e "$javaSource" ]; then
+            if [ ! -e "$javaClass" ]; then
+                log " - Compiling MavenWrapperDownloader.java ..."
+                ("$JAVA_HOME/bin/javac" "$javaSource")
+            fi
+            if [ -e "$javaClass" ]; then
+                log " - Running MavenWrapperDownloader.java ..."
+                ("$JAVA_HOME/bin/java" -cp .mvn/wrapper MavenWrapperDownloader "$wrapperUrl" "$wrapperJarPath") || rm -f "$wrapperJarPath"
+            fi
+        fi
+    fi
+fi
+##########################################################################################
+# End of extension
+##########################################################################################
+
+# If specified, validate the SHA-256 sum of the Maven wrapper jar file
+wrapperSha256Sum=""
+while IFS="=" read -r key value; do
+  case "$key" in (wrapperSha256Sum) wrapperSha256Sum=$value; break ;;
+  esac
+done < "$MAVEN_PROJECTBASEDIR/.mvn/wrapper/maven-wrapper.properties"
+if [ -n "$wrapperSha256Sum" ]; then
+  wrapperSha256Result=false
+  if command -v sha256sum > /dev/null; then
+    if echo "$wrapperSha256Sum  $wrapperJarPath" | sha256sum -c > /dev/null 2>&1; then
+      wrapperSha256Result=true
+    fi
+  elif command -v shasum > /dev/null; then
+    if echo "$wrapperSha256Sum  $wrapperJarPath" | shasum -a 256 -c > /dev/null 2>&1; then
+      wrapperSha256Result=true
+    fi
+  else
+    echo "Checksum validation was requested but neither 'sha256sum' or 'shasum' are available."
+    echo "Please install either command, or disable validation by removing 'wrapperSha256Sum' from your maven-wrapper.properties."
+    exit 1
+  fi
+  if [ $wrapperSha256Result = false ]; then
+    echo "Error: Failed to validate Maven wrapper SHA-256, your Maven wrapper might be compromised." >&2
+    echo "Investigate or delete $wrapperJarPath to attempt a clean download." >&2
+    echo "If you updated your Maven version, you need to update the specified wrapperSha256Sum property." >&2
+    exit 1
+  fi
+fi
+
+MAVEN_OPTS="$(concat_lines "$MAVEN_PROJECTBASEDIR/.mvn/jvm.config") $MAVEN_OPTS"
+
+# For Cygwin, switch paths to Windows format before running java
+if $cygwin; then
+  [ -n "$JAVA_HOME" ] &&
+    JAVA_HOME=$(cygpath --path --windows "$JAVA_HOME")
+  [ -n "$CLASSPATH" ] &&
+    CLASSPATH=$(cygpath --path --windows "$CLASSPATH")
+  [ -n "$MAVEN_PROJECTBASEDIR" ] &&
+    MAVEN_PROJECTBASEDIR=$(cygpath --path --windows "$MAVEN_PROJECTBASEDIR")
+fi
+
+# Provide a "standardized" way to retrieve the CLI args that will
+# work with both Windows and non-Windows executions.
+MAVEN_CMD_LINE_ARGS="$MAVEN_CONFIG $*"
+export MAVEN_CMD_LINE_ARGS
+
+WRAPPER_LAUNCHER=org.apache.maven.wrapper.MavenWrapperMain
+
+# shellcheck disable=SC2086 # safe args
+exec "$JAVACMD" \
+  $MAVEN_OPTS \
+  $MAVEN_DEBUG_OPTS \
+  -classpath "$MAVEN_PROJECTBASEDIR/.mvn/wrapper/maven-wrapper.jar" \
+  "-Dmaven.multiModuleProjectDirectory=${MAVEN_PROJECTBASEDIR}" \
+  ${WRAPPER_LAUNCHER} $MAVEN_CONFIG "$@"

+ 205 - 0
mvnw.cmd

@@ -0,0 +1,205 @@
+@REM ----------------------------------------------------------------------------
+@REM Licensed to the Apache Software Foundation (ASF) under one
+@REM or more contributor license agreements.  See the NOTICE file
+@REM distributed with this work for additional information
+@REM regarding copyright ownership.  The ASF licenses this file
+@REM to you under the Apache License, Version 2.0 (the
+@REM "License"); you may not use this file except in compliance
+@REM with the License.  You may obtain a copy of the License at
+@REM
+@REM    https://www.apache.org/licenses/LICENSE-2.0
+@REM
+@REM Unless required by applicable law or agreed to in writing,
+@REM software distributed under the License is distributed on an
+@REM "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
+@REM KIND, either express or implied.  See the License for the
+@REM specific language governing permissions and limitations
+@REM under the License.
+@REM ----------------------------------------------------------------------------
+
+@REM ----------------------------------------------------------------------------
+@REM Apache Maven Wrapper startup batch script, version 3.2.0
+@REM
+@REM Required ENV vars:
+@REM JAVA_HOME - location of a JDK home dir
+@REM
+@REM Optional ENV vars
+@REM MAVEN_BATCH_ECHO - set to 'on' to enable the echoing of the batch commands
+@REM MAVEN_BATCH_PAUSE - set to 'on' to wait for a keystroke before ending
+@REM MAVEN_OPTS - parameters passed to the Java VM when running Maven
+@REM     e.g. to debug Maven itself, use
+@REM set MAVEN_OPTS=-Xdebug -Xrunjdwp:transport=dt_socket,server=y,suspend=y,address=8000
+@REM MAVEN_SKIP_RC - flag to disable loading of mavenrc files
+@REM ----------------------------------------------------------------------------
+
+@REM Begin all REM lines with '@' in case MAVEN_BATCH_ECHO is 'on'
+@echo off
+@REM set title of command window
+title %0
+@REM enable echoing by setting MAVEN_BATCH_ECHO to 'on'
+@if "%MAVEN_BATCH_ECHO%" == "on"  echo %MAVEN_BATCH_ECHO%
+
+@REM set %HOME% to equivalent of $HOME
+if "%HOME%" == "" (set "HOME=%HOMEDRIVE%%HOMEPATH%")
+
+@REM Execute a user defined script before this one
+if not "%MAVEN_SKIP_RC%" == "" goto skipRcPre
+@REM check for pre script, once with legacy .bat ending and once with .cmd ending
+if exist "%USERPROFILE%\mavenrc_pre.bat" call "%USERPROFILE%\mavenrc_pre.bat" %*
+if exist "%USERPROFILE%\mavenrc_pre.cmd" call "%USERPROFILE%\mavenrc_pre.cmd" %*
+:skipRcPre
+
+@setlocal
+
+set ERROR_CODE=0
+
+@REM To isolate internal variables from possible post scripts, we use another setlocal
+@setlocal
+
+@REM ==== START VALIDATION ====
+if not "%JAVA_HOME%" == "" goto OkJHome
+
+echo.
+echo Error: JAVA_HOME not found in your environment. >&2
+echo Please set the JAVA_HOME variable in your environment to match the >&2
+echo location of your Java installation. >&2
+echo.
+goto error
+
+:OkJHome
+if exist "%JAVA_HOME%\bin\java.exe" goto init
+
+echo.
+echo Error: JAVA_HOME is set to an invalid directory. >&2
+echo JAVA_HOME = "%JAVA_HOME%" >&2
+echo Please set the JAVA_HOME variable in your environment to match the >&2
+echo location of your Java installation. >&2
+echo.
+goto error
+
+@REM ==== END VALIDATION ====
+
+:init
+
+@REM Find the project base dir, i.e. the directory that contains the folder ".mvn".
+@REM Fallback to current working directory if not found.
+
+set MAVEN_PROJECTBASEDIR=%MAVEN_BASEDIR%
+IF NOT "%MAVEN_PROJECTBASEDIR%"=="" goto endDetectBaseDir
+
+set EXEC_DIR=%CD%
+set WDIR=%EXEC_DIR%
+:findBaseDir
+IF EXIST "%WDIR%"\.mvn goto baseDirFound
+cd ..
+IF "%WDIR%"=="%CD%" goto baseDirNotFound
+set WDIR=%CD%
+goto findBaseDir
+
+:baseDirFound
+set MAVEN_PROJECTBASEDIR=%WDIR%
+cd "%EXEC_DIR%"
+goto endDetectBaseDir
+
+:baseDirNotFound
+set MAVEN_PROJECTBASEDIR=%EXEC_DIR%
+cd "%EXEC_DIR%"
+
+:endDetectBaseDir
+
+IF NOT EXIST "%MAVEN_PROJECTBASEDIR%\.mvn\jvm.config" goto endReadAdditionalConfig
+
+@setlocal EnableExtensions EnableDelayedExpansion
+for /F "usebackq delims=" %%a in ("%MAVEN_PROJECTBASEDIR%\.mvn\jvm.config") do set JVM_CONFIG_MAVEN_PROPS=!JVM_CONFIG_MAVEN_PROPS! %%a
+@endlocal & set JVM_CONFIG_MAVEN_PROPS=%JVM_CONFIG_MAVEN_PROPS%
+
+:endReadAdditionalConfig
+
+SET MAVEN_JAVA_EXE="%JAVA_HOME%\bin\java.exe"
+set WRAPPER_JAR="%MAVEN_PROJECTBASEDIR%\.mvn\wrapper\maven-wrapper.jar"
+set WRAPPER_LAUNCHER=org.apache.maven.wrapper.MavenWrapperMain
+
+set WRAPPER_URL="https://repo.maven.apache.org/maven2/org/apache/maven/wrapper/maven-wrapper/3.2.0/maven-wrapper-3.2.0.jar"
+
+FOR /F "usebackq tokens=1,2 delims==" %%A IN ("%MAVEN_PROJECTBASEDIR%\.mvn\wrapper\maven-wrapper.properties") DO (
+    IF "%%A"=="wrapperUrl" SET WRAPPER_URL=%%B
+)
+
+@REM Extension to allow automatically downloading the maven-wrapper.jar from Maven-central
+@REM This allows using the maven wrapper in projects that prohibit checking in binary data.
+if exist %WRAPPER_JAR% (
+    if "%MVNW_VERBOSE%" == "true" (
+        echo Found %WRAPPER_JAR%
+    )
+) else (
+    if not "%MVNW_REPOURL%" == "" (
+        SET WRAPPER_URL="%MVNW_REPOURL%/org/apache/maven/wrapper/maven-wrapper/3.2.0/maven-wrapper-3.2.0.jar"
+    )
+    if "%MVNW_VERBOSE%" == "true" (
+        echo Couldn't find %WRAPPER_JAR%, downloading it ...
+        echo Downloading from: %WRAPPER_URL%
+    )
+
+    powershell -Command "&{"^
+		"$webclient = new-object System.Net.WebClient;"^
+		"if (-not ([string]::IsNullOrEmpty('%MVNW_USERNAME%') -and [string]::IsNullOrEmpty('%MVNW_PASSWORD%'))) {"^
+		"$webclient.Credentials = new-object System.Net.NetworkCredential('%MVNW_USERNAME%', '%MVNW_PASSWORD%');"^
+		"}"^
+		"[Net.ServicePointManager]::SecurityProtocol = [Net.SecurityProtocolType]::Tls12; $webclient.DownloadFile('%WRAPPER_URL%', '%WRAPPER_JAR%')"^
+		"}"
+    if "%MVNW_VERBOSE%" == "true" (
+        echo Finished downloading %WRAPPER_JAR%
+    )
+)
+@REM End of extension
+
+@REM If specified, validate the SHA-256 sum of the Maven wrapper jar file
+SET WRAPPER_SHA_256_SUM=""
+FOR /F "usebackq tokens=1,2 delims==" %%A IN ("%MAVEN_PROJECTBASEDIR%\.mvn\wrapper\maven-wrapper.properties") DO (
+    IF "%%A"=="wrapperSha256Sum" SET WRAPPER_SHA_256_SUM=%%B
+)
+IF NOT %WRAPPER_SHA_256_SUM%=="" (
+    powershell -Command "&{"^
+       "$hash = (Get-FileHash \"%WRAPPER_JAR%\" -Algorithm SHA256).Hash.ToLower();"^
+       "If('%WRAPPER_SHA_256_SUM%' -ne $hash){"^
+       "  Write-Output 'Error: Failed to validate Maven wrapper SHA-256, your Maven wrapper might be compromised.';"^
+       "  Write-Output 'Investigate or delete %WRAPPER_JAR% to attempt a clean download.';"^
+       "  Write-Output 'If you updated your Maven version, you need to update the specified wrapperSha256Sum property.';"^
+       "  exit 1;"^
+       "}"^
+       "}"
+    if ERRORLEVEL 1 goto error
+)
+
+@REM Provide a "standardized" way to retrieve the CLI args that will
+@REM work with both Windows and non-Windows executions.
+set MAVEN_CMD_LINE_ARGS=%*
+
+%MAVEN_JAVA_EXE% ^
+  %JVM_CONFIG_MAVEN_PROPS% ^
+  %MAVEN_OPTS% ^
+  %MAVEN_DEBUG_OPTS% ^
+  -classpath %WRAPPER_JAR% ^
+  "-Dmaven.multiModuleProjectDirectory=%MAVEN_PROJECTBASEDIR%" ^
+  %WRAPPER_LAUNCHER% %MAVEN_CONFIG% %*
+if ERRORLEVEL 1 goto error
+goto end
+
+:error
+set ERROR_CODE=1
+
+:end
+@endlocal & set ERROR_CODE=%ERROR_CODE%
+
+if not "%MAVEN_SKIP_RC%"=="" goto skipRcPost
+@REM check for post script, once with legacy .bat ending and once with .cmd ending
+if exist "%USERPROFILE%\mavenrc_post.bat" call "%USERPROFILE%\mavenrc_post.bat"
+if exist "%USERPROFILE%\mavenrc_post.cmd" call "%USERPROFILE%\mavenrc_post.cmd"
+:skipRcPost
+
+@REM pause the script if MAVEN_BATCH_PAUSE is set to 'on'
+if "%MAVEN_BATCH_PAUSE%"=="on" pause
+
+if "%MAVEN_TERMINATE_CMD%"=="on" exit %ERROR_CODE%
+
+cmd /C exit /B %ERROR_CODE%

+ 112 - 0
pom.xml

@@ -0,0 +1,112 @@
+<?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 https://maven.apache.org/xsd/maven-4.0.0.xsd">
+	<modelVersion>4.0.0</modelVersion>
+	<parent>
+		<groupId>org.springframework.boot</groupId>
+		<artifactId>spring-boot-starter-parent</artifactId>
+		<version>3.1.4</version>
+		<relativePath/> <!-- lookup parent from repository -->
+	</parent>
+	<groupId>com.example</groupId>
+	<artifactId>uni</artifactId>
+	<version>0.0.1</version>
+	<name>uni</name>
+	<description>uni</description>
+	<properties>
+		<java.version>17</java.version>
+		<graalvm.version>23.0.1</graalvm.version>
+	</properties>
+	<dependencies>
+		<dependency>
+			<groupId>org.springframework.boot</groupId>
+			<artifactId>spring-boot-starter-actuator</artifactId>
+		</dependency>
+		<dependency>
+			<groupId>org.springframework.boot</groupId>
+			<artifactId>spring-boot-starter-webflux</artifactId>
+		</dependency>
+
+		<dependency>
+			<groupId>org.springframework.boot</groupId>
+			<artifactId>spring-boot-devtools</artifactId>
+			<scope>runtime</scope>
+			<optional>true</optional>
+		</dependency>
+		<dependency>
+			<groupId>com.h2database</groupId>
+			<artifactId>h2</artifactId>
+			<scope>runtime</scope>
+		</dependency>
+		<dependency>
+			<groupId>com.mysql</groupId>
+			<artifactId>mysql-connector-j</artifactId>
+			<scope>runtime</scope>
+		</dependency>
+		<dependency>
+			<groupId>org.springframework.boot</groupId>
+			<artifactId>spring-boot-starter-test</artifactId>
+			<scope>test</scope>
+		</dependency>
+		<dependency>
+			<groupId>io.projectreactor</groupId>
+			<artifactId>reactor-test</artifactId>
+			<scope>test</scope>
+		</dependency>
+        <dependency>
+            <groupId>org.apache.kafka</groupId>
+            <artifactId>kafka-clients</artifactId>
+        </dependency>
+		<dependency>
+			<groupId>com.ibm.mq</groupId>
+			<artifactId>com.ibm.mq.allclient</artifactId>
+			<version>9.3.2.0</version>
+		</dependency>
+		<dependency>
+			<groupId>co.elastic.clients</groupId>
+			<artifactId>elasticsearch-java</artifactId>
+		</dependency>
+		<dependency>
+			<groupId>com.rabbitmq</groupId>
+			<artifactId>amqp-client</artifactId>
+			<version>5.16.0</version>
+		</dependency>
+        <dependency>
+            <groupId>com.fasterxml.jackson.core</groupId>
+            <artifactId>jackson-databind</artifactId>
+        </dependency>
+		<dependency>
+			<groupId>commons-net</groupId>
+			<artifactId>commons-net</artifactId>
+			<version>3.9.0</version>
+		</dependency>
+		<dependency>
+			<groupId>org.graalvm.js</groupId>
+			<artifactId>js</artifactId>
+			<version>${graalvm.version}</version>
+		</dependency>
+		<dependency>
+			<groupId>com.zaxxer</groupId>
+			<artifactId>HikariCP</artifactId>
+		</dependency>
+		<dependency>
+			<groupId>org.xerial</groupId>
+			<artifactId>sqlite-jdbc</artifactId>
+			<version>3.42.0.0</version>
+		</dependency>
+		<dependency>
+			<groupId>org.springframework.boot</groupId>
+			<artifactId>spring-boot-starter-aop</artifactId>
+		</dependency>
+	</dependencies>
+
+	<build>
+		<plugins>
+			<plugin>
+				<groupId>org.springframework.boot</groupId>
+				<artifactId>spring-boot-maven-plugin</artifactId>
+			</plugin>
+		</plugins>
+	</build>
+
+</project>

+ 13 - 0
src/main/java/com/scbfkj/uni/UniApplication.java

@@ -0,0 +1,13 @@
+package com.scbfkj.uni;
+
+import org.springframework.boot.SpringApplication;
+import org.springframework.boot.autoconfigure.SpringBootApplication;
+
+@SpringBootApplication
+public class UniApplication {
+
+	public static void main(String[] args) {
+		SpringApplication.run(UniApplication.class, args);
+	}
+
+}

+ 7 - 0
src/main/java/com/scbfkj/uni/api/ControlApi.java

@@ -0,0 +1,7 @@
+package com.scbfkj.uni.api;
+
+import org.springframework.web.bind.annotation.RestController;
+
+@RestController
+public class ControlApi {
+}

+ 7 - 0
src/main/java/com/scbfkj/uni/api/DataProcessApi.java

@@ -0,0 +1,7 @@
+package com.scbfkj.uni.api;
+
+import org.springframework.web.bind.annotation.RestController;
+
+@RestController
+public class DataProcessApi {
+}

+ 7 - 0
src/main/java/com/scbfkj/uni/api/GenericApi.java

@@ -0,0 +1,7 @@
+package com.scbfkj.uni.api;
+
+import org.springframework.web.bind.annotation.RestController;
+
+@RestController
+public class GenericApi {
+}

+ 26 - 0
src/main/java/com/scbfkj/uni/api/LogAop.java

@@ -0,0 +1,26 @@
+package com.scbfkj.uni.api;
+
+import org.aspectj.lang.ProceedingJoinPoint;
+import org.aspectj.lang.annotation.Around;
+import org.aspectj.lang.annotation.Aspect;
+import org.aspectj.lang.annotation.Pointcut;
+import org.springframework.stereotype.Component;
+
+import java.util.Map;
+
+@Component
+@Aspect
+public class LogAop {
+
+    @Pointcut("within( com.scbfkj.uni.api.*)")
+    public void pointcut() {
+
+    }
+
+    @Around("pointcut() && args(body,params)")
+    public Object invoke(ProceedingJoinPoint joinPoint, Map<String, Object> body, Map<String, String> params) {
+//        todo 待实现
+        return null;
+    }
+
+}

+ 136 - 0
src/main/java/com/scbfkj/uni/api/SecurityApi.java

@@ -0,0 +1,136 @@
+package com.scbfkj.uni.api;
+
+import com.fasterxml.jackson.core.JsonProcessingException;
+import org.springframework.http.ResponseEntity;
+import org.springframework.http.server.reactive.ServerHttpRequest;
+import org.springframework.web.bind.annotation.PostMapping;
+import org.springframework.web.bind.annotation.RequestBody;
+import org.springframework.web.bind.annotation.RequestHeader;
+import org.springframework.web.bind.annotation.RestController;
+
+import java.util.Map;
+
+@RestController
+public class SecurityApi {
+
+
+    /**
+     * 获取appToken appToken
+     *
+     * @param headers
+     * @param body
+     * @return
+     */
+    @PostMapping("user/getToken")
+    public ResponseEntity getToken(@RequestHeader Map<String, Object> headers, @RequestBody Map<String, Object> body, ServerHttpRequest httpRequest) throws JsonProcessingException {
+        return ResponseEntity.ok(null);
+    }
+
+    /**
+     * 刷新appToken
+     *
+     * @param headers
+     * @return
+     */
+    @PostMapping("user/refreshToken")
+    public ResponseEntity refreshToken(@RequestHeader Map<String, Object> headers, ServerHttpRequest httpRequest) throws JsonProcessingException {
+        return ResponseEntity.ok(null);
+    }
+
+    /**
+     * 校验token 包含appToken 和用户token
+     *
+     * @param headers
+     * @param body
+     * @return
+     */
+    @PostMapping({"user/testToken", "foxlibc/testToken"})
+    public ResponseEntity testToken(@RequestHeader Map<String, Object> headers, @RequestBody Map<String, Object> body, ServerHttpRequest httpRequest) throws JsonProcessingException {
+        return ResponseEntity.ok(null);
+    }
+
+    /**
+     * 获取验证码
+     *
+     * @param headers
+     * @param body
+     * @return
+     */
+    @PostMapping({"user/verifyCode", "foxlibc/verification-code"})
+    public ResponseEntity getCode(@RequestHeader Map<String, Object> headers, @RequestBody Map<String, Object> body, ServerHttpRequest httpRequest) throws JsonProcessingException {
+        return ResponseEntity.ok(null);
+    }
+
+    /**
+     * 强制登录
+     *
+     * @param headers
+     * @param body
+     * @return
+     */
+    @PostMapping({"user/forceLogin", "foxlibc/force_sign"})
+    public ResponseEntity forceLogin(@RequestHeader Map<String, Object> headers, @RequestBody Map<String, Object> body, ServerHttpRequest httpRequest) throws JsonProcessingException {
+        return ResponseEntity.ok(null);
+    }
+
+    /**
+     * 登录
+     *
+     * @param headers
+     * @param body
+     * @return
+     */
+    @PostMapping({"user/login", "foxlibc/sign-in"})
+    public ResponseEntity login(@RequestHeader Map<String, Object> headers, @RequestBody Map<String, Object> body, ServerHttpRequest httpRequest) throws JsonProcessingException {
+        return ResponseEntity.ok(null);
+    }
+
+    /**
+     * 获取权限
+     *
+     * @param headers
+     * @param body
+     * @return
+     */
+    @PostMapping({"user/permissions", "foxlibc/permissions"})
+    public ResponseEntity getPermissions(@RequestHeader Map<String, Object> headers, @RequestBody Map<String, Object> body, ServerHttpRequest httpRequest) throws JsonProcessingException {
+        return ResponseEntity.ok(null);
+    }
+
+
+    /**
+     * 更改密码
+     *
+     * @param headers
+     * @param body
+     * @return
+     */
+    @PostMapping({"user/changePassword", "foxlibc/reset-passwd"})
+    public ResponseEntity changePwd(@RequestHeader Map<String, Object> headers, @RequestBody Map<String, Object> body, ServerHttpRequest httpRequest) throws JsonProcessingException {
+        return ResponseEntity.ok(null);
+    }
+
+    /**
+     * 登出注销
+     *
+     * @param headers
+     * @param body
+     * @return
+     */
+    @PostMapping({"user/logOut", "foxlibc/sign-out"})
+    public ResponseEntity logOut(@RequestHeader Map<String, Object> headers, @RequestBody Map<String, Object> body, ServerHttpRequest httpRequest) throws JsonProcessingException {
+        return ResponseEntity.ok(null);
+    }
+
+    /**
+     * 用户心跳检查   判断用户是否在线
+     *
+     * @param headers
+     * @param body
+     * @return
+     */
+    @PostMapping({"user/health", "foxlibc/health"})
+    public ResponseEntity health(@RequestHeader Map<String, Object> headers, @RequestBody Map<String, Object> body, ServerHttpRequest httpRequest) {
+        return ResponseEntity.ok(null);
+    }
+}

+ 18 - 0
src/main/java/com/scbfkj/uni/config/CorsConfig.java

@@ -0,0 +1,18 @@
+package com.scbfkj.uni.config;
+
+import org.springframework.context.annotation.Configuration;
+import org.springframework.web.reactive.config.CorsRegistry;
+import org.springframework.web.reactive.config.WebFluxConfigurer;
+
+@Configuration // 一定不要忽略此注解
+public class CorsConfig implements WebFluxConfigurer {
+    @Override
+    public void addCorsMappings(CorsRegistry registry) {
+        registry.addMapping("/**") // 所有接口
+                .allowCredentials(true) // 是否发送 Cookie
+                .allowedOriginPatterns("*") // 支持域
+                .allowedMethods(new String[]{"GET", "POST", "PUT", "DELETE"}) // 支持方法
+                .allowedHeaders("*")
+                .exposedHeaders("*");
+    }
+}

+ 41 - 0
src/main/java/com/scbfkj/uni/config/InitBeanConfig.java

@@ -0,0 +1,41 @@
+package com.scbfkj.uni.config;
+
+import com.oracle.truffle.js.runtime.builtins.temporal.TemporalYear;
+import com.scbfkj.uni.library.DataEncryptionUtil;
+import com.zaxxer.hikari.HikariConfig;
+import com.zaxxer.hikari.pool.HikariPool;
+import org.springframework.beans.factory.annotation.Value;
+import org.springframework.context.annotation.Bean;
+import org.springframework.context.annotation.Configuration;
+
+@Configuration
+public class InitBeanConfig {
+
+    @Value("${db.url:jdbc:h2:file:./center.h2}")
+    private String url;
+    @Value("${db.username}")
+    private String username;
+    @Value("${db.password}")
+    private String password;
+    @Value("${db.driver:org.h2.Driver}")
+    private String driver;
+
+    @Value("${cer.private-key}")
+    private String privateKeyStr;
+
+    private final String TYPE = "RSA";
+
+    private final String ALGORITHM = "RSA/ECB/PKCS1Padding";
+
+    @Bean("centerPool")
+    public HikariPool hikariPool() throws Exception {
+        HikariConfig hikariConfig = new HikariConfig();
+        hikariConfig.setJdbcUrl(DataEncryptionUtil.decryptByPrivateKey(url, privateKeyStr, TYPE, ALGORITHM));
+        hikariConfig.setUsername(username);
+        hikariConfig.setPassword(password);
+        hikariConfig.setDriverClassName(driver);
+        hikariConfig.setAutoCommit(false);
+        hikariConfig.setPoolName("center");
+        return new HikariPool(hikariConfig);
+    }
+}

+ 17 - 0
src/main/java/com/scbfkj/uni/library/CodeUtil.java

@@ -0,0 +1,17 @@
+package com.scbfkj.uni.library;
+
+import java.security.SecureRandom;
+
+public class CodeUtil {
+
+    private static final SecureRandom RANDOM = new SecureRandom();
+
+    public static String createCode(int size, String source) {
+        StringBuilder verifyCode = new StringBuilder(size);
+        int codesLen = source.length();
+        for (int i = 0; i < size; i++) {
+            verifyCode.append(source.charAt(RANDOM.nextInt(codesLen - 1)));
+        }
+        return verifyCode.toString();
+    }
+}

+ 4 - 0
src/main/java/com/scbfkj/uni/library/DataAliasGetUtil.java

@@ -0,0 +1,4 @@
+package com.scbfkj.uni.library;
+
+public class DataAliasGetUtil {
+}

+ 402 - 0
src/main/java/com/scbfkj/uni/library/DataEncryptionUtil.java

@@ -0,0 +1,402 @@
+package com.scbfkj.uni.library;
+
+import jakarta.annotation.Nonnull;
+
+import javax.crypto.BadPaddingException;
+import javax.crypto.Cipher;
+import javax.crypto.IllegalBlockSizeException;
+import javax.crypto.NoSuchPaddingException;
+import javax.crypto.spec.SecretKeySpec;
+import java.nio.charset.StandardCharsets;
+import java.security.*;
+import java.security.spec.InvalidKeySpecException;
+import java.security.spec.PKCS8EncodedKeySpec;
+import java.security.spec.X509EncodedKeySpec;
+import java.util.Base64;
+import java.util.Objects;
+
+public class DataEncryptionUtil {
+
+
+    /**
+     * 对给定的字符串进行加密操作
+     *
+     * @param source 原始字符串
+     * @param type   加密类型(BASE64、DES、3DES、AES、)
+     * @param key    密钥(用于DES、3DES、AES)
+     * @return 加密后的字符串
+     * @throws Exception 加密异常
+     */
+    public static String encrypt(String source, String type, String key) throws Exception {
+        switch (type.toUpperCase()) {
+            case "BASE64" -> {
+                return encryptBase64(source);
+            }
+            case "DES" -> {
+                return encryptDES(source, key);
+
+            }
+            case "3DES" -> {
+                return encrypt3DES(source, key);
+
+            }
+            case "AES" -> {
+                return encryptAES(source, key);
+
+            }
+            default -> {
+                return null;
+            }
+        }
+    }
+
+    /**
+     * 对给定的字符串进行解密操作
+     *
+     * @param source 加密后的字符串
+     * @param type   解密类型(BASE64、DES、3DES、AES、RSA)
+     * @param key    密钥(用于DES、3DES、AES、RSA加密)
+     * @return 解密后的字符串
+     * @throws Exception 解密异常
+     */
+    public static String decrypt(String source, String type, String key) throws Exception {
+        switch (type.toUpperCase()) {
+            case "BASE64" -> {
+                return decryptBase64(source);
+            }
+            case "DES" -> {
+                return decryptDES(source, key);
+            }
+            case "3DES" -> {
+                return decrypt3DES(source, key);
+            }
+            case "AES" -> {
+                return decryptAES(source, key);
+            }
+            default -> {
+                return null;
+            }
+        }
+    }
+
+    /**
+     * 使用Base64编码对数据进行加密
+     *
+     * @param data 待加密的数据
+     * @return 加密后的数据
+     */
+    private static String encryptBase64(String data) {
+        return Base64.getEncoder().encodeToString(data.getBytes(StandardCharsets.UTF_8));
+    }
+
+    /**
+     * 使用Base64解密数据
+     *
+     * @param data 要解密的数据
+     * @return 解密后的字符串
+     */
+    private static String decryptBase64(String data) {
+        return new String(Base64.getDecoder().decode(data));
+    }
+
+    private static byte[] encryptByType(byte[] data, String type, String key, String algorithm) throws NoSuchPaddingException, NoSuchAlgorithmException, InvalidKeyException, IllegalBlockSizeException, BadPaddingException {
+// 创建AES加密算法实例
+        Cipher cipher = Cipher.getInstance(algorithm);
+
+        // 创建密钥规则
+        SecretKeySpec secretKeySpec = new SecretKeySpec(key.getBytes(), type);
+
+        // 初始化加密模式
+        cipher.init(Cipher.ENCRYPT_MODE, secretKeySpec);
+
+        // 执行加密操作
+        return cipher.doFinal(data);
+    }
+
+    private static byte[] decryptByType(byte[] encryptedData, String type, String key, String algorithm) throws Exception {
+        // 创建AES解密算法实例
+        Cipher cipher = Cipher.getInstance(algorithm);
+
+        // 创建密钥规则
+        SecretKeySpec secretKeySpec = new SecretKeySpec(key.getBytes(), type);
+
+        // 初始化解密模式
+        cipher.init(Cipher.DECRYPT_MODE, secretKeySpec);
+
+        // 执行解密操作
+        byte[] decryptedBytes = cipher.doFinal(encryptedData);
+
+        // 将解密后的字节数组转换为字符串
+
+        return decryptedBytes;
+    }
+
+    /**
+     * 使用DES算法对数据进行加密
+     *
+     * @param data 要加密的数据
+     * @param key  加密密钥
+     * @return 加密后的数据,以Base64编码的字符串形式返回
+     * @throws Exception 加密过程中可能抛出的异常
+     */
+    private static String encryptDES(String data, String key) throws Exception {
+        // 将加密后的字节数组转换为Base64编码的字符串
+        return Base64.getEncoder().encodeToString(encryptByType(data.getBytes(), "DES", key, "DES/ECB/PKCS5Padding"));
+    }
+
+    private static String decryptDES(String encryptedData, String key) throws Exception {
+        // 将解密后的字节数组转换为字符串
+        return new String(decryptByType(Base64.getDecoder().decode(encryptedData), "DES", key, "DES/ECB/PKCS5Padding"));
+    }
+
+    private static String encryptAES(String data, String key) throws Exception {
+        return Base64.getEncoder().encodeToString(encryptByType(data.getBytes(), "AES", key, "AES/ECB/PKCS5Padding"));
+    }
+
+    private static String decryptAES(String encryptedData, String key) throws Exception {
+        return new String(decryptByType(Base64.getDecoder().decode(encryptedData), "AES", key, "AES/ECB/PKCS5Padding"));
+    }
+
+    private static String encrypt3DES(String data, String key) throws Exception {
+        return Base64.getEncoder().encodeToString(encryptByType(data.getBytes(), "DESede", key, "DESede/ECB/PKCS5Padding"));
+    }
+
+    private static String decrypt3DES(String encryptedData, String key) throws Exception {
+        return new String(decryptByType(Base64.getDecoder().decode(encryptedData), "DESede", key, "DESede/ECB/PKCS5Padding"));
+    }
+
+    private static byte[] doFinalByKeyStr(int mode, byte[] data, String keyStr, String type, String algorithm, int opmode) throws NoSuchAlgorithmException, InvalidKeySpecException, NoSuchPaddingException, InvalidKeyException, IllegalBlockSizeException, BadPaddingException {
+
+        //根据转换的名称获取密码对象Cipher(转换的名称:算法/工作模式/填充模式)
+        Cipher cipher = Cipher.getInstance(algorithm);
+
+        switch (mode) {
+            case 1 -> {
+                //根据PKCS8编码密钥规范产生私钥对象
+                PrivateKey privateKey = getPrivateKey(keyStr, checkType(type));
+                //用私钥初始化此Cipher对象(解密模式)
+                cipher.init(opmode, privateKey);
+            }
+            default -> {
+                //根据PKCS8编码密钥规范产生私钥对象
+                PublicKey publicKey = getPublicKey(keyStr, checkType(type));
+                //用私钥初始化此Cipher对象(解密模式)
+                cipher.init(opmode, publicKey);
+            }
+        }
+
+        return cipher.doFinal(data);
+    }
+
+    /**
+     * 公钥加密(用于数据加密)
+     *
+     * @param data         加密前的字符串
+     * @param publicKeyStr base64编码后的公钥
+     * @return base64编码后的字符串
+     * @throws Exception
+     */
+    public static String encryptByPublicKey(@Nonnull String data, @Nonnull String publicKeyStr, @Nonnull String type, @Nonnull String algorithm) throws Exception {
+        //返回base64编码后的字符串
+        return Base64.getEncoder().encodeToString(doFinalByKeyStr(0, data.getBytes(), publicKeyStr, type, algorithm, Cipher.ENCRYPT_MODE));
+    }
+
+
+    /**
+     * 私钥解密(用于数据解密)
+     *
+     * @param data          解密前的字符串
+     * @param privateKeyStr 私钥
+     * @return 解密后的字符串
+     * @throws Exception
+     */
+    public static String decryptByPrivateKey(@Nonnull String data, @Nonnull String privateKeyStr, @Nonnull String type, @Nonnull String algorithm) throws Exception {
+        return new String(doFinalByKeyStr(1, Base64.getDecoder().decode(data), privateKeyStr, type, algorithm, Cipher.DECRYPT_MODE));
+
+    }
+
+
+    /**
+     * 私钥加密(用于数据加密)
+     *
+     * @param data          加密前的字符串
+     * @param privateKeyStr base64编码后的私钥
+     * @return base64编码后的字符串
+     * @throws Exception
+     */
+    public static String encryptByPrivateKey(@Nonnull String data, @Nonnull String privateKeyStr, @Nonnull String type, @Nonnull String algorithm) throws Exception {
+        return Base64.getEncoder().encodeToString(doFinalByKeyStr(1, data.getBytes(), privateKeyStr, type, algorithm, Cipher.ENCRYPT_MODE));
+    }
+
+    /**
+     * 公钥解密(用于数据解密)
+     *
+     * @param data         解密前的字符串
+     * @param publicKeyStr 公钥
+     * @return 解密后的字符串
+     * @throws Exception
+     */
+    public static String decryptByPublicKey(@Nonnull String data, @Nonnull String publicKeyStr, @Nonnull String type, @Nonnull String algorithm) throws Exception {
+        return new String(doFinalByKeyStr(0, Base64.getDecoder().decode(data), publicKeyStr, type, algorithm, Cipher.DECRYPT_MODE));
+    }
+
+
+    public static String signatureSHA(String data, String algorithm) throws NoSuchAlgorithmException {
+        // 创建MessageDigest对象,指定使用SHA算法
+        MessageDigest md = MessageDigest.getInstance(checkSHAAlgorithm(algorithm));
+
+        // 将数据转换为字节数组
+        byte[] dataBytes = data.getBytes();
+
+        // 执行加密操作
+        byte[] encryptedBytes = md.digest(dataBytes);
+
+        // 将加密后的字节数组转换为十六进制字符串
+        StringBuilder sb = new StringBuilder();
+        for (byte b : encryptedBytes) {
+            sb.append(String.format("%02x", b));
+        }
+
+        return sb.toString();
+    }
+
+
+    public static boolean verifySHA(String encryptedData, String algorithm, String sourceData) throws Exception {
+        return signatureSHA(sourceData, checkSHAAlgorithm(algorithm)).equals(encryptedData);
+    }
+
+
+    public static String signatureMD5(String data) throws NoSuchAlgorithmException {
+        // 创建MessageDigest对象,指定使用MD5算法
+        MessageDigest md = MessageDigest.getInstance("MD5");
+
+        // 将数据转换为字节数组
+        byte[] dataBytes = data.getBytes();
+
+        // 执行加密操作
+        byte[] encryptedBytes = md.digest(dataBytes);
+
+        // 将加密后的字节数组转换为十六进制字符串
+        StringBuilder sb = new StringBuilder();
+        for (byte b : encryptedBytes) {
+            sb.append(String.format("%02x", b));
+        }
+
+        return sb.toString();
+    }
+
+    public static boolean verifyMD5(String data, String encryptedData) throws NoSuchAlgorithmException {
+        return signatureMD5(data).equals(encryptedData);
+    }
+
+
+    private static PublicKey getPublicKey(String publicKeyStr, String type) throws NoSuchAlgorithmException, InvalidKeySpecException {
+        X509EncodedKeySpec keySpec = new X509EncodedKeySpec(Base64.getDecoder().decode(publicKeyStr.getBytes()));
+        KeyFactory keyFactory = KeyFactory.getInstance(type);
+        return keyFactory.generatePublic(keySpec);
+    }
+
+    private static PrivateKey getPrivateKey(String privateKeyStr, String type) throws NoSuchAlgorithmException, InvalidKeySpecException {
+        PKCS8EncodedKeySpec keySpec = new PKCS8EncodedKeySpec(Base64.getDecoder().decode(privateKeyStr.getBytes()));
+        KeyFactory keyFactory = KeyFactory.getInstance(type);
+        return keyFactory.generatePrivate(keySpec);
+    }
+
+
+    /**
+     * RSA签名
+     *
+     * @param data      待签名数据
+     * @param priKey    私钥
+     * @param type      RSA或DSA
+     * @param algorithm SHA1或256
+     * @return 签名
+     * @throws Exception
+     */
+    public static String sign(String data, String priKey, String type, String algorithm) throws Exception {
+        return sign(data.getBytes(), Base64.getDecoder().decode(priKey), type, algorithm);
+    }
+
+    private static String sign(byte[] data, byte[] priKey, String type, String algorithm) throws Exception {
+        //创建PKCS8编码密钥规范
+        PKCS8EncodedKeySpec pkcs8KeySpec = new PKCS8EncodedKeySpec(priKey);
+        //返回转换指定算法的KeyFactory对象
+        KeyFactory keyFactory = KeyFactory.getInstance(checkSingType(type));
+        //根据PKCS8编码密钥规范产生私钥对象
+        PrivateKey privateKey = keyFactory.generatePrivate(pkcs8KeySpec);
+        //用指定算法产生签名对象Signature
+        Signature signature = Signature.getInstance(algorithm);
+        //用私钥初始化签名对象Signature
+        signature.initSign(privateKey);
+        //将待签名的数据传送给签名对象(须在初始化之后)
+        signature.update(data);
+        //返回签名结果字节数组
+        byte[] sign = signature.sign();
+        //返回Base64编码后的字符串
+        return Base64.getEncoder().encodeToString(sign);
+    }
+
+    /**
+     * RSA校验数字签名
+     *
+     * @param data      待校验数据
+     * @param sign      数字签名
+     * @param pubKey    公钥
+     * @param type      RSA或DSA
+     * @param algorithm SHA1或256
+     * @return boolean 校验成功返回true,失败返回false
+     */
+    public static boolean verify(String data, String sign, String pubKey, String type, String algorithm) throws Exception {
+        return verify(data.getBytes(), Base64.getDecoder().decode(sign), Base64.getDecoder().decode(pubKey), type, algorithm);
+    }
+
+    private static boolean verify(byte[] data, byte[] sign, byte[] pubKey, String type, String algorithm) throws Exception {
+        //返回转换指定算法的KeyFactory对象
+        KeyFactory keyFactory = KeyFactory.getInstance(checkSingType(type));
+        //创建X509编码密钥规范
+        X509EncodedKeySpec x509KeySpec = new X509EncodedKeySpec(pubKey);
+        //根据X509编码密钥规范产生公钥对象
+        PublicKey publicKey = keyFactory.generatePublic(x509KeySpec);
+        //用指定算法产生签名对象Signature
+        Signature signature = Signature.getInstance(algorithm);
+        //用公钥初始化签名对象,用于验证签名
+        signature.initVerify(publicKey);
+        //更新签名内容
+        signature.update(data);
+        //得到验证结果
+        return signature.verify(sign);
+    }
+
+
+    private static String checkType(String type) {
+        if (Objects.isNull(type)) return "RSA";
+        if (type.equalsIgnoreCase("RSA")) {
+            return type.toUpperCase();
+        }
+        return "RSA";
+    }
+
+    private static String checkSingType(String type) {
+        if (Objects.isNull(type)) return "RSA";
+        switch (type.toUpperCase()) {
+            case "RSA", "DSA" -> {
+                return type.toUpperCase();
+            }
+            default -> {
+                return "RSA";
+            }
+        }
+    }
+
+    private static String checkSHAAlgorithm(String algorithm) {
+        if (Objects.isNull(algorithm)) return "SHA-256";
+        switch (algorithm.toUpperCase()) {
+            case "SHA-256", "SHA-1", "SHA-224", "SHA-384", "SHA-512" -> {
+                return algorithm.toUpperCase();
+            }
+            default -> {
+                return "SHA-256";
+            }
+        }
+    }
+}

+ 4 - 0
src/main/java/com/scbfkj/uni/library/DataFormatUtil.java

@@ -0,0 +1,4 @@
+package com.scbfkj.uni.library;
+
+public class DataFormatUtil {
+}

+ 4 - 0
src/main/java/com/scbfkj/uni/library/FileUtil.java

@@ -0,0 +1,4 @@
+package com.scbfkj.uni.library;
+
+public class FileUtil {
+}

+ 76 - 0
src/main/java/com/scbfkj/uni/library/ImageUtil.java

@@ -0,0 +1,76 @@
+package com.scbfkj.uni.library;
+
+import org.springframework.core.io.ClassPathResource;
+
+import javax.imageio.ImageIO;
+import java.awt.*;
+import java.awt.image.BufferedImage;
+import java.io.ByteArrayOutputStream;
+import java.io.File;
+import java.io.IOException;
+import java.security.SecureRandom;
+import java.util.Base64;
+
+public class ImageUtil {
+
+    private static final int WIDTH = 120; // 图片宽度
+    private static final int HEIGHT = 45; // 图片高度
+    private static final String IMAGE_FORMAT = "JPG";
+    private static final Color[] COLORS = new Color[]{
+            new Color(0, 0, 255),
+            new Color(0, 255, 0),
+            new Color(255, 0, 0)
+    };
+    private static final SecureRandom RANDOM = new SecureRandom();
+
+
+    public static String stringToImage(String code) throws IOException, FontFormatException {
+        try (ByteArrayOutputStream outputStream = new ByteArrayOutputStream()) {
+            BufferedImage image = createImage(code);
+            ImageIO.write(image, IMAGE_FORMAT, outputStream);
+
+            byte[] data = outputStream.toByteArray();
+            return "data:image/" + IMAGE_FORMAT + ";base64," + Base64.getEncoder().encodeToString(data);
+        }
+    }
+
+    private static BufferedImage createImage(String verifyCode) throws IOException, FontFormatException {
+        BufferedImage image = new BufferedImage(WIDTH, HEIGHT, BufferedImage.TYPE_INT_RGB);
+        Graphics graphics = image.getGraphics();
+
+        graphics.setColor(Color.WHITE);
+        graphics.fillRect(0, 0, WIDTH, HEIGHT);
+
+
+        Font font = graphics.getFont();
+        if (font == null) {
+            File fontFile = new ClassPathResource("font/SourceHanSansSC-Regular-2.otf").getFile();
+            font = Font.createFont(Font.TRUETYPE_FONT, fontFile);
+        }
+        font  = font.deriveFont((float) (HEIGHT - 10));
+        graphics.setFont(font);
+
+        int desX, desY, distance = 16;
+        for (int i = 0; i < verifyCode.length(); i++) {
+            graphics.setColor(COLORS[RANDOM.nextInt(COLORS.length)]);
+            desX = (i + 1) * distance;
+            desY = distance + RANDOM.nextInt(HEIGHT - 2 * distance);
+            graphics.drawString(Character.toString(verifyCode.charAt(i)), desX, desY);
+        }
+
+        for (int x = 0; x < 150; x++) {
+            graphics.setColor(getRandomColor());
+            graphics.drawOval(RANDOM.nextInt(WIDTH), RANDOM.nextInt(HEIGHT), 1, 1);
+        }
+
+        graphics.dispose();
+        return image;
+    }
+
+    private static Color getRandomColor() {
+        int r = RANDOM.nextInt(256);
+        int g = RANDOM.nextInt(256);
+        int b = RANDOM.nextInt(256);
+        return new Color(r, g, b);
+    }
+}

+ 4 - 0
src/main/java/com/scbfkj/uni/library/ScriptEngineUtil.java

@@ -0,0 +1,4 @@
+package com.scbfkj.uni.library;
+
+public class ScriptEngineUtil {
+}

+ 53 - 0
src/main/java/com/scbfkj/uni/library/UniReturnUtil.java

@@ -0,0 +1,53 @@
+package com.scbfkj.uni.library;
+
+import java.util.HashMap;
+import java.util.Map;
+import java.util.Objects;
+
+public class UniReturnUtil {
+
+    public Map<String, Object> success(Object data) {
+        HashMap<String, Object> result = new HashMap<>();
+        result.put("code", "0");
+
+        return result;
+    }
+
+    public Map<String, Object> success(Object data, Map<String, Object> other) {
+        Map<String, Object> result = success(data);
+        if (Objects.nonNull(other)) {
+            result.putAll(other);
+        }
+        return result;
+    }
+
+    public Map<String, Object> fail(String message, Map<String, Object> other) {
+        Map<String, Object> result = fail(message);
+        if (Objects.nonNull(other)) {
+            result.putAll(other);
+        }
+        return result;
+    }
+
+    public Map<String, Object> fail(String message) {
+        HashMap<String, Object> result = new HashMap<>();
+        result.put("message", message);
+        result.put("code", "-1");
+        return result;
+    }
+
+    public Map<String, Object> fail(String code, String message, Map<String, Object> other) {
+        Map<String, Object> result = fail(code, message);
+        if (Objects.nonNull(other)) {
+            result.putAll(other);
+        }
+        return result;
+    }
+
+    public Map<String, Object> fail(String code, String message) {
+        HashMap<String, Object> result = new HashMap<>();
+        result.put("message", message);
+        result.put("code", code);
+        return result;
+    }
+}

+ 22 - 0
src/main/java/com/scbfkj/uni/process/DataBase.java

@@ -0,0 +1,22 @@
+package com.scbfkj.uni.process;
+
+import com.zaxxer.hikari.pool.HikariPool;
+
+import java.util.ArrayList;
+import java.util.List;
+import java.util.Map;
+
+public class DataBase {
+
+    public static List<Map<String, Object>> query(HikariPool pool, String sql, List<Object[]> argsList) {
+        return new ArrayList<>();
+    }
+
+    public static int[] updateBatch(HikariPool pool, String sql, List<Object[]> argsList) {
+        return new int[]{};
+    }
+    public static int[] exec(HikariPool pool, String sql) {
+        return new int[]{};
+    }
+
+}

+ 4 - 0
src/main/java/com/scbfkj/uni/process/Elasticsearch.java

@@ -0,0 +1,4 @@
+package com.scbfkj.uni.process;
+
+public class Elasticsearch {
+}

+ 4 - 0
src/main/java/com/scbfkj/uni/process/FTP.java

@@ -0,0 +1,4 @@
+package com.scbfkj.uni.process;
+
+public class FTP {
+}

+ 4 - 0
src/main/java/com/scbfkj/uni/process/IBMMQ.java

@@ -0,0 +1,4 @@
+package com.scbfkj.uni.process;
+
+public class IBMMQ {
+}

+ 4 - 0
src/main/java/com/scbfkj/uni/process/Kafka.java

@@ -0,0 +1,4 @@
+package com.scbfkj.uni.process;
+
+public class Kafka {
+}

+ 4 - 0
src/main/java/com/scbfkj/uni/process/RabbitMq.java

@@ -0,0 +1,4 @@
+package com.scbfkj.uni.process;
+
+public class RabbitMq {
+}

+ 4 - 0
src/main/java/com/scbfkj/uni/process/Web.java

@@ -0,0 +1,4 @@
+package com.scbfkj.uni.process;
+
+public class Web {
+}

+ 4 - 0
src/main/java/com/scbfkj/uni/service/ControlService.java

@@ -0,0 +1,4 @@
+package com.scbfkj.uni.service;
+
+public class ControlService {
+}

+ 4 - 0
src/main/java/com/scbfkj/uni/service/DataProcessService.java

@@ -0,0 +1,4 @@
+package com.scbfkj.uni.service;
+
+public class DataProcessService {
+}

+ 4 - 0
src/main/java/com/scbfkj/uni/service/LoggerService.java

@@ -0,0 +1,4 @@
+package com.scbfkj.uni.service;
+
+public class LoggerService {
+}

+ 4 - 0
src/main/java/com/scbfkj/uni/service/SecurityService.java

@@ -0,0 +1,4 @@
+package com.scbfkj.uni.service;
+
+public class SecurityService {
+}

+ 4 - 0
src/main/java/com/scbfkj/uni/system/Config.java

@@ -0,0 +1,4 @@
+package com.scbfkj.uni.system;
+
+public class Config {
+}

+ 4 - 0
src/main/java/com/scbfkj/uni/system/ScheduleTask.java

@@ -0,0 +1,4 @@
+package com.scbfkj.uni.system;
+
+public class ScheduleTask {
+}

+ 4 - 0
src/main/java/com/scbfkj/uni/system/ScheduleUtil.java

@@ -0,0 +1,4 @@
+package com.scbfkj.uni.system;
+
+public class ScheduleUtil {
+}

+ 51 - 0
src/main/java/com/scbfkj/uni/system/SpringContextApplication.java

@@ -0,0 +1,51 @@
+package com.scbfkj.uni.system;
+
+import org.springframework.beans.BeansException;
+import org.springframework.beans.factory.support.BeanDefinitionBuilder;
+import org.springframework.beans.factory.support.DefaultListableBeanFactory;
+import org.springframework.context.ApplicationContext;
+import org.springframework.context.ApplicationContextAware;
+import org.springframework.context.ConfigurableApplicationContext;
+import org.springframework.stereotype.Component;
+
+/**
+ * 用于获取Bean对象
+ */
+@Component
+public class SpringContextApplication implements ApplicationContextAware {
+    private static ApplicationContext applicationContext;
+
+    @Override
+    public void setApplicationContext(ApplicationContext applicationContext) throws BeansException {
+        SpringContextApplication.applicationContext = applicationContext;
+    }
+
+    @SuppressWarnings("unchecked")
+    public static <T> T getBean(String beanName) throws BeansException {
+        return (T) applicationContext.getBean(beanName);
+    }
+
+
+    /**
+     * 动态注入单例bean实例
+     *
+     * @param beanName        bean名称
+     * @param singletonObject 单例bean实例
+     * @return 注入实例
+     */
+    public static Object registerSingletonBean(String beanName, Object singletonObject) {
+
+        //将applicationContext转换为ConfigurableApplicationContext
+        ConfigurableApplicationContext configurableApplicationContext = (ConfigurableApplicationContext) applicationContext;
+
+        //获取BeanFactory
+        DefaultListableBeanFactory defaultListableBeanFactory = (DefaultListableBeanFactory) configurableApplicationContext.getAutowireCapableBeanFactory();
+
+        //动态注册bean.
+        defaultListableBeanFactory.registerSingleton(beanName, singletonObject);
+
+        //获取动态注册的bean.
+        return configurableApplicationContext.getBean(beanName);
+    }
+
+}

+ 16 - 0
src/main/java/com/scbfkj/uni/system/SystemInit.java

@@ -0,0 +1,16 @@
+package com.scbfkj.uni.system;
+
+import jakarta.annotation.PostConstruct;
+import org.springframework.stereotype.Component;
+
+@Component
+public class SystemInit  {
+
+
+    @PostConstruct
+    public void init(){
+
+
+
+    }
+}

+ 4 - 0
src/main/resources/application.properties

@@ -0,0 +1,4 @@
+db.url=XwvGDpBZSBmSSTgwYR/tP7TpjDOvxCbfcglDFj++b1Fedp1LiiAhzeXvfe2025PchJIJuMDp6u0fxe24i8VfQxYG8MY2n8tyiQftih0drHi8OA7dqB8pEtZm5xs1d3kYSt2Q1ffs8fmnJC7aRkmJSk+urgyS/M1q70B3ikpMkKs=
+db.driver=org.h2.Driver
+cer.public-key=MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQCfbyuRrG+YUX7dy/ziNqxsPP7YPKUnti+m3yDfJdN2MKa1GcIvPkfIXZ5EfEkoI9m5NwPfeC+kwM1fDWxvY/oMo/lWpIAo2zkhxssIXSkukF79I0N4vH+JAcuHN7llPYgMGkkyIe/FP/A1ZkGEayjMMqm4cfPs3vthsWgdmbnxHwIDAQAB
+cer.private-key=MIICdgIBADANBgkqhkiG9w0BAQEFAASCAmAwggJcAgEAAoGBAJ9vK5Gsb5hRft3L/OI2rGw8/tg8pSe2L6bfIN8l03YwprUZwi8+R8hdnkR8SSgj2bk3A994L6TAzV8NbG9j+gyj+VakgCjbOSHGywhdKS6QXv0jQ3i8f4kBy4c3uWU9iAwaSTIh78U/8DVmQYRrKMwyqbhx8+ze+2GxaB2ZufEfAgMBAAECgYAyMdTcuxYzNU0k1SkbqyzjstxlBcrVUtVzywHVX1pQ9oY1tBNfvlLpMRg35Y0+tvLADiMJAxS04QKHb3l5JFe/jE24hNxMj2h9JfxO36bGblyqZ7PlS+5/pvXdVaFYolN+5Rocf63/Iq2RSCb8W3D5uUQqLwO/i1iFQT+UROUA4QJBAOvvOJSB4BIu4VD/6XGqZ5cLU3DMtwzHIyvTTH2REGF33eEHc0z83VYi4xbUDGxvDD1d58bPqkpnvJiByXmYVa8CQQCs/mHfpO8fDy7ZKGzs1u4eBsPowSnJLsGbY2mYiaawnHeeLYOaGEdtxRVk06+seTFLw5oi3FDJG8U8LP6FiGeRAkAjZiQeHBJrh/8kcREsjb23KurdDMoWL7a2N6DNYjuL9DklL0H8diAbcWaTIUOv7UVv26wP506MlV31n9uD0/hfAkBo3gwWtrT97wZHPepJ6ECQkylPf0kFXAKhX7Izdb5GcZNRn+WXFAC42jAN3wUvWIg5lWlqmIOgZeU6hUwFRpsBAkEAsSe8v0cho1YTdmXiGQ7uhUxZ455mrw81AdzmuvDxvWFLx1uHAZna9eylZsfbEa7Y9DcmakLJKGWaTvKvYc55ZQ==

+ 223 - 0
src/main/resources/schema/V1__init.sql

@@ -0,0 +1,223 @@
+create table apiinfo
+(
+    apiid       int auto_increment comment '自增长主键'
+        primary key,
+    apiname     varchar(255) null comment 'api名称',
+    apitype     varchar(255) null comment '类型(外部api、内部方法、服务)',
+    requestpath varchar(255) null comment '请求路径',
+    routepath   varchar(255) null comment '转发路径(外部api完整路径、带类名的内部方法名、服务编号)'
+);
+
+create table appconnectlog
+(
+    connid      int auto_increment comment '自增主键'
+        primary key,
+    appid       varchar(16) null comment '应用编码',
+    requesttime datetime    null comment '连接时间',
+    requestip   varchar(32) null comment '请求ip',
+    apptoken    varchar(64) null comment 'app连接token',
+    expiretime  datetime    null comment 'token过期时间',
+    lasttime    datetime    null comment '最后活跃时间'
+);
+
+create table application
+(
+    applicationid         int auto_increment comment '自增主键'
+        primary key,
+    appid                 varchar(16)  null comment '应用编码',
+    appsecret             varchar(32)  null comment '应用密钥',
+    appname               varchar(64)  null comment '应用名称',
+    appengname            varchar(128) null comment '应用英文名称',
+    appdescribe           varchar(256) null comment '应用描述',
+    applogo               varchar(256) null comment '应用图标',
+    smalllogo             varchar(256) null comment '应用小图标',
+    backgroundimage       varchar(256) null comment '背景图',
+    apptokeneffective     int          null comment '应用令牌有效时长(分钟,从连接起)',
+    securitycoderule      varchar(128) null comment '验证码规则',
+    securitycodeeffective int          null comment '验证码有效时长(秒)',
+    multilogin            int          null comment '是否允许多机登录',
+    passwordrule          varchar(128) null comment '密码规则',
+    passwordeffective     int          null comment '密码过期时长'
+);
+
+create table applicationpermissions
+(
+    applicationpermissionsid int auto_increment comment '自增长主键应用api权限编号'
+        primary key,
+    appid                    int          null comment 'app编号',
+    apiid                    int          null comment 'api编号',
+    columnlist               varchar(200) null comment '列权限',
+    filterset                varchar(200) null comment '行权限'
+);
+
+create table breakerrule
+(
+    breakerruleid        int auto_increment comment '自增长主键熔断策略编号'
+        primary key,
+    breakerrulename      varchar(50)   null comment '策略名',
+    duration             int           null comment '单位时间(秒)',
+    limitvalue           int           null comment '流量上限',
+    averageerrorrate     decimal(5, 2) null comment '平均错误率',
+    errorcount           int           null comment '错误次数',
+    averageexecutiontime int           null comment '平均执行时长',
+    returnmessage        varchar(100)  null comment '超限熔断返回提示'
+);
+
+create table container
+(
+    containerid       int auto_increment comment '自增长主键容器编号'
+        primary key,
+    containercode     varchar(50)  null comment '运行实例编号',
+    containername     varchar(50)  null comment '名称',
+    containerdescribe varchar(200) null comment '用途说明',
+    requesturi        varchar(200) null comment '访问路径',
+    containervesion   varchar(50)  null comment '版本号',
+    runstate          varchar(20)  null comment '当前状态',
+    lasttime          datetime     null comment '最后活跃时间'
+);
+
+create table datasource
+(
+    datasourceid       int auto_increment comment '自增长主键'
+        primary key,
+    datasourcedescribe varchar(200) null comment '数据源说明',
+    connectset         varchar(200) null comment '连接字符串'
+);
+
+create table pageconfiguration
+(
+    pageconfigurationid int auto_increment comment '自增长主键界面配置编号'
+        primary key,
+    pagetype            varchar(50)  null comment '类型(模块、页面、按钮、表格)',
+    superiorid          int          null comment '页面配置上级编号',
+    pagename            varchar(50)  null comment '名称',
+    pagecode            varchar(50)  null comment '界面控件编码',
+    pagedescribe        varchar(200) null comment '描述',
+    serviceid           int          null comment '绑定服务编号'
+);
+
+create table ratelimitrule
+(
+    ratelimitingid   int auto_increment comment '自增长主键限流策略编号'
+        primary key,
+    ratelimitingname varchar(50)  null comment '策略名',
+    duration         int          null comment '单位时间(秒)',
+    limitvalue       int          null comment '流量上限',
+    returnmessage    varchar(100) null comment '超限保护返回提示',
+    apiid            varchar(100) null comment 'api编号'
+);
+
+create table servicestate
+(
+    servicestateid int auto_increment comment '自增长主键'
+        primary key,
+    serviceid      int         null comment '服务编号',
+    containerid    int         null comment '容器编号',
+    containercode  varchar(50) null comment '运行实例编号',
+    starttime      datetime    null comment '启动时间',
+    stoptime       datetime    null comment '停止时间',
+    runstate       varchar(20) null comment '当前状态',
+    lasttime       datetime    null comment '最后活跃时间'
+);
+
+create table tableconfiguration
+(
+    tableconfigurationid int auto_increment comment '自增长主键表格配置编号'
+        primary key,
+    pagecode             varchar(50)  null,
+    columnname           varchar(50)  null comment '列名',
+    columncode           varchar(50)  null comment '列标识',
+    groupname            varchar(50)  null comment '上级分组名称',
+    columndescribe       varchar(200) null comment '列描述',
+    datatype             varchar(50)  null comment '数据类型',
+    datalength           int          null comment '数据长度',
+    isdisplay            int          null comment '是否显示',
+    displaynumber        int          null comment '显示顺序',
+    displaywidth         int          null comment '显示宽度',
+    enablesort           int          null comment '启用排序',
+    enablefilter         int          null comment '启用过滤',
+    enablegroup          int          null comment '启用分组',
+    enablecount          int          null comment '启用计算',
+    isfiltercolumn       int          null comment '是否为过滤列',
+    isprimarykey         int          null comment '是否为主键',
+    defaultparameters    varchar(200) null comment '默认查询参数'
+);
+
+create table tempsecuritycode
+(
+    codeid       int auto_increment comment '自增主键'
+        primary key,
+    appid        varchar(16) null comment '应用编码',
+    requestip    varchar(32) null comment '请求ip',
+    sessionid    varchar(64) null comment '连接sessionid',
+    securitycode varchar(8)  null comment '验证码',
+    expiretime   datetime    null comment '过期时间'
+);
+
+create table usergroup
+(
+    usergroupid       int auto_increment comment '自增长主键用户组编号'
+        primary key,
+    superiorid        int          null comment '上级用户组编号',
+    usergroupname     varchar(50)  null comment '名称',
+    usergroupdescribe varchar(200) null comment '描述'
+);
+
+create table usergrouppermissions
+(
+    userpermissionsid   int auto_increment comment '自增长主键用户组权限编号'
+        primary key,
+    usergroupid         int          null comment '用户组编号',
+    pageconfigurationid int          null comment '页面配置编号',
+    serviceid           int          null comment '服务编号',
+    insertcolumnlist    varchar(200) null comment '列权限插入列表',
+    updatecolumnlist    varchar(200) null comment '列权限更新列表',
+    selectcolumnlist    varchar(200) null comment '列权限查询列表',
+    filterset           varchar(200) null comment '行权限过滤条件'
+);
+
+create table userinfo
+(
+    userid                    int auto_increment comment '自增长主键用户编号'
+        primary key,
+    usergroupid               int          null comment '用户组编号',
+    username                  varchar(50)  null comment '用户名',
+    account                   varchar(50)  null comment '账号',
+    userpassword              varchar(50)  null comment '密码',
+    userdescribe              varchar(200) null comment '描述',
+    isenable                  int          null comment '是否启用账号',
+    secondarypassword         varchar(50)  null comment '二级安全密码',
+    lastestchangepasswordtime datetime     null comment '最后修改密码时间'
+);
+
+create table userloginlog
+(
+    loginid       int auto_increment comment '自增长主键登录编号'
+        primary key,
+    userid        int          null,
+    requestip     varchar(50)  null comment '请求地址',
+    sessionid     varchar(50)  null comment '请求编号',
+    logintime     datetime     null comment '登录时间',
+    usertoken     varchar(100) null comment '用户令牌',
+    lasttime      datetime     null comment '最后活跃时间',
+    lastheartbeat datetime     null comment '最后心跳时间',
+    logouttime    datetime     null comment '登出时间',
+    apptoken      varchar(128) null comment '连接令牌',
+    isexpires     int          null comment '是否过期',
+    appid         varchar(16)  null comment 'app编号',
+    expirestime   datetime     null comment '过期时间'
+);
+
+create table userpermissions
+(
+    userpermissionsid   int auto_increment comment '自增长主键用户权限编号'
+        primary key,
+    userid              int          null comment '用户编号',
+    pageconfigurationid int          null comment '页面配置编号',
+    serviceid           int          null comment '服务编号',
+    insertcolumnlist    varchar(200) null comment '列权限插入列表',
+    updatecolumnlist    varchar(200) null comment '列权限更新列表',
+    selectcolumnlist    varchar(200) null comment '列权限查询列表',
+    filterset           varchar(200) null comment '行权限过滤条件'
+);
+

+ 13 - 0
src/test/java/com/scbfkj/uni/UniApplicationTests.java

@@ -0,0 +1,13 @@
+package com.scbfkj.uni;
+
+import org.junit.jupiter.api.Test;
+import org.springframework.boot.test.context.SpringBootTest;
+
+@SpringBootTest
+class UniApplicationTests {
+
+	@Test
+	void contextLoads() {
+	}
+
+}