master
20918 3 months ago
commit 16aaed06a4

6
.gitignore vendored

@ -0,0 +1,6 @@
/target/
/.springBeans
/.project
/.factorypath
/.classpath
/.settings/

10
.idea/.gitignore vendored

@ -0,0 +1,10 @@
# 默认忽略的文件
/shelf/
/workspace.xml
# 基于编辑器的 HTTP 客户端请求
/httpRequests/
# Datasource local storage ignored files
/dataSources/
/dataSources.local.xml
# Zeppelin ignored files
/ZeppelinRemoteNotebooks/

@ -0,0 +1,19 @@
<?xml version="1.0" encoding="UTF-8"?>
<project version="4">
<component name="CompilerConfiguration">
<annotationProcessing>
<profile default="true" name="Default" enabled="true" />
<profile name="Maven default annotation processors profile" enabled="true">
<sourceOutputDir name="target/generated-sources/annotations" />
<sourceTestOutputDir name="target/generated-test-sources/test-annotations" />
<outputRelativeToContentRoot value="true" />
<module name="active4j-boot" />
</profile>
</annotationProcessing>
</component>
<component name="JavacSettings">
<option name="ADDITIONAL_OPTIONS_OVERRIDE">
<module name="active4j-boot" options="-parameters" />
</option>
</component>
</project>

@ -0,0 +1,6 @@
<?xml version="1.0" encoding="UTF-8"?>
<project version="4">
<component name="Encoding" defaultCharsetForPropertiesFiles="UTF-8">
<file url="file://$PROJECT_DIR$/src/main/java" charset="UTF-8" />
</component>
</project>

@ -0,0 +1,68 @@
<component name="InspectionProjectProfileManager">
<profile version="1.0">
<option name="myName" value="Project Default" />
<inspection_tool class="AliAccessStaticViaInstance" enabled="true" level="WARNING" enabled_by_default="true" />
<inspection_tool class="AliArrayNamingShouldHaveBracket" enabled="true" level="WARNING" enabled_by_default="true" />
<inspection_tool class="AliControlFlowStatementWithoutBraces" enabled="true" level="WARNING" enabled_by_default="true" />
<inspection_tool class="AliDeprecation" enabled="true" level="WARNING" enabled_by_default="true" />
<inspection_tool class="AliEqualsAvoidNull" enabled="true" level="WARNING" enabled_by_default="true" />
<inspection_tool class="AliLongLiteralsEndingWithLowercaseL" enabled="true" level="WARNING" enabled_by_default="true" />
<inspection_tool class="AliMissingOverrideAnnotation" enabled="true" level="WARNING" enabled_by_default="true" />
<inspection_tool class="AliWrapperTypeEquality" enabled="true" level="WARNING" enabled_by_default="true" />
<inspection_tool class="AlibabaAbstractClassShouldStartWithAbstractNaming" enabled="true" level="WARNING" enabled_by_default="true" />
<inspection_tool class="AlibabaAbstractMethodOrInterfaceMethodMustUseJavadoc" enabled="true" level="WARNING" enabled_by_default="true" />
<inspection_tool class="AlibabaAvoidApacheBeanUtilsCopy" enabled="true" level="WARNING" enabled_by_default="true" />
<inspection_tool class="AlibabaAvoidCallStaticSimpleDateFormat" enabled="true" level="WARNING" enabled_by_default="true" />
<inspection_tool class="AlibabaAvoidCommentBehindStatement" enabled="true" level="WARNING" enabled_by_default="true" />
<inspection_tool class="AlibabaAvoidComplexCondition" enabled="true" level="WARNING" enabled_by_default="true" />
<inspection_tool class="AlibabaAvoidConcurrentCompetitionRandom" enabled="true" level="WARNING" enabled_by_default="true" />
<inspection_tool class="AlibabaAvoidDoubleOrFloatEqualCompare" enabled="true" level="WARNING" enabled_by_default="true" />
<inspection_tool class="AlibabaAvoidManuallyCreateThread" enabled="true" level="WARNING" enabled_by_default="true" />
<inspection_tool class="AlibabaAvoidMissUseOfMathRandom" enabled="true" level="WARNING" enabled_by_default="true" />
<inspection_tool class="AlibabaAvoidNegationOperator" enabled="true" level="WARNING" enabled_by_default="true" />
<inspection_tool class="AlibabaAvoidNewDateGetTime" enabled="true" level="WARNING" enabled_by_default="true" />
<inspection_tool class="AlibabaAvoidPatternCompileInMethod" enabled="true" level="WARNING" enabled_by_default="true" />
<inspection_tool class="AlibabaAvoidReturnInFinally" enabled="true" level="WARNING" enabled_by_default="true" />
<inspection_tool class="AlibabaAvoidStartWithDollarAndUnderLineNaming" enabled="true" level="WARNING" enabled_by_default="true" />
<inspection_tool class="AlibabaAvoidUseTimer" enabled="true" level="WARNING" enabled_by_default="true" />
<inspection_tool class="AlibabaBigDecimalAvoidDoubleConstructor" enabled="true" level="WARNING" enabled_by_default="true" />
<inspection_tool class="AlibabaBooleanPropertyShouldNotStartWithIs" enabled="true" level="WARNING" enabled_by_default="true" />
<inspection_tool class="AlibabaClassCastExceptionWithSubListToArrayList" enabled="true" level="WARNING" enabled_by_default="true" />
<inspection_tool class="AlibabaClassCastExceptionWithToArray" enabled="true" level="WARNING" enabled_by_default="true" />
<inspection_tool class="AlibabaClassMustHaveAuthor" enabled="true" level="WARNING" enabled_by_default="true" />
<inspection_tool class="AlibabaClassNamingShouldBeCamel" enabled="true" level="WARNING" enabled_by_default="true" />
<inspection_tool class="AlibabaCollectionInitShouldAssignCapacity" enabled="true" level="WARNING" enabled_by_default="true" />
<inspection_tool class="AlibabaCommentsMustBeJavadocFormat" enabled="true" level="WARNING" enabled_by_default="true" />
<inspection_tool class="AlibabaConcurrentExceptionWithModifyOriginSubList" enabled="true" level="WARNING" enabled_by_default="true" />
<inspection_tool class="AlibabaConstantFieldShouldBeUpperCase" enabled="true" level="WARNING" enabled_by_default="true" />
<inspection_tool class="AlibabaCountDownShouldInFinally" enabled="true" level="WARNING" enabled_by_default="true" />
<inspection_tool class="AlibabaDontModifyInForeachCircle" enabled="true" level="WARNING" enabled_by_default="true" />
<inspection_tool class="AlibabaEnumConstantsMustHaveComment" enabled="true" level="WARNING" enabled_by_default="true" />
<inspection_tool class="AlibabaExceptionClassShouldEndWithException" enabled="true" level="WARNING" enabled_by_default="true" />
<inspection_tool class="AlibabaIbatisMethodQueryForList" enabled="true" level="WARNING" enabled_by_default="true" />
<inspection_tool class="AlibabaLockShouldWithTryFinally" enabled="true" level="WARNING" enabled_by_default="true" />
<inspection_tool class="AlibabaLowerCamelCaseVariableNaming" enabled="true" level="WARNING" enabled_by_default="true" />
<inspection_tool class="AlibabaMethodReturnWrapperType" enabled="true" level="WARNING" enabled_by_default="true" />
<inspection_tool class="AlibabaMethodTooLong" enabled="true" level="WARNING" enabled_by_default="true" />
<inspection_tool class="AlibabaPackageNaming" enabled="true" level="WARNING" enabled_by_default="true" />
<inspection_tool class="AlibabaPojoMustOverrideToString" enabled="true" level="WARNING" enabled_by_default="true" />
<inspection_tool class="AlibabaPojoMustUsePrimitiveField" enabled="true" level="WARNING" enabled_by_default="true" />
<inspection_tool class="AlibabaPojoNoDefaultValue" enabled="true" level="WARNING" enabled_by_default="true" />
<inspection_tool class="AlibabaRemoveCommentedCode" enabled="true" level="WARNING" enabled_by_default="true" />
<inspection_tool class="AlibabaServiceOrDaoClassShouldEndWithImpl" enabled="true" level="WARNING" enabled_by_default="true" />
<inspection_tool class="AlibabaSneakyThrowsWithoutExceptionType" enabled="true" level="WARNING" enabled_by_default="true" />
<inspection_tool class="AlibabaStringConcat" enabled="true" level="WARNING" enabled_by_default="true" />
<inspection_tool class="AlibabaSwitchExpression" enabled="true" level="WARNING" enabled_by_default="true" />
<inspection_tool class="AlibabaSwitchStatement" enabled="true" level="WARNING" enabled_by_default="true" />
<inspection_tool class="AlibabaTestClassShouldEndWithTestNaming" enabled="true" level="WARNING" enabled_by_default="true" />
<inspection_tool class="AlibabaThreadLocalShouldRemove" enabled="true" level="WARNING" enabled_by_default="true" />
<inspection_tool class="AlibabaThreadPoolCreation" enabled="true" level="WARNING" enabled_by_default="true" />
<inspection_tool class="AlibabaThreadShouldSetName" enabled="true" level="WARNING" enabled_by_default="true" />
<inspection_tool class="AlibabaTransactionMustHaveRollback" enabled="true" level="WARNING" enabled_by_default="true" />
<inspection_tool class="AlibabaUndefineMagicConstant" enabled="true" level="WARNING" enabled_by_default="true" />
<inspection_tool class="AlibabaUnsupportedExceptionWithModifyAsList" enabled="true" level="WARNING" enabled_by_default="true" />
<inspection_tool class="AlibabaUseQuietReferenceNotation" enabled="true" level="WARNING" enabled_by_default="true" />
<inspection_tool class="AlibabaUseRightCaseForDateFormat" enabled="true" level="WARNING" enabled_by_default="true" />
<inspection_tool class="MapOrSetKeyShouldOverrideHashCodeEquals" enabled="true" level="WARNING" enabled_by_default="true" />
</profile>
</component>

@ -0,0 +1,20 @@
<?xml version="1.0" encoding="UTF-8"?>
<project version="4">
<component name="RemoteRepositoriesConfiguration">
<remote-repository>
<option name="id" value="central" />
<option name="name" value="Central Repository" />
<option name="url" value="http://maven.aliyun.com/nexus/content/repositories/central/" />
</remote-repository>
<remote-repository>
<option name="id" value="central" />
<option name="name" value="Maven Central repository" />
<option name="url" value="https://repo1.maven.org/maven2" />
</remote-repository>
<remote-repository>
<option name="id" value="jboss.community" />
<option name="name" value="JBoss Community repository" />
<option name="url" value="https://repository.jboss.org/nexus/content/repositories/public/" />
</remote-repository>
</component>
</project>

@ -0,0 +1,12 @@
<?xml version="1.0" encoding="UTF-8"?>
<project version="4">
<component name="ExternalStorageConfigurationManager" enabled="true" />
<component name="MavenProjectsManager">
<option name="originalFiles">
<list>
<option value="$PROJECT_DIR$/pom.xml" />
</list>
</option>
</component>
<component name="ProjectRootManager" version="2" languageLevel="JDK_1_8" default="true" project-jdk-name="1.8" project-jdk-type="JavaSDK" />
</project>

@ -0,0 +1,223 @@
<?xml version="1.0" encoding="UTF-8"?>
<project version="4">
<component name="com.aicode.state.project.ProjectInfoState">
<option name="libraries">
<list>
<option value="Maven: org.assertj:assertj-core:3.16.1" />
<option value="Maven: org.junit.vintage:junit-vintage-engine:5.6.2" />
<option value="Maven: org.quartz-scheduler:quartz:2.3.2" />
<option value="Maven: com.ibeetl:beetlsql:2.10.34" />
<option value="Maven: org.springframework.boot:spring-boot-test:2.3.3.RELEASE" />
<option value="Maven: org.apache.poi:poi:3.15" />
<option value="Maven: org.mockito:mockito-junit-jupiter:3.3.3" />
<option value="Maven: org.checkerframework:checker-qual:2.10.0" />
<option value="Maven: com.squareup.okio:okio:1.17.2" />
<option value="Maven: org.apache.httpcomponents:httpclient:4.5.6" />
<option value="Maven: org.messaginghub:pooled-jms:1.1.2" />
<option value="Maven: com.alipay.sdk:alipay-sdk-java:3.7.110.ALL" />
<option value="Maven: com.baomidou:mybatis-plus-annotation:3.0.7.1" />
<option value="Maven: org.jeecgframework:autopoi-web:1.3" />
<option value="Maven: com.zaxxer:HikariCP:3.4.5" />
<option value="Maven: org.apache.shiro:shiro-crypto-cipher:1.4.0" />
<option value="Maven: org.springframework:spring-webmvc:5.2.8.RELEASE" />
<option value="Maven: com.aliyun.oss:aliyun-sdk-oss:3.11.2" />
<option value="Maven: javax.inject:javax.inject:1" />
<option value="Maven: org.apache.geronimo.specs:geronimo-j2ee-management_1.1_spec:1.0.1" />
<option value="Maven: org.apache.commons:commons-collections4:4.1" />
<option value="Maven: org.yaml:snakeyaml:1.26" />
<option value="Maven: javax.activation:javax.activation-api:1.2.0" />
<option value="Maven: org.springframework.data:spring-data-commons:2.3.3.RELEASE" />
<option value="Maven: com.jhlabs:filters:2.0.235-1" />
<option value="Maven: ch.qos.logback:logback-classic:1.2.3" />
<option value="Maven: org.apache.shiro:shiro-cache:1.4.0" />
<option value="Maven: org.springframework.boot:spring-boot-starter-json:2.3.3.RELEASE" />
<option value="Maven: jakarta.activation:jakarta.activation-api:1.2.2" />
<option value="Maven: org.junit.jupiter:junit-jupiter-engine:5.6.2" />
<option value="Maven: com.ibeetl:beetl-framework-starter:1.1.63.RELEASE" />
<option value="Maven: org.springframework:spring-tx:5.2.8.RELEASE" />
<option value="Maven: org.springframework.boot:spring-boot-starter-test:2.3.3.RELEASE" />
<option value="Maven: com.fasterxml.jackson.core:jackson-core:2.11.2" />
<option value="Maven: com.github.ben-manes.caffeine:caffeine:2.8.0" />
<option value="Maven: org.objenesis:objenesis:2.6" />
<option value="Maven: jakarta.jms:jakarta.jms-api:2.0.3" />
<option value="Maven: eu.bitwalker:UserAgentUtils:1.20" />
<option value="Maven: com.baomidou:mybatis-plus-core:3.0.7.1" />
<option value="Maven: javax.activation:activation:1.1.1" />
<option value="Maven: org.springframework.boot:spring-boot-starter-jdbc:2.3.3.RELEASE" />
<option value="Maven: cn.hutool:hutool-core:5.3.8" />
<option value="Maven: org.springframework:spring-web:5.2.8.RELEASE" />
<option value="Maven: org.apache.shiro:shiro-crypto-hash:1.4.0" />
<option value="Maven: com.squareup.okhttp3:okhttp:3.14.9" />
<option value="Maven: org.fusesource.hawtbuf:hawtbuf:1.11" />
<option value="Maven: com.google.inject:guice:3.0" />
<option value="Maven: org.springframework:spring-jcl:5.2.8.RELEASE" />
<option value="Maven: javax.servlet:javax.servlet-api:4.0.1" />
<option value="Maven: org.springframework.data:spring-data-keyvalue:2.3.3.RELEASE" />
<option value="Maven: javax.xml.bind:jaxb-api:2.3.1" />
<option value="Maven: org.springframework.boot:spring-boot-starter-logging:2.3.3.RELEASE" />
<option value="Maven: com.github.jsqlparser:jsqlparser:3.2" />
<option value="Maven: org.springframework.boot:spring-boot-starter-web:2.3.3.RELEASE" />
<option value="Maven: org.apache.shiro:shiro-core:1.4.0" />
<option value="Maven: net.java.dev.jna:jna-platform:4.5.2" />
<option value="Maven: org.mybatis:mybatis:3.4.6" />
<option value="Maven: org.junit.jupiter:junit-jupiter:5.6.2" />
<option value="Maven: org.junit.platform:junit-platform-engine:1.6.2" />
<option value="Maven: commons-io:commons-io:2.4" />
<option value="Maven: com.jayway.jsonpath:json-path:2.4.0" />
<option value="Maven: org.antlr:antlr4-runtime:4.2" />
<option value="Maven: com.vaadin.external.google:android-json:0.0.20131108.vaadin1" />
<option value="Maven: com.google.inject.extensions:guice-multibindings:3.0" />
<option value="Maven: com.google.guava:guava:28.2-jre" />
<option value="Maven: org.bouncycastle:bcprov-jdk15on:1.59" />
<option value="Maven: org.apache.geronimo.specs:geronimo-jms_2.0_spec:1.0-alpha-2" />
<option value="Maven: xerces:xercesImpl:2.9.1" />
<option value="Maven: org.apache.shiro:shiro-all:1.4.0" />
<option value="Maven: com.fasterxml.jackson.datatype:jackson-datatype-jsr310:2.11.2" />
<option value="Maven: org.springframework:spring-beans:5.2.8.RELEASE" />
<option value="Maven: org.codehaus.jettison:jettison:1.1" />
<option value="Maven: org.apache.shiro:shiro-aspectj:1.4.0" />
<option value="Maven: org.springframework.boot:spring-boot-starter-activemq:2.3.3.RELEASE" />
<option value="Maven: org.apache.poi:poi-ooxml-schemas:3.15" />
<option value="Maven: com.github.qcloudsms:qcloudsms:1.0.6" />
<option value="Maven: org.springframework:spring-test:5.2.8.RELEASE" />
<option value="Maven: org.glassfish:jakarta.el:3.0.3" />
<option value="Maven: org.jeecgframework:minidao-spring-boot-starter:1.7.3" />
<option value="Maven: com.sun.xml.bind:jaxb-impl:2.1" />
<option value="Maven: org.apache.commons:commons-pool2:2.8.1" />
<option value="Maven: org.apache.logging.log4j:log4j-to-slf4j:2.13.3" />
<option value="Maven: com.github.oshi:oshi-core:3.9.1" />
<option value="Maven: org.hamcrest:hamcrest:2.2" />
<option value="Maven: com.ibeetl:beetl:2.9.3" />
<option value="Maven: org.apiguardian:apiguardian-api:1.1.0" />
<option value="Maven: com.mchange:mchange-commons-java:0.2.15" />
<option value="Maven: org.springframework.boot:spring-boot-test-autoconfigure:2.3.3.RELEASE" />
<option value="Maven: com.google.errorprone:error_prone_annotations:2.3.3" />
<option value="Maven: org.skyscreamer:jsonassert:1.5.0" />
<option value="Maven: aopalliance:aopalliance:1.0" />
<option value="Maven: org.slf4j:slf4j-api:1.7.30" />
<option value="Maven: org.apache.httpcomponents:httpcore:4.4.13" />
<option value="Maven: org.mybatis:mybatis-spring:1.3.2" />
<option value="Maven: org.apache.shiro:shiro-web:1.4.0" />
<option value="Maven: org.springframework:spring-jdbc:5.2.8.RELEASE" />
<option value="Maven: org.jeecgframework:autopoi:1.3" />
<option value="Maven: org.springframework:spring-expression:5.2.8.RELEASE" />
<option value="Maven: org.apache.shiro:shiro-event:1.4.0" />
<option value="Maven: org.jdom:jdom2:2.0.6" />
<option value="Maven: org.apache.activemq:activemq-openwire-legacy:5.15.13" />
<option value="Maven: com.github.yunchaoyun:yunsms:1.1" />
<option value="Maven: org.springframework.boot:spring-boot-starter-validation:2.3.3.RELEASE" />
<option value="Maven: org.apache.poi:poi-ooxml:3.15" />
<option value="Maven: org.springframework:spring-oxm:5.2.8.RELEASE" />
<option value="Maven: com.sun.xml.bind:jaxb-core:2.1.14" />
<option value="Maven: ch.qos.logback:logback-core:1.2.3" />
<option value="Maven: org.jeecgframework.jimureport:spring-boot-starter-jimureport:1.3.1-beta4" />
<option value="Maven: com.fasterxml.jackson.datatype:jackson-datatype-jdk8:2.11.2" />
<option value="Maven: com.google.zxing:javase:3.0.0" />
<option value="Maven: com.google.protobuf:protobuf-java:3.19.4" />
<option value="Maven: net.minidev:accessors-smart:1.2" />
<option value="Maven: joda-time:joda-time:2.9.9" />
<option value="Maven: org.mockito:mockito-core:3.3.3" />
<option value="Maven: org.antlr:antlr4-annotations:4.2" />
<option value="Maven: jakarta.validation:jakarta.validation-api:2.0.2" />
<option value="Maven: com.hazelcast:hazelcast:3.12.8" />
<option value="Maven: com.google.guava:listenablefuture:9999.0-empty-to-avoid-conflict-with-guava" />
<option value="Maven: org.springframework:spring-context-support:5.2.8.RELEASE" />
<option value="Maven: com.baomidou:mybatis-plus-boot-starter:3.0.7.1" />
<option value="Maven: org.opentest4j:opentest4j:1.2.0" />
<option value="Maven: org.apache.shiro:shiro-config-core:1.4.0" />
<option value="Maven: org.springframework.boot:spring-boot-starter-tomcat:2.3.3.RELEASE" />
<option value="Maven: org.apache.poi:poi-scratchpad:4.1.2" />
<option value="Maven: org.apache.shiro:shiro-ehcache:1.4.0" />
<option value="Maven: org.springframework:spring-messaging:5.2.8.RELEASE" />
<option value="Maven: com.aliyun:aliyun-java-sdk-kms:2.11.0" />
<option value="Maven: org.apache.httpcomponents:httpmime:4.5.12" />
<option value="Maven: org.springframework.boot:spring-boot-configuration-processor:2.3.3.RELEASE" />
<option value="Maven: stax:stax-api:1.0.1" />
<option value="Maven: org.slf4j:jul-to-slf4j:1.7.30" />
<option value="Maven: commons-logging:commons-logging:1.2" />
<option value="Maven: org.springframework.boot:spring-boot-starter-aop:2.3.3.RELEASE" />
<option value="Maven: org.freemarker:freemarker:2.3.30" />
<option value="Maven: org.springframework.boot:spring-boot:2.3.3.RELEASE" />
<option value="Maven: com.mysql:mysql-connector-j:8.0.31" />
<option value="Maven: net.java.dev.jna:jna:4.5.2" />
<option value="Maven: net.minidev:json-smart:2.3" />
<option value="Maven: com.qcloud:cos_api:5.5.2" />
<option value="Maven: org.abego.treelayout:org.abego.treelayout.core:1.0.1" />
<option value="Maven: junit:junit:4.13" />
<option value="Maven: org.hibernate.validator:hibernate-validator:6.1.5.Final" />
<option value="Maven: com.google.guava:failureaccess:1.0.1" />
<option value="Maven: org.apache.shiro:shiro-hazelcast:1.4.0" />
<option value="Maven: org.projectlombok:lombok:1.18.12" />
<option value="Maven: org.springframework.boot:spring-boot-starter-mail:2.3.3.RELEASE" />
<option value="Maven: org.junit.jupiter:junit-jupiter-api:5.6.2" />
<option value="Maven: xml-apis:xml-apis:1.3.04" />
<option value="Maven: com.fasterxml.jackson.module:jackson-module-parameter-names:2.11.2" />
<option value="Maven: org.apache.shiro:shiro-lang:1.4.0" />
<option value="Maven: com.aliyun:aliyun-java-sdk-ram:3.1.0" />
<option value="Maven: org.springframework:spring-jms:5.2.8.RELEASE" />
<option value="Maven: org.aspectj:aspectjrt:1.9.6" />
<option value="Maven: org.apache.xmlbeans:xmlbeans:2.6.0" />
<option value="Maven: org.xmlunit:xmlunit-core:2.7.0" />
<option value="Maven: org.json:json:20170516" />
<option value="Maven: org.apache.logging.log4j:log4j-api:2.13.3" />
<option value="Maven: org.jeecgframework:minidao-pe:1.7.3" />
<option value="Maven: commons-codec:commons-codec:1.14" />
<option value="Maven: commons-beanutils:commons-beanutils:1.9.3" />
<option value="Maven: org.springframework.boot:spring-boot-starter:2.3.3.RELEASE" />
<option value="Maven: org.junit.jupiter:junit-jupiter-params:5.6.2" />
<option value="Maven: org.springframework.boot:spring-boot-starter-quartz:2.3.3.RELEASE" />
<option value="Maven: com.alibaba:druid:1.1.10" />
<option value="Maven: jakarta.xml.bind:jakarta.xml.bind-api:2.3.3" />
<option value="Maven: net.bytebuddy:byte-buddy-agent:1.10.14" />
<option value="Maven: com.fasterxml:classmate:1.5.1" />
<option value="Maven: com.alibaba:fastjson:1.2.62" />
<option value="Maven: com.fasterxml.jackson.core:jackson-annotations:2.11.2" />
<option value="Maven: redis.clients:jedis:3.3.0" />
<option value="Maven: com.google.j2objc:j2objc-annotations:1.3" />
<option value="Maven: com.sun.activation:jakarta.activation:1.2.2" />
<option value="Maven: com.baomidou:mybatis-plus-extension:3.0.7.1" />
<option value="Maven: cn.hutool:hutool-crypto:5.3.8" />
<option value="Maven: org.apache.shiro:shiro-crypto-core:1.4.0" />
<option value="Maven: org.apache.tomcat.embed:tomcat-embed-websocket:9.0.37" />
<option value="Maven: com.carrotsearch.thirdparty:simple-xml-safe:2.7.1" />
<option value="Maven: org.apache.shiro:shiro-guice:1.4.0" />
<option value="Maven: org.apache.activemq:activemq-client:5.15.13" />
<option value="Maven: com.github.penggle:kaptcha:2.3.2" />
<option value="Maven: com.google.code.gson:gson:2.8.6" />
<option value="Maven: org.springframework.data:spring-data-redis:2.3.3.RELEASE" />
<option value="Maven: org.springframework:spring-core:5.2.8.RELEASE" />
<option value="Maven: org.javassist:javassist:3.15.0-GA" />
<option value="Maven: org.apache.shiro:shiro-spring:1.4.0" />
<option value="Maven: org.aspectj:aspectjweaver:1.9.6" />
<option value="Maven: org.springframework.boot:spring-boot-autoconfigure:2.3.3.RELEASE" />
<option value="Maven: org.junit.platform:junit-platform-commons:1.6.2" />
<option value="Maven: com.alibaba:druid-spring-boot-starter:1.1.10" />
<option value="Maven: com.google.zxing:core:3.0.0" />
<option value="Maven: org.ow2.asm:asm:5.0.4" />
<option value="Maven: org.apache.commons:commons-lang3:3.10" />
<option value="Maven: net.bytebuddy:byte-buddy:1.10.14" />
<option value="Maven: org.jboss.logging:jboss-logging:3.4.1.Final" />
<option value="Maven: com.fasterxml.jackson.core:jackson-databind:2.11.2" />
<option value="Maven: com.google.code.findbugs:jsr305:3.0.2" />
<option value="Maven: org.crazycake:shiro-redis:3.2.3" />
<option value="Maven: com.baomidou:mybatis-plus:3.0.7.1" />
<option value="Maven: com.sun.mail:jakarta.mail:1.6.5" />
<option value="Maven: org.apache.tomcat.embed:tomcat-embed-core:9.0.37" />
<option value="Maven: org.apache.shiro:shiro-config-ogdl:1.4.0" />
<option value="Maven: org.apache.poi:ooxml-schemas:1.4" />
<option value="Maven: org.apache.activemq:activemq-broker:5.15.13" />
<option value="Maven: net.sf.ehcache:ehcache-core:2.6.11" />
<option value="Maven: io.minio:minio:8.0.3" />
<option value="Maven: org.springframework.boot:spring-boot-starter-data-redis:2.3.3.RELEASE" />
<option value="Maven: com.aliyun:aliyun-java-sdk-core:4.0.3" />
<option value="Maven: jakarta.annotation:jakarta.annotation-api:1.3.5" />
<option value="Maven: com.github.virtuald:curvesapi:1.04" />
<option value="Maven: org.springframework:spring-aop:5.2.8.RELEASE" />
<option value="Maven: commons-collections:commons-collections:3.2.2" />
<option value="Maven: org.springframework:spring-context:5.2.8.RELEASE" />
<option value="Maven: opensymphony:ognl:2.6.11" />
</list>
</option>
<option name="projectName" value="Springboot-Active4j" />
</component>
</project>

@ -0,0 +1,6 @@
<?xml version="1.0" encoding="UTF-8"?>
<project version="4">
<component name="VcsDirectoryMappings">
<mapping directory="$PROJECT_DIR$" vcs="Git" />
</component>
</project>

@ -0,0 +1,20 @@
The MIT License (MIT)
Copyright (c) 2020 Active4j 麻木神
Permission is hereby granted, free of charge, to any person obtaining a copy of
this software and associated documentation files (the "Software"), to deal in
the Software without restriction, including without limitation the rights to
use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
the Software, and to permit persons to whom the Software is furnished to do so,
subject to the following conditions:
The above copyright notice and this permission notice shall be included in all
copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.

@ -0,0 +1,161 @@
![active4j](https://zh-active4j-1251505225.cos.ap-shanghai.myqcloud.com/active4jboot/logo.png "active4j")
Active4j-Boot是基于SpingBoot2.0轻量级的java快速开发框架。以Spring Framework为核心容器Spring MVC为模型视图控制器Mybatis Plus为数据访问层 Apache Shiro为权限授权层, Redis为分布式缓存Quartz为分布式集群调度beetl为模版引擎layui作为前端框架的开源框架。
------------
# 项目介绍
- Active4j-Boot是基于SpingBoot2.0轻量级的java快速开发框架。以Spring Framework为核心容器Spring MVC为模型视图控制器Mybatis Plus为数据访问层 Apache Shiro为权限授权层, Redis为分布式缓存Quartz为分布式集群调度beetl为模版引擎layui作为前端框架的开源框架。
- Active4j-Boot目前内置了部门管理、用户管理、角色管理、菜单管理、数据数据字典、定时任务、常用系统监控等基础功能并内置了文件上传下载、导入导出、微信支付、支付宝支付、短信功能、邮件发送等常用工具整合了layui前端常用组件。
- Active4j-Boot定位于企业快速开发平台建设代码全部开源持续更新共同维护。Active4j可以应用在任何J2EE的项目开发中尤其适合企业信息管理系统MIS企业办公系统OA客户关系管理系统CRM内容管理系统CMS等。
# 技术文档
- 讨论加群qq群①203802692 qq群②773872959
- 演示地址:[http://www.active4j.com:9001/boot](http://www.active4j.com:9001/boot "http://www.active4j.com:9001/boot")
- 官方网站:[www.active4j.com](http://www.active4j.com "www.active4j.com")
- 文档地址:[http://www.active4j.com/doc.html](http://www.active4j.com/doc.html "http://www.active4j.com/doc.html")
# 生态系统
| 版本 | 地址 |
| ------------ | ------------ |
| 前后端分离版本github | [https://github.com/yunchaoyun/active4j](https://github.com/yunchaoyun/active4j "https://github.com/yunchaoyun/active4j") |
| 前后端分离版本gitee | [https://gitee.com/active4j/active4j](https://gitee.com/active4j/active4j "https://gitee.com/active4j/active4j") |
| boot单体版本github | [https://github.com/yunchaoyun/active4j-boot](https://github.com/yunchaoyun/active4j-boot "https://github.com/yunchaoyun/active4j-boot") |
| boot单体版本gitee | [https://gitee.com/active4j/active4j-boot](https://gitee.com/active4j/active4j-boot "https://gitee.com/active4j/active4j-boot") |
|jsp版本github|[https://github.com/yunchaoyun/active4j-jsp](https://github.com/yunchaoyun/active4j-jsp "https://github.com/yunchaoyun/active4j-jsp")|
|jsp版本gitee|[https://gitee.com/active4j/active4j-jsp](https://gitee.com/active4j/active4j-jsp "https://gitee.com/active4j/active4j-jsp")|
| 工作流版本github | [https://github.com/yunchaoyun/active4j-flow](https://github.com/yunchaoyun/active4j-flow "https://github.com/yunchaoyun/active4j-flow") |
| 工作流版本gitee | [https://gitee.com/active4j/active4j-flow](https://gitee.com/active4j/active4j-flow "https://gitee.com/active4j/active4j-flow")|
| OA办公系统github|[https://github.com/yunchaoyun/active4j-oa](https://github.com/yunchaoyun/active4j-oa "https://github.com/yunchaoyun/active4j-oa")|
|OA办公系统gitee|[https://gitee.com/active4j/active4j-oa](https://gitee.com/active4j/active4j-oa "https://gitee.com/active4j/active4j-oa")|
# 项目特点
- 开箱即用,节省开发时间,提高开发效率
- 代码全部开源,持续更新,共同维护
- 基于SpringBoot简化了大量项目配置和maven依赖让您更专注于业务开发
- 使用分层设计分为daoserviceControllerview层层次清楚低耦合高内聚
- 友好的代码结构及注释,便于阅读及二次开发
- 支持分布式部署session集成了redis
- 灵活的权限控制, 整合shiro可控制到页面或按钮满足绝大部分的权限需求,优化权限注解方便权限配置
- 日志记录采用aop(LogAop类)方式,可对用户所有操作进行记录
- 引入quartz定时任务可动态完成任务的添加、修改、删除、暂停、恢复及日志查看等功能
- 数据统计报表:丰富的报表统计功能
- 集成积木报表。jimureport
- 利用beetl模板引擎对前台页面进行封装和拆分使代码变得简洁更加易维护
- 前端组件丰富集成layuiadmin基本涵盖了所有前端开发需求
- 前端页面简洁优美,支持移动端
- 支持多种浏览器: Google, 火狐, IE,360等
# 组织结构
com.zhonghe.active4j
• com.zhonghe.active4j.common -- 通用代码
• com.zhonghe.active4j.core -- 核心功能redis、线程池、缓存、shiro等
• com.zhonghe.active4j.demo -- 示例
• com.zhonghe.active4j.func -- 常用功能
• com.zhonghe.active4j.func.captcha -- 验证码
• com.zhonghe.active4j.func.email -- 邮件发送
• com.zhonghe.active4j.func.export -- 导入导出
• com.zhonghe.active4j.func.layedit -- 富文本编辑器
• com.zhonghe.active4j.func.message -- 系统消息
• com.zhonghe.active4j.func.pay -- 支付功能
• com.zhonghe.active4j.func.report -- 集成积木报表
• com.zhonghe.active4j.func.sms -- 短信发送
• com.zhonghe.active4j.func.timer -- 定时任务
• com.zhonghe.active4j.func.upload -- 上传下载
• com.zhonghe.active4j.monitor -- 系统监控/在线用户
• com.zhonghe.active4j.system -- 系统管理
# 技术选型
### 服务端
| 技术 | 说明 | 官网 |
| ------------ | ------------ | ------------ |
|Spring Boot2|核心框架|[https://spring.io/projects/spring-boot/](https://spring.io/projects/spring-boot/ "https://spring.io/projects/spring-boot/")|
|Spring MVC|视图框架|[http://docs.spring.io/spring/docs/current/spring-framework-reference/htmlsingle/#mvc](http://docs.spring.io/spring/docs/current/spring-framework-reference/htmlsingle/#mvc "http://docs.spring.io/spring/docs/current/spring-framework-reference/htmlsingle/#mvc")|
|Apache Shiro|权限框架|[http://shiro.apache.org/](http://shiro.apache.org/ "http://shiro.apache.org/")|
|MyBatis|持久层框架|[http://www.mybatis.org/mybatis-3/zh/index.html](http://www.mybatis.org/mybatis-3/zh/index.html "http://www.mybatis.org/mybatis-3/zh/index.html")|
|MyBatis-Plus|MyBatis增强工具|[https://mp.baomidou.com/](https://mp.baomidou.com/ "https://mp.baomidou.com/")|
|Alibaba Druid|数据库连接池|[https://github.com/alibaba/druid](https://github.com/alibaba/druid "https://github.com/alibaba/druid")|
|Redis|分布式缓存数据库|[https://redis.io/](https://redis.io/ "https://redis.io/")|
|Quartz|作业调度框架|[http://www.quartz-scheduler.org/](http://www.quartz-scheduler.org/ "http://www.quartz-scheduler.org/")|
|ActiveMQ|消息队列|[http://activemq.apache.org/](http://activemq.apache.org/ "http://activemq.apache.org/")|
|SLF4J|日志组件|[http://www.slf4j.org/](http://www.slf4j.org/ "http://www.slf4j.org/")|
|QcloudCOS|腾讯云存储|[https://www.qcloud.com/product/cos](https://www.qcloud.com/product/cos "https://www.qcloud.com/product/cos")|
|Maven|项目构建管理|[http://maven.apache.org/](http://maven.apache.org/ "http://maven.apache.org/")|
|Beetl|模版引擎|[http://ibeetl.com/](http://ibeetl.com/ "http://ibeetl.com/")|
|Apache Commons|工具类|[http://commons.apache.org/](http://commons.apache.org/ "http://commons.apache.org/")|
|fastjson|JSON解析库|[https://github.com/alibaba/fastjson](https://github.com/alibaba/fastjson "https://github.com/alibaba/fastjson")|
### 前端
|技术|名称|官网|
| ------------ | ------------ | ------------ |
|jQuery|js库|[http://jquery.com/](http://jquery.com/ "http://jquery.com/")|
|layui.table|数据表格|[https://www.layui.com/doc/modules/table.html](https://www.layui.com/doc/modules/table.html "https://www.layui.com/doc/modules/table.html")|
|bootstrap-treeview|树形结构|[http://www.treejs.cn/v3/](http://www.treejs.cn/v3/ "http://www.treejs.cn/v3/")|
|layui|前端框架|[https://www.layui.com/](https://www.layui.com/ "https://www.layui.com/")|
|layui.layer|弹出组件|[https://www.layui.com/doc/modules/layer.html](https://www.layui.com/doc/modules/layer.html "https://www.layui.com/doc/modules/layer.html")|
|layui.treeTable|树形表格|[https://fly.layui.com/jie/30625/](https://fly.layui.com/jie/30625/ "https://fly.layui.com/jie/30625/")|
# 功能列表
```html
- 项目主页:介绍项目简介、技术介绍、更新日志等信息
○ 示例主页一
○ 示例主页二
○ 示例主页三
- 系统管理
○ 用户管理:用于管理后台系统的用户,可进行增删改查等操作
○ 部门管理:通过不同的部门来管理和区分用户
○ 菜单管理:维护系统菜单,操作权限,按钮权限
○ 角色管理:维护系统角色信息,以角色为单位分配系统权限
○ 数据字段管理:对系统中经常使用的一些较为固定的数据进行维护,如:是否、男女、类别、级别等
○ 日志管理:系统正常操作日志记录和查询;系统异常信息日志记录和查询
- 系统监控
○ Druid连接池监控监视当前系统数据库连接池状态可进行分析SQL找出系统性能瓶颈
○ 服务器监控显示服务器内存信息、CPU信息、磁盘信息、JVM信息等性能指标
○ 在线用户列表:显示在线用户信息
- 常用功能
○ 邮件发送集成邮件发送功能富文本编辑器支持发送普通文本HTML文本等
○ 微信支付集成微信native支付功能
○ 支付宝支付:集成支付宝网站二维码支付功能
○ 报表插件集成JimuReport,积木报表
○ 短信服务
•阿里云短信集成阿里云短信SDK
•腾讯云短信集成腾讯云短信SDK
•云潮云短信集成云潮云短信SDK
○ 定时任务支持注解配置定时任务支持动态维护定时任务引入Quartz分布式定时调度
○ 富文本编辑器集成layui社区的layedit、kz.layedit、tinymce编辑器
○ 上传下载集成普通文件上传、图片上传、多文件上传、拖动上传、腾讯云COS存储等功能
○ 导入导出引入POI工具整合excel等导入导出功能
○ 系统消息:支持发送系统消息
○ 验证码集成google验证码插件支持算术验证码、动态验证码
- 前端实例组件
○ 格栅
○ 按钮
○ 表单
○ 导航
○ 选项卡
○ 进度条
○ 面板
○ 徽章
○ 时间线
○ 动画
○ 辅助
○ 通用弹出层
○ 上传
○ 时间日期
○ 数据表格
○ 分页
○ 滑块
○ 评分
○ 轮播
○ 流加载
○ 工具
○ 代码修饰
○ 颜色选择器
```

File diff suppressed because one or more lines are too long

@ -0,0 +1,302 @@
-- ----------------------------
-- Table structure for sys_dict
-- ----------------------------
CREATE TABLE `sys_dict` (
`id` varchar(32) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL,
`dict_name` varchar(100) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL COMMENT '字典名称',
`dict_code` varchar(100) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL COMMENT '字典编码',
`description` varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL COMMENT '描述',
`del_flag` int(1) NULL DEFAULT NULL COMMENT '删除状态',
`create_by` varchar(32) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL COMMENT '创建人',
`create_time` datetime(0) NULL DEFAULT NULL COMMENT '创建时间',
`update_by` varchar(32) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL COMMENT '更新人',
`update_time` datetime(0) NULL DEFAULT NULL COMMENT '更新时间',
`type` int(1) UNSIGNED ZEROFILL NULL DEFAULT 0 COMMENT '字典类型0为string,1为number',
PRIMARY KEY (`id`) USING BTREE,
UNIQUE INDEX `uk_sd_dict_code`(`dict_code`) USING BTREE
) ENGINE = InnoDB CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;
-- ----------------------------
-- Records of sys_dict
-- ----------------------------
INSERT INTO `sys_dict` VALUES ('0b1dac3e87ed7229ae19a586a8b8c8f8', '物资类型', 'wz_cc_type', NULL, 0, 'admin', '2019-04-26 18:25:48', NULL, NULL, 0);
INSERT INTO `sys_dict` VALUES ('0b5d19e1fce4b2e6647e6b4a17760c14', '通告类型', 'msg_category', '消息类型1:通知公告2:系统消息', 0, 'admin', '2019-04-22 18:01:35', NULL, NULL, 0);
INSERT INTO `sys_dict` VALUES ('1166528843122561025', '测试字典员工类型', 'ceshi_code', '', 0, 'admin', '2019-08-28 09:52:04', 'admin', '2021-01-08 14:33:43', 0);
INSERT INTO `sys_dict` VALUES ('1174509082208395266', '职务职级', 'position_rank', '职务表职级字典', 0, 'admin', '2019-09-19 10:22:41', NULL, NULL, 0);
INSERT INTO `sys_dict` VALUES ('1174511106530525185', '机构类型', 'org_category', '机构类型 1公司2部门 3岗位', 0, 'admin', '2019-09-19 10:30:43', NULL, NULL, 0);
INSERT INTO `sys_dict` VALUES ('1178295274528845826', '表单权限策略', 'form_perms_type', '', 0, 'admin', '2019-09-29 21:07:39', 'admin', '2019-09-29 21:08:26', NULL);
INSERT INTO `sys_dict` VALUES ('1199517671259906049', '紧急程度', 'urgent_level', '日程计划紧急程度', 0, 'admin', '2019-11-27 10:37:53', NULL, NULL, 0);
INSERT INTO `sys_dict` VALUES ('1199518099888414722', '日程计划类型', 'eoa_plan_type', '', 0, 'admin', '2019-11-27 10:39:36', NULL, NULL, 0);
INSERT INTO `sys_dict` VALUES ('1199525215290306561', '日程计划状态', 'eoa_plan_status', '', 0, 'admin', '2019-11-27 11:07:52', 'admin', '2019-11-27 11:10:11', 0);
INSERT INTO `sys_dict` VALUES ('1204580702536957953', '打卡类型', 'sign_type', '', 0, 'admin', '2019-12-11 09:56:34', 'admin', '2020-02-13 14:21:36', 0);
INSERT INTO `sys_dict` VALUES ('1204581134206337025', '打卡状态', 'sign_status', '', 0, 'admin', '2019-12-11 09:58:17', NULL, NULL, 0);
INSERT INTO `sys_dict` VALUES ('1209733563293962241', '数据库类型', 'database_type', '', 0, 'admin', '2019-12-25 15:12:12', NULL, NULL, 0);
INSERT INTO `sys_dict` VALUES ('1232913193820581889', 'Online表单业务分类', 'ol_form_biz_type', '', 0, 'admin', '2020-02-27 14:19:46', 'admin', '2020-02-27 14:20:23', 0);
INSERT INTO `sys_dict` VALUES ('1242281790421389314', '会议类型', 'mettingType', '', 0, 'admin', '2020-03-24 10:47:13', NULL, NULL, 0);
INSERT INTO `sys_dict` VALUES ('1242298510024429569', '提醒方式', 'remindMode', '', 0, 'admin', '2020-03-24 11:53:40', 'admin', '2020-03-24 12:03:22', 0);
INSERT INTO `sys_dict` VALUES ('1244538302904672258', '提醒时间', 'remindTime', '', 0, 'admin', '2020-03-30 16:13:48', NULL, NULL, 0);
INSERT INTO `sys_dict` VALUES ('1244538772909989889', '重复提醒', 'reminders', '', 0, 'admin', '2020-03-30 16:15:40', NULL, NULL, 0);
INSERT INTO `sys_dict` VALUES ('1244941599661178882', '表单设计器路由类型', 'desform_route_type', '表单设计器下一步路由跳转类型', 0, 'admin', '2020-03-31 18:56:22', NULL, NULL, 0);
INSERT INTO `sys_dict` VALUES ('1250687930947620866', '定时任务状态', 'quartz_status', '', 0, 'admin', '2020-04-16 15:30:14', '', NULL, NULL);
INSERT INTO `sys_dict` VALUES ('1252881342601908225', '栏目类型', 'cms_menu_type', '', 0, 'admin', '2020-04-22 16:46:04', '', NULL, NULL);
INSERT INTO `sys_dict` VALUES ('1253673013610672130', '会议室规模', 'meeting_scale', '', 0, 'admin', '2020-04-24 21:11:53', '', NULL, NULL);
INSERT INTO `sys_dict` VALUES ('1272739651112034306', '缓急', 'urgency', '', 0, 'admin', '2020-06-16 11:55:54', NULL, NULL, 0);
INSERT INTO `sys_dict` VALUES ('1272740254731100161', '密级', 'secret_level', '', 0, 'admin', '2020-06-16 11:58:18', NULL, NULL, 0);
INSERT INTO `sys_dict` VALUES ('1280401766745718786', '租户状态', 'tenant_status', '租户状态', 0, 'admin', '2020-07-07 15:22:25', NULL, NULL, 0);
INSERT INTO `sys_dict` VALUES ('1336551227544694785', '999', '999', '', 1, 'admin', '2020-12-09 14:00:19', NULL, NULL, 0);
INSERT INTO `sys_dict` VALUES ('1338811917237489665', '报表测试职务', 'zhiwu', '积木报表演示', 0, 'admin', '2020-12-15 19:43:30', 'admin', '2021-01-13 14:03:13', 0);
INSERT INTO `sys_dict` VALUES ('20863a840c7622c3eab0ee69e55a8c7c', '常用审批语', 'approval_remarks', '常用审批语', 0, 'admin', '2019-03-15 11:03:26', 'admin', '2019-06-10 19:38:31', 0);
INSERT INTO `sys_dict` VALUES ('236e8a4baff0db8c62c00dd95632834f', '同步工作流引擎', 'activiti_sync', '同步工作流引擎', 0, 'admin', '2019-05-15 15:27:33', NULL, NULL, 0);
INSERT INTO `sys_dict` VALUES ('2e02df51611a4b9632828ab7e5338f00', '权限策略', 'perms_type', '权限策略', 0, 'admin', '2019-04-26 18:26:55', NULL, NULL, 0);
INSERT INTO `sys_dict` VALUES ('2f0320997ade5dd147c90130f7218c3e', '推送类别', 'msg_type', '', 0, 'admin', '2019-03-17 21:21:32', 'admin', '2019-03-26 19:57:45', 0);
INSERT INTO `sys_dict` VALUES ('3486f32803bb953e7155dab3513dc68b', '删除状态', 'del_flag', '', 0, 'admin', '2019-10-18 21:46:26', 'admin', '2019-05-31 11:32:41', 0);
INSERT INTO `sys_dict` VALUES ('36d57175542a3ea85073923e8fccc21c', '尺码类型', 'air_china_size', NULL, 0, 'admin', '2019-04-23 23:02:44', NULL, NULL, 0);
INSERT INTO `sys_dict` VALUES ('3d9a351be3436fbefb1307d4cfb49bf2', '性别', 'sex', NULL, 0, NULL, '2019-01-04 14:56:32', 'admin', '2019-03-30 11:28:27', 1);
INSERT INTO `sys_dict` VALUES ('4274efc2292239b6f000b153f50823ff', '全局权限策略', 'global_perms_type', '全局权限策略', 0, 'admin', '2019-05-10 17:54:05', NULL, NULL, 0);
INSERT INTO `sys_dict` VALUES ('49a0f7247f9c2a7df4e5733b790a4c9f', '供应商', 'air_china_ supplier', NULL, 0, 'admin', '2019-04-24 16:49:25', NULL, NULL, 0);
INSERT INTO `sys_dict` VALUES ('4c03fca6bf1f0299c381213961566349', 'Online图表展示模板', 'online_graph_display_template', 'Online图表展示模板', 0, 'admin', '2019-04-12 17:28:50', NULL, NULL, 0);
INSERT INTO `sys_dict` VALUES ('4c753b5293304e7a445fd2741b46529d', '字典状态', 'dict_item_status', NULL, 0, 'admin', '2019-06-18 23:18:42', 'admin', '2019-03-30 19:33:52', 1);
INSERT INTO `sys_dict` VALUES ('4d7fec1a7799a436d26d02325eff295e', '优先级', 'priority', '优先级', 0, 'admin', '2019-03-16 17:03:34', 'admin', '2019-04-16 17:39:23', 0);
INSERT INTO `sys_dict` VALUES ('4e4602b3e3686f0911384e188dc7efb4', '条件规则', 'rule_conditions', '', 0, 'admin', '2019-04-01 10:15:03', 'admin', '2019-04-01 10:30:47', 0);
INSERT INTO `sys_dict` VALUES ('4f69be5f507accea8d5df5f11346181a', '发送消息类型', 'msgType', NULL, 0, 'admin', '2019-04-11 14:27:09', NULL, NULL, 0);
INSERT INTO `sys_dict` VALUES ('68168534ff5065a152bfab275c2136f8', '有效无效状态', 'valid_status', '有效无效状态', 0, 'admin', '2020-09-26 19:21:14', 'admin', '2019-06-07 00:30:10', 0);
INSERT INTO `sys_dict` VALUES ('72cce0989df68887546746d8f09811aa', 'Online表单类型', 'cgform_table_type', '', 0, 'admin', '2019-01-27 10:13:02', 'admin', '2019-03-30 11:37:36', 0);
INSERT INTO `sys_dict` VALUES ('76c1d6755018a918c9eeda575dbf3f98', '计量单位', 'air_china_unit', NULL, 0, 'admin', '2017-12-23 23:00:02', 'admin', '2019-04-23 23:13:52', 0);
INSERT INTO `sys_dict` VALUES ('78bda155fe380b1b3f175f1e88c284c6', '流程状态', 'bpm_status', '流程状态', 0, 'admin', '2019-05-09 16:31:52', NULL, NULL, 0);
INSERT INTO `sys_dict` VALUES ('83bfb33147013cc81640d5fd9eda030c', '日志类型', 'log_type', NULL, 0, 'admin', '2019-03-18 23:22:19', NULL, NULL, 1);
INSERT INTO `sys_dict` VALUES ('880a895c98afeca9d9ac39f29e67c13e', '操作类型', 'operate_type', '操作类型', 0, 'admin', '2019-07-22 10:54:29', NULL, NULL, 0);
INSERT INTO `sys_dict` VALUES ('8dfe32e2d29ea9430a988b3b558bf233', '发布状态', 'send_status', '发布状态', 0, 'admin', '2019-04-16 17:40:42', NULL, NULL, 0);
INSERT INTO `sys_dict` VALUES ('a7adbcd86c37f7dbc9b66945c82ef9e6', '1是0否', 'yn', '', 1, 'admin', '2019-05-22 19:29:29', NULL, NULL, 0);
INSERT INTO `sys_dict` VALUES ('a9d9942bd0eccb6e89de92d130ec4c4a', '消息发送状态', 'msgSendStatus', NULL, 0, 'admin', '2019-04-12 18:18:17', NULL, NULL, 0);
INSERT INTO `sys_dict` VALUES ('ac2f7c0c5c5775fcea7e2387bcb22f01', '菜单类型', 'menu_type', NULL, 0, 'admin', '2019-12-18 23:24:32', 'admin', '2019-04-01 15:27:06', 1);
INSERT INTO `sys_dict` VALUES ('bd1b8bc28e65d6feefefb6f3c79f42fd', 'Online图表数据类型', 'online_graph_data_type', 'Online图表数据类型', 0, 'admin', '2019-04-12 17:24:24', 'admin', '2019-04-12 17:24:57', 0);
INSERT INTO `sys_dict` VALUES ('c36169beb12de8a71c8683ee7c28a503', '部门状态', 'depart_status', NULL, 0, 'admin', '2019-03-18 21:59:51', NULL, NULL, 0);
INSERT INTO `sys_dict` VALUES ('c5a14c75172783d72cbee6ee7f5df5d1', 'Online图表类型', 'online_graph_type', 'Online图表类型', 0, 'admin', '2019-04-12 17:04:06', NULL, NULL, 0);
INSERT INTO `sys_dict` VALUES ('c72e92c2c13cdbc07b455e6abcc60d47', '启动状态', 'air_china_valid', NULL, 0, 'admin', '2019-04-23 23:05:29', NULL, NULL, 0);
INSERT INTO `sys_dict` VALUES ('d6e1152968b02d69ff358c75b48a6ee1', '流程类型', 'bpm_process_type', NULL, 0, 'admin', '2019-02-22 19:26:54', 'admin', '2019-03-30 18:14:44', 0);
INSERT INTO `sys_dict` VALUES ('fc6cd58fde2e8481db10d3a1e68ce70c', '用户状态', 'user_status', NULL, 0, 'admin', '2019-03-18 21:57:25', 'admin', '2019-03-18 23:11:58', 1);
-- ----------------------------
-- Table structure for sys_dict_item
-- ----------------------------
CREATE TABLE `sys_dict_item` (
`id` varchar(32) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL,
`dict_id` varchar(32) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL COMMENT '字典id',
`item_text` varchar(100) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL COMMENT '字典项文本',
`item_value` varchar(100) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL COMMENT '字典项值',
`description` varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL COMMENT '描述',
`sort_order` int(10) NULL DEFAULT NULL COMMENT '排序',
`status` int(11) NULL DEFAULT NULL COMMENT '状态1启用 0不启用',
`create_by` varchar(32) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
`create_time` datetime(0) NULL DEFAULT NULL,
`update_by` varchar(32) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
`update_time` datetime(0) NULL DEFAULT NULL,
PRIMARY KEY (`id`) USING BTREE,
INDEX `idx_sdi_role_dict_id`(`dict_id`) USING BTREE,
INDEX `idx_sdi_role_sort_order`(`sort_order`) USING BTREE,
INDEX `idx_sdi_status`(`status`) USING BTREE,
INDEX `idx_sdi_dict_val`(`dict_id`, `item_value`) USING BTREE
) ENGINE = InnoDB CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;
-- ----------------------------
-- Records of sys_dict_item
-- ----------------------------
INSERT INTO `sys_dict_item` VALUES ('0072d115e07c875d76c9b022e2179128', '4d7fec1a7799a436d26d02325eff295e', '', 'L', '', 3, 1, 'admin', '2019-04-16 17:04:59', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('00cd5762c968332e2bf8d1fdae872f26', '76c1d6755018a918c9eeda575dbf3f98', '', '3', NULL, 3, 1, 'admin', '2019-04-23 23:00:42', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('05a2e732ce7b00aa52141ecc3e330b4e', '3486f32803bb953e7155dab3513dc68b', '已删除', '1', NULL, NULL, 1, 'admin', '2025-10-18 21:46:56', 'admin', '2019-03-28 22:23:20');
INSERT INTO `sys_dict_item` VALUES ('0737b49b097033b35e1882f970d43263', '36d57175542a3ea85073923e8fccc21c', '量体类', '1', NULL, 1, 1, 'admin', '2019-04-23 23:03:02', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('08ec6c5c986766cc0f398bf88b2c7fd5', '20863a840c7622c3eab0ee69e55a8c7c', '呈领导阅示', '呈领导阅示', '呈领导阅示', 7, 1, 'admin', '2019-05-15 11:07:59', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('096c2e758d823def3855f6376bc736fb', 'bd1b8bc28e65d6feefefb6f3c79f42fd', 'SQL', 'sql', NULL, 1, 1, 'admin', '2019-04-12 17:26:26', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('0c9532916f5cd722017b46bc4d953e41', '2f0320997ade5dd147c90130f7218c3e', '指定用户', 'USER', NULL, NULL, 1, 'admin', '2019-03-17 21:22:19', 'admin', '2019-03-17 21:22:28');
INSERT INTO `sys_dict_item` VALUES ('0ca4beba9efc4f9dd54af0911a946d5c', '72cce0989df68887546746d8f09811aa', '附表', '3', NULL, 3, 1, 'admin', '2019-03-27 10:13:43', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('1030a2652608f5eac3b49d70458b8532', '2e02df51611a4b9632828ab7e5338f00', '禁用', '2', '禁用', 2, 1, 'admin', '2021-03-26 18:27:28', 'admin', '2019-04-26 18:39:11');
INSERT INTO `sys_dict_item` VALUES ('10e3b1b78da8b40161b7b89cefb2f31b', '0b1dac3e87ed7229ae19a586a8b8c8f8', '衣服', 'yifu', NULL, 1, 1, 'admin', '2019-04-26 18:26:04', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('1166528884218351617', '1166528843122561025', '普通员工', '1', '', 1, 1, 'admin', '2019-08-28 09:52:14', 'admin', '2021-01-08 14:33:52');
INSERT INTO `sys_dict_item` VALUES ('1166528900752297986', '1166528843122561025', '领导', '2', '', 1, 1, 'admin', '2019-08-28 09:52:18', 'admin', '2021-01-08 14:33:57');
INSERT INTO `sys_dict_item` VALUES ('1174509082208395266', '1174511106530525185', '岗位', '3', '岗位', 1, 1, 'admin', '2019-09-19 10:31:16', '', NULL);
INSERT INTO `sys_dict_item` VALUES ('1174509601047994369', '1174509082208395266', '员级', '1', '', 1, 1, 'admin', '2019-09-19 10:24:45', 'admin', '2019-09-23 11:46:39');
INSERT INTO `sys_dict_item` VALUES ('1174509667297026049', '1174509082208395266', '助级', '2', '', 2, 1, 'admin', '2019-09-19 10:25:01', 'admin', '2019-09-23 11:46:47');
INSERT INTO `sys_dict_item` VALUES ('1174509713568587777', '1174509082208395266', '中级', '3', '', 3, 1, 'admin', '2019-09-19 10:25:12', 'admin', '2019-09-23 11:46:56');
INSERT INTO `sys_dict_item` VALUES ('1174509788361416705', '1174509082208395266', '副高级', '4', '', 4, 1, 'admin', '2019-09-19 10:25:30', 'admin', '2019-09-23 11:47:06');
INSERT INTO `sys_dict_item` VALUES ('1174509835803189250', '1174509082208395266', '正高级', '5', '', 5, 1, 'admin', '2019-09-19 10:25:41', 'admin', '2019-09-23 11:47:12');
INSERT INTO `sys_dict_item` VALUES ('1174511197735665665', '1174511106530525185', '公司', '1', '公司', 1, 1, 'admin', '2019-09-19 10:31:05', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('1174511244036587521', '1174511106530525185', '部门', '2', '部门', 1, 1, 'admin', '2019-09-19 10:31:16', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('1178295553450061826', '1178295274528845826', '可编辑(未授权禁用)', '2', '', 2, 1, 'admin', '2019-09-29 21:08:46', 'admin', '2019-09-29 21:09:18');
INSERT INTO `sys_dict_item` VALUES ('1178295639554928641', '1178295274528845826', '可见(未授权不可见)', '1', '', 1, 1, 'admin', '2019-09-29 21:09:06', 'admin', '2019-09-29 21:09:24');
INSERT INTO `sys_dict_item` VALUES ('1199517884758368257', '1199517671259906049', '一般', '1', '', 1, 1, 'admin', '2019-11-27 10:38:44', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('1199517914017832962', '1199517671259906049', '重要', '2', '', 1, 1, 'admin', '2019-11-27 10:38:51', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('1199517941339529217', '1199517671259906049', '紧急', '3', '', 1, 1, 'admin', '2019-11-27 10:38:58', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('1199518186144276482', '1199518099888414722', '日常记录', '1', '', 1, 1, 'admin', '2019-11-27 10:39:56', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('1199518214858481666', '1199518099888414722', '本周工作', '2', '', 1, 1, 'admin', '2019-11-27 10:40:03', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('1199518235943247874', '1199518099888414722', '下周计划', '3', '', 1, 1, 'admin', '2019-11-27 10:40:08', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('1199525468672405505', '1199525215290306561', '未开始', '0', '', 1, 1, 'admin', '2019-11-27 11:08:52', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('1199525490575060993', '1199525215290306561', '进行中', '2', '', 3, 1, 'admin', '2019-11-27 11:08:58', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('1199525506429530114', '1199525215290306561', '已完成', '3', '', 4, 1, 'admin', '2019-11-27 11:09:02', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('1199607547704647681', '4f69be5f507accea8d5df5f11346181a', '系统', '4', '', 1, 1, 'admin', '2019-11-27 16:35:02', 'admin', '2019-11-27 19:37:46');
INSERT INTO `sys_dict_item` VALUES ('1203571948706095105', '1199525215290306561', '已提醒', '1', '', 2, 1, 'admin', '2019-12-08 15:08:09', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('1204581455016067074', '1204580702536957953', '上班打卡', '1', '', 1, 1, 'admin', '2019-12-11 09:59:34', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('1204581521328013314', '1204580702536957953', '下班打卡', '2', '', 1, 1, 'admin', '2019-12-11 09:59:49', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('1204581542945456129', '1204580702536957953', '外出打卡', '3', '', 1, 1, 'admin', '2019-12-11 09:59:55', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('1204581564143468546', '1204580702536957953', '请假', '4', '', 1, 1, 'admin', '2019-12-11 10:00:00', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('1204581583089139713', '1204580702536957953', '出差', '5', '', 1, 1, 'admin', '2019-12-11 10:00:04', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('1204581803613061122', '1204581134206337025', '缺卡', '0', '', 1, 1, 'admin', '2019-12-11 10:00:57', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('1204581830603407362', '1204581134206337025', '正常', '1', '', 1, 1, 'admin', '2019-12-11 10:01:03', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('1204581850283081729', '1204581134206337025', '迟到', '2', '', 1, 1, 'admin', '2019-12-11 10:01:08', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('1204581868406669314', '1204581134206337025', '旷工', '3', '', 1, 1, 'admin', '2019-12-11 10:01:12', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('1204581886026940417', '1204581134206337025', '早退', '4', '', 1, 1, 'admin', '2019-12-11 10:01:16', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('1209733775114702850', '1209733563293962241', 'MySQL5.5', '1', '', 1, 1, 'admin', '2019-12-25 15:13:02', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('1209733839933476865', '1209733563293962241', 'Oracle', '2', '', 3, 1, 'admin', '2019-12-25 15:13:18', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('1209733903020003330', '1209733563293962241', 'SQLServer', '3', '', 4, 1, 'admin', '2019-12-25 15:13:33', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('1232913424813486081', '1232913193820581889', '官方示例', 'demo', '', 1, 1, 'admin', '2020-02-27 14:20:42', 'admin', '2020-02-27 14:21:37');
INSERT INTO `sys_dict_item` VALUES ('1232913493717512194', '1232913193820581889', '流程表单', 'bpm', '', 2, 1, 'admin', '2020-02-27 14:20:58', 'admin', '2020-02-27 14:22:20');
INSERT INTO `sys_dict_item` VALUES ('1232913605382467585', '1232913193820581889', '测试表单', 'temp', '', 4, 1, 'admin', '2020-02-27 14:21:25', 'admin', '2020-02-27 14:22:16');
INSERT INTO `sys_dict_item` VALUES ('1232914232372195330', '1232913193820581889', '导入表单', 'bdfl_include', '', 5, 1, 'admin', '2020-02-27 14:23:54', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('1233279228474138625', '4e4602b3e3686f0911384e188dc7efb4', '左模糊', 'LEFT_LIKE', '', 7, 1, 'admin', '2020-02-28 14:34:16', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('1233279337333104641', '4e4602b3e3686f0911384e188dc7efb4', '右模糊', 'RIGHT_LIKE', '', 7, 1, 'admin', '2020-02-28 14:34:42', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('1242281959082741761', '1242281790421389314', '部门会议', 'depart', '', 1, 1, 'admin', '2020-03-24 10:47:54', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('1242282018893516802', '1242281790421389314', '临时会议', 'temp', '', 1, 1, 'admin', '2020-03-24 10:48:08', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('1242282141274918913', '1242281790421389314', '公司会议', 'company', '', 1, 1, 'admin', '2020-03-24 10:48:37', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('1242282318563954690', '1242281790421389314', '培训会议', 'train', '', 1, 1, 'admin', '2020-03-24 10:49:19', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('1242282375325470721', '1242281790421389314', '普通会议', 'common', '', 1, 1, 'admin', '2020-03-24 10:49:33', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('1242300779390357505', '1242298510024429569', '短信提醒', '2', '', 2, 1, 'admin', '2020-03-24 12:02:41', 'admin', '2020-03-30 18:21:33');
INSERT INTO `sys_dict_item` VALUES ('1242300814383435777', '1242298510024429569', '邮件提醒', '1', '', 1, 1, 'admin', '2020-03-24 12:02:49', 'admin', '2020-03-30 18:21:26');
INSERT INTO `sys_dict_item` VALUES ('1242300887343353857', '1242298510024429569', '系统消息', '4', '', 4, 1, 'admin', '2020-03-24 12:03:07', 'admin', '2020-03-30 18:21:43');
INSERT INTO `sys_dict_item` VALUES ('1244538412480864258', '1244538302904672258', '不提醒', '0', '', 1, 1, 'admin', '2020-03-30 16:14:14', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('1244538453169807361', '1244538302904672258', '开始时', '1', '', 1, 1, 'admin', '2020-03-30 16:14:24', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('1244538498132746241', '1244538302904672258', '提前5分钟', '2', '', 2, 1, 'admin', '2020-03-30 16:14:35', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('1244538537420791810', '1244538302904672258', '提前10分钟', '3', '', 3, 1, 'admin', '2020-03-30 16:14:44', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('1244538569926647810', '1244538302904672258', '提前15分钟', '4', '', 4, 1, 'admin', '2020-03-30 16:14:52', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('1244538620744835073', '1244538302904672258', '提前30分钟', '5', '', 5, 1, 'admin', '2020-03-30 16:15:04', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('1244538674016690178', '1244538302904672258', '提前1小时', '6', '', 6, 1, 'admin', '2020-03-30 16:15:16', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('1244538712323268610', '1244538302904672258', '提前2小时', '7', '', 7, 1, 'admin', '2020-03-30 16:15:26', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('1244538832364249090', '1244538772909989889', '不重复', '0', '', 1, 1, 'admin', '2020-03-30 16:15:54', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('1244538882335186946', '1244538772909989889', '每天', '1', '', 1, 1, 'admin', '2020-03-30 16:16:06', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('1244538920792760321', '1244538772909989889', '每周', '2', '', 2, 1, 'admin', '2020-03-30 16:16:15', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('1244538964811980802', '1244538772909989889', '每月(当日)', '3', '', 3, 1, 'admin', '2020-03-30 16:16:26', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('1244539005064716289', '1244538772909989889', '每年(当日)', '4', '', 4, 1, 'admin', '2020-03-30 16:16:35', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('1244941726052335617', '1244941599661178882', '跳转到表单', '1', '', 1, 1, 'admin', '2020-03-31 18:56:52', 'admin', '2020-03-31 21:16:05');
INSERT INTO `sys_dict_item` VALUES ('1244941755555069953', '1244941599661178882', '跳转到菜单', '2', '', 2, 1, 'admin', '2020-03-31 18:56:59', 'admin', '2020-03-31 21:16:09');
INSERT INTO `sys_dict_item` VALUES ('1244941784743231489', '1244941599661178882', '跳转到外部', '3', '', 3, 1, 'admin', '2020-03-31 18:57:06', 'admin', '2020-03-31 21:16:14');
INSERT INTO `sys_dict_item` VALUES ('1250688147579228161', '1250687930947620866', '正常', '0', '', 1, 1, 'admin', '2020-04-16 15:31:05', '', NULL);
INSERT INTO `sys_dict_item` VALUES ('1250688201064992770', '1250687930947620866', '停止', '-1', '', 1, 1, 'admin', '2020-04-16 15:31:18', '', NULL);
INSERT INTO `sys_dict_item` VALUES ('1252882203973537794', '1252881342601908225', '列表', '1', '', 1, 1, 'admin', '2020-04-22 16:49:29', '', NULL);
INSERT INTO `sys_dict_item` VALUES ('1252882248991002626', '1252881342601908225', '链接', '2', '', 1, 1, 'admin', '2020-04-22 16:49:40', '', NULL);
INSERT INTO `sys_dict_item` VALUES ('1253673087988264962', '1253673013610672130', '小型', 'S', '', 1, 1, 'admin', '2020-04-24 21:12:10', '', NULL);
INSERT INTO `sys_dict_item` VALUES ('1253673146364588034', '1253673013610672130', '中型', 'M', '', 1, 1, 'admin', '2020-04-24 21:12:24', '', NULL);
INSERT INTO `sys_dict_item` VALUES ('1253673184885075970', '1253673013610672130', '大型', 'L', '', 1, 1, 'admin', '2020-04-24 21:12:34', '', NULL);
INSERT INTO `sys_dict_item` VALUES ('1272739846449160193', '1272739651112034306', '一般', '0', '', 1, 1, 'admin', '2020-06-16 11:56:40', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('1272739980616556545', '1272739651112034306', '平急', '1', '', 1, 1, 'admin', '2020-06-16 11:57:12', 'admin', '2020-10-28 17:50:22');
INSERT INTO `sys_dict_item` VALUES ('1272740017782284289', '1272739651112034306', '加急', '2', '', 1, 1, 'admin', '2020-06-16 11:57:21', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('1272740063856713730', '1272739651112034306', '特急', '3', '', 1, 1, 'admin', '2020-06-16 11:57:32', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('1272740134505570306', '1272739651112034306', '特提', '4', '', 1, 1, 'admin', '2020-06-16 11:57:49', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('1272740342673072129', '1272740254731100161', '一般', '0', '', 1, 1, 'admin', '2020-06-16 11:58:39', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('1272740397966581762', '1272740254731100161', '秘密', '1', '', 1, 1, 'admin', '2020-06-16 11:58:52', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('1272740445697761282', '1272740254731100161', '机密', '2', '', 1, 1, 'admin', '2020-06-16 11:59:03', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('1272740494238441473', '1272740254731100161', '绝密', '3', '', 1, 1, 'admin', '2020-06-16 11:59:15', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('1280401815068295170', '1280401766745718786', '正常', '1', '', 1, 1, 'admin', '2020-07-07 15:22:36', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('1280401847607705602', '1280401766745718786', '冻结', '0', '', 1, 1, 'admin', '2020-07-07 15:22:44', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('1280417387279060994', '1199525215290306561', '已接受', '4', '', 4, 1, 'admin', '2020-07-07 16:24:28', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('1280417420456005634', '1199525215290306561', '已取消', '5', '5', 5, 1, 'admin', '2020-07-07 16:24:36', 'admin', '2020-07-07 16:24:45');
INSERT INTO `sys_dict_item` VALUES ('1305827309355302914', 'bd1b8bc28e65d6feefefb6f3c79f42fd', 'API', 'api', '', 3, 1, 'admin', '2020-09-15 19:14:26', 'admin', '2020-09-15 19:14:41');
INSERT INTO `sys_dict_item` VALUES ('1334440962954936321', '1209733563293962241', 'MYSQL5.7', '4', NULL, 1, 1, 'admin', '2020-12-03 18:16:02', 'admin', '2020-12-03 18:16:02');
INSERT INTO `sys_dict_item` VALUES ('1338812279746990082', '1338811917237489665', '研发经理', '1', '', 1, 1, 'admin', '2020-12-15 19:44:56', 'admin', '2021-01-13 14:00:13');
INSERT INTO `sys_dict_item` VALUES ('1338812321702612993', '1338811917237489665', '研发专员', '2', '', 1, 1, 'admin', '2020-12-15 19:45:06', 'admin', '2021-01-13 14:00:16');
INSERT INTO `sys_dict_item` VALUES ('1338812381655994370', '1338811917237489665', '财务经理', '3', '', 1, 1, 'admin', '2020-12-15 19:45:20', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('1338812417886392322', '1338811917237489665', '财务专员', '4', '', 1, 1, 'admin', '2020-12-15 19:45:29', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('1338812461297438721', '1338811917237489665', '客服经理', '5', '', 1, 1, 'admin', '2020-12-15 19:45:39', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('1338812495665565697', '1338811917237489665', '客服专员', '6', '', 1, 1, 'admin', '2020-12-15 19:45:48', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('147c48ff4b51545032a9119d13f3222a', 'd6e1152968b02d69ff358c75b48a6ee1', '测试流程', 'test', NULL, 1, 1, 'admin', '2019-03-22 19:27:05', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('1543fe7e5e26fb97cdafe4981bedc0c8', '4c03fca6bf1f0299c381213961566349', '单排布局', 'single', NULL, 2, 1, 'admin', '2022-07-12 17:43:39', 'admin', '2019-04-12 17:43:57');
INSERT INTO `sys_dict_item` VALUES ('1db531bcff19649fa82a644c8a939dc4', '4c03fca6bf1f0299c381213961566349', '组合布局', 'combination', '', 4, 1, 'admin', '2019-05-11 16:07:08', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('222705e11ef0264d4214affff1fb4ff9', '4f69be5f507accea8d5df5f11346181a', '短信', '1', '', 1, 1, 'admin', '2023-02-28 10:50:36', 'admin', '2019-04-28 10:58:11');
INSERT INTO `sys_dict_item` VALUES ('23a5bb76004ed0e39414e928c4cde155', '4e4602b3e3686f0911384e188dc7efb4', '不等于', '!=', '不等于', 3, 1, 'admin', '2019-04-01 16:46:15', 'admin', '2019-04-01 17:48:40');
INSERT INTO `sys_dict_item` VALUES ('25847e9cb661a7c711f9998452dc09e6', '4e4602b3e3686f0911384e188dc7efb4', '小于等于', '<=', '小于等于', 6, 1, 'admin', '2019-04-01 16:44:34', 'admin', '2019-04-01 17:49:10');
INSERT INTO `sys_dict_item` VALUES ('2d51376643f220afdeb6d216a8ac2c01', '68168534ff5065a152bfab275c2136f8', '有效', '1', '有效', 1, 1, 'admin', '2020-10-26 19:22:01', 'admin', '2019-10-04 17:46:58');
INSERT INTO `sys_dict_item` VALUES ('308c8aadf0c37ecdde188b97ca9833f5', '8dfe32e2d29ea9430a988b3b558bf233', '已发布', '1', '已发布', 2, 1, 'admin', '2019-04-16 17:41:24', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('333e6b2196e01ef9a5f76d74e86a6e33', '8dfe32e2d29ea9430a988b3b558bf233', '未发布', '0', '未发布', 1, 1, 'admin', '2019-04-16 17:41:12', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('337ea1e401bda7233f6258c284ce4f50', 'bd1b8bc28e65d6feefefb6f3c79f42fd', 'JSON', 'json', NULL, 1, 1, 'admin', '2019-04-12 17:26:33', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('33bc9d9f753cf7dc40e70461e50fdc54', 'a9d9942bd0eccb6e89de92d130ec4c4a', '发送失败', '2', NULL, 3, 1, 'admin', '2019-04-12 18:20:02', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('3c209b31417aba7cd5663355611d12c5', '36d57175542a3ea85073923e8fccc21c', '羊毛衫及毛背心类', '3', NULL, 3, 1, 'admin', '2019-04-23 23:03:27', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('3fbc03d6c994ae06d083751248037c0e', '78bda155fe380b1b3f175f1e88c284c6', '已完成', '3', '已完成', 3, 1, 'admin', '2019-05-09 16:33:25', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('41d7aaa40c9b61756ffb1f28da5ead8e', '0b5d19e1fce4b2e6647e6b4a17760c14', '通知公告', '1', NULL, 1, 1, 'admin', '2019-04-22 18:01:57', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('41fa1e9571505d643aea87aeb83d4d76', '4e4602b3e3686f0911384e188dc7efb4', '等于', '=', '等于', 4, 1, 'admin', '2019-04-01 16:45:24', 'admin', '2019-04-01 17:49:00');
INSERT INTO `sys_dict_item` VALUES ('4d7bcaf63f274e262c8e919470e47e5f', '20863a840c7622c3eab0ee69e55a8c7c', '同意', '同意', '同意', 1, 1, 'admin', '2019-05-15 11:04:31', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('4f05fb5376f4c61502c5105f52e4dd2b', '83bfb33147013cc81640d5fd9eda030c', '操作日志', '2', NULL, NULL, 1, 'admin', '2019-03-18 23:22:49', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('50223341bfb5ba30bf6319789d8d17fe', 'd6e1152968b02d69ff358c75b48a6ee1', '业务办理', 'business', NULL, 3, 1, 'admin', '2023-04-22 19:28:05', 'admin', '2019-03-22 23:24:39');
INSERT INTO `sys_dict_item` VALUES ('51222413e5906cdaf160bb5c86fb827c', 'a7adbcd86c37f7dbc9b66945c82ef9e6', '', '1', '', 1, 1, 'admin', '2019-05-22 19:29:45', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('538fca35afe004972c5f3947c039e766', '2e02df51611a4b9632828ab7e5338f00', '显示', '1', '显示', 1, 1, 'admin', '2025-03-26 18:27:13', 'admin', '2019-04-26 18:39:07');
INSERT INTO `sys_dict_item` VALUES ('5584c21993bde231bbde2b966f2633ac', '4e4602b3e3686f0911384e188dc7efb4', '自定义SQL', 'USE_SQL_RULES', '自定义SQL表达式', 9, 1, 'admin', '2019-04-01 10:45:24', 'admin', '2019-04-01 17:49:27');
INSERT INTO `sys_dict_item` VALUES ('56b9f1c6364c775236e1aa16ff97afae', '20863a840c7622c3eab0ee69e55a8c7c', '不同意', '不同意', '不同意', 6, 1, 'admin', '2019-05-15 11:07:17', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('58b73b344305c99b9d8db0fc056bbc0a', '72cce0989df68887546746d8f09811aa', '主表', '2', NULL, 2, 1, 'admin', '2019-03-27 10:13:36', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('598380c65be4568b6ad507e563aba667', '76c1d6755018a918c9eeda575dbf3f98', '', '8', NULL, 8, 1, 'admin', '2019-04-23 23:01:58', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('5b65a88f076b32e8e69d19bbaadb52d5', '2f0320997ade5dd147c90130f7218c3e', '全体用户', 'ALL', NULL, NULL, 1, 'admin', '2020-10-17 21:22:43', 'admin', '2019-03-28 22:17:09');
INSERT INTO `sys_dict_item` VALUES ('5d833f69296f691843ccdd0c91212b6b', '880a895c98afeca9d9ac39f29e67c13e', '修改', '3', '', 3, 1, 'admin', '2019-07-22 10:55:07', 'admin', '2019-07-22 10:55:41');
INSERT INTO `sys_dict_item` VALUES ('5d84a8634c8fdfe96275385075b105c9', '3d9a351be3436fbefb1307d4cfb49bf2', '', '2', NULL, 2, 1, NULL, '2019-01-04 14:56:56', NULL, '2019-01-04 17:38:12');
INSERT INTO `sys_dict_item` VALUES ('66c952ae2c3701a993e7db58f3baf55e', '4e4602b3e3686f0911384e188dc7efb4', '大于', '>', '大于', 1, 1, 'admin', '2019-04-01 10:45:46', 'admin', '2019-04-01 17:48:29');
INSERT INTO `sys_dict_item` VALUES ('69cacf64e244100289ddd4aa9fa3b915', 'a9d9942bd0eccb6e89de92d130ec4c4a', '未发送', '0', NULL, 1, 1, 'admin', '2019-04-12 18:19:23', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('6a7a9e1403a7943aba69e54ebeff9762', '4f69be5f507accea8d5df5f11346181a', '邮件', '2', '', 2, 1, 'admin', '2031-02-28 10:50:44', 'admin', '2019-04-28 10:59:03');
INSERT INTO `sys_dict_item` VALUES ('6c682d78ddf1715baf79a1d52d2aa8c2', '72cce0989df68887546746d8f09811aa', '单表', '1', NULL, 1, 1, 'admin', '2019-03-27 10:13:29', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('6d404fd2d82311fbc87722cd302a28bc', '4e4602b3e3686f0911384e188dc7efb4', '模糊', 'LIKE', '模糊', 7, 1, 'admin', '2019-04-01 16:46:02', 'admin', '2019-04-01 17:49:20');
INSERT INTO `sys_dict_item` VALUES ('6d4e26e78e1a09699182e08516c49fc4', '4d7fec1a7799a436d26d02325eff295e', '', 'H', '', 1, 1, 'admin', '2019-04-16 17:04:24', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('6e65c7d1cb1a433b5cccc2e072f6c536', '76c1d6755018a918c9eeda575dbf3f98', '', '4', NULL, 4, 1, 'admin', '2019-04-23 23:01:10', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('7050c1522702bac3be40e3b7d2e1dfd8', 'c5a14c75172783d72cbee6ee7f5df5d1', '柱状图', 'bar', NULL, 1, 1, 'admin', '2019-04-12 17:05:17', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('71b924faa93805c5c1579f12e001c809', 'd6e1152968b02d69ff358c75b48a6ee1', 'OA办公', 'oa', NULL, 2, 1, 'admin', '2021-03-22 19:27:17', 'admin', '2019-03-22 23:24:36');
INSERT INTO `sys_dict_item` VALUES ('75b260d7db45a39fc7f21badeabdb0ed', 'c36169beb12de8a71c8683ee7c28a503', '不启用', '0', NULL, NULL, 1, 'admin', '2019-03-18 23:29:41', 'admin', '2019-03-18 23:29:54');
INSERT INTO `sys_dict_item` VALUES ('7688469db4a3eba61e6e35578dc7c2e5', 'c36169beb12de8a71c8683ee7c28a503', '启用', '1', NULL, NULL, 1, 'admin', '2019-03-18 23:29:28', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('78ea6cadac457967a4b1c4eb7aaa418c', 'fc6cd58fde2e8481db10d3a1e68ce70c', '正常', '1', NULL, NULL, 1, 'admin', '2019-03-18 23:30:28', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('7ccf7b80c70ee002eceb3116854b75cb', 'ac2f7c0c5c5775fcea7e2387bcb22f01', '按钮权限', '2', NULL, NULL, 1, 'admin', '2019-03-18 23:25:40', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('81fb2bb0e838dc68b43f96cc309f8257', 'fc6cd58fde2e8481db10d3a1e68ce70c', '冻结', '2', NULL, NULL, 1, 'admin', '2019-03-18 23:30:37', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('83250269359855501ec4e9c0b7e21596', '4274efc2292239b6f000b153f50823ff', '可见/可访问(授权后可见/可访问)', '1', '', 1, 1, 'admin', '2023-06-10 17:54:51', 'admin', '2019-06-05 19:43:11');
INSERT INTO `sys_dict_item` VALUES ('84778d7e928bc843ad4756db1322301f', '4e4602b3e3686f0911384e188dc7efb4', '大于等于', '>=', '大于等于', 5, 1, 'admin', '2019-04-01 10:46:02', 'admin', '2019-04-01 17:49:05');
INSERT INTO `sys_dict_item` VALUES ('848d4da35ebd93782029c57b103e5b36', 'c5a14c75172783d72cbee6ee7f5df5d1', '饼图', 'pie', NULL, 3, 1, 'admin', '2019-04-12 17:05:49', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('84dfc178dd61b95a72900fcdd624c471', '78bda155fe380b1b3f175f1e88c284c6', '处理中', '2', '处理中', 2, 1, 'admin', '2019-05-09 16:33:01', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('86f19c7e0a73a0bae451021ac05b99dd', 'ac2f7c0c5c5775fcea7e2387bcb22f01', '子菜单', '1', NULL, NULL, 1, 'admin', '2019-03-18 23:25:27', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('8bccb963e1cd9e8d42482c54cc609ca2', '4f69be5f507accea8d5df5f11346181a', '微信', '3', NULL, 3, 1, 'admin', '2021-05-11 14:29:12', 'admin', '2019-04-11 14:29:31');
INSERT INTO `sys_dict_item` VALUES ('8c618902365ca681ebbbe1e28f11a548', '4c753b5293304e7a445fd2741b46529d', '启用', '1', NULL, 0, 0, 'admin', '2019-03-18 23:19:27', 'admin', '2019-03-20 09:33:30');
INSERT INTO `sys_dict_item` VALUES ('8cdf08045056671efd10677b8456c999', '4274efc2292239b6f000b153f50823ff', '可编辑(未授权时禁用)', '2', '', 2, 1, 'admin', '2019-05-10 17:55:38', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('8ff48e657a7c5090d4f2a59b37d1b878', '4d7fec1a7799a436d26d02325eff295e', '', 'M', '', 2, 1, 'admin', '2019-04-16 17:04:40', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('948923658baa330319e59b2213cda97c', '880a895c98afeca9d9ac39f29e67c13e', '添加', '2', '', 2, 1, 'admin', '2019-07-22 10:54:59', 'admin', '2019-07-22 10:55:36');
INSERT INTO `sys_dict_item` VALUES ('9a96c4a4e4c5c9b4e4d0cbf6eb3243cc', '4c753b5293304e7a445fd2741b46529d', '不启用', '0', NULL, 1, 1, 'admin', '2019-03-18 23:19:53', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('9c5b6144c4f954d938c96384e2e948aa', '20863a840c7622c3eab0ee69e55a8c7c', '请审批', '请审批', '请审批', 8, 1, 'admin', '2019-05-15 11:08:35', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('a05f177a7d9aeb84125ee8bc9c4fc64b', '49a0f7247f9c2a7df4e5733b790a4c9f', '耐克供应商', '2', NULL, 1, 1, 'admin', '2023-01-24 16:49:39', 'admin', '2019-04-24 16:49:59');
INSERT INTO `sys_dict_item` VALUES ('a1e7d1ca507cff4a480c8caba7c1339e', '880a895c98afeca9d9ac39f29e67c13e', '导出', '6', '', 6, 1, 'admin', '2019-07-22 12:06:50', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('a2be752dd4ec980afaec1efd1fb589af', '8dfe32e2d29ea9430a988b3b558bf233', '已撤销', '2', '已撤销', 3, 1, 'admin', '2019-04-16 17:41:39', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('aa0d8a8042a18715a17f0a888d360aa4', 'ac2f7c0c5c5775fcea7e2387bcb22f01', '一级菜单', '0', NULL, NULL, 1, 'admin', '2019-03-18 23:24:52', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('adcf2a1fe93bb99a84833043f475fe0b', '4e4602b3e3686f0911384e188dc7efb4', '包含', 'IN', '包含', 8, 1, 'admin', '2019-04-01 16:45:47', 'admin', '2019-04-01 17:49:24');
INSERT INTO `sys_dict_item` VALUES ('b029a41a851465332ee4ee69dcf0a4c2', '0b5d19e1fce4b2e6647e6b4a17760c14', '系统消息', '2', NULL, 1, 1, 'admin', '2019-02-22 18:02:08', 'admin', '2019-04-22 18:02:13');
INSERT INTO `sys_dict_item` VALUES ('b038e6f80c527d684c9ca0e1ecbef72f', '49a0f7247f9c2a7df4e5733b790a4c9f', '阿迪供应商', '1', NULL, 1, 1, 'admin', '2023-01-24 16:49:34', 'admin', '2019-04-24 16:50:02');
INSERT INTO `sys_dict_item` VALUES ('b2a8b4bb2c8e66c2c4b1bb086337f393', '3486f32803bb953e7155dab3513dc68b', '正常', '0', NULL, NULL, 1, 'admin', '2022-10-18 21:46:48', 'admin', '2019-03-28 22:22:20');
INSERT INTO `sys_dict_item` VALUES ('b5f3bd5f66bb9a83fecd89228c0d93d1', '68168534ff5065a152bfab275c2136f8', '无效', '0', '无效', 2, 1, 'admin', '2020-09-26 19:21:49', 'admin', '2019-05-13 17:20:07');
INSERT INTO `sys_dict_item` VALUES ('b96af20aef0c9388f2ae843ea7f8d722', '20863a840c7622c3eab0ee69e55a8c7c', '请***阅示', '请***阅示', '请***阅示', 4, 1, 'admin', '2019-05-15 11:06:25', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('b9fbe2a3602d4a27b45c100ac5328484', '78bda155fe380b1b3f175f1e88c284c6', '待提交', '1', '待提交', 1, 1, 'admin', '2019-05-09 16:32:35', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('ba27737829c6e0e582e334832703d75e', '236e8a4baff0db8c62c00dd95632834f', '同步', '1', '同步', 1, 1, 'admin', '2019-05-15 15:28:15', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('bcec04526b04307e24a005d6dcd27fd6', '880a895c98afeca9d9ac39f29e67c13e', '导入', '5', '', 5, 1, 'admin', '2019-07-22 12:06:41', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('bdeae295bf98a61b45e9be0322657d4b', 'c72e92c2c13cdbc07b455e6abcc60d47', '不启动', '2', NULL, 1, 1, 'admin', '2019-04-23 23:05:57', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('c4896da3525689b477b3c868d728c87f', 'c72e92c2c13cdbc07b455e6abcc60d47', '启动', '1', NULL, 1, 1, 'admin', '2019-04-23 23:05:40', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('c53da022b9912e0aed691bbec3c78473', '880a895c98afeca9d9ac39f29e67c13e', '查询', '1', '', 1, 1, 'admin', '2019-07-22 10:54:51', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('c5700a71ad08994d18ad1dacc37a71a9', 'a7adbcd86c37f7dbc9b66945c82ef9e6', '', '0', '', 1, 1, 'admin', '2019-05-22 19:29:55', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('c83d907903a7a5ff52de60aabf3550ee', '76c1d6755018a918c9eeda575dbf3f98', '', '1', NULL, 1, 1, 'admin', '2018-12-23 23:00:17', 'admin', '2019-04-23 23:14:00');
INSERT INTO `sys_dict_item` VALUES ('c8e63916333e588ef52d3eb3be9b6944', '0b1dac3e87ed7229ae19a586a8b8c8f8', 'dd', 'dd', NULL, 1, 1, 'admin', '2019-04-26 18:26:07', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('c9c3fb6c8a06b7bf577b4f574adccd12', '20863a840c7622c3eab0ee69e55a8c7c', '请指示', '请指示', '请指示', 3, 1, 'admin', '2019-05-15 11:05:58', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('cbfcc5b88fc3a90975df23ffc8cbe29c', 'c5a14c75172783d72cbee6ee7f5df5d1', '曲线图', 'line', NULL, 2, 1, 'admin', '2019-05-12 17:05:30', 'admin', '2019-04-12 17:06:06');
INSERT INTO `sys_dict_item` VALUES ('d217592908ea3e00ff986ce97f24fb98', 'c5a14c75172783d72cbee6ee7f5df5d1', '数据列表', 'table', NULL, 4, 1, 'admin', '2019-04-12 17:05:56', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('d76e35d4fa1c2892ff812e1de08b8684', '36d57175542a3ea85073923e8fccc21c', '标准尺码类', '4', NULL, 4, 1, 'admin', '2019-04-23 23:03:37', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('da01e5c526fc1984ca60fdcf13354d05', '20863a840c7622c3eab0ee69e55a8c7c', '同意***的意见', '同意***的意见', '同意***的意见', 2, 1, 'admin', '2019-05-15 11:05:33', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('db681e7aabd2ff52fdfaf6c2770448ff', '76c1d6755018a918c9eeda575dbf3f98', '', '2', NULL, 2, 1, 'admin', '2019-04-23 23:00:32', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('df168368dcef46cade2aadd80100d8aa', '3d9a351be3436fbefb1307d4cfb49bf2', '', '1', '', 1, 1, NULL, '2027-08-04 14:56:49', 'admin', '2020-05-11 14:07:04');
INSERT INTO `sys_dict_item` VALUES ('e05d424ee35c707d7bc20de3719fb3ae', '76c1d6755018a918c9eeda575dbf3f98', '', '7', NULL, 7, 1, 'admin', '2019-01-23 23:01:36', 'admin', '2019-04-23 23:01:48');
INSERT INTO `sys_dict_item` VALUES ('e6329e3a66a003819e2eb830b0ca2ea0', '4e4602b3e3686f0911384e188dc7efb4', '小于', '<', '小于', 2, 1, 'admin', '2019-04-01 16:44:15', 'admin', '2019-04-01 17:48:34');
INSERT INTO `sys_dict_item` VALUES ('e8f34a36f38f35e2efb1aaa342509242', '78bda155fe380b1b3f175f1e88c284c6', '已挂起', '5', '已挂起', 5, 1, 'admin', '2019-05-23 16:12:42', 'admin', '2019-05-22 18:39:42');
INSERT INTO `sys_dict_item` VALUES ('e94eb7af89f1dbfa0d823580a7a6e66a', '236e8a4baff0db8c62c00dd95632834f', '不同步', '0', '不同步', 2, 1, 'admin', '2019-05-15 15:28:28', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('ecb788a9b71d3d11357c31a0febefaaa', '36d57175542a3ea85073923e8fccc21c', '男衬衫类', '2', NULL, 2, 1, 'admin', '2019-04-23 23:03:18', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('f16c5706f3ae05c57a53850c64ce7c45', 'a9d9942bd0eccb6e89de92d130ec4c4a', '发送成功', '1', NULL, 2, 1, 'admin', '2019-04-12 18:19:43', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('f2688992fffa5c62e31ce50bbb1919d9', '20863a840c7622c3eab0ee69e55a8c7c', '审核无误', '审核无误', '审核无误', 9, 1, 'admin', '2019-05-15 11:08:58', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('f2bda3b1ca643b789a2e712ad53b06fb', '36d57175542a3ea85073923e8fccc21c', '固定型号', '5', NULL, 5, 1, 'admin', '2019-04-23 23:03:47', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('f37f90c496ec9841c4c326b065e00bb2', '83bfb33147013cc81640d5fd9eda030c', '登录日志', '1', NULL, NULL, 1, 'admin', '2019-03-18 23:22:37', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('f64ca22c7a2d5793a271590e7b01eb6b', '76c1d6755018a918c9eeda575dbf3f98', '', '5', NULL, 6, 1, 'admin', '2019-04-23 23:01:21', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('f753aff60ff3931c0ecb4812d8b5e643', '4c03fca6bf1f0299c381213961566349', '双排布局', 'double', NULL, 3, 1, 'admin', '2019-04-12 17:43:51', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('f80a8f6838215753b05e1a5ba3346d22', '880a895c98afeca9d9ac39f29e67c13e', '删除', '4', '', 4, 1, 'admin', '2019-07-22 10:55:14', 'admin', '2019-07-22 10:55:30');
INSERT INTO `sys_dict_item` VALUES ('fb80836f3e69d977303e56023cf4b0ca', '20863a840c7622c3eab0ee69e55a8c7c', '请处理', '请处理', '请处理', 5, 1, 'admin', '2019-05-15 11:06:57', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('fcec03570f68a175e1964808dc3f1c91', '4c03fca6bf1f0299c381213961566349', 'Tab风格', 'tab', NULL, 1, 1, 'admin', '2019-04-12 17:43:31', NULL, NULL);
INSERT INTO `sys_dict_item` VALUES ('fe50b23ae5e68434def76f67cef35d2d', '78bda155fe380b1b3f175f1e88c284c6', '已作废', '4', '已作废', 4, 1, 'admin', '2021-09-09 16:33:43', 'admin', '2019-05-09 16:34:40');

File diff suppressed because it is too large Load Diff

@ -0,0 +1,189 @@
/*
Navicat MySQL Data Transfer
Source Server : 194
Source Server Version : 50513
Source Host : 182.254.245.194:3307
Source Database : yun_enterprise_cms
Target Server Type : MYSQL
Target Server Version : 50513
File Encoding : 65001
Date: 2019-12-09 11:25:42
*/
SET FOREIGN_KEY_CHECKS=0;
-- ----------------------------
-- Table structure for qrtz_blob_triggers
-- ----------------------------
DROP TABLE IF EXISTS `qrtz_blob_triggers`;
CREATE TABLE `qrtz_blob_triggers` (
`SCHED_NAME` varchar(120) NOT NULL,
`TRIGGER_NAME` varchar(200) NOT NULL,
`TRIGGER_GROUP` varchar(200) NOT NULL,
`BLOB_DATA` blob,
PRIMARY KEY (`SCHED_NAME`,`TRIGGER_NAME`,`TRIGGER_GROUP`),
CONSTRAINT `qrtz_blob_triggers_ibfk_1` FOREIGN KEY (`SCHED_NAME`, `TRIGGER_NAME`, `TRIGGER_GROUP`) REFERENCES `qrtz_triggers` (`SCHED_NAME`, `TRIGGER_NAME`, `TRIGGER_GROUP`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
-- ----------------------------
-- Table structure for qrtz_calendars
-- ----------------------------
DROP TABLE IF EXISTS `qrtz_calendars`;
CREATE TABLE `qrtz_calendars` (
`SCHED_NAME` varchar(120) NOT NULL,
`CALENDAR_NAME` varchar(200) NOT NULL,
`CALENDAR` blob NOT NULL,
PRIMARY KEY (`SCHED_NAME`,`CALENDAR_NAME`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
-- ----------------------------
-- Table structure for qrtz_cron_triggers
-- ----------------------------
DROP TABLE IF EXISTS `qrtz_cron_triggers`;
CREATE TABLE `qrtz_cron_triggers` (
`SCHED_NAME` varchar(120) NOT NULL,
`TRIGGER_NAME` varchar(200) NOT NULL,
`TRIGGER_GROUP` varchar(200) NOT NULL,
`CRON_EXPRESSION` varchar(200) NOT NULL,
`TIME_ZONE_ID` varchar(80) DEFAULT NULL,
PRIMARY KEY (`SCHED_NAME`,`TRIGGER_NAME`,`TRIGGER_GROUP`),
CONSTRAINT `qrtz_cron_triggers_ibfk_1` FOREIGN KEY (`SCHED_NAME`, `TRIGGER_NAME`, `TRIGGER_GROUP`) REFERENCES `qrtz_triggers` (`SCHED_NAME`, `TRIGGER_NAME`, `TRIGGER_GROUP`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
-- ----------------------------
-- Table structure for qrtz_fired_triggers
-- ----------------------------
DROP TABLE IF EXISTS `qrtz_fired_triggers`;
CREATE TABLE `qrtz_fired_triggers` (
`SCHED_NAME` varchar(120) NOT NULL,
`ENTRY_ID` varchar(95) NOT NULL,
`TRIGGER_NAME` varchar(200) NOT NULL,
`TRIGGER_GROUP` varchar(200) NOT NULL,
`INSTANCE_NAME` varchar(200) NOT NULL,
`FIRED_TIME` bigint(13) NOT NULL,
`SCHED_TIME` bigint(13) NOT NULL,
`PRIORITY` int(11) NOT NULL,
`STATE` varchar(16) NOT NULL,
`JOB_NAME` varchar(200) DEFAULT NULL,
`JOB_GROUP` varchar(200) DEFAULT NULL,
`IS_NONCONCURRENT` varchar(1) DEFAULT NULL,
`REQUESTS_RECOVERY` varchar(1) DEFAULT NULL,
PRIMARY KEY (`SCHED_NAME`,`ENTRY_ID`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
-- ----------------------------
-- Table structure for qrtz_job_details
-- ----------------------------
DROP TABLE IF EXISTS `qrtz_job_details`;
CREATE TABLE `qrtz_job_details` (
`SCHED_NAME` varchar(120) NOT NULL,
`JOB_NAME` varchar(200) NOT NULL,
`JOB_GROUP` varchar(200) NOT NULL,
`DESCRIPTION` varchar(250) DEFAULT NULL,
`JOB_CLASS_NAME` varchar(250) NOT NULL,
`IS_DURABLE` varchar(1) NOT NULL,
`IS_NONCONCURRENT` varchar(1) NOT NULL,
`IS_UPDATE_DATA` varchar(1) NOT NULL,
`REQUESTS_RECOVERY` varchar(1) NOT NULL,
`JOB_DATA` blob,
PRIMARY KEY (`SCHED_NAME`,`JOB_NAME`,`JOB_GROUP`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
-- ----------------------------
-- Table structure for qrtz_locks
-- ----------------------------
DROP TABLE IF EXISTS `qrtz_locks`;
CREATE TABLE `qrtz_locks` (
`SCHED_NAME` varchar(120) NOT NULL,
`LOCK_NAME` varchar(40) NOT NULL,
PRIMARY KEY (`SCHED_NAME`,`LOCK_NAME`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
-- ----------------------------
-- Table structure for qrtz_paused_trigger_grps
-- ----------------------------
DROP TABLE IF EXISTS `qrtz_paused_trigger_grps`;
CREATE TABLE `qrtz_paused_trigger_grps` (
`SCHED_NAME` varchar(120) NOT NULL,
`TRIGGER_GROUP` varchar(200) NOT NULL,
PRIMARY KEY (`SCHED_NAME`,`TRIGGER_GROUP`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
-- ----------------------------
-- Table structure for qrtz_scheduler_state
-- ----------------------------
DROP TABLE IF EXISTS `qrtz_scheduler_state`;
CREATE TABLE `qrtz_scheduler_state` (
`SCHED_NAME` varchar(120) NOT NULL,
`INSTANCE_NAME` varchar(200) NOT NULL,
`LAST_CHECKIN_TIME` bigint(13) NOT NULL,
`CHECKIN_INTERVAL` bigint(13) NOT NULL,
PRIMARY KEY (`SCHED_NAME`,`INSTANCE_NAME`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
-- ----------------------------
-- Table structure for qrtz_simple_triggers
-- ----------------------------
DROP TABLE IF EXISTS `qrtz_simple_triggers`;
CREATE TABLE `qrtz_simple_triggers` (
`SCHED_NAME` varchar(120) NOT NULL,
`TRIGGER_NAME` varchar(200) NOT NULL,
`TRIGGER_GROUP` varchar(200) NOT NULL,
`REPEAT_COUNT` bigint(7) NOT NULL,
`REPEAT_INTERVAL` bigint(12) NOT NULL,
`TIMES_TRIGGERED` bigint(10) NOT NULL,
PRIMARY KEY (`SCHED_NAME`,`TRIGGER_NAME`,`TRIGGER_GROUP`),
CONSTRAINT `qrtz_simple_triggers_ibfk_1` FOREIGN KEY (`SCHED_NAME`, `TRIGGER_NAME`, `TRIGGER_GROUP`) REFERENCES `qrtz_triggers` (`SCHED_NAME`, `TRIGGER_NAME`, `TRIGGER_GROUP`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
-- ----------------------------
-- Table structure for qrtz_simprop_triggers
-- ----------------------------
DROP TABLE IF EXISTS `qrtz_simprop_triggers`;
CREATE TABLE `qrtz_simprop_triggers` (
`SCHED_NAME` varchar(120) NOT NULL,
`TRIGGER_NAME` varchar(200) NOT NULL,
`TRIGGER_GROUP` varchar(200) NOT NULL,
`STR_PROP_1` varchar(512) DEFAULT NULL,
`STR_PROP_2` varchar(512) DEFAULT NULL,
`STR_PROP_3` varchar(512) DEFAULT NULL,
`INT_PROP_1` int(11) DEFAULT NULL,
`INT_PROP_2` int(11) DEFAULT NULL,
`LONG_PROP_1` bigint(20) DEFAULT NULL,
`LONG_PROP_2` bigint(20) DEFAULT NULL,
`DEC_PROP_1` decimal(13,4) DEFAULT NULL,
`DEC_PROP_2` decimal(13,4) DEFAULT NULL,
`BOOL_PROP_1` varchar(1) DEFAULT NULL,
`BOOL_PROP_2` varchar(1) DEFAULT NULL,
PRIMARY KEY (`SCHED_NAME`,`TRIGGER_NAME`,`TRIGGER_GROUP`),
CONSTRAINT `qrtz_simprop_triggers_ibfk_1` FOREIGN KEY (`SCHED_NAME`, `TRIGGER_NAME`, `TRIGGER_GROUP`) REFERENCES `qrtz_triggers` (`SCHED_NAME`, `TRIGGER_NAME`, `TRIGGER_GROUP`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
-- ----------------------------
-- Table structure for qrtz_triggers
-- ----------------------------
DROP TABLE IF EXISTS `qrtz_triggers`;
CREATE TABLE `qrtz_triggers` (
`SCHED_NAME` varchar(120) NOT NULL,
`TRIGGER_NAME` varchar(200) NOT NULL,
`TRIGGER_GROUP` varchar(200) NOT NULL,
`JOB_NAME` varchar(200) NOT NULL,
`JOB_GROUP` varchar(200) NOT NULL,
`DESCRIPTION` varchar(250) DEFAULT NULL,
`NEXT_FIRE_TIME` bigint(13) DEFAULT NULL,
`PREV_FIRE_TIME` bigint(13) DEFAULT NULL,
`PRIORITY` int(11) DEFAULT NULL,
`TRIGGER_STATE` varchar(16) NOT NULL,
`TRIGGER_TYPE` varchar(8) NOT NULL,
`START_TIME` bigint(13) NOT NULL,
`END_TIME` bigint(13) DEFAULT NULL,
`CALENDAR_NAME` varchar(200) DEFAULT NULL,
`MISFIRE_INSTR` smallint(2) DEFAULT NULL,
`JOB_DATA` blob,
PRIMARY KEY (`SCHED_NAME`,`TRIGGER_NAME`,`TRIGGER_GROUP`),
KEY `SCHED_NAME` (`SCHED_NAME`,`JOB_NAME`,`JOB_GROUP`) USING BTREE,
CONSTRAINT `qrtz_triggers_ibfk_1` FOREIGN KEY (`SCHED_NAME`, `JOB_NAME`, `JOB_GROUP`) REFERENCES `qrtz_job_details` (`SCHED_NAME`, `JOB_NAME`, `JOB_GROUP`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

@ -0,0 +1,319 @@
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.3.3.RELEASE</version>
<relativePath />
</parent>
<groupId>com.zhonghe</groupId>
<artifactId>active4j-boot</artifactId>
<version>1.0</version>
<name>active4j-boot</name>
<description></description>
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
<java.version>1.8</java.version>
</properties>
<dependencies>
<!-- exclude掉缺省的jdbc配置 -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-jdbc</artifactId>
<exclusions>
<exclusion>
<groupId>org.apache.tomcat</groupId>
<artifactId>tomcat-jdbc</artifactId>
</exclusion>
</exclusions>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-validation</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-configuration-processor</artifactId>
<optional>true</optional>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-redis</artifactId>
<exclusions>
<exclusion>
<groupId>io.lettuce</groupId>
<artifactId>lettuce-core</artifactId>
</exclusion>
</exclusions>
</dependency>
<dependency>
<groupId>org.apache.commons</groupId>
<artifactId>commons-pool2</artifactId>
</dependency>
<dependency>
<groupId>commons-codec</groupId>
<artifactId>commons-codec</artifactId>
<version>1.14</version>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-aop</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-activemq</artifactId>
</dependency>
<!--消息队列连接池 -->
<dependency>
<groupId>org.messaginghub</groupId>
<artifactId>pooled-jms</artifactId>
</dependency>
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<optional>true</optional>
</dependency>
<dependency>
<groupId>com.baomidou</groupId>
<artifactId>mybatis-plus-boot-starter</artifactId>
<version>3.0.7.1</version>
</dependency>
<dependency>
<groupId>mySQL</groupId>
<artifactId>mysql-connector-Java</artifactId>
<version>8.0.31</version>
</dependency>
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>druid-spring-boot-starter</artifactId>
<version>1.1.10</version>
</dependency>
<dependency>
<groupId>com.ibeetl</groupId>
<artifactId>beetl-framework-starter</artifactId>
<version>1.1.63.RELEASE</version>
</dependency>
<dependency>
<groupId>org.apache.commons</groupId>
<artifactId>commons-lang3</artifactId>
</dependency>
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>fastjson</artifactId>
<version>1.2.62</version>
</dependency>
<!-- caffeine本地缓存 -->
<dependency>
<groupId>com.github.ben-manes.caffeine</groupId>
<artifactId>caffeine</artifactId>
<version>2.8.0</version>
</dependency>
<!-- 集成云潮云短信服务 -->
<dependency>
<groupId>com.github.yunchaoyun</groupId>
<artifactId>yunsms</artifactId>
<version>1.1</version>
</dependency>
<!-- 集成腾讯云短信服务 -->
<dependency>
<groupId>com.github.qcloudsms</groupId>
<artifactId>qcloudsms</artifactId>
<version>1.0.6</version>
</dependency>
<!-- 集成阿里云短信服务 -->
<dependency>
<groupId>com.aliyun</groupId>
<artifactId>aliyun-java-sdk-core</artifactId>
<version>4.0.3</version>
</dependency>
<dependency>
<groupId>commons-beanutils</groupId>
<artifactId>commons-beanutils</artifactId>
<version>1.9.3</version>
</dependency>
<!--spring boot 整合shiro依赖 -->
<dependency>
<groupId>org.apache.shiro</groupId>
<artifactId>shiro-spring</artifactId>
<version>1.4.0</version>
</dependency>
<!--shiro依赖 -->
<dependency>
<groupId>org.apache.shiro</groupId>
<artifactId>shiro-all</artifactId>
<version>1.4.0</version>
<exclusions>
<exclusion>
<groupId>org.apache.shiro</groupId>
<artifactId>shiro-quartz</artifactId>
</exclusion>
</exclusions>
</dependency>
<dependency>
<groupId>org.crazycake</groupId>
<artifactId>shiro-redis</artifactId>
<version>3.2.3</version>
</dependency>
<dependency>
<groupId>eu.bitwalker</groupId>
<artifactId>UserAgentUtils</artifactId>
<version>1.20</version>
</dependency>
<dependency>
<groupId>org.apache.httpcomponents</groupId>
<artifactId>httpclient</artifactId>
<version>4.5.6</version>
</dependency>
<dependency>
<groupId>org.bouncycastle</groupId>
<artifactId>bcprov-jdk15on</artifactId>
<version>1.59</version>
</dependency>
<!-- 加入发送邮件依赖 -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-mail</artifactId>
</dependency>
<!-- 加入发送邮件依赖结束 -->
<dependency>
<groupId>javax.activation</groupId>
<artifactId>activation</artifactId>
<version>1.1.1</version>
</dependency>
<!-- 支付宝支付 -->
<dependency>
<groupId>com.alipay.sdk</groupId>
<artifactId>alipay-sdk-java</artifactId>
<version>3.7.110.ALL</version>
</dependency>
<!-- 获取系统信息 -->
<dependency>
<groupId>com.github.oshi</groupId>
<artifactId>oshi-core</artifactId>
<version>3.9.1</version>
</dependency>
<!-- google 二维码 -->
<dependency>
<groupId>com.google.zxing</groupId>
<artifactId>javase</artifactId>
<version>3.0.0</version>
</dependency>
<!--quartz相关依赖 -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-quartz</artifactId>
</dependency>
<!-- io常用工具类 -->
<dependency>
<groupId>commons-io</groupId>
<artifactId>commons-io</artifactId>
<version>2.4</version>
</dependency>
<!-- 腾讯云 对象存储 -->
<dependency>
<groupId>com.qcloud</groupId>
<artifactId>cos_api</artifactId>
<version>5.5.2</version>
<exclusions>
<exclusion>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-log4j12</artifactId>
</exclusion>
</exclusions>
</dependency>
<!-- poi -->
<dependency>
<groupId>org.apache.poi</groupId>
<artifactId>poi</artifactId>
<version>3.15</version>
</dependency>
<dependency>
<groupId>org.apache.poi</groupId>
<artifactId>poi-ooxml</artifactId>
<version>3.15</version>
</dependency>
<!-- 谷歌 验证码插件(由于谷歌自己的无法下载,这里使用阿里库中的) -->
<dependency>
<groupId>com.github.penggle</groupId>
<artifactId>kaptcha</artifactId>
<version>2.3.2</version>
</dependency>
<!-- 集成jimu报表JimuReport -->
<dependency>
<groupId>org.jeecgframework.jimureport</groupId>
<artifactId>spring-boot-starter-jimureport</artifactId>
<version>1.3.1-beta4</version>
</dependency>
<dependency>
<groupId>com.yomahub</groupId>
<artifactId>tlog-all-spring-boot-starter</artifactId>
<version>1.5.2</version>
</dependency>
<!-- Sa-Token 权限认证在线文档https://sa-token.cc -->
<dependency>
<groupId>cn.dev33</groupId>
<artifactId>sa-token-spring-boot-starter</artifactId>
<version>1.39.0</version>
</dependency>
<!-- Sa-Token 整合 Redis (使用 jackson 序列化方式) -->
<dependency>
<groupId>cn.dev33</groupId>
<artifactId>sa-token-redis-jackson</artifactId>
<version>1.39.0</version>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
</project>

@ -0,0 +1,28 @@
package com.zhonghe.active4j;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.scheduling.annotation.EnableScheduling;
import lombok.extern.slf4j.Slf4j;
/**
*
* @author teli_
*
*/
@SpringBootApplication(scanBasePackages = {"org.jeecg.modules.jmreport", "com.zhonghe.active4j"})
@EnableScheduling //开启定时任务注解
@Slf4j
public class Active4jbootApplication {
public static void main(String[] args) {
log.info("============服务开始启动=============");
SpringApplication.run(Active4jbootApplication.class, args);
log.info("============服务启动成功=============");
}
}

@ -0,0 +1,62 @@
package com.zhonghe.active4j.common.Wrapper;
import java.util.List;
import com.alibaba.fastjson.JSON;
import com.baomidou.mybatisplus.core.metadata.IPage;
import lombok.Getter;
import lombok.Setter;
/**
* layui
* @author teli_
*
* @param <T>
*/
@Getter
@Setter
public class BaseWrapper<T> {
private int code = 0;
private String msg = "";
private long count = 0;
private List<T> data;
public BaseWrapper() {
}
/**
* list
* @param pageResult
*/
public BaseWrapper(IPage<T> pageResult) {
this.setCount(pageResult.getTotal());
this.setData(pageResult.getRecords());
}
public BaseWrapper(List<T> lstResult) {
this.setCount(null == lstResult ? 0 : lstResult.size());
this.setData(lstResult);
}
/**
*
* @return
*/
public String wrap() {
return JSON.toJSONString(this);
}
}

@ -0,0 +1,33 @@
package com.zhonghe.active4j.common.constant;
/**
*
* @author teli_
*
*/
public class GlobalConstant {
/**
* Key
*/
public static final String SESSION_KEY_OF_RAND_CODE = "randCode"; // todo 要统一常量
/**
* layui
*/
public static final String Order_Field = "field";//排序字段
public static final String Order_Type = "order";//排序类型
/**
*
*/
public static final String Err_Msg_No_Auth = "没有权限进行此操作";
public static final String Err_Msg_All = "系统错误,请联系管理员";
/**
*
*/
public static final String Default_Create_Name = "system";
}

@ -0,0 +1,30 @@
package com.zhonghe.active4j.common.controller;
import java.util.Date;
import org.springframework.web.bind.WebDataBinder;
import org.springframework.web.bind.annotation.InitBinder;
import com.zhonghe.active4j.core.config.web.DateConvertEditor;
import com.zhonghe.active4j.core.config.web.IntegerConvertEditor;
import lombok.extern.slf4j.Slf4j;
/**
* controller
* @author teli_
*
*/
@Slf4j
public class BaseController {
@InitBinder
public void initBinder(WebDataBinder binder) {
// Date 类型转换
binder.registerCustomEditor(Date.class, new DateConvertEditor());
binder.registerCustomEditor(int.class, new IntegerConvertEditor());
}
}

@ -0,0 +1,48 @@
package com.zhonghe.active4j.common.entity;
import java.util.Date;
import com.baomidou.mybatisplus.annotation.FieldFill;
import com.baomidou.mybatisplus.annotation.IdType;
import com.baomidou.mybatisplus.annotation.TableField;
import com.baomidou.mybatisplus.annotation.TableId;
import com.baomidou.mybatisplus.annotation.Version;
import com.baomidou.mybatisplus.extension.activerecord.Model;
import lombok.Getter;
import lombok.Setter;
/**
*
* @author teli_
*
*/
@Getter
@Setter
public class BaseEntity extends Model<BaseEntity>{
/**
*
*/
private static final long serialVersionUID = -3890934764385076499L;
@TableId(value="ID", type=IdType.UUID)
private String id;
@Version
@TableField(fill=FieldFill.INSERT)
private Integer versions;
@TableField(value="CREATE_NAME", fill=FieldFill.INSERT)
private String createName;
@TableField(value="CREATE_DATE", fill=FieldFill.INSERT)
private Date createDate;
@TableField(value="UPDATE_NAME", fill=FieldFill.UPDATE)
private String updateName;
@TableField(value="UPDATE_DATE", fill=FieldFill.UPDATE)
private Date updateDate;
}

@ -0,0 +1,33 @@
package com.zhonghe.active4j.core.annotation;
import static java.lang.annotation.ElementType.METHOD;
import static java.lang.annotation.RetentionPolicy.RUNTIME;
import java.lang.annotation.Documented;
import java.lang.annotation.Inherited;
import java.lang.annotation.Retention;
import java.lang.annotation.Target;
import com.zhonghe.active4j.core.model.LogType;
/**
*
*
* @author 38943
*
*/
@Documented
@Retention(RUNTIME)
@Target(METHOD)
@Inherited
public @interface Log {
// 类型
LogType type();
// 名称
String name() default "";
// 备注
String memo() default "";
}

@ -0,0 +1,29 @@
package com.zhonghe.active4j.core.annotation;
import static java.lang.annotation.ElementType.FIELD;
import static java.lang.annotation.RetentionPolicy.RUNTIME;
import java.lang.annotation.Documented;
import java.lang.annotation.Inherited;
import java.lang.annotation.Retention;
import java.lang.annotation.Target;
import com.zhonghe.active4j.core.model.QueryCondition;
/**
* QueryWrapper
* @author teli_
*
*/
@Documented
@Retention(RUNTIME)
@Target(FIELD)
@Inherited
public @interface QueryField {
String queryColumn();
QueryCondition condition() default QueryCondition.eq;
}

@ -0,0 +1,172 @@
package com.zhonghe.active4j.core.aop;
import java.lang.reflect.Method;
import javax.servlet.http.HttpServletRequest;
import com.zhonghe.active4j.core.sm.TSS;
import org.aspectj.lang.ProceedingJoinPoint;
import org.aspectj.lang.Signature;
import org.aspectj.lang.annotation.Around;
import org.aspectj.lang.annotation.Aspect;
import org.aspectj.lang.annotation.Pointcut;
import org.aspectj.lang.reflect.MethodSignature;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Component;
import org.springframework.web.context.request.RequestContextHolder;
import org.springframework.web.context.request.ServletRequestAttributes;
import com.zhonghe.active4j.core.annotation.Log;
import com.zhonghe.active4j.core.model.LogType;
import com.zhonghe.active4j.core.threadpool.ThreadPoolManager;
import com.zhonghe.active4j.core.util.DateUtils;
import com.zhonghe.active4j.core.util.IpUtil;
import com.zhonghe.active4j.core.util.ShiroUtils;
import com.zhonghe.active4j.system.entity.SysLogEntity;
import com.zhonghe.active4j.system.service.SysLogService;
import eu.bitwalker.useragentutils.Browser;
import eu.bitwalker.useragentutils.UserAgent;
import lombok.extern.slf4j.Slf4j;
/**
*
* @title LogAop.java
* @description
spring aop
* @time 2019123 10:15:12
* @author chenxl
* @version 1.0
*/
@Component
@Aspect
@Slf4j
public class LogAop {
@Autowired
private SysLogService sysLogService;
/**
*
*/
@Pointcut(value = "@annotation(com.zhonghe.active4j.core.annotation.Log)")
public void cutService() {
}
@Around("cutService()")
public Object recordSysLog(ProceedingJoinPoint point) throws Throwable {
//先执行业务
Object result = point.proceed();
try {
handle(point);
} catch (Exception e) {
log.error("日志记录出错!", e);
}
return result;
}
private void handle(ProceedingJoinPoint point) throws Exception {
//获取拦截的方法名
Signature sig = point.getSignature();
MethodSignature msig = null;
if(!(sig instanceof MethodSignature)) {
throw new IllegalArgumentException("该注解只能用于方法");
}
msig = (MethodSignature) sig;
Object target = point.getTarget();
Method currentMethod = target.getClass().getMethod(msig.getName(), msig.getParameterTypes());
String methodName = currentMethod.getName();
//如果获取不到用户名则记录为system
String userName = "system";
if(ShiroUtils.hasLogin()) {
userName = ShiroUtils.getSessionUserName();
}
//获取拦截方法的参数
String className = point.getTarget().getClass().getName();
Object[] params = point.getArgs();
StringBuilder sb = new StringBuilder();
for (Object param : params) {
sb.append(param);
sb.append(" & ");
}
//获取操作类型,名称,备注
Log annotation = currentMethod.getAnnotation(Log.class);
LogType type = annotation.type();
String name = annotation.name();
String memo = annotation.memo();
//获取request作用域
ServletRequestAttributes attr = (ServletRequestAttributes) RequestContextHolder.currentRequestAttributes();
HttpServletRequest request = attr.getRequest();
//得到UserAgent对象
UserAgent userAgent = UserAgent.parseUserAgentString(request.getHeader("User-Agent"));
//获得浏览器信息
Browser browser = userAgent.getBrowser();
//获得IP地址
String ip = IpUtil.getIpAddr(request);
//日志实体赋值
SysLogEntity sysLog = new SysLogEntity();
sysLog.setUserName(userName);
sysLog.setName(name);
sysLog.setType(getLogType(type));
sysLog.setOperatorTime(DateUtils.getNow());
sysLog.setBroswer(browser.toString());
sysLog.setIp(ip);
sysLog.setClassName(className);
sysLog.setMethodName(methodName);
sysLog.setParams(sb.toString());
sysLog.setMemo(memo);
sysLog.setTimeStamp(TSS.createTS(String.valueOf(sysLog.getOperatorTime())));
//多线程异步执行
ThreadPoolManager.me().execute(() -> {
//新增日志
sysLogService.addLog(sysLog);
});
}
private String getLogType(LogType logType) {
String type = "";
switch (logType) {
case login:
type = "1";
break;
case logout:
type = "2";
break;
case save:
type = "3";
break;
case insert:
type = "4";
break;
case del:
type = "5";
break;
case update:
type = "6";
break;
case timer:
type = "7";
break;
case normal:
type = "8";
break;
case abnormal:
type = "9";
break;
default:
break;
}
return type;
}
}

@ -0,0 +1,59 @@
package com.zhonghe.active4j.core.beetl.tag;
import java.io.IOException;
import com.baomidou.mybatisplus.core.toolkit.StringUtils;
import com.zhonghe.active4j.core.util.ShiroUtils;
/**
* Button
*
* @author teli_
*
*/
public class ButtonTag extends CommonParamsTag {
private String id;
private String layEvent;
private String label;
private String cssClass;
private String permission;
@Override
public void render() {
// 参数赋值
if (args.length > 1) {
this.id = this.getParameterString("id");
this.layEvent = this.getParameterString("layEvent");
this.label = this.getParameterString("label");
this.cssClass = this.getParameterString("cssClass");
this.permission = this.getParameterString("permission");
}
StringBuffer sb = new StringBuffer();
//有权限才显示
if(StringUtils.isEmpty(permission) || ShiroUtils.hasPermission(permission)) {
sb = sb.append("<button class=\"").append(this.cssClass).append("\"").append(" lay-event=\"").append(this.layEvent)
.append("\"");
if(StringUtils.isNotEmpty(this.id)) {
sb = sb.append(" id=\"").append(id).append("\"");
}
sb = sb.append(">").append(this.label).append("</button>");
}
try {
this.ctx.byteWriter.writeString(sb.toString());
} catch (IOException e) {
e.printStackTrace();
}
}
}

@ -0,0 +1,52 @@
package com.zhonghe.active4j.core.beetl.tag;
import java.util.Map;
import org.beetl.core.Tag;
/**
*
* @author teli_
*
*/
public abstract class CommonParamsTag extends Tag{
public String getParameterString(String parameter) {
Map map = (Map) this.args[1];
if(null != map && map.containsKey(parameter)) {
return (String)map.get(parameter);
}
return "";
}
public Boolean getParameterBoolean(String parameter) {
Map map = (Map) this.args[1];
if(null != map && map.containsKey(parameter)) {
return Boolean.parseBoolean((String)map.get(parameter));
}
return null;
}
public Integer getParameterInteger(String parameter) {
Map map = (Map) this.args[1];
if(null != map && map.containsKey(parameter)) {
return Integer.valueOf((String)map.get(parameter));
}
return null;
}
public Object getParamter(String parameter) {
Map map = (Map) this.args[1];
return map.get(parameter);
}
}

@ -0,0 +1,42 @@
package com.zhonghe.active4j.core.beetl.tag;
import java.io.IOException;
import com.baomidou.mybatisplus.core.toolkit.StringUtils;
import lombok.Getter;
import lombok.Setter;
/**
*
* @author teli_
*
*/
@Getter
@Setter
public class JsBaseTag extends CommonParamsTag {
//页面脚本文件
private String jsFile;
@Override
public void render() {
if(args.length > 1) {
this.jsFile = this.getParameterString("jsFile");
}
StringBuffer sb = new StringBuffer();
if(StringUtils.isNotEmpty(jsFile)) {
sb = sb.append("<script src=\"").append(this.getJsFile()).append("\"></script>");
}
try {
this.ctx.byteWriter.writeString(sb.toString());
} catch (IOException e) {
e.printStackTrace();
}
}
}

@ -0,0 +1,59 @@
package com.zhonghe.active4j.core.beetl.tag;
import java.io.IOException;
import com.baomidou.mybatisplus.core.toolkit.StringUtils;
import com.zhonghe.active4j.core.util.ShiroUtils;
/**
* a link
*
* @author teli_
*
*/
public class LinkTag extends CommonParamsTag {
private String id;
private String layEvent;
private String label;
private String cssClass;
private String permission;
@Override
public void render() {
// 参数赋值
if (args.length > 1) {
this.id = this.getParameterString("id");
this.layEvent = this.getParameterString("layEvent");
this.label = this.getParameterString("label");
this.cssClass = this.getParameterString("cssClass");
this.permission = this.getParameterString("permission");
}
StringBuffer sb = new StringBuffer();
//有权限才显示
if(StringUtils.isEmpty(permission) || ShiroUtils.hasPermission(permission)) {
sb = sb.append("<a class=\"").append(this.cssClass).append("\"").append(" lay-event=\"").append(this.layEvent)
.append("\"");
if(StringUtils.isNotEmpty(this.id)) {
sb = sb.append(" id=\"").append(id).append("\"");
}
sb = sb.append(">").append(this.label).append("</a>");
}
try {
this.ctx.byteWriter.writeString(sb.toString());
} catch (IOException e) {
e.printStackTrace();
}
}
}

@ -0,0 +1,53 @@
package com.zhonghe.active4j.core.beetl.tag;
import java.io.IOException;
import java.util.Map;
import org.apache.commons.lang3.StringUtils;
import com.zhonghe.active4j.system.util.SystemUtils;
/**
* radio
* @author teli_
*
*/
public class RadioTag extends CommonParamsTag {
private String name;
private String defaultValue;
private String dicCode;
@Override
public void render() {
//参数赋值
if(args.length > 1) {
this.name = this.getParameterString("name");
this.defaultValue = this.getParameterString("defaultValue");
this.dicCode = this.getParameterString("dicCode");
}
StringBuffer sb = new StringBuffer();
Map<String, String> map = SystemUtils.getDictionaryMap(dicCode);
if(null != map && map.keySet().size() > 0) {
for(String key : map.keySet()) {
if(StringUtils.equals(key, defaultValue)) {
sb = sb.append("<input type=\"radio\" name=\"").append(this.name).append("\" value=\"").append(key).append("\" title=\"").append(map.get(key)).append("\" checked>");
}else {
sb = sb.append("<input type=\"radio\" name=\"").append(this.name).append("\" value=\"").append(key).append("\" title=\"").append(map.get(key)).append("\">");
}
}
}
try {
this.ctx.byteWriter.writeString(sb.toString());
} catch (IOException e) {
e.printStackTrace();
}
}
}

@ -0,0 +1,81 @@
package com.zhonghe.active4j.core.beetl.tag;
import java.io.IOException;
import java.util.Map;
import org.apache.commons.lang3.StringUtils;
import com.zhonghe.active4j.system.util.SystemUtils;
import lombok.Getter;
import lombok.Setter;
/**
*
* @author teli_
*
*/
@Getter
@Setter
public class SelectTag extends CommonParamsTag {
private String id;
private String dicCode;
private String name;
private Boolean must;
private String blank;
private String defaultValue;
@Override
public void render() {
//参数赋值
if(args.length > 1) {
this.id = this.getParameterString("id");
this.dicCode = this.getParameterString("dicCode");
this.name = this.getParameterString("name");
this.must = this.getParameterBoolean("must");
this.blank = this.getParameterString("blank");
this.defaultValue = this.getParameterString("defaultValue");
//默认值
if(StringUtils.isEmpty(id)) {
this.id = name;
}
if(null == must) {
must = false;
}
}
StringBuffer sb = new StringBuffer();
Map<String, String> map = SystemUtils.getDictionaryMap(dicCode);
if(null != map && map.keySet().size() > 0) {
sb = sb.append("<select class=\"layui-input\" id=\"").append(this.id).append("\" name=\"").append(this.getName()).append("\" ");
if(must) {
sb = sb.append("lay-verify=\"required\">");
}else {
sb = sb.append(">");
}
if(StringUtils.isNotEmpty(blank)) {
sb = sb.append("<option value=\"\">").append(blank).append("</option>");
}
for(String key : map.keySet()) {
if(StringUtils.isNotEmpty(defaultValue) && StringUtils.equals(defaultValue, key)) {
sb = sb.append("<option value=\"").append(key).append("\" selected=\"selected\">").append(map.get(key)).append("</option>");
}else {
sb = sb.append("<option value=\"").append(key).append("\">").append(map.get(key)).append("</option>");
}
}
sb = sb.append("</select>");
}
try {
this.ctx.byteWriter.writeString(sb.toString());
} catch (IOException e) {
e.printStackTrace();
}
}
}

@ -0,0 +1,46 @@
package com.zhonghe.active4j.core.cache;
import java.time.Duration;
import com.github.benmanes.caffeine.cache.Caffeine;
import com.github.benmanes.caffeine.cache.LoadingCache;
/**
* @title CacheUtils.java
* @description
Caffeine使
* @time 20191213 2:10:31
* @author
* @version 1.0
*/
public class CacheUtils {
/**
*
*/
public static LoadingCache<String, String> stringCache = Caffeine.newBuilder()
.maximumSize(100) //设置最大缓存个数
.expireAfterAccess(Duration.ofHours(10)) //设置10个小时不访问 缓存回收
.refreshAfterWrite(Duration.ofSeconds(60))//设置每隔60秒刷新一次
.build(key -> {
/**
*
*/
return null;
});
/**
*
* @description
*
* @return String
* @author
* @time 20191213 2:17:11
*/
public static String getStringCache(String key) {
return stringCache.get(key);
}
}

@ -0,0 +1,70 @@
package com.zhonghe.active4j.core.config;
import org.mybatis.spring.annotation.MapperScan;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.context.properties.ConfigurationProperties;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.transaction.annotation.EnableTransactionManagement;
import com.alibaba.druid.pool.DruidDataSource;
import com.baomidou.mybatisplus.annotation.DbType;
import com.baomidou.mybatisplus.extension.plugins.OptimisticLockerInterceptor;
import com.baomidou.mybatisplus.extension.plugins.PaginationInterceptor;
import com.zhonghe.active4j.core.config.properties.DataSourceProperties;
/**
*
* 使Mybatis plus: mybatis
* 使druid
* @author teli_
*
*/
@Configuration
@EnableTransactionManagement
@MapperScan(basePackages = {"com.zhonghe.**.dao"})
public class DbConfig {
@Autowired
private DataSourceProperties dataSourceProperties;
/**
* properties
* @return
*/
@Bean
@ConfigurationProperties(prefix = "spring.datasource")
public DataSourceProperties dataSourceProperties() {
return new DataSourceProperties();
}
/**
* druid
*/
@Bean(initMethod = "init", destroyMethod="close")
public DruidDataSource dataSource() {
DruidDataSource dataSource = new DruidDataSource();
dataSourceProperties.initTo(dataSource);
return dataSource;
}
/**
* mybatis-plus
*/
@Bean
public PaginationInterceptor paginationInterceptor() {
PaginationInterceptor paginationInterceptor = new PaginationInterceptor();
paginationInterceptor.setDialectType(DbType.MYSQL.getDb());
return paginationInterceptor;
}
/**
*
* @return
*/
@Bean
public OptimisticLockerInterceptor optimisticLockerInterceptor() {
return new OptimisticLockerInterceptor();
}
}

@ -0,0 +1,15 @@
package com.zhonghe.active4j.core.config;
import org.springframework.context.annotation.Configuration;
/**
* spring mvc web
*
* @author teli_
*
*/
@Configuration
public class WebConfig {
}

@ -0,0 +1,90 @@
package com.zhonghe.active4j.core.config.properties;
import java.sql.SQLException;
import com.alibaba.druid.pool.DruidDataSource;
import lombok.Data;
/**
*
* @author teli_
*
*/
@Data
public class DataSourceProperties {
private String url;
private String username;
private String password;
private String driverClassName;
private Integer initialSize = 30;
private Integer minIdle = 10;
private Integer maxActive = 200;
private Integer maxWait = 60000;
private Integer timeBetweenEvictionRunsMillis = 60000;
private Integer minEvictableIdleTimeMillis = 300000;
private String validationQuery = "SELECT 1";
private Boolean testWhileIdle = true;
private Boolean testOnBorrow = false;
private Boolean testOnReturn = false;
private Boolean poolPreparedStatements = true;
private Integer maxPoolPreparedStatementPerConnectionSize = 20;
private String filters = "stat";
/**
* dataSource
*
* @param dataSource
*/
public void initTo(DruidDataSource dataSource) {
dataSource.setUrl(url);
dataSource.setUsername(username);
dataSource.setPassword(password);
dataSource.setDriverClassName(driverClassName);
dataSource.setInitialSize(initialSize); // 定义初始连接数
dataSource.setMinIdle(minIdle); // 最小空闲
dataSource.setMaxActive(maxActive); // 定义最大连接数
dataSource.setMaxWait(maxWait); // 最长等待时间
// 配置间隔多久才进行一次检测,检测需要关闭的空闲连接,单位是毫秒
dataSource.setTimeBetweenEvictionRunsMillis(timeBetweenEvictionRunsMillis);
// 配置一个连接在池中最小生存的时间,单位是毫秒
dataSource.setMinEvictableIdleTimeMillis(minEvictableIdleTimeMillis);
dataSource.setValidationQuery(validationQuery);
dataSource.setTestWhileIdle(testWhileIdle);
dataSource.setTestOnBorrow(testOnBorrow);
dataSource.setTestOnReturn(testOnReturn);
// 打开PSCache并且指定每个连接上PSCache的大小
dataSource.setPoolPreparedStatements(poolPreparedStatements);
dataSource.setMaxPoolPreparedStatementPerConnectionSize(maxPoolPreparedStatementPerConnectionSize);
try {
dataSource.setFilters(filters);
} catch (SQLException e) {
e.printStackTrace();
}
}
}

@ -0,0 +1,23 @@
package com.zhonghe.active4j.core.config.properties;
import org.springframework.boot.context.properties.ConfigurationProperties;
import org.springframework.context.annotation.Configuration;
import lombok.Data;
/**
*
* @author teli_
*
*/
@Configuration
@ConfigurationProperties(prefix = "vercode")
@Data
public class VerCodeProperties {
private int randCodeLength;
private String randCodeType;
}

@ -0,0 +1,45 @@
package com.zhonghe.active4j.core.config.web;
import java.beans.PropertyEditorSupport;
import java.text.ParseException;
import java.text.SimpleDateFormat;
import org.springframework.util.StringUtils;
/**
*
*
*/
public class DateConvertEditor extends PropertyEditorSupport {
private SimpleDateFormat datetimeFormat = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
private SimpleDateFormat datetime2Format = new SimpleDateFormat("yyyy-MM-dd HH:mm");
private SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd");
private SimpleDateFormat timeFormat = new SimpleDateFormat("HH:mm");
public void setAsText(String text) throws IllegalArgumentException {
if (StringUtils.hasText(text)) {
try {
if(text.indexOf(":") > 0 && text.length() == 5){
setValue(this.timeFormat.parse(text));
}else if (text.indexOf(":") == -1 && text.length() == 10) {
setValue(this.dateFormat.parse(text));
} else if (text.indexOf(":") > 0 && text.length() == 19) {
setValue(this.datetimeFormat.parse(text));
} else if (text.indexOf(":") > 0 && text.length() == 16) {
setValue(this.datetime2Format.parse(text));
} else if (text.indexOf(":") > 0 && text.length() == 21) {
text = text.replace(".0", "");
setValue(this.datetimeFormat.parse(text));
} else {
throw new IllegalArgumentException(
"Could not parse date, date format is error ");
}
} catch (ParseException ex) {
IllegalArgumentException iae = new IllegalArgumentException(
"Could not parse date: " + ex.getMessage());
iae.initCause(ex);
throw iae;
}
} else {
setValue(null);
}
}
}

@ -0,0 +1,89 @@
package com.zhonghe.active4j.core.config.web;
import java.util.List;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.apache.shiro.authz.UnauthorizedException;
import org.springframework.validation.BindException;
import org.springframework.validation.ObjectError;
import org.springframework.web.bind.annotation.ControllerAdvice;
import org.springframework.web.bind.annotation.ExceptionHandler;
import org.springframework.web.servlet.ModelAndView;
import com.zhonghe.active4j.common.constant.GlobalConstant;
import com.zhonghe.active4j.core.model.AjaxJson;
import com.zhonghe.active4j.core.util.RequestUtil;
import com.zhonghe.active4j.core.util.ResponseUtil;
import lombok.extern.slf4j.Slf4j;
/**
* @title GlobalExceptionHandler.java
* @description
* @time 20191211 5:09:21
* @author
* @version 1.0
*/
@ControllerAdvice
@Slf4j
public class GlobalExceptionHandler {
/**
*
* @description
*
* @return void
* @author
* @time 20191211 5:25:57
*/
@ExceptionHandler(BindException.class)
public void methodArgumentNotValidException(BindException ex, HttpServletRequest request, HttpServletResponse response) {
//打印异常信息
log.error(ex.getMessage());
//返回前端
List<ObjectError> errors = ex.getBindingResult().getAllErrors();
if(null != errors && errors.size() > 0) {
//构造返回前端json字符串
AjaxJson j = new AjaxJson();
j.setSuccess(false);
j.setMsg(errors.get(0).getDefaultMessage());
ResponseUtil.writeJson(response, j.toJsonStr());
}
}
@ExceptionHandler(UnauthorizedException.class)
public ModelAndView unauthorizedException(UnauthorizedException ex, HttpServletRequest request, HttpServletResponse response) {
//判断返回页面还是json
if(RequestUtil.isAjaxRequest(request)) {
//对于ajax异步请求需要返回json结果
ResponseUtil.writeJson(response, AjaxJson.getErrorStr(GlobalConstant.Err_Msg_No_Auth));
return null;
}else {
//直接返回异常页面
ModelAndView mv = new ModelAndView("/403");
return mv;
}
}
@ExceptionHandler(Exception.class)
public ModelAndView exception(Exception ex, HttpServletRequest request, HttpServletResponse response) {
//判断返回页面还是json
if(RequestUtil.isAjaxRequest(request)) {
//对于ajax异步请求需要返回json结果
ResponseUtil.writeJson(response, AjaxJson.getErrorStr(GlobalConstant.Err_Msg_All));
return null;
}else {
//直接返回异常页面
ModelAndView mv = new ModelAndView("/500");
return mv;
}
}
}

@ -0,0 +1,22 @@
package com.zhonghe.active4j.core.config.web;
import java.beans.PropertyEditorSupport;
import org.apache.commons.lang3.StringUtils;
/**
*
* int int:0
*/
public class IntegerConvertEditor extends PropertyEditorSupport {
@Override
public void setAsText(String text) throws IllegalArgumentException {
if(StringUtils.isEmpty(text)) {
text = "0";
}
Integer i = Integer.parseInt(text);
super.setValue(i);
}
}

@ -0,0 +1,53 @@
package com.zhonghe.active4j.core.init;
import org.springframework.beans.factory.DisposableBean;
import org.springframework.beans.factory.InitializingBean;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.context.annotation.Configuration;
import com.zhonghe.active4j.core.threadpool.ThreadPoolManager;
import com.zhonghe.active4j.system.service.SystemService;
import lombok.extern.slf4j.Slf4j;
/**
*
* @author teli_
*
*/
@Slf4j
@Configuration
public class CommonStartConfig implements InitializingBean, DisposableBean {
@Autowired
private SystemService systemService;
/**
* spring
*/
@Override
public void afterPropertiesSet() throws Exception {
log.info("---------------初始化启动执行---------------");
//系统初始化数据字典
systemService.initDictionary();
//系统初始化部门数据
systemService.initDeparts();
}
/**
*
*/
@Override
public void destroy() throws Exception {
log.info("---------------容器销毁启动执行---------------");
//关闭线程池
ThreadPoolManager.me().shutdown();
log.info("---------------容器销毁启动执行完成---------------");
}
}

@ -0,0 +1,101 @@
package com.zhonghe.active4j.core.metadata;
import org.apache.ibatis.reflection.MetaObject;
import org.springframework.stereotype.Component;
import com.baomidou.mybatisplus.core.handlers.MetaObjectHandler;
import com.zhonghe.active4j.core.util.DateUtils;
import com.zhonghe.active4j.core.util.ShiroUtils;
/**
*
*
* @author teli_
*
*/
@Component
public class CustomMetaDataObjectHandle implements MetaObjectHandler {
/**
*
*/
@Override
public void insertFill(MetaObject metaObject) {
/**
*
*/
Object versions = getFieldValByName(getVersionsFieldName(), metaObject);
if (versions == null) {
setFieldValByName(getVersionsFieldName(), 0, metaObject);
}
/**
*
*/
Object createDate = getFieldValByName(getCreateTimeFieldName(), metaObject);
if (null == createDate) {
setFieldValByName(getCreateTimeFieldName(), DateUtils.getNow(), metaObject);
}
/**
*
*/
Object createName = getFieldValByName(getCreateNameFieldName(), metaObject);
if (null == createName) {
if(ShiroUtils.hasLogin()) {
setFieldValByName(getCreateNameFieldName(), ShiroUtils.getSessionUserName(), metaObject);
}else {
setFieldValByName(getCreateNameFieldName(), "system", metaObject);
}
}
}
/**
*
*/
@Override
public void updateFill(MetaObject metaObject) {
Object updateDate = getFieldValByName(getUpdateTimeFieldName(), metaObject);
if (null == updateDate) {
setFieldValByName(getUpdateTimeFieldName(), DateUtils.getNow(), metaObject);
}
Object updateName = getFieldValByName(getUpdateNameFieldName(), metaObject);
if (null == updateName) {
if(ShiroUtils.hasLogin()) {
setFieldValByName(getUpdateNameFieldName(), ShiroUtils.getSessionUserName(), metaObject);
}else {
setFieldValByName(getUpdateNameFieldName(), "system", metaObject);
}
}
}
/**
*
*
* @return
*/
protected String getVersionsFieldName() {
return "versions";
}
protected String getCreateTimeFieldName() {
return "createDate";
}
protected String getCreateNameFieldName() {
return "createName";
}
protected String getUpdateTimeFieldName() {
return "updateDate";
}
protected String getUpdateNameFieldName() {
return "updateName";
}
}

@ -0,0 +1,57 @@
package com.zhonghe.active4j.core.model;
import java.util.Map;
import com.alibaba.fastjson.JSON;
import com.alibaba.fastjson.JSONObject;
import lombok.Getter;
import lombok.Setter;
/**
* ajax json
*
* @author teli_
*
*/
@Getter
@Setter
public class AjaxJson {
private boolean success = true;// 是否成功
private String msg = "操作成功";// 提示信息
private Object obj = null;// 其他信息
private Map<String, Object> attributes;// 其他参数
/**
* @description
* json
* @return String
* @author
* @time 20191211 5:29:56
*/
public String toJsonStr() {
JSONObject obj = new JSONObject();
obj.put("success", this.isSuccess());
obj.put("msg", this.getMsg());
obj.put("obj", this.obj);
obj.put("attributes", this.attributes);
return obj.toJSONString();
}
/**
*
* @param msg
* @return
*/
public static String getErrorStr(String msg) {
AjaxJson j = new AjaxJson();
j.setSuccess(false);
j.setMsg(msg);
return JSON.toJSONString(j);
}
}

@ -0,0 +1,6 @@
package com.zhonghe.active4j.core.model;
public enum LogType {
login, logout, save, insert, del, update, timer, normal, abnormal;
}

@ -0,0 +1,25 @@
package com.zhonghe.active4j.core.model;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import lombok.Getter;
import lombok.Setter;
@Getter
@Setter
public class PageInfo<T> {
private long page;
private long limit;
public Page<T> getPageEntity() {
return new Page<T>(this.getPage(), this.getLimit());
}
}

@ -0,0 +1,5 @@
package com.zhonghe.active4j.core.model;
public enum QueryCondition {
eq, like, range
}

@ -0,0 +1,23 @@
package com.zhonghe.active4j.core.model;
import lombok.Getter;
import lombok.Setter;
/**
*
* @author teli_
*
*/
@Getter
@Setter
public class ResultJson {
private int code = 0;
private boolean success = true;
private String msg = "操作成功";
private Object data;
}

@ -0,0 +1,43 @@
package com.zhonghe.active4j.core.model;
import java.util.List;
/**
*
* @author teli_
*
*/
public class TreeModel {
private String id;
private String label;
private List<TreeModel> children;
public String getId() {
return id;
}
public void setId(String id) {
this.id = id;
}
public String getLabel() {
return label;
}
public void setLabel(String label) {
this.label = label;
}
public List<TreeModel> getChildren() {
return children;
}
public void setChildren(List<TreeModel> children) {
this.children = children;
}
}

@ -0,0 +1,143 @@
package com.zhonghe.active4j.core.query;
import java.lang.reflect.Field;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;
import java.util.Map;
import org.apache.commons.lang3.StringUtils;
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.zhonghe.active4j.common.constant.GlobalConstant;
import com.zhonghe.active4j.common.entity.BaseEntity;
import com.zhonghe.active4j.core.annotation.QueryField;
import com.zhonghe.active4j.core.model.QueryCondition;
import com.zhonghe.active4j.core.util.ReflectUtil;
/**
*
* @author teli_
*
*/
public class QueryUtils {
/**
*
* @param baseEntity
* @param paramsMap _begin _end
* @return
*/
public static <T> QueryWrapper<T> installQueryWrapper(BaseEntity baseEntity){
return installQueryWrapper(baseEntity, null);
}
/**
*
* @param baseEntity
* @return
*/
public static <T> QueryWrapper<T> installQueryWrapper(BaseEntity baseEntity, Map<String, String[]> paramsMap){
QueryWrapper<T> t = new QueryWrapper<T>();
List<Field> fields = new ArrayList<Field>();
Class<?> clazz = baseEntity.getClass();
while(null != clazz) {
fields.addAll(Arrays.asList(clazz.getDeclaredFields()));
clazz = clazz.getSuperclass();
}
//查询条件的拼接
for(Field field : fields) {
QueryField qf = field.getAnnotation(QueryField.class);
if(null != qf) {
//字段,取的是表的列名,不是实体名
String queryColumn = qf.queryColumn();
//构建的查询条件
QueryCondition conditon = qf.condition();
//如果是范围查询,主要是针对日期时间类型的 从 到
if(QueryCondition.range.equals(conditon) && null != paramsMap) {
//范围查询的开始值
String[] beginValue = paramsMap.get(field.getName() + "_begin");
if(null != beginValue && beginValue.length > 0) {
if(StringUtils.isNotEmpty(beginValue[0].trim())) {
t.ge(queryColumn, beginValue[0].trim());
}
}
//范围查询的结束值
String[] endValue = paramsMap.get(field.getName() + "_end");
if(null != endValue && endValue.length > 0) {
if(StringUtils.isNotEmpty(endValue[0].trim())) {
t.le(queryColumn, endValue[0].trim());
}
}
}
//普通字段查询
else {
//通过反射技术获取字段的值,用于拼接查询条件
Object value = ReflectUtil.getValueByField(field, baseEntity);
//构建查询
buildQueryWrapper(t, queryColumn, conditon, value);
}
}
}
//排序规则的处理
String[] orderFields = paramsMap.get(GlobalConstant.Order_Field);
String[] orderTypes = paramsMap.get(GlobalConstant.Order_Type);
if(null != orderFields && null != orderTypes) {
String orderField = orderFields[0].trim();
String orderType = orderTypes[0].trim();
if(StringUtils.equals(orderType, "asc")) {
//升序排列
t.orderByAsc(com.baomidou.mybatisplus.core.toolkit.StringUtils.camelToUnderline(orderField));
}else if(StringUtils.equals(orderType, "desc")){
//降序排列
t.orderByDesc(com.baomidou.mybatisplus.core.toolkit.StringUtils.camelToUnderline(orderField));
}
}
return t;
}
/**
*
* @param <T>
* @param column
* @param conditon
* @param value
*/
public static <T> void buildQueryWrapper(QueryWrapper<T> queryWrapper, String column, QueryCondition condition, Object value) {
if(StringUtils.isNotEmpty(column) && null != value) {
switch(condition) {
case eq:
queryWrapper.eq(column, value);
break;
case like:
queryWrapper.like(column, value);
break;
default:
break;
}
}
}
}

@ -0,0 +1,48 @@
package com.zhonghe.active4j.core.redis;
import java.nio.charset.Charset;
import org.springframework.data.redis.serializer.RedisSerializer;
import org.springframework.data.redis.serializer.SerializationException;
import com.alibaba.fastjson.JSON;
import com.alibaba.fastjson.serializer.SerializerFeature;
/**
* @title FastJson2JsonRedisSerializer.java
* @description fastjsonredis
* @time 20191217 4:57:27
* @author
* @version 1.0
*/
public class FastJson2JsonRedisSerializer<T> implements RedisSerializer<T> {
public static final Charset DEFAULT_CHARSET = Charset.forName("UTF-8");
private Class<T> clazz;
public FastJson2JsonRedisSerializer(Class<T> clazz) {
super();
this.clazz = clazz;
}
@Override
public byte[] serialize(T t) throws SerializationException {
if (t == null) {
return new byte[0];
}
return JSON.toJSONString(t, SerializerFeature.WriteClassName).getBytes(DEFAULT_CHARSET);
}
@Override
public T deserialize(byte[] bytes) throws SerializationException {
if (bytes == null || bytes.length <= 0) {
return null;
}
String str = new String(bytes, DEFAULT_CHARSET);
return (T) JSON.parseObject(str, clazz);
}
}

@ -0,0 +1,570 @@
package com.zhonghe.active4j.core.redis;
import java.util.List;
import java.util.Map;
import java.util.Set;
import java.util.concurrent.TimeUnit;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.stereotype.Component;
import org.springframework.util.CollectionUtils;
/**
* @title RedisUtil.java
* @description redis
* @time 20191217 5:00:05
* @author
* @version 1.0
*/
@Component
public class RedisApi {
@Autowired
private RedisTemplate<String, Object> redisTemplate;
// =============================common============================
/**
*
*
* @param key
* @param time ()
* @return
*/
public boolean expire(String key, long time) {
try {
if (time > 0) {
redisTemplate.expire(key, time, TimeUnit.SECONDS);
}
return true;
} catch (Exception e) {
e.printStackTrace();
return false;
}
}
/**
* key
*
* @param key null
* @return () 0
*/
public long getExpire(String key) {
return redisTemplate.getExpire(key, TimeUnit.SECONDS);
}
/**
* key
*
* @param key
* @return true false
*/
public boolean hasKey(String key) {
try {
return redisTemplate.hasKey(key);
} catch (Exception e) {
e.printStackTrace();
return false;
}
}
/**
*
*
* @param key
*/
@SuppressWarnings("unchecked")
public void del(String... key) {
if (key != null && key.length > 0) {
if (key.length == 1) {
redisTemplate.delete(key[0]);
} else {
redisTemplate.delete(CollectionUtils.arrayToList(key));
}
}
}
// ============================String=============================
/**
*
*
* @param key
* @return
*/
public Object get(String key) {
return key == null ? null : redisTemplate.opsForValue().get(key);
}
/**
*
*
* @param key
* @param value
* @return true false
*/
public boolean set(String key, Object value) {
try {
redisTemplate.opsForValue().set(key, value);
return true;
} catch (Exception e) {
e.printStackTrace();
return false;
}
}
/**
*
*
* @param key
* @param value
* @param time () time0 time0
* @return true false
*/
public boolean set(String key, Object value, long time) {
try {
if (time > 0) {
redisTemplate.opsForValue().set(key, value, time, TimeUnit.SECONDS);
} else {
set(key, value);
}
return true;
} catch (Exception e) {
e.printStackTrace();
return false;
}
}
/**
*
*
* @param key
* @param delta (0)
* @return
*/
public long incr(String key, long delta) {
if (delta < 0) {
throw new RuntimeException("递增因子必须大于0");
}
return redisTemplate.opsForValue().increment(key, delta);
}
/**
*
*
* @param key
* @param delta (0)
* @return
*/
public long decr(String key, long delta) {
if (delta < 0) {
throw new RuntimeException("递减因子必须大于0");
}
return redisTemplate.opsForValue().increment(key, -delta);
}
// ================================Map=================================
/**
* HashGet
*
* @param key null
* @param item null
* @return
*/
public Object hget(String key, String item) {
return redisTemplate.opsForHash().get(key, item);
}
/**
* hashKey
*
* @param key
* @return
*/
public Map<Object, Object> hmget(String key) {
return redisTemplate.opsForHash().entries(key);
}
/**
* HashSet
*
* @param key
* @param map
* @return true false
*/
public boolean hmset(String key, Map<String, Object> map) {
try {
redisTemplate.opsForHash().putAll(key, map);
return true;
} catch (Exception e) {
e.printStackTrace();
return false;
}
}
/**
* HashSet
*
* @param key
* @param map
* @param time ()
* @return true false
*/
public boolean hmset(String key, Map<String, Object> map, long time) {
try {
redisTemplate.opsForHash().putAll(key, map);
if (time > 0) {
expire(key, time);
}
return true;
} catch (Exception e) {
e.printStackTrace();
return false;
}
}
/**
* hash,
*
* @param key
* @param item
* @param value
* @return true false
*/
public boolean hset(String key, String item, Object value) {
try {
redisTemplate.opsForHash().put(key, item, value);
return true;
} catch (Exception e) {
e.printStackTrace();
return false;
}
}
/**
* hash,
*
* @param key
* @param item
* @param value
* @param time () :hash,
* @return true false
*/
public boolean hset(String key, String item, Object value, long time) {
try {
redisTemplate.opsForHash().put(key, item, value);
if (time > 0) {
expire(key, time);
}
return true;
} catch (Exception e) {
e.printStackTrace();
return false;
}
}
/**
* hash
*
* @param key null
* @param item 使 null
*/
public void hdel(String key, Object... item) {
redisTemplate.opsForHash().delete(key, item);
}
/**
* hash
*
* @param key null
* @param item null
* @return true false
*/
public boolean hHasKey(String key, String item) {
return redisTemplate.opsForHash().hasKey(key, item);
}
/**
* hash ,
*
* @param key
* @param item
* @param by (0)
* @return
*/
public double hincr(String key, String item, double by) {
return redisTemplate.opsForHash().increment(key, item, by);
}
/**
* hash
*
* @param key
* @param item
* @param by (0)
* @return
*/
public double hdecr(String key, String item, double by) {
return redisTemplate.opsForHash().increment(key, item, -by);
}
// ============================set=============================
/**
* keySet
*
* @param key
* @return
*/
public Set<Object> sGet(String key) {
try {
return redisTemplate.opsForSet().members(key);
} catch (Exception e) {
e.printStackTrace();
return null;
}
}
/**
* valueset,
*
* @param key
* @param value
* @return true false
*/
public boolean sHasKey(String key, Object value) {
try {
return redisTemplate.opsForSet().isMember(key, value);
} catch (Exception e) {
e.printStackTrace();
return false;
}
}
/**
* set
*
* @param key
* @param values
* @return
*/
public long sSet(String key, Object... values) {
try {
return redisTemplate.opsForSet().add(key, values);
} catch (Exception e) {
e.printStackTrace();
return 0;
}
}
/**
* set
*
* @param key
* @param time ()
* @param values
* @return
*/
public long sSetAndTime(String key, long time, Object... values) {
try {
Long count = redisTemplate.opsForSet().add(key, values);
if (time > 0)
expire(key, time);
return count;
} catch (Exception e) {
e.printStackTrace();
return 0;
}
}
/**
* set
*
* @param key
* @return
*/
public long sGetSetSize(String key) {
try {
return redisTemplate.opsForSet().size(key);
} catch (Exception e) {
e.printStackTrace();
return 0;
}
}
/**
* value
*
* @param key
* @param values
* @return
*/
public long setRemove(String key, Object... values) {
try {
Long count = redisTemplate.opsForSet().remove(key, values);
return count;
} catch (Exception e) {
e.printStackTrace();
return 0;
}
}
// ===============================list=================================
/**
* list
*
* @param key
* @param start
* @param end 0 -1
* @return
*/
public List<Object> lGet(String key, long start, long end) {
try {
return redisTemplate.opsForList().range(key, start, end);
} catch (Exception e) {
e.printStackTrace();
return null;
}
}
/**
* list
*
* @param key
* @return
*/
public long lGetListSize(String key) {
try {
return redisTemplate.opsForList().size(key);
} catch (Exception e) {
e.printStackTrace();
return 0;
}
}
/**
* list
*
* @param key
* @param index index>=0 0 1 index<0-1-2
* @return
*/
public Object lGetIndex(String key, long index) {
try {
return redisTemplate.opsForList().index(key, index);
} catch (Exception e) {
e.printStackTrace();
return null;
}
}
/**
* list
*
* @param key
* @param value
* @param time ()
* @return
*/
public boolean lSet(String key, Object value) {
try {
redisTemplate.opsForList().rightPush(key, value);
return true;
} catch (Exception e) {
e.printStackTrace();
return false;
}
}
/**
* list
*
* @param key
* @param value
* @param time ()
* @return
*/
public boolean lSet(String key, Object value, long time) {
try {
redisTemplate.opsForList().rightPush(key, value);
if (time > 0)
expire(key, time);
return true;
} catch (Exception e) {
e.printStackTrace();
return false;
}
}
/**
* list
*
* @param key
* @param value
* @param time ()
* @return
*/
public boolean lSet(String key, List<Object> value) {
try {
redisTemplate.opsForList().rightPushAll(key, value);
return true;
} catch (Exception e) {
e.printStackTrace();
return false;
}
}
/**
* list
*
* @param key
* @param value
* @param time ()
* @return
*/
public boolean lSet(String key, List<Object> value, long time) {
try {
redisTemplate.opsForList().rightPushAll(key, value);
if (time > 0)
expire(key, time);
return true;
} catch (Exception e) {
e.printStackTrace();
return false;
}
}
/**
* list
*
* @param key
* @param index
* @param value
* @return
*/
public boolean lUpdateIndex(String key, long index, Object value) {
try {
redisTemplate.opsForList().set(key, index, value);
return true;
} catch (Exception e) {
e.printStackTrace();
return false;
}
}
/**
* Nvalue
*
* @param key
* @param count
* @param value
* @return
*/
public long lRemove(String key, long count, Object value) {
try {
Long remove = redisTemplate.opsForList().remove(key, count, value);
return remove;
} catch (Exception e) {
e.printStackTrace();
return 0;
}
}
}

@ -0,0 +1,41 @@
package com.zhonghe.active4j.core.redis;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.data.redis.connection.RedisConnectionFactory;
import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.data.redis.serializer.StringRedisSerializer;
/**
* @title RedisConfig.java
* @description
redis
* @time 20191217 4:41:31
* @author
* @version 1.0
*/
@Configuration
public class RedisConfig {
@Bean
@SuppressWarnings("all")
public RedisTemplate<String, Object> redisTemplate(RedisConnectionFactory factory) {
RedisTemplate<String, Object> template = new RedisTemplate<String, Object>();
template.setConnectionFactory(factory);
FastJson2JsonRedisSerializer fastJsonRedisSerializer = new FastJson2JsonRedisSerializer(Object.class);
StringRedisSerializer stringRedisSerializer = new StringRedisSerializer();
// key采用String的序列化方式
template.setKeySerializer(stringRedisSerializer);
// hash的key也采用String的序列化方式
template.setHashKeySerializer(stringRedisSerializer);
// value序列化方式采用jackson
template.setValueSerializer(fastJsonRedisSerializer);
// hash的value序列化方式采用jackson
template.setHashValueSerializer(fastJsonRedisSerializer);
template.afterPropertiesSet();
return template;
}
}

@ -0,0 +1,35 @@
package com.zhonghe.active4j.core.redis;
import org.springframework.boot.autoconfigure.condition.ConditionalOnProperty;
import org.springframework.boot.context.properties.ConfigurationProperties;
import org.springframework.context.annotation.Configuration;
import lombok.Getter;
import lombok.Setter;
/**
* @title RedisPropertiesLoader.java
* @description
redis shiro使
* @time 20191217 2:58:24
* @author
* @version 1.0
*/
@ConfigurationProperties(prefix="spring.redis")
@Configuration
@ConditionalOnProperty(prefix="spring.redis",value={"host", "port", "password", "timeout", "database"}, matchIfMissing=false)
@Getter
@Setter
public class RedisPropertiesLoader {
private String host;
private int port;
private String password;
private int timeout;
private int database;
}

@ -0,0 +1,19 @@
package com.zhonghe.active4j.core.sa_token;
import cn.dev33.satoken.interceptor.SaInterceptor;
import cn.dev33.satoken.stp.StpUtil;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.servlet.config.annotation.InterceptorRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;
@Configuration
public class SaTokenConfigure implements WebMvcConfigurer {
// 注册拦截器
@Override
public void addInterceptors(InterceptorRegistry registry) {
// 注册 Sa-Token 拦截器,校验规则为 StpUtil.checkLogin() 登录校验。
registry.addInterceptor(new SaInterceptor(handle -> StpUtil.checkLogin()))
.addPathPatterns("/**")
.excludePathPatterns("/login/login");
}
}

@ -0,0 +1,30 @@
package com.zhonghe.active4j.core.session;
/**
* @title GlobalSessionConstant.java
* @description
session使
* @time 2019126 9:28:33
* @author
* @version 1.0
*/
public class GlobalSessionConstant {
//操作系统
public static final String SESSION_OS = "session_os";
//浏览器
public static final String SESSION_BROWSER = "session_browser";
//用户
public static final String SESSION_USER = "user";
/**
* session
*/
public static final String SESSION_SAVE_TIME = "session_save_time";
//session是否需要保存
public static final String SESSION_NEED_SAVE = "session_need_save";
}

@ -0,0 +1,52 @@
package com.zhonghe.active4j.core.session;
import javax.servlet.http.HttpServletRequest;
import org.apache.shiro.session.Session;
import org.apache.shiro.session.mgt.SessionContext;
import org.apache.shiro.session.mgt.SessionFactory;
import org.apache.shiro.session.mgt.SimpleSession;
import org.apache.shiro.web.session.mgt.WebSessionContext;
import com.zhonghe.active4j.core.util.DateUtils;
import com.zhonghe.active4j.core.util.IpUtil;
import com.zhonghe.active4j.core.util.RequestUtil;
import eu.bitwalker.useragentutils.UserAgent;
/**
* @title MySessionFactory.java
* @description session factory
* @time 2019126 9:20:57
* @author
* @version 1.0
*/
public class MySessionFactory implements SessionFactory {
@Override
public Session createSession(SessionContext initData) {
SimpleSession session = new SimpleSession();
if (initData != null && initData instanceof WebSessionContext) {
WebSessionContext sessionContext = (WebSessionContext) initData;
HttpServletRequest request = (HttpServletRequest) sessionContext.getServletRequest();
if (null != request) {
UserAgent userAgent = UserAgent.parseUserAgentString(RequestUtil.getRequest().getHeader("User-Agent"));
// 获取客户端操作系统
String os = userAgent.getOperatingSystem().getName();
// 获取客户端浏览器
String browser = userAgent.getBrowser().getName();
session.setHost(IpUtil.getIpAddr(request));
//借用session的attribute赋值
session.setAttribute(GlobalSessionConstant.SESSION_OS, os);
session.setAttribute(GlobalSessionConstant.SESSION_BROWSER, browser);
session.setAttribute(GlobalSessionConstant.SESSION_SAVE_TIME, DateUtils.getNow());
session.setAttribute(GlobalSessionConstant.SESSION_NEED_SAVE, false);
}
}
return session;
}
}

@ -0,0 +1,409 @@
package com.zhonghe.active4j.core.session;
import java.io.Serializable;
import java.util.Collection;
import java.util.Collections;
import java.util.List;
import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.apache.shiro.session.ExpiredSessionException;
import org.apache.shiro.session.InvalidSessionException;
import org.apache.shiro.session.Session;
import org.apache.shiro.session.mgt.DefaultSessionManager;
import org.apache.shiro.session.mgt.DelegatingSession;
import org.apache.shiro.session.mgt.SessionContext;
import org.apache.shiro.session.mgt.SessionKey;
import org.apache.shiro.session.mgt.ValidatingSession;
import org.apache.shiro.web.servlet.Cookie;
import org.apache.shiro.web.servlet.ShiroHttpServletRequest;
import org.apache.shiro.web.servlet.ShiroHttpSession;
import org.apache.shiro.web.servlet.SimpleCookie;
import org.apache.shiro.web.session.mgt.WebSessionKey;
import org.apache.shiro.web.session.mgt.WebSessionManager;
import org.apache.shiro.web.util.WebUtils;
import org.crazycake.shiro.RedisSessionDAO;
import com.zhonghe.active4j.core.util.ApplicationContextUtil;
import com.zhonghe.active4j.core.util.DateUtils;
import com.zhonghe.active4j.monitor.entity.OnlineSessionEntity;
import com.zhonghe.active4j.monitor.service.OnlineSessionService;
import lombok.extern.slf4j.Slf4j;
/**
* @title MyWebSessionManager.java
* @description websessionmanager
* @time 2019126 4:01:00
* @author
* @version 1.0
*/
@Slf4j
public class MyWebSessionManager extends DefaultSessionManager implements WebSessionManager {
/**
* sessionsession
* 线线
* 使sessiondao
*/
@Override
public void validateSessions() {
/**
* getActiveSessions sessions
*/
super.validateSessions();
//新增功能,不需要时可以去除
validateOnlineSession();
}
/**
* session使redisredisactivesession使keysredis使keys
* sesion使redissession
*/
@Override
protected Collection<Session> getActiveSessions() {
if(this.sessionDAO instanceof RedisSessionDAO) {
log.info("系统采用redis管理session,建议不能够使用Keys返回session");
return Collections.<Session>emptySet();
}else {
return super.getActiveSessions();
}
}
/**
* @description
* 线session
* @return void
* @author
* @time 2019129 10:01:15
*/
private void validateOnlineSession() {
/**
* active session
* 线使
*/
OnlineSessionService onlineSessionService = ApplicationContextUtil.getContext().getBean(OnlineSessionService.class);
List<OnlineSessionEntity> lstOnlineSessions = onlineSessionService.list();
if(null != lstOnlineSessions && lstOnlineSessions.size() > 0) {
for(OnlineSessionEntity onlineSession : lstOnlineSessions) {
//根据onlinesession获取session
try {
Session session = this.sessionDAO.readSession(onlineSession.getSessionId());
if(null != session) {
//存在session
if(session instanceof ValidatingSession) {
((ValidatingSession) session).validate();
}
//更新session时间
onlineSession.setLastTime(session.getLastAccessTime());
onlineSession.setUpdateDate(DateUtils.getNow());
onlineSession.setUpdateName("system");
onlineSessionService.saveOrUpdate(onlineSession);
}else {
//不存在session
onlineSessionService.removeById(onlineSession.getId());
}
}catch(Exception e) {
//或者取不到session或者session已经过期删除session
onlineSessionService.removeById(onlineSession.getId());
log.warn(e.getMessage(), e);
}
}
}
}
private Cookie sessionIdCookie;
private boolean sessionIdCookieEnabled;
private boolean sessionIdUrlRewritingEnabled;
public MyWebSessionManager() {
Cookie cookie = new SimpleCookie(ShiroHttpSession.DEFAULT_SESSION_ID_NAME);
cookie.setHttpOnly(true); // more secure, protects against XSS attacks
this.sessionIdCookie = cookie;
this.sessionIdCookieEnabled = true;
this.sessionIdUrlRewritingEnabled = true;
}
public Cookie getSessionIdCookie() {
return sessionIdCookie;
}
@SuppressWarnings({ "UnusedDeclaration" })
public void setSessionIdCookie(Cookie sessionIdCookie) {
this.sessionIdCookie = sessionIdCookie;
}
public boolean isSessionIdCookieEnabled() {
return sessionIdCookieEnabled;
}
@SuppressWarnings({ "UnusedDeclaration" })
public void setSessionIdCookieEnabled(boolean sessionIdCookieEnabled) {
this.sessionIdCookieEnabled = sessionIdCookieEnabled;
}
public boolean isSessionIdUrlRewritingEnabled() {
return sessionIdUrlRewritingEnabled;
}
@SuppressWarnings({ "UnusedDeclaration" })
public void setSessionIdUrlRewritingEnabled(boolean sessionIdUrlRewritingEnabled) {
this.sessionIdUrlRewritingEnabled = sessionIdUrlRewritingEnabled;
}
private void storeSessionId(Serializable currentId, HttpServletRequest request, HttpServletResponse response) {
if (currentId == null) {
String msg = "sessionId cannot be null when persisting for subsequent requests.";
throw new IllegalArgumentException(msg);
}
Cookie template = getSessionIdCookie();
Cookie cookie = new SimpleCookie(template);
String idString = currentId.toString();
cookie.setValue(idString);
cookie.saveTo(request, response);
log.trace("Set session ID cookie for session with id {}", idString);
}
private void removeSessionIdCookie(HttpServletRequest request, HttpServletResponse response) {
getSessionIdCookie().removeFrom(request, response);
}
private String getSessionIdCookieValue(ServletRequest request, ServletResponse response) {
if (!isSessionIdCookieEnabled()) {
log.debug("Session ID cookie is disabled - session id will not be acquired from a request cookie.");
return null;
}
if (!(request instanceof HttpServletRequest)) {
log.debug("Current request is not an HttpServletRequest - cannot get session ID cookie. Returning null.");
return null;
}
HttpServletRequest httpRequest = (HttpServletRequest) request;
return getSessionIdCookie().readValue(httpRequest, WebUtils.toHttp(response));
}
private Serializable getReferencedSessionId(ServletRequest request, ServletResponse response) {
String id = getSessionIdCookieValue(request, response);
if (id != null) {
request.setAttribute(ShiroHttpServletRequest.REFERENCED_SESSION_ID_SOURCE, ShiroHttpServletRequest.COOKIE_SESSION_ID_SOURCE);
} else {
// not in a cookie, or cookie is disabled - try the request URI as a fallback
// (i.e. due to URL rewriting):
// try the URI path segment parameters first:
id = getUriPathSegmentParamValue(request, ShiroHttpSession.DEFAULT_SESSION_ID_NAME);
if (id == null) {
// not a URI path segment parameter, try the query parameters:
String name = getSessionIdName();
id = request.getParameter(name);
if (id == null) {
// try lowercase:
id = request.getParameter(name.toLowerCase());
}
}
if (id != null) {
request.setAttribute(ShiroHttpServletRequest.REFERENCED_SESSION_ID_SOURCE, ShiroHttpServletRequest.URL_SESSION_ID_SOURCE);
}
}
if (id != null) {
request.setAttribute(ShiroHttpServletRequest.REFERENCED_SESSION_ID, id);
// automatically mark it valid here. If it is invalid, the
// onUnknownSession method below will be invoked and we'll remove the attribute
// at that time.
request.setAttribute(ShiroHttpServletRequest.REFERENCED_SESSION_ID_IS_VALID, Boolean.TRUE);
}
// always set rewrite flag - SHIRO-361
request.setAttribute(ShiroHttpServletRequest.SESSION_ID_URL_REWRITING_ENABLED, isSessionIdUrlRewritingEnabled());
return id;
}
// SHIRO-351
// also see
// http://cdivilly.wordpress.com/2011/04/22/java-servlets-uri-parameters/
// since 1.2.2
private String getUriPathSegmentParamValue(ServletRequest servletRequest, String paramName) {
if (!(servletRequest instanceof HttpServletRequest)) {
return null;
}
HttpServletRequest request = (HttpServletRequest) servletRequest;
String uri = request.getRequestURI();
if (uri == null) {
return null;
}
int queryStartIndex = uri.indexOf('?');
if (queryStartIndex >= 0) { // get rid of the query string
uri = uri.substring(0, queryStartIndex);
}
int index = uri.indexOf(';'); // now check for path segment parameters:
if (index < 0) {
// no path segment params - return:
return null;
}
// there are path segment params, let's get the last one that may exist:
final String TOKEN = paramName + "=";
uri = uri.substring(index + 1); // uri now contains only the path segment params
// we only care about the last JSESSIONID param:
index = uri.lastIndexOf(TOKEN);
if (index < 0) {
// no segment param:
return null;
}
uri = uri.substring(index + TOKEN.length());
index = uri.indexOf(';'); // strip off any remaining segment params:
if (index >= 0) {
uri = uri.substring(0, index);
}
return uri; // what remains is the value
}
// since 1.2.1
private String getSessionIdName() {
String name = this.sessionIdCookie != null ? this.sessionIdCookie.getName() : null;
if (name == null) {
name = ShiroHttpSession.DEFAULT_SESSION_ID_NAME;
}
return name;
}
protected Session createExposedSession(Session session, SessionContext context) {
if (!WebUtils.isWeb(context)) {
return super.createExposedSession(session, context);
}
ServletRequest request = WebUtils.getRequest(context);
ServletResponse response = WebUtils.getResponse(context);
SessionKey key = new WebSessionKey(session.getId(), request, response);
return new DelegatingSession(this, key);
}
protected Session createExposedSession(Session session, SessionKey key) {
if (!WebUtils.isWeb(key)) {
return super.createExposedSession(session, key);
}
ServletRequest request = WebUtils.getRequest(key);
ServletResponse response = WebUtils.getResponse(key);
SessionKey sessionKey = new WebSessionKey(session.getId(), request, response);
return new DelegatingSession(this, sessionKey);
}
/**
* Stores the Session's ID, usually as a Cookie, to associate with future
* requests.
*
* @param session the session that was just {@link #createSession created}.
*/
@Override
protected void onStart(Session session, SessionContext context) {
super.onStart(session, context);
if (!WebUtils.isHttp(context)) {
log.debug("SessionContext argument is not HTTP compatible or does not have an HTTP request/response " + "pair. No session ID cookie will be set.");
return;
}
HttpServletRequest request = WebUtils.getHttpRequest(context);
HttpServletResponse response = WebUtils.getHttpResponse(context);
if (isSessionIdCookieEnabled()) {
Serializable sessionId = session.getId();
storeSessionId(sessionId, request, response);
} else {
log.debug("Session ID cookie is disabled. No cookie has been set for new session with id {}", session.getId());
}
request.removeAttribute(ShiroHttpServletRequest.REFERENCED_SESSION_ID_SOURCE);
request.setAttribute(ShiroHttpServletRequest.REFERENCED_SESSION_IS_NEW, Boolean.TRUE);
}
@Override
public Serializable getSessionId(SessionKey key) {
Serializable id = super.getSessionId(key);
if (id == null && WebUtils.isWeb(key)) {
ServletRequest request = WebUtils.getRequest(key);
ServletResponse response = WebUtils.getResponse(key);
id = getSessionId(request, response);
}
return id;
}
protected Serializable getSessionId(ServletRequest request, ServletResponse response) {
return getReferencedSessionId(request, response);
}
@Override
protected void onExpiration(Session s, ExpiredSessionException ese, SessionKey key) {
super.onExpiration(s, ese, key);
onInvalidation(key);
}
@Override
protected void onInvalidation(Session session, InvalidSessionException ise, SessionKey key) {
super.onInvalidation(session, ise, key);
onInvalidation(key);
}
private void onInvalidation(SessionKey key) {
ServletRequest request = WebUtils.getRequest(key);
if (request != null) {
request.removeAttribute(ShiroHttpServletRequest.REFERENCED_SESSION_ID_IS_VALID);
}
if (WebUtils.isHttp(key)) {
log.debug("Referenced session was invalid. Removing session ID cookie.");
removeSessionIdCookie(WebUtils.getHttpRequest(key), WebUtils.getHttpResponse(key));
} else {
log.debug("SessionKey argument is not HTTP compatible or does not have an HTTP request/response " + "pair. Session ID cookie will not be removed due to invalidated session.");
}
}
@Override
protected void onStop(Session session, SessionKey key) {
super.onStop(session, key);
if (WebUtils.isHttp(key)) {
HttpServletRequest request = WebUtils.getHttpRequest(key);
HttpServletResponse response = WebUtils.getHttpResponse(key);
log.debug("Session has been stopped (subject logout or explicit stop). Removing session ID cookie.");
removeSessionIdCookie(request, response);
} else {
log.debug("SessionKey argument is not HTTP compatible or does not have an HTTP request/response " + "pair. Session ID cookie will not be removed due to stopped session.");
}
}
/**
* This is a native session manager implementation, so this method returns
* {@code false} always.
*
* @return {@code false} always
* @since 1.2
*/
public boolean isServletContainerSessions() {
return false;
}
}

@ -0,0 +1,109 @@
package com.zhonghe.active4j.core.shiro;
import java.util.HashSet;
import java.util.List;
import java.util.Set;
import cn.org.bjca.exceptions.CommonClientException;
import cn.org.bjca.utils.Base64;
import com.zhonghe.active4j.core.sm.SM4;
import org.apache.commons.lang3.StringUtils;
import org.apache.shiro.authc.AuthenticationException;
import org.apache.shiro.authc.AuthenticationInfo;
import org.apache.shiro.authc.AuthenticationToken;
import org.apache.shiro.authc.LockedAccountException;
import org.apache.shiro.authc.SimpleAuthenticationInfo;
import org.apache.shiro.authc.UnknownAccountException;
import org.apache.shiro.authz.AuthorizationInfo;
import org.apache.shiro.authz.SimpleAuthorizationInfo;
import org.apache.shiro.realm.AuthorizingRealm;
import org.apache.shiro.subject.PrincipalCollection;
import org.apache.shiro.util.ByteSource;
import com.zhonghe.active4j.core.session.GlobalSessionConstant;
import com.zhonghe.active4j.core.util.ApplicationContextUtil;
import com.zhonghe.active4j.core.util.ShiroUtils;
import com.zhonghe.active4j.monitor.service.OnlineSessionService;
import com.zhonghe.active4j.system.entity.SysMenuEntity;
import com.zhonghe.active4j.system.entity.SysRoleEntity;
import com.zhonghe.active4j.system.entity.SysUserEntity;
import com.zhonghe.active4j.system.model.ActiveUser;
import com.zhonghe.active4j.system.service.SysUserService;
public class MyShiroRealm extends AuthorizingRealm {
@Override
protected AuthorizationInfo doGetAuthorizationInfo(PrincipalCollection principals) {
ActiveUser user = (ActiveUser) principals.getPrimaryPrincipal();
// 基于角色的权限
List<SysRoleEntity> lstRoles = user.getRoles();
Set<String> lstStrRoles = new HashSet<String>();
if (null != lstRoles && lstRoles.size() > 0) {
for (SysRoleEntity role : lstRoles) {
lstStrRoles.add(role.getRoleNo());
}
}
// 基于资源的权限
List<SysMenuEntity> lstMenus = user.getPermissions();
Set<String> lstStrMenus = new HashSet<String>();
if (null != lstMenus && lstMenus.size() > 0) {
for (SysMenuEntity menu : lstMenus) {
if (StringUtils.isNotEmpty(menu.getUrl())) {
lstStrMenus.add(menu.getUrl());
}
}
}
SimpleAuthorizationInfo info = new SimpleAuthorizationInfo();
info.addStringPermissions(lstStrMenus);
info.addRoles(lstStrRoles);
return info;
}
/**
*
*/
@Override
protected AuthenticationInfo doGetAuthenticationInfo(AuthenticationToken authcToken) throws AuthenticationException {
// 根据用户名查询用户
SysUserService userService = ApplicationContextUtil.getContext().getBean(SysUserService.class);
// 用户名
String userName = (String) authcToken.getPrincipal();
// 查询用户
SysUserEntity sysUser = userService.getUserByUseName(userName);
if (null == sysUser) {
throw new UnknownAccountException("账号或密码不正确");
}
if (StringUtils.equals(sysUser.getStatus(), "0")) {
throw new LockedAccountException("账号已被锁定,请联系管理员");
}
ActiveUser user = userService.getActiveUserByUser(sysUser);
SimpleAuthenticationInfo info = null;
try {
info = new SimpleAuthenticationInfo(user, ShiroUtils.md5(SM4.SM4Decrypt(Base64.decode(sysUser.getPassword())),sysUser.getSalt()), ByteSource.Util.bytes(sysUser.getSalt()), getName());
} catch (CommonClientException e) {
throw new RuntimeException(e);
}
//info = new SimpleAuthenticationInfo(user, sysUser.getPassword(), ByteSource.Util.bytes(sysUser.getSalt()), getName());
ShiroUtils.getSession().setAttribute(GlobalSessionConstant.SESSION_USER, user);
/**
* sessionDB线使
*/
OnlineSessionService onlineSessionService = ApplicationContextUtil.getContext().getBean(OnlineSessionService.class);
onlineSessionService.saveOnlineSession(ShiroUtils.getSession());
return info;
}
}

@ -0,0 +1,168 @@
package com.zhonghe.active4j.core.shiro;
import java.util.LinkedHashMap;
import org.apache.commons.lang3.StringUtils;
import org.apache.shiro.authc.credential.HashedCredentialsMatcher;
import org.apache.shiro.mgt.SecurityManager;
import org.apache.shiro.spring.security.interceptor.AuthorizationAttributeSourceAdvisor;
import org.apache.shiro.spring.web.ShiroFilterFactoryBean;
import org.apache.shiro.web.mgt.DefaultWebSecurityManager;
import org.crazycake.shiro.RedisCacheManager;
import org.crazycake.shiro.RedisManager;
import org.crazycake.shiro.RedisSessionDAO;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.autoconfigure.condition.ConditionalOnBean;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import com.zhonghe.active4j.core.redis.RedisPropertiesLoader;
import com.zhonghe.active4j.core.session.MySessionFactory;
import com.zhonghe.active4j.core.session.MyWebSessionManager;
/**
* shiro
*
* @author teli_
*
*/
@Configuration
public class ShiroConfig {
@Autowired(required=false)
private RedisPropertiesLoader redisProperties;
@Bean
public SecurityManager securityManager() {
DefaultWebSecurityManager securityManager = new DefaultWebSecurityManager();
securityManager.setSessionManager(sessionManager());
// 设置realm.
securityManager.setRealm(myShiroRealm());
if(null != redisProperties) {
securityManager.setCacheManager(cacheManager());
}
return securityManager;
}
/**
*
* @author
* @time 2019126 9:20:06
*/
public MySessionFactory sessionFactory() {
MySessionFactory sessionFactory = new MySessionFactory();
return sessionFactory;
}
@Bean
public MyWebSessionManager sessionManager() {
/**
* WebSessionManager session redissession
*/
MyWebSessionManager sessionManager = new MyWebSessionManager();
//修改为10分钟验证一次主要是为了刷新在线session最后更新时间
sessionManager.setSessionValidationInterval(10 * 60 * 1000l);
if(null != redisProperties) {
sessionManager.setSessionDAO(redisSessionDAO());
}
// 自定义sessionfactory 为了在创建session时赋值上浏览器操作系统等信息
sessionManager.setSessionFactory(sessionFactory());
return sessionManager;
}
@Bean
ShiroFilterFactoryBean shiroFilterFactoryBean(SecurityManager securityManager) {
ShiroFilterFactoryBean shiroFilterFactoryBean = new ShiroFilterFactoryBean();
// 必须设置 SecurityManager
shiroFilterFactoryBean.setSecurityManager(securityManager);
// 如果不设置默认会自动寻找Web工程根目录下的"/login.jsp"页面
shiroFilterFactoryBean.setLoginUrl("/login");
shiroFilterFactoryBean.setSuccessUrl("/index");
shiroFilterFactoryBean.setUnauthorizedUrl("/403");
LinkedHashMap<String, String> filterChainDefinitionMap = new LinkedHashMap<>();
filterChainDefinitionMap.put("/login", "anon");
filterChainDefinitionMap.put("/CAlogin", "anon");
filterChainDefinitionMap.put("/logout", "anon");
filterChainDefinitionMap.put("/layuiadmin/**", "anon");
filterChainDefinitionMap.put("/assets/**", "anon");
filterChainDefinitionMap.put("/bootstrap/**", "anon");
filterChainDefinitionMap.put("/jquery/**", "anon");
filterChainDefinitionMap.put("/tools/**", "anon");
filterChainDefinitionMap.put("/treeview/**", "anon");
filterChainDefinitionMap.put("/third/**", "anon");
filterChainDefinitionMap.put("/vercode", "anon");
filterChainDefinitionMap.put("/func/weixin/**", "anon");
filterChainDefinitionMap.put("/func/ali/**", "anon");
filterChainDefinitionMap.put("/**", "authc");
shiroFilterFactoryBean.setFilterChainDefinitionMap(filterChainDefinitionMap);
return shiroFilterFactoryBean;
}
@Bean
public MyShiroRealm myShiroRealm() {
MyShiroRealm myShiroRealm = new MyShiroRealm();
myShiroRealm.setCredentialsMatcher(hashedCredentialsMatcher());
return myShiroRealm;
}
@Bean
public HashedCredentialsMatcher hashedCredentialsMatcher() {
HashedCredentialsMatcher hashedCredentialsMatcher = new HashedCredentialsMatcher();
hashedCredentialsMatcher.setHashAlgorithmName("md5");// 散列算法:这里使用MD5算法;
hashedCredentialsMatcher.setHashIterations(2);// 散列的次数,比如散列两次,相当于 md5(md5(""));
return hashedCredentialsMatcher;
}
/**
* shiro aop. 使;;
*
* @param securityManager
* @return
*/
@Bean
public AuthorizationAttributeSourceAdvisor authorizationAttributeSourceAdvisor(SecurityManager securityManager) {
AuthorizationAttributeSourceAdvisor authorizationAttributeSourceAdvisor = new AuthorizationAttributeSourceAdvisor();
authorizationAttributeSourceAdvisor.setSecurityManager(securityManager);
return authorizationAttributeSourceAdvisor;
}
/**
* shiro redisManager使shiro-redis
*/
@Bean
@ConditionalOnBean(RedisPropertiesLoader.class)
public RedisManager redisManager() {
RedisManager redisManager = new RedisManager();
redisManager.setHost(redisProperties.getHost() + ":" + redisProperties.getPort());
if (StringUtils.isNotEmpty(redisProperties.getPassword())) {
redisManager.setPassword(redisProperties.getPassword());
}
redisManager.setTimeout(redisProperties.getTimeout());
redisManager.setDatabase(redisProperties.getDatabase());
return redisManager;
}
@Bean
@ConditionalOnBean(RedisManager.class)
public RedisSessionDAO redisSessionDAO() {
RedisSessionDAO redisSessionDAO = new RedisSessionDAO();
redisSessionDAO.setRedisManager(redisManager());
redisSessionDAO.setKeyPrefix("shiro:user:");
return redisSessionDAO;
}
@Bean
@ConditionalOnBean(RedisManager.class)
public RedisCacheManager cacheManager() {
RedisCacheManager redisCacheManager = new RedisCacheManager();
redisCacheManager.setRedisManager(redisManager());
return redisCacheManager;
}
}

@ -0,0 +1,122 @@
package com.zhonghe.active4j.core.sm;
import cn.org.bjca.client.security.SecurityEngineDeal;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.multipart.MultipartFile;
import java.io.*;
import java.nio.charset.StandardCharsets;
import java.nio.file.Files;
import java.nio.file.Path;
import java.nio.file.Paths;
public class FileEnDe {
public static String encryptFile(@RequestParam("file") MultipartFile file) {
try {
// 加载证书库
SecurityEngineDeal.setProfilePath("src/main/resources/config/config2");
SecurityEngineDeal sed =
SecurityEngineDeal.getInstance("SVSDefault");
String key = sed.genRandom(24);
String savePath = "upfiles/";
String inFile = file.getOriginalFilename();
String fileName = file.getOriginalFilename().substring(0, file.getOriginalFilename().lastIndexOf("."));
File directory = new File(savePath);
if (!directory.exists()) {
directory.mkdirs();
}
//Path path = Paths.get("upfiles/keys/key"+ inFile);
Path path = Paths.get("src/main/resources/upfiles/keys/key" + fileName + ".txt");
Files.write(path, key.getBytes(StandardCharsets.UTF_8));
System.out.println(key);
String fileinpath = savePath + inFile;
FileOutputStream fos = new FileOutputStream(fileinpath);
fos.write(file.getBytes());
fos.close();
System.out.println(fileinpath);
String outFile = String.valueOf(new File("src/main/resources/upfiles/fileencode/" + inFile));
boolean encRes = sed.encryptFile(key, fileinpath, outFile);
System.out.println(encRes);
return "文件加密成功";
} catch (Exception e) {
e.printStackTrace();
return "文件加密失败";
}
}
//文件解密
public static String decryptFile(MultipartFile file) {
try {
// 加载证书库
SecurityEngineDeal.setProfilePath("/src/main/resources/config2");
SecurityEngineDeal sed =
SecurityEngineDeal.getInstance("SVSDefault");
//String key = sed.genRandom(24);
String inFile = file.getOriginalFilename();
String fileName = file.getOriginalFilename().substring(0, file.getOriginalFilename().lastIndexOf("."));
String savePath = "upfiles/";
File directory = new File(savePath);
if (!directory.exists()) {
directory.mkdirs();
}
String filePath = savePath + inFile;
FileOutputStream fos = new FileOutputStream(filePath);
fos.write(file.getBytes());
fos.close();
String path = String.valueOf(Paths.get("/src/main/resources/upfiles/keys/key" + fileName + ".txt"));
String key = readFileToString(path);
System.out.println(key);
System.out.println(filePath);
String outFile = String.valueOf(new File("/src/main/resources/upfiles/filedecode/" + inFile));
boolean decRes = sed.decryptFile(key, filePath, outFile);
System.out.println(outFile);
System.out.println(decRes);
return "文件解密成功";
} catch (Exception e) {
e.printStackTrace();
return "文件解密失败";
}
}
public static String readFileToString(String path) {
// 定义返回结果
String jsonString = "";
BufferedReader in = null;
try {
in = new BufferedReader(new InputStreamReader(new FileInputStream(new File(path)), "UTF-8"));// 读取文件
String thisLine = null;
while ((thisLine = in.readLine()) != null) {
jsonString += thisLine;
}
in.close();
} catch (IOException e) {
e.printStackTrace();
} finally {
if (in != null) {
try {
in.close();
} catch (IOException el) {
}
}
}
// 返回拼接好的JSON String
return jsonString;
}
}

@ -0,0 +1,56 @@
package com.zhonghe.active4j.core.sm;
import cn.org.bjca.chaos.jce.provider.BJCAJCEProvider;
import cn.org.bjca.utils.Base64;
import javax.crypto.Cipher;
import java.security.*;
/**
* @ClassName SM2
* @Description TODO
* @Author @luo
* @Date 2023/5/25 9:00
*/
public final class SM2 {
public static byte[] SM2Encrypt(String strSrc) {
byte[] encrypted = new byte[0];
try {
Security.addProvider(new BJCAJCEProvider("src/main/resources/config/config1"));
KeyPairGenerator gen = KeyPairGenerator.getInstance("SM2", "BJCAJCE");
//传入密钥索引 2*n 是加密密钥,比如密码机中密钥索引是 1加密密钥传入 2*1
gen.initialize((2*1) << 16);
KeyPair sm2KeyPair = gen.generateKeyPair();
PublicKey publicKey = sm2KeyPair.getPublic();
Cipher cipher = Cipher.getInstance("SM2", "BJCAJCE");
//加密
cipher.init(Cipher.ENCRYPT_MODE, sm2KeyPair.getPublic());
encrypted = cipher.doFinal(strSrc.getBytes());
} catch (Exception e) {
e.printStackTrace();
}
return encrypted;
}
public static byte[] SM2Decrypt(byte[] encrypted) {
byte[] decrypted = new byte[0];
try {
Security.addProvider(new BJCAJCEProvider("src/main/resources/config/config1"));
KeyPairGenerator gen = KeyPairGenerator.getInstance("SM2", "BJCAJCE");
//传入密钥索引 2*n 是加密密钥,比如密码机中密钥索引是 1加密密钥传入 2*1
gen.initialize((2*1) << 16);
KeyPair sm2KeyPair = gen.generateKeyPair();
PrivateKey privateKey = sm2KeyPair.getPrivate();
Cipher cipher = Cipher.getInstance("SM2", "BJCAJCE");
//解密
cipher.init(Cipher.DECRYPT_MODE, sm2KeyPair.getPrivate());
decrypted = cipher.doFinal(encrypted);// encrypted 为加密后密文
} catch (Exception e) {
e.printStackTrace();
}
return decrypted;
}
}

@ -0,0 +1,22 @@
package com.zhonghe.active4j.core.sm;
import cn.org.bjca.chaos.jce.provider.BJCAJCEProvider;
import java.security.MessageDigest;
import java.security.Security;
public final class SM3 {
public static byte[] SM3Encrypt(String strSrc){
byte[] encrypted = new byte[0];
try{
if (Security.getProvider("BJCAJCE") == null){
Security.addProvider(new BJCAJCEProvider("src/main/resources/config/config1"));
}
MessageDigest instant = MessageDigest.getInstance("SM3","BJCAJCE");
encrypted = instant.digest(strSrc.getBytes());//传入原文值
}catch (Exception e){
e.printStackTrace();
}
return encrypted;
}
}

@ -0,0 +1,63 @@
package com.zhonghe.active4j.core.sm;
import cn.org.bjca.chaos.jce.provider.BJCAJCEProvider;
import cn.org.bjca.chaos.util.encoders.Base64;
import org.springframework.boot.availability.AvailabilityState;
import javax.crypto.Cipher;
import javax.crypto.KeyGenerator;
import javax.crypto.SecretKey;
import javax.crypto.spec.IvParameterSpec;
import javax.crypto.spec.SecretKeySpec;
import java.security.Security;
public final class SM4 {
public static byte[] SM4Encrypt(String strSrc) {
byte[] encrypted = new byte[0];
try {
if (Security.getProvider("BJCAJCE") == null){
Security.addProvider(new BJCAJCEProvider("src/main/resources/config/config1"));
}
KeyGenerator keyGenerator = KeyGenerator.getInstance("SM4", "BJCAJCE");
//可通过索引获取内部密钥 取 1 号密钥init 传: 1<<16
keyGenerator.init(1 << 16);
SecretKey secretKey = keyGenerator.generateKey();
Cipher cipher = Cipher.getInstance("SM4/CBC/PKCS5Padding", "BJCAJCE");
//iv 值为 16 个字节,可根据自己需要定义
IvParameterSpec iv = new IvParameterSpec("1234567812345678".getBytes());
//加密
cipher.init(Cipher.ENCRYPT_MODE, secretKey,iv);
encrypted = cipher.doFinal(strSrc.getBytes());
} catch (Exception e) {
e.printStackTrace();
}
return encrypted;
}
public static String SM4Decrypt(byte[] by) {
byte[] decrypted;
String strDecrypted = null;
try {
if (Security.getProvider("BJCAJCE") == null){
Security.addProvider(new BJCAJCEProvider("src/main/resources/config/config1"));
}
KeyGenerator keyGenerator = KeyGenerator.getInstance("SM4", "BJCAJCE");
//可通过索引获取内部密钥 取 1 号密钥init 传: 1<<16
keyGenerator.init(1 << 16);
SecretKey secretKey = keyGenerator.generateKey();
Cipher cipher = Cipher.getInstance("SM4/CBC/PKCS5Padding", "BJCAJCE");
//iv 值为 16 个字节,可根据自己需要定义
IvParameterSpec iv = new IvParameterSpec("1234567812345678".getBytes());
//解密
cipher.init(Cipher.DECRYPT_MODE, secretKey,iv);
decrypted = cipher.doFinal(by);// encrypted 为加密后密文
strDecrypted = new String(decrypted);
} catch (Exception e) {
e.printStackTrace();
}
return strDecrypted;
}
}

@ -0,0 +1,75 @@
package com.zhonghe.active4j.core.sm;
import cn.org.bjca.client.exceptions.*;
import cn.org.bjca.client.security.SecurityEngineDeal;
import cn.org.bjca.exceptions.CommonClientException;
import cn.org.bjca.utils.Base64;
public final class Sign {
public static String DataSign(String strSrc) {
SecurityEngineDeal.setProfilePath("src/main/resources/config/config2");
SecurityEngineDeal sed;
String signedValue = null;
try {
sed = SecurityEngineDeal.getInstance("SVSDefault");
byte[] data = strSrc.getBytes();
signedValue = sed.signData(data);
} catch (SVSConnectException | ApplicationNotFoundException | InitException | ParameterTooLongException e) {
e.printStackTrace();
}
return signedValue;
}
public static boolean DataSignVerify(String str, String signValue) {
//传入两个参数:
//第一个参数为需要签名的字符串
//第二个参数为签名结果
SecurityEngineDeal.setProfilePath("src/main/resources/config/config2");
SecurityEngineDeal sed = null;
boolean verifyRes = false;
try {
sed = SecurityEngineDeal.getInstance("SVSDefault");
String cert = sed.getServerCertificate();
byte[] data = str.getBytes();
byte[] base64Decode = sed.base64Decode(signValue);
byte[] decode = Base64.decode(signValue);
verifyRes = sed.verifySignedData(cert, data, base64Decode);
System.out.println(verifyRes);
} catch (SVSConnectException | ApplicationNotFoundException | InitException | ParameterTooLongException |
ParameterInvalidException | UnkownException e) {
e.printStackTrace();
} catch (CommonClientException e) {
throw new RuntimeException(e);
}
return verifyRes;
}
public static String FileSign(String strSrc) {
SecurityEngineDeal.setProfilePath("src/main/resources/config/config2");
SecurityEngineDeal sed;
byte[] signedValueByte = new byte[0];
String signedValue = null;
try {
sed = SecurityEngineDeal.getInstance("SVSDefault");
signedValue = sed.signFile(strSrc);
} catch (SVSConnectException | ApplicationNotFoundException | InitException e) {
e.printStackTrace();
}
return signedValue;
}
public static boolean FileSignVerify(String str, String signValue) {
SecurityEngineDeal.setProfilePath("src/main/resources/config/config2");
SecurityEngineDeal sed;
boolean verifyRes = false;
try {
sed = SecurityEngineDeal.getInstance("SVSDefault");
String cert = sed.getServerCertificate();
verifyRes = sed.verifySignedFile(cert, str, signValue);
} catch (SVSConnectException | ApplicationNotFoundException | InitException | ParameterTooLongException | ParameterInvalidException | UnkownException e) {
e.printStackTrace();
}
return verifyRes;
}
}

@ -0,0 +1,166 @@
package com.zhonghe.active4j.core.sm;
import cn.org.bjca.client.exceptions.*;
import cn.org.bjca.client.security.SecurityEngineDeal;
import java.util.Arrays;
//创建时间戳
public final class TSS {
/**
*
* @param strSrc
* @return
*/
public static String TSSCreate(String strSrc) {
String tsReq = null;
try {
SecurityEngineDeal sed;
SecurityEngineDeal.setProfilePath("src/main/resources/config/config2");
sed = SecurityEngineDeal.getInstance("TSSSM2");
tsReq = sed.createTSByOriginalData(strSrc);
} catch (ApplicationNotFoundException | InitException | SVSConnectException | ParameterTooLongException e) {
e.printStackTrace();
}
return tsReq;
}
/**
*
* @param strSrc
* @return
*/
public static byte[] TSSAnalysis(String strSrc) {
String tsInfo;
byte[] s1 = new byte[0];
try {
SecurityEngineDeal sed;
SecurityEngineDeal.setProfilePath("src/main/resources/config/config2");
sed = SecurityEngineDeal.getInstance("TSSSM2");
String tsRep = sed.createTSRequest(strSrc.getBytes(), true);
String ts = sed.createTS(tsRep);
tsInfo = sed.getTSInfo(ts, 1);
s1 = sed.base64Decode(tsInfo);
//System.out.println(Arrays.toString(s1));
} catch (ParameterTooLongException | ApplicationNotFoundException | ParameterInvalidException | InitException | SVSConnectException | ParameterOutRangeException e) {
e.printStackTrace();
}
return s1;
}
//解析时间戳响应
//返回:时间戳
public static String TSSTest(String strSrc) {
String tsInfo = null;
try {
SecurityEngineDeal sed;
SecurityEngineDeal.setProfilePath("src/main/resources/config/config2");
sed = SecurityEngineDeal.getInstance("TSSSM2");
String tsRep = sed.createTSRequest(strSrc.getBytes(), true);
String ts = sed.createTS(tsRep);
tsInfo = sed.getTSInfo(ts, 1);
} catch (ParameterTooLongException | ApplicationNotFoundException | ParameterInvalidException | InitException | SVSConnectException | ParameterOutRangeException e) {
e.printStackTrace();
}
return tsInfo;
}
public static int TSSVerify(String strSrc) {
int verifyRes = 0;
try {
SecurityEngineDeal sed;
SecurityEngineDeal.setProfilePath("src/main/resources/config/config2");
sed = SecurityEngineDeal.getInstance("TSSSM2");
String tsReq = sed.createTSRequest(strSrc.getBytes(), true);
String tsRep = sed.createTS(tsReq);
verifyRes = sed.verifyTS(tsRep, strSrc.getBytes());
//System.out.println(verifyRes);
} catch (ApplicationNotFoundException | InitException | SVSConnectException | ParameterTooLongException | ParameterInvalidException e) {
e.printStackTrace();
}
return verifyRes;
}
public static String createTSByOriginalData(String inData) {
SecurityEngineDeal sed;
SecurityEngineDeal.setProfilePath("src/main/resources/config/config2");
String tsRep = null;
try {
sed = SecurityEngineDeal.getInstance("TSSSM2");
tsRep = sed.createTSByOriginalData(inData);
} catch (SVSConnectException e) {
e.printStackTrace();
} catch (ApplicationNotFoundException e) {
e.printStackTrace();
} catch (InitException e) {
e.printStackTrace();
} catch (ParameterTooLongException e) {
e.printStackTrace();
}
return tsRep;
}
public static boolean verifyTimeStamp (String tsRep) {
SecurityEngineDeal sed;
SecurityEngineDeal.setProfilePath("src/main/resources/config/config2");
boolean verifyRes = false;
try {
sed = SecurityEngineDeal.getInstance("TSSSM2");
verifyRes = sed.verifyTimeStamp(tsRep);
} catch (SVSConnectException e) {
e.printStackTrace();
} catch (ApplicationNotFoundException e) {
e.printStackTrace();
} catch (InitException e) {
e.printStackTrace();
} catch (ParameterTooLongException e) {
e.printStackTrace();
} catch (ParameterInvalidException e) {
e.printStackTrace();
}
return verifyRes;
}
/**
*
* @param inData
* @return
*/
public static String createTS(String inData) {
SecurityEngineDeal sed;
SecurityEngineDeal.setProfilePath("src/main/resources/config/config2");
String tsRep = null;
try {
sed = SecurityEngineDeal.getInstance("TSSSM2");
String tsReq = sed.createTSRequest(inData.getBytes(), true);
tsRep = sed.createTS(tsReq);
} catch (SVSConnectException | ApplicationNotFoundException | ParameterTooLongException | InitException |
ParameterInvalidException e) {
e.printStackTrace();
}
return tsRep;
}
/**
*
*/
public static String getTSInfo(String tsRep, int type) {
SecurityEngineDeal sed;
SecurityEngineDeal.setProfilePath("src/main/resources/config/config2");
String tsInfo = null;
try {
sed = SecurityEngineDeal.getInstance("TSSSM2");
tsInfo = sed.getTSInfo(tsRep, type);
} catch (SVSConnectException | ApplicationNotFoundException | InitException | ParameterInvalidException |
ParameterTooLongException | ParameterOutRangeException e) {
e.printStackTrace();
}
return tsInfo;
}
}

@ -0,0 +1,88 @@
package com.zhonghe.active4j.core.threadpool;
import java.util.concurrent.LinkedBlockingQueue;
import java.util.concurrent.ThreadPoolExecutor;
import java.util.concurrent.TimeUnit;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import lombok.extern.slf4j.Slf4j;
/**
* @title ThreadPoolConfig.java
* @description
线
* @time 2019124 4:24:02
* @author
* @version 1.0
*/
@Configuration
@Slf4j
public class ThreadPoolConfig {
@Autowired
private ThreadPoolProperties loader;
/**
*
* @description
* 线 spring线
* @return ThreadPoolTaskExecutor
* @author
* @time 2019124 5:00:52
*/
// @Bean
// public ThreadPoolTaskExecutor threadPoolTaskExecutor(){
// ThreadPoolTaskExecutor poolTask = new ThreadPoolTaskExecutor();
// poolTask.setCorePoolSize(loader.getCorePoolSize()); //核心线程数
// poolTask.setMaxPoolSize(loader.getMaxPoolSize()); //最大线程数
// poolTask.setQueueCapacity(loader.getQueueCapacity()); //等待队列长度
// poolTask.setKeepAliveSeconds(loader.getKeepAliveSeconds()); //空闲线程存活时间
// //拒绝策略
// poolTask.setRejectedExecutionHandler(new ThreadPoolExecutor.CallerRunsPolicy() {
// @Override
// public void rejectedExecution(Runnable r, ThreadPoolExecutor executor) {
// log.warn("注意,有任务超过线程池配置");
// if(!executor.isShutdown()) {
// r.run();
// }
// }
// });
// return poolTask;
// }
/**
* @description
* 线 jdk
* @return ThreadPoolExecutor
* @author
* @time 2019124 5:01:14
*/
@Bean
public ThreadPoolExecutor threadPoolExecutor() {
ThreadPoolExecutor poolTask =
new ThreadPoolExecutor(loader.getCorePoolSize(), //核心线程数
loader.getMaxPoolSize(), //最大线程数
loader.getKeepAliveSeconds(), //空闲线程存活时间
TimeUnit.SECONDS, //时间单位
new LinkedBlockingQueue<Runnable>(loader.getQueueCapacity()), //等待队列长度
//拒绝策略
new ThreadPoolExecutor.CallerRunsPolicy() {
@Override
public void rejectedExecution(Runnable r, ThreadPoolExecutor executor) {
log.warn("注意,有任务超过线程池配置");
if(!executor.isShutdown()) {
r.run();
}
}
});
return poolTask;
}
}

@ -0,0 +1,48 @@
package com.zhonghe.active4j.core.threadpool;
import java.util.concurrent.ThreadPoolExecutor;
import com.zhonghe.active4j.core.util.ApplicationContextUtil;
/**
* @title ThreadPoolManager.java
* @description
线
* @time 2019124 5:04:26
* @author
* @version 1.0
*/
public class ThreadPoolManager {
private ThreadPoolManager() {}
private static ThreadPoolManager me = new ThreadPoolManager();
//返回单例
public static ThreadPoolManager me() {
return me;
}
//线程池
private ThreadPoolExecutor threadPoolExecutor = ApplicationContextUtil.getContext().getBean(ThreadPoolExecutor.class);
//交给线程池执行
public void execute(Runnable runnable) {
threadPoolExecutor.execute(runnable);
}
/**
*
* @description
* 线线
* @return void
* @author
* @time 2019124 5:28:08
*/
public void shutdown() {
if(!threadPoolExecutor.isShutdown()) {
threadPoolExecutor.shutdown();
}
}
}

@ -0,0 +1,32 @@
package com.zhonghe.active4j.core.threadpool;
import org.springframework.boot.context.properties.ConfigurationProperties;
import org.springframework.stereotype.Component;
import lombok.Getter;
import lombok.Setter;
/**
* @title ThreadPoolProperties.java
* @description
线
* @time 2019124 4:18:45
* @author
* @version 1.0
*/
@Component
@ConfigurationProperties(prefix = "thread.pool")
@Getter
@Setter
public class ThreadPoolProperties {
private int corePoolSize;
private int maxPoolSize;
private int queueCapacity;
private int keepAliveSeconds;
}

@ -0,0 +1,22 @@
package com.zhonghe.active4j.core.util;
import org.springframework.beans.BeansException;
import org.springframework.context.ApplicationContext;
import org.springframework.context.ApplicationContextAware;
import org.springframework.stereotype.Component;
@Component
public class ApplicationContextUtil implements ApplicationContextAware {
private static ApplicationContext context;
public void setApplicationContext(ApplicationContext context)
throws BeansException {
this.context = context;
}
public static ApplicationContext getContext() {
return context;
}
}

@ -0,0 +1,123 @@
package com.zhonghe.active4j.core.util;
import java.math.BigDecimal;
import java.math.RoundingMode;
import java.text.DecimalFormat;
import java.text.NumberFormat;
public class ArithUtil {
private static final int DEF_DIV_SCALE = 10;
private ArithUtil() {
}
// 加
public static double add(double d1, double d2) {
BigDecimal b1 = new BigDecimal(Double.toString(d1));
BigDecimal b2 = new BigDecimal(Double.toString(d2));
return b1.add(b2).doubleValue();
}
// 减
public static double sub(double d1, double d2) {
BigDecimal b1 = new BigDecimal(Double.toString(d1));
BigDecimal b2 = new BigDecimal(Double.toString(d2));
return b1.subtract(b2).doubleValue();
}
// 乘以
public static double mul(double d1, double d2) {
BigDecimal b1 = new BigDecimal(Double.toString(d1));
BigDecimal b2 = new BigDecimal(Double.toString(d2));
return b1.multiply(b2).doubleValue();
}
// 除以
public static double div(double d1, double d2) {
return div(d1, d2, DEF_DIV_SCALE);
}
public static double div(double d1, double d2, int scale) {
if (scale < 0) {
throw new IllegalArgumentException("The scale must be a positive integer or zero");
}
BigDecimal b1 = new BigDecimal(Double.toString(d1));
BigDecimal b2 = new BigDecimal(Double.toString(d2));
return b1.divide(b2, scale, BigDecimal.ROUND_HALF_UP).doubleValue();
}
/**
*
*
* @param a
* @param b
* @return
*/
public static String getSuccessRate(double a, double b, NumberFormat nt) {
// 设置百分数保留两位小数
nt.setMinimumFractionDigits(2);
// 计算成功率
String successRate = "0.00%";
if (b != 0) {
successRate = nt.format(a / b);
}
return successRate;
}
/**
* 2
*
* @param s
* @return
*/
public static String stringToTwoDecimal(String s) {
Double a = null;
a = Double.parseDouble(s);
// 四舍五入保留两位小数
DecimalFormat df = new DecimalFormat("0.00");
String str = df.format(a);
return str;
}
/**
* double2
*
* @param s
* @return
*/
public static String doubleToTwoDecimal(double s) {
// 四舍五入保留两位小数
DecimalFormat df = new DecimalFormat("0.00");
String str = df.format(s);
return str;
}
/**
*
*
* @param v
* @param scale
* @return
*/
public static double round(double v, int scale) {
if (scale < 0) {
throw new IllegalArgumentException("The scale must be a positive integer or zero");
}
BigDecimal b = new BigDecimal(Double.toString(v));
BigDecimal one = new BigDecimal("1");
return b.divide(one, scale, RoundingMode.HALF_UP).doubleValue();
}
}

@ -0,0 +1,316 @@
package com.zhonghe.active4j.core.util;
import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.time.Instant;
import java.time.LocalDate;
import java.time.LocalDateTime;
import java.time.ZoneId;
import java.time.ZonedDateTime;
import java.time.format.DateTimeFormatter;
import java.time.temporal.ChronoUnit;
import java.util.Date;
/**
*
*
* @author teli_
*
*/
public class DateUtils extends org.apache.commons.lang3.time.DateUtils {
public static DateTimeFormatter pattern_yyyy_MM_dd = DateTimeFormatter.ofPattern("yyyy年MM月dd日");
public static DateTimeFormatter pattern_yyyyMMdd = DateTimeFormatter.ofPattern("yyyyMMdd");
public static DateTimeFormatter pattern_yyMMdd = DateTimeFormatter.ofPattern("yyMMdd");
public static DateTimeFormatter pattern_yyyy_MM_DD_HH_mm_ss = DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss");
public static DateTimeFormatter pattern_yyyyMMDDHHmmss = DateTimeFormatter.ofPattern("yyyyMMddHHmmss");
public static DateTimeFormatter pattern_yyyy_MM = DateTimeFormatter.ofPattern("yyyy-MM");
public static DateTimeFormatter pattern_yyyy_MM_DD = DateTimeFormatter.ofPattern("yyyy-MM-dd");
public static final SimpleDateFormat SDF_YYYY_MM_DD_HH_MM_SS = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
/**
*
*
* @return
*/
public static Date getNow() {
return new Date();
}
/**
*
* @description long date
* @params
* @return Date
* @author
* @time 2019123 4:56:36
*/
public static Date getDate(long l) {
return new Date(l);
}
/**
*
*/
public static String getDateYYYY_MM_DD() {
LocalDate date = LocalDate.now();
return date.format(pattern_yyyyMMdd);
}
/**
*
*/
public static String getDateYYMMDD() {
LocalDate date = LocalDate.now();
return date.format(pattern_yyMMdd);
}
/**
*
*/
public static String getDateYY_MM_DD() {
LocalDate date = LocalDate.now();
return date.format(pattern_yyyy_MM_dd);
}
/**
* -- ::
*
* @param date
* @return
*/
public static String getDate2Str(Date date) {
Instant instant = date.toInstant();
ZoneId zone = ZoneId.systemDefault();
LocalDateTime localDateTime = LocalDateTime.ofInstant(instant, zone);
return localDateTime.format(pattern_yyyy_MM_DD_HH_mm_ss);
}
/**
*
*
* @param date
* @return
*/
public static String getDate2Str(Date date, DateTimeFormatter formatter) {
Instant instant = date.toInstant();
ZoneId zone = ZoneId.systemDefault();
LocalDateTime localDateTime = LocalDateTime.ofInstant(instant, zone);
return localDateTime.format(formatter);
}
/**
* localDateTimedate
*
* @param localDateTime
* @return
*/
public static Date localDateTime2Date(LocalDateTime localDateTime) {
ZoneId zoneId = ZoneId.systemDefault();
ZonedDateTime zdt = localDateTime.atZone(zoneId);
Date date = Date.from(zdt.toInstant());
return date;
}
/**
* date
*
* @param strDate
* @return
*/
public static Date getStr2Date(String strDate) {
LocalDateTime localDateTime = LocalDateTime.parse(strDate, pattern_yyyy_MM_DD_HH_mm_ss);
return localDateTime2Date(localDateTime);
}
/**
* yyyyMMddHHmmss
*
* @return
*/
public static String getDate2StrYYYYMMDDHHMMSS() {
LocalDateTime date = LocalDateTime.now();
return date.format(pattern_yyyyMMDDHHmmss);
}
/**
* 30
*
* @return
*/
public static String getDate2StrYYYYMMDDHHMMSSAdd30M() {
LocalDateTime date = LocalDateTime.now();
LocalDateTime dateNew = date.plus(30l, ChronoUnit.MINUTES);
return dateNew.format(pattern_yyyyMMDDHHmmss);
}
/**
* java cronExpression
*
* @param date
* @return
*/
public static String getCron(Date date) {
String dateFormat = "ss mm HH dd MM ? yyyy";
return formatDateByPattern(date, dateFormat);
}
/**
*
*
* @param date
* @param dateFormat
* @return
*/
public static String formatDateByPattern(Date date, String dateFormat) {
SimpleDateFormat sdf = new SimpleDateFormat(dateFormat);
String formatTimeStr = null;
if (date != null) {
formatTimeStr = sdf.format(date);
}
return formatTimeStr;
}
/**
* Stringyyyy-MM-dd HH:mm:ss long
*
* @param str
* @return
* @throws Exception
* @throws Exception
*/
public static long StringToLong(String str) throws Exception {
Date date = SDF_YYYY_MM_DD_HH_MM_SS.parse(str);
// 转换为Date类
long timestampStr = date.getTime();
return timestampStr;
}
/**
*
* @description
*
* @params
* endDate
* nowDate
* @return String
* @author
* @time 2019123 4:58:05
*/
public static String getDateDiff(Date endDate, Date nowDate) {
long nd = 1000 * 24 * 60 * 60;
long nh = 1000 * 60 * 60;
long nm = 1000 * 60;
// long ns = 1000;
// 获得两个时间的毫秒时间差异
long diff = endDate.getTime() - nowDate.getTime();
// 计算差多少天
long day = diff / nd;
// 计算差多少小时
long hour = diff % nd / nh;
// 计算差多少分钟
long min = diff % nd % nh / nm;
// 计算差多少秒//输出结果
// long sec = diff % nd % nh % nm / ns;
return day + "天" + hour + "小时" + min + "分钟";
}
/**
*
* @description
* javaDate
* @params
* @return Date
* @author guyp
* @time 20191217 3:37:51
*/
public static Date parseDateObj(Object o) {
if(o == null) {
return null;
}
if(o instanceof Date) {
return (Date) o;
}
if(o instanceof java.sql.Date) {
return (Date) o;
}
if(o instanceof String) {
// yyyy-MM-dd HH:mm:ss /
String d = (String) o;
StringBuilder format = new StringBuilder("yyyy");
if(d.charAt(4) == '-') {
format.append("-MM-dd");
}else if(d.charAt(4) == '/') {
format.append("/MM/dd");
}else if(d.charAt(4) == '_'){
format.append("_MM_dd");
}else {
format.append("MMdd");
}
if(d.length() < format.length()) {
return null;
}else if(d.length() == format.length()) {
return parseDate(d, format.toString());
}
if(d.charAt(format.length()) == ' ') {
format.append(' ');
}
if(d.charAt(format.length() + 2) == ':') {
format.append("HH:mm:ss");
}else if(d.charAt(format.length() + 2) == '/') {
format.append("HH/mm/ss");
}else {
format.append("HHmmss");
}
if(d.length() < format.length()) {
return null;
}
if(d.length() == format.length()) {
return parseDate(d, format.toString());
}
if(d.charAt(format.length()) == '.' && d.length() == (format.length() + 4)) {
format.append(".SSS");
}else if(d.length() == (format.length() + 3)){
format.append("SSS");
}else {
d = d.substring(0, format.length());
}
return parseDate(d, format.toString());
}
if (o instanceof Long) {
long l = (long) o;
if (l < 10000000000l) {
return new Date(l*1000);
}
return new Date(l);
}
if (o instanceof Integer) {
long l = (int) o * 1000;
return new Date(l);
}
return null;
}
/**
*
* @description
* , null
* @params
* @return Date
* @author guyp
* @time 20191217 3:37:32
*/
public static Date parseDate(String d, String format) {
try {
return new SimpleDateFormat(format).parse(d);
} catch (ParseException e) {
return null;
}
}
}

@ -0,0 +1,29 @@
package com.zhonghe.active4j.core.util;
import javax.servlet.http.HttpServletRequest;
public class IpUtil {
/**
* IP
*
* @param request
* @return
*/
public static String getIpAddr(HttpServletRequest request) {
String ip = request.getHeader("x-forwarded-for");
if (ip == null || ip.length() == 0 || "unknown".equalsIgnoreCase(ip)) {
ip = request.getHeader("Proxy-Client-IP");
}
if (ip == null || ip.length() == 0 || "unknown".equalsIgnoreCase(ip)) {
ip = request.getHeader("WL-Proxy-Client-IP");
}
if (ip == null || ip.length() == 0 || "unknown".equalsIgnoreCase(ip)) {
ip = request.getRemoteAddr();
}
if (ip.equals("0:0:0:0:0:0:0:1")) {
ip = "本地";
}
return ip;
}
}

@ -0,0 +1,70 @@
package com.zhonghe.active4j.core.util;
import java.security.MessageDigest;
public class Md5Util {
/***
* MD5 32md5
*/
public static String string2MD5(String inStr){
MessageDigest md5 = null;
try{
md5 = MessageDigest.getInstance("MD5");
}catch (Exception e){
e.printStackTrace();
return "";
}
char[] charArray = inStr.toCharArray();
byte[] byteArray = new byte[charArray.length];
for (int i = 0; i < charArray.length; i++)
byteArray[i] = (byte) charArray[i];
byte[] md5Bytes = md5.digest(byteArray);
StringBuffer hexValue = new StringBuffer();
for (int i = 0; i < md5Bytes.length; i++){
int val = ((int) md5Bytes[i]) & 0xff;
if (val < 16)
hexValue.append("0");
hexValue.append(Integer.toHexString(val));
}
return hexValue.toString();
}
public static String MD5Encode(String origin, String charsetname) {
String resultString = null;
try {
resultString = new String(origin);
MessageDigest md = MessageDigest.getInstance("MD5");
if (charsetname == null || "".equals(charsetname))
resultString = byteArrayToHexString(md.digest(resultString
.getBytes()));
else
resultString = byteArrayToHexString(md.digest(resultString
.getBytes(charsetname)));
} catch (Exception exception) {
}
return resultString;
}
private static String byteArrayToHexString(byte b[]) {
StringBuffer resultSb = new StringBuffer();
for (int i = 0; i < b.length; i++)
resultSb.append(byteToHexString(b[i]));
return resultSb.toString();
}
private static String byteToHexString(byte b) {
int n = b;
if (n < 0)
n += 256;
int d1 = n / 16;
int d2 = n % 16;
return hexDigits[d1] + hexDigits[d2];
}
private static final String hexDigits[] = { "0", "1", "2", "3", "4", "5",
"6", "7", "8", "9", "a", "b", "c", "d", "e", "f" };
}

@ -0,0 +1,331 @@
package com.zhonghe.active4j.core.util;
import java.beans.BeanInfo;
import java.beans.Introspector;
import java.beans.PropertyDescriptor;
import java.lang.reflect.InvocationTargetException;
import java.lang.reflect.Method;
import java.util.Iterator;
import java.util.Map;
import org.apache.commons.beanutils.DynaBean;
import org.apache.commons.beanutils.DynaProperty;
import org.apache.commons.beanutils.PropertyUtils;
/**
* <p>
* Title:
* </p>
* <p>
* Description:
* </p>
*
* @version 1.0
*/
public class MyBeanUtils extends org.apache.commons.beanutils.BeanUtils {
private static void convert(Object dest, Object orig) throws IllegalAccessException, InvocationTargetException {
// Validate existence of the specified beans
if (dest == null) {
throw new IllegalArgumentException("No destination bean specified");
}
if (orig == null) {
throw new IllegalArgumentException("No origin bean specified");
}
// Copy the properties, converting as necessary
if (orig instanceof DynaBean) {
DynaProperty origDescriptors[] = ((DynaBean) orig).getDynaClass().getDynaProperties();
for (int i = 0; i < origDescriptors.length; i++) {
String name = origDescriptors[i].getName();
if (PropertyUtils.isWriteable(dest, name)) {
Object value = ((DynaBean) orig).get(name);
try {
copyProperty(dest, name, value);
} catch (Exception e) {
; // Should not happen
}
}
}
} else if (orig instanceof Map) {
Iterator names = ((Map) orig).keySet().iterator();
while (names.hasNext()) {
String name = (String) names.next();
if (PropertyUtils.isWriteable(dest, name)) {
Object value = ((Map) orig).get(name);
try {
copyProperty(dest, name, value);
} catch (Exception e) {
; // Should not happen
}
}
}
} else
/* if (orig is a standard JavaBean) */
{
PropertyDescriptor origDescriptors[] = PropertyUtils.getPropertyDescriptors(orig);
for (int i = 0; i < origDescriptors.length; i++) {
String name = origDescriptors[i].getName();
// String type =
// origDescriptors[i].getPropertyType().toString();
if ("class".equals(name)) {
continue; // No point in trying to set an object's class
}
if (PropertyUtils.isReadable(orig, name) && PropertyUtils.isWriteable(dest, name)) {
try {
Object value = PropertyUtils.getSimpleProperty(orig, name);
copyProperty(dest, name, value);
} catch (java.lang.IllegalArgumentException ie) {
; // Should not happen
} catch (Exception e) {
; // Should not happen
}
}
}
}
}
/**
*
*
* @param dataObject
* @param toObject
* @throws NoSuchMethodException
* copy
*/
public static void copyBeanNotNull2Bean(Object databean, Object tobean) throws Exception {
PropertyDescriptor origDescriptors[] = PropertyUtils.getPropertyDescriptors(databean);
for (int i = 0; i < origDescriptors.length; i++) {
String name = origDescriptors[i].getName();
// String type = origDescriptors[i].getPropertyType().toString();
if ("class".equals(name)) {
continue; // No point in trying to set an object's class
}
if (PropertyUtils.isReadable(databean, name) && PropertyUtils.isWriteable(tobean, name)) {
try {
Object value = PropertyUtils.getSimpleProperty(databean, name);
if (value != null) {
copyProperty(tobean, name, value);
}
} catch (java.lang.IllegalArgumentException ie) {
; // Should not happen
} catch (Exception e) {
; // Should not happen
}
}
}
}
/**
* origdestvaluedest
*
* @param dest
* @param orig
* @throws IllegalAccessException
* @throws InvocationTargetException
*/
public static void copyBean2Bean(Object dest, Object orig) throws Exception {
convert(dest, orig);
}
public static void copyBean2Map(Map map, Object bean) {
PropertyDescriptor[] pds = PropertyUtils.getPropertyDescriptors(bean);
for (int i = 0; i < pds.length; i++) {
PropertyDescriptor pd = pds[i];
String propname = pd.getName();
try {
Object propvalue = PropertyUtils.getSimpleProperty(bean, propname);
map.put(propname, propvalue);
} catch (IllegalAccessException e) {
// e.printStackTrace();
} catch (InvocationTargetException e) {
// e.printStackTrace();
} catch (NoSuchMethodException e) {
// e.printStackTrace();
}
}
}
/**
* MapkeyBeanBEAN
*
* @param bean
* Object
* @param properties
* Map
* @throws IllegalAccessException
* @throws InvocationTargetException
*/
public static void copyMap2Bean(Object bean, Map properties) throws IllegalAccessException, InvocationTargetException {
// Do nothing unless both arguments have been specified
if ((bean == null) || (properties == null)) {
return;
}
// Loop through the property name/value pairs to be set
Iterator names = properties.keySet().iterator();
while (names.hasNext()) {
String name = (String) names.next();
// Identify the property name and value(s) to be assigned
if (name == null) {
continue;
}
Object value = properties.get(name);
try {
Class clazz = PropertyUtils.getPropertyType(bean, name);
if (null == clazz) {
continue;
}
String className = clazz.getName();
if (className.equalsIgnoreCase("java.sql.Timestamp")) {
if (value == null || value.equals("")) {
continue;
}
}
setProperty(bean, name, value);
} catch (NoSuchMethodException e) {
continue;
}
}
}
// Map --> Bean 1: 利用Introspector,PropertyDescriptor实现 Map --> Bean
public static void transMap2Bean(Map<String, Object> map, Object obj) {
try {
BeanInfo beanInfo = Introspector.getBeanInfo(obj.getClass());
PropertyDescriptor[] propertyDescriptors = beanInfo.getPropertyDescriptors();
for (PropertyDescriptor property : propertyDescriptors) {
String key = property.getName();
if (map.containsKey(key)) {
Object value = map.get(key);
// 得到property对应的setter方法
Method setter = property.getWriteMethod();
setter.invoke(obj, value);
}
}
} catch (Exception e) {
System.out.println("transMap2Bean Error " + e);
}
return;
}
/**
* Map key MapkeyBeanBEAN
*
* @param bean
* Object
* @param properties
* Map
* @throws IllegalAccessException
* @throws InvocationTargetException
*/
public static void copyMap2Bean_Nobig(Object bean, Map properties) throws IllegalAccessException, InvocationTargetException {
// Do nothing unless both arguments have been specified
if ((bean == null) || (properties == null)) {
return;
}
// Loop through the property name/value pairs to be set
Iterator names = properties.keySet().iterator();
while (names.hasNext()) {
String name = (String) names.next();
// Identify the property name and value(s) to be assigned
if (name == null) {
continue;
}
Object value = properties.get(name);
// 命名应该大小写应该敏感(否则取不到对象的属性)
// name = name.toLowerCase();
try {
if (value == null) { // 不光Date类型好多类型在null时会出错
continue; // 如果为null不用设 (对象如果有特殊初始值也可以保留?)
}
Class clazz = PropertyUtils.getPropertyType(bean, name);
if (null == clazz) { // 在bean中这个属性不存在
continue;
}
String className = clazz.getName();
// 临时对策(如果不处理默认的类型转换时会出错)
if (className.equalsIgnoreCase("java.util.Date")) {
value = new java.util.Date(((java.sql.Timestamp) value).getTime());// wait
// to
// do貌似有时区问题,
// 待进一步确认
}
// if (className.equalsIgnoreCase("java.sql.Timestamp")) {
// if (value == null || value.equals("")) {
// continue;
// }
// }
setProperty(bean, name, value);
} catch (NoSuchMethodException e) {
continue;
}
}
}
/**
* MapkeyBeanBEAN
*
* @param bean
* Object
* @param properties
* Map
* @param defaultValue
* String
* @throws IllegalAccessException
* @throws InvocationTargetException
*/
public static void copyMap2Bean(Object bean, Map properties, String defaultValue) throws IllegalAccessException, InvocationTargetException {
// Do nothing unless both arguments have been specified
if ((bean == null) || (properties == null)) {
return;
}
// Loop through the property name/value pairs to be set
Iterator names = properties.keySet().iterator();
while (names.hasNext()) {
String name = (String) names.next();
// Identify the property name and value(s) to be assigned
if (name == null) {
continue;
}
Object value = properties.get(name);
try {
Class clazz = PropertyUtils.getPropertyType(bean, name);
if (null == clazz) {
continue;
}
String className = clazz.getName();
if (className.equalsIgnoreCase("java.sql.Timestamp")) {
if (value == null || value.equals("")) {
continue;
}
}
if (className.equalsIgnoreCase("java.lang.String")) {
if (value == null) {
value = defaultValue;
}
}
setProperty(bean, name, value);
} catch (NoSuchMethodException e) {
continue;
}
}
}
public MyBeanUtils() {
super();
}
}

@ -0,0 +1,30 @@
package com.zhonghe.active4j.core.util;
import org.apache.commons.lang3.StringUtils;
/**
*
*
* @author teli_
*
*/
public class MyStringUtils extends StringUtils {
/**
*
*
* @param str
* @param strs
* @return true
*/
public static boolean inStringIgnoreCase(String str, String... strs) {
if (str != null && strs != null) {
for (String s : strs) {
if (str.equalsIgnoreCase(StringUtils.trim(s))) {
return true;
}
}
}
return false;
}
}

@ -0,0 +1,22 @@
package com.zhonghe.active4j.core.util;
import java.util.regex.Matcher;
import java.util.regex.Pattern;
public class NumberUtil {
/**
*
* @param s
* @return
*/
public static boolean isDouble(String s) {
Pattern pattern = Pattern.compile("^(([1-9]{1}\\d*)|([0]{1}))(\\.(\\d){0,2})?$"); // 判断小数点后2位的数字的正则表达式
Matcher match = pattern.matcher(s);
return match.matches();
}
}

@ -0,0 +1,26 @@
package com.zhonghe.active4j.core.util;
/**
*
* @author 38943
*
*/
public class PagerUtil {
public PagerUtil() {
}
/**
*
* @param l
* @param m
* @return
*/
public static int getFirstResult(int l, int m) {
if(l < 1) {
return 0;
}
return (l - 1) * m;
}
}

@ -0,0 +1,216 @@
package com.zhonghe.active4j.core.util;
import java.awt.BasicStroke;
import java.awt.Graphics;
import java.awt.Graphics2D;
import java.awt.Image;
import java.awt.Shape;
import java.awt.geom.RoundRectangle2D;
import java.awt.image.BufferedImage;
import java.io.File;
import java.io.OutputStream;
import java.util.Hashtable;
import java.util.Random;
import javax.imageio.ImageIO;
import com.google.zxing.BarcodeFormat;
import com.google.zxing.BinaryBitmap;
import com.google.zxing.DecodeHintType;
import com.google.zxing.EncodeHintType;
import com.google.zxing.MultiFormatReader;
import com.google.zxing.MultiFormatWriter;
import com.google.zxing.Result;
import com.google.zxing.client.j2se.BufferedImageLuminanceSource;
import com.google.zxing.common.BitMatrix;
import com.google.zxing.common.HybridBinarizer;
import com.google.zxing.qrcode.decoder.ErrorCorrectionLevel;
public class QrCodeUtils {
private static final String CHARSET = "utf-8";
public static final String FORMAT_NAME = "JPG";
// 二维码尺寸
private static final int QRCODE_SIZE = 300;
// LOGO宽度
private static final int WIDTH = 60;
// LOGO高度
private static final int HEIGHT = 60;
/**
*
*
* @param content
* @return
* @throws Exception
*/
public static BufferedImage createImage(String content) throws Exception {
Hashtable hints = new Hashtable();
hints.put(EncodeHintType.ERROR_CORRECTION, ErrorCorrectionLevel.H);
hints.put(EncodeHintType.CHARACTER_SET, CHARSET);
hints.put(EncodeHintType.MARGIN, 1);
BitMatrix bitMatrix = new MultiFormatWriter().encode(content, BarcodeFormat.QR_CODE, QRCODE_SIZE, QRCODE_SIZE, hints);
int width = bitMatrix.getWidth();
int height = bitMatrix.getHeight();
BufferedImage image = new BufferedImage(width, height, BufferedImage.TYPE_INT_RGB);
for (int x = 0; x < width; x++) {
for (int y = 0; y < height; y++) {
image.setRGB(x, y, bitMatrix.get(x, y) ? 0xFF000000 : 0xFFFFFFFF);
}
}
return image;
}
/**
*
*
* @param content
* @param imgPath
* @param needCompress
* @return
* @throws Exception
*/
private static BufferedImage createImage(String content, String imgPath, boolean needCompress) throws Exception {
Hashtable hints = new Hashtable();
hints.put(EncodeHintType.ERROR_CORRECTION, ErrorCorrectionLevel.H);
hints.put(EncodeHintType.CHARACTER_SET, CHARSET);
hints.put(EncodeHintType.MARGIN, 1);
BitMatrix bitMatrix = new MultiFormatWriter().encode(content, BarcodeFormat.QR_CODE, QRCODE_SIZE, QRCODE_SIZE, hints);
int width = bitMatrix.getWidth();
int height = bitMatrix.getHeight();
BufferedImage image = new BufferedImage(width, height, BufferedImage.TYPE_INT_RGB);
for (int x = 0; x < width; x++) {
for (int y = 0; y < height; y++) {
image.setRGB(x, y, bitMatrix.get(x, y) ? 0xFF000000 : 0xFFFFFFFF);
}
}
if (imgPath == null || "".equals(imgPath)) {
return image;
}
// 插入图片
QrCodeUtils.insertImage(image, imgPath, needCompress);
return image;
}
/**
*
*
* @param source
* @param imgPath
* @param needCompress
* @throws Exception
*/
private static void insertImage(BufferedImage source, String imgPath, boolean needCompress) throws Exception {
File file = new File(imgPath);
if (!file.exists()) {
System.err.println("" + imgPath + " 该文件不存在!");
return;
}
Image src = ImageIO.read(new File(imgPath));
int width = src.getWidth(null);
int height = src.getHeight(null);
if (needCompress) { // 压缩LOGO
if (width > WIDTH) {
width = WIDTH;
}
if (height > HEIGHT) {
height = HEIGHT;
}
Image image = src.getScaledInstance(width, height, Image.SCALE_SMOOTH);
BufferedImage tag = new BufferedImage(width, height, BufferedImage.TYPE_INT_RGB);
Graphics g = tag.getGraphics();
g.drawImage(image, 0, 0, null); // 绘制缩小后的图
g.dispose();
src = image;
}
// 插入LOGO
Graphics2D graph = source.createGraphics();
int x = (QRCODE_SIZE - width) / 2;
int y = (QRCODE_SIZE - height) / 2;
graph.drawImage(src, x, y, width, height, null);
Shape shape = new RoundRectangle2D.Float(x, y, width, width, 6, 6);
graph.setStroke(new BasicStroke(3f));
graph.draw(shape);
graph.dispose();
}
/**
* logo
*
* @param content
* @param imgPath logo
* @param destPath
* @param needCompress
* @throws Exception
*/
public static void encode(String content, String imgPath, String destPath, boolean needCompress) throws Exception {
BufferedImage image = QrCodeUtils.createImage(content, imgPath, needCompress);
mkdirs(destPath);
String file = new Random().nextInt(99999999) + ".jpg";// 生成随机文件名
ImageIO.write(image, FORMAT_NAME, new File(destPath + "/" + file));
}
public static void mkdirs(String destPath) {
File file = new File(destPath);
// 当文件夹不存在时mkdirs会自动创建多层目录区别于mkdir。(mkdir如果父目录不存在则会抛出异常)
if (!file.exists() && !file.isDirectory()) {
file.mkdirs();
}
}
public static void encode(String content, String imgPath, String destPath) throws Exception {
QrCodeUtils.encode(content, imgPath, destPath, false);
}
public static void encode(String content, String destPath, boolean needCompress) throws Exception {
QrCodeUtils.encode(content, null, destPath, needCompress);
}
public static void encode(String content, String destPath) throws Exception {
QrCodeUtils.encode(content, null, destPath, false);
}
public static void encode(String content, String imgPath, OutputStream output, boolean needCompress) throws Exception {
BufferedImage image = QrCodeUtils.createImage(content, imgPath, needCompress);
ImageIO.write(image, FORMAT_NAME, output);
}
public static void encode(String content, OutputStream output) throws Exception {
QrCodeUtils.encode(content, null, output, false);
}
/**
*
*
* @param file
* @return
* @throws Exception
*/
public static String decode(File file) throws Exception {
BufferedImage image;
image = ImageIO.read(file);
if (image == null) {
return null;
}
BufferedImageLuminanceSource source = new BufferedImageLuminanceSource(image);
BinaryBitmap bitmap = new BinaryBitmap(new HybridBinarizer(source));
Result result;
Hashtable hints = new Hashtable();
hints.put(DecodeHintType.CHARACTER_SET, CHARSET);
result = new MultiFormatReader().decode(bitmap, hints);
String resultStr = result.getText();
return resultStr;
}
public static String decode(String path) throws Exception {
return QrCodeUtils.decode(new File(path));
}
}

@ -0,0 +1,147 @@
package com.zhonghe.active4j.core.util;
import java.lang.reflect.Field;
import java.lang.reflect.Method;
import java.util.Date;
import org.apache.commons.lang3.StringUtils;
import lombok.extern.slf4j.Slf4j;
/**
*
* @author teli_
*
*/
@Slf4j
public class ReflectUtil {
/**
*
*/
public static final String TYPE_String = "class java.lang.String";
public static final String TYPE_Integer = "class java.lang.Integer";
public static final String TYPE_Double = "class java.lang.Double";
public static final String TYPE_Boolean = "class java.lang.Boolean";
public static final String TYPE_Date = "class java.util.Date";
public static final String Type_Short = "class java.lang.Short";
public static final String BASE_TYPE_Boolean = "boolean";
public static final String BASE_TYPE_Integer = "int";
public static final String BASE_TYPE_Long = "long";
public static Object getValueByField(Field field, Object sourceObj) {
Object result = null;
try {
//如果类型是string的
if(StringUtils.equals(field.getGenericType().toString(), TYPE_String)) {
// 拿到该属性的gettet方法
Method m = (Method) sourceObj.getClass().getMethod("get" + getMethodName(field.getName()));
String val = (String) m.invoke(sourceObj);// 调用getter方法获取属性值
if (StringUtils.isNotEmpty(val)) {
result = val;
}
}
// 如果类型是Integer
else if (StringUtils.equals(field.getGenericType().toString(), TYPE_Integer)) {
Method m = (Method) sourceObj.getClass().getMethod("get" + getMethodName(field.getName()));
Integer val = (Integer) m.invoke(sourceObj);
if (val != null) {
result = val;
}
}
// 如果类型是Double
else if (StringUtils.equals(field.getGenericType().toString(), TYPE_Double)) {
Method m = (Method) sourceObj.getClass().getMethod("get" + getMethodName(field.getName()));
Double val = (Double) m.invoke(sourceObj);
if (val != null) {
result = val;
}
}
// 如果类型是Boolean 是封装类
else if (StringUtils.equals(field.getGenericType().toString(), TYPE_Boolean)) {
Method m = (Method) sourceObj.getClass().getMethod(field.getName());
Boolean val = (Boolean) m.invoke(sourceObj);
if (val != null) {
result = val;
}
}
// 如果类型是boolean 基本数据类型不一样 这里有点说名如果定义名是 isXXX的 那就全都是isXXX的
// 反射找不到getter的具体名
else if (StringUtils.equals(field.getGenericType().toString(), BASE_TYPE_Boolean)) {
Method m = (Method) sourceObj.getClass().getMethod(field.getName());
Boolean val = (Boolean) m.invoke(sourceObj);
if (val != null) {
result = val;
}
}
// 如果类型是Date
else if (StringUtils.equals(field.getGenericType().toString(), TYPE_Date)) {
Method m = (Method) sourceObj.getClass().getMethod("get" + getMethodName(field.getName()));
Date val = (Date) m.invoke(sourceObj);
if (val != null) {
result = val;
}
}
// 如果类型是Short
else if (StringUtils.equals(field.getGenericType().toString(), Type_Short)) {
Method m = (Method) sourceObj.getClass().getMethod("get" + getMethodName(field.getName()));
Short val = (Short) m.invoke(sourceObj);
if (val != null) {
result = val;
}
}
// 如果是int类型
else if (StringUtils.equals(field.getGenericType().toString(), BASE_TYPE_Integer)) {
Method m = (Method) sourceObj.getClass().getMethod("get" + getMethodName(field.getName()));
Integer val = (Integer) m.invoke(sourceObj);
if (val != null) {
result = val;
}
}
// 如果是long类型
else if (StringUtils.equals(field.getGenericType().toString(), BASE_TYPE_Long)) {
Method m = (Method) sourceObj.getClass().getMethod("get" + getMethodName(field.getName()));
Long val = (Long) m.invoke(sourceObj);
if (val != null) {
result = val;
}
}
// 如果还需要其他的类型请自己做扩展
}catch(Exception e) {
log.error("通过反射获取字段值出错,错误信息:" + e.getMessage());
e.printStackTrace();
}
return result;
}
// 把一个字符串的第一个字母大写、效率是最高的、
private static String getMethodName(String fildeName) throws Exception{
byte[] items = fildeName.getBytes();
items[0] = (byte) ((char) items[0] - 'a' + 'A');
return new String(items);
}
}

@ -0,0 +1,58 @@
package com.zhonghe.active4j.core.util;
import javax.servlet.http.HttpServletRequest;
import org.springframework.web.context.request.RequestAttributes;
import org.springframework.web.context.request.RequestContextHolder;
import org.springframework.web.context.request.ServletRequestAttributes;
/**
* request
*
* @author teli_
*
*/
public class RequestUtil {
public static ServletRequestAttributes getRequestAttributes() {
RequestAttributes attributes = RequestContextHolder.getRequestAttributes();
return (ServletRequestAttributes) attributes;
}
/**
* request
*/
public static HttpServletRequest getRequest() {
return getRequestAttributes().getRequest();
}
/**
*
*
* @param request
* @return
*/
public static boolean isAjaxRequest(HttpServletRequest request) {
String accept = request.getHeader("accept");
if (accept != null && accept.indexOf("application/json") != -1) {
return true;
}
String xRequestedWith = request.getHeader("X-Requested-With");
if (xRequestedWith != null && xRequestedWith.indexOf("XMLHttpRequest") != -1) {
return true;
}
String uri = request.getRequestURI();
if (MyStringUtils.inStringIgnoreCase(uri, ".json", ".xml")) {
return true;
}
String ajax = request.getParameter("__ajax");
if (MyStringUtils.inStringIgnoreCase(ajax, "json", "xml")) {
return true;
}
return false;
}
}

@ -0,0 +1,60 @@
package com.zhonghe.active4j.core.util;
import java.io.IOException;
import java.io.PrintWriter;
import javax.servlet.http.HttpServletResponse;
import lombok.extern.slf4j.Slf4j;
/**
*
*
* @author teli_
*
*/
@Slf4j
public class ResponseUtil {
/**
*
* @param response
* @param result
*/
public static void write(HttpServletResponse response, String result) {
response.setContentType("text/xml;charset=utf-8");
response.setCharacterEncoding("utf-8");
response.setHeader("Cache-Control", "no-store");
try {
PrintWriter pw = response.getWriter();
pw.write(result);
pw.flush();
pw.close();
} catch (IOException e) {
log.error("往客户端写出数据报错,错误信息:" + e.getMessage());
log.error(e.getMessage(), e);
}
}
/**
* json
* @param response
* @param result
*/
public static void writeJson(HttpServletResponse response, String result) {
response.setCharacterEncoding("UTF-8");
response.setContentType("application/json;charset=UTF-8");
response.setHeader("Cache-Control", "no-store");
try {
PrintWriter pw = response.getWriter();
pw.write(result);
pw.flush();
pw.close();
} catch (IOException e) {
log.error("往客户端写出数据报错,错误信息:" + e.getMessage());
log.error(e.getMessage(), e);
}
}
}

@ -0,0 +1,142 @@
package com.zhonghe.active4j.core.util;
import org.apache.commons.lang3.RandomStringUtils;
import org.apache.shiro.SecurityUtils;
import org.apache.shiro.crypto.hash.SimpleHash;
import org.apache.shiro.session.Session;
import org.apache.shiro.subject.Subject;
import org.apache.shiro.util.ByteSource;
import com.baomidou.mybatisplus.core.toolkit.StringUtils;
import com.zhonghe.active4j.system.model.ActiveUser;
/**
* shiro
* @author teli_
*
*/
public class ShiroUtils {
/**
*
*/
public final static String hashAlgorithmName = "MD5";
/**
*
*/
public final static int hashIterations = 2;
/**
* shiro
*
* @param credentials
* @param saltSource
* @return
*/
public static String md5(String credentials, String saltSource) {
return new SimpleHash(hashAlgorithmName, credentials, ByteSource.Util.bytes(saltSource), hashIterations).toString();
}
/**
*
* @return
*/
public static String getRandomSalt() {
String index = RandomStringUtils.random(1, "23456789");
String str = RandomStringUtils.random(Integer.valueOf(index), "abcdefghijklmnopqrstuvwxyz0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ");
return str;
}
/**
* Subject
*
* @return Subject
*/
public static Subject getSubject() {
return SecurityUtils.getSubject();
}
public static boolean hasLogin() {
return null != getSubject() && getSubject().isAuthenticated() && null != getSubject().getPrincipals();
}
/**
*
* @param
* @return
*/
public static boolean hasRole(String roleCode) {
return getSubject() != null && StringUtils.isNotEmpty(roleCode) && getSubject().hasRole(roleCode);
}
/**
*
* @param permission
* @return
*/
public static boolean hasPermission(String permission) {
return getSubject() != null && permission != null
&& permission.length() > 0
&& getSubject().isPermitted(permission);
}
/**
* shirosession
*/
public static Session getSession() {
return getSubject().getSession();
}
/**
* shiro session
* @param key
* @return
*/
public static String getSessionValue(String key) {
return (String)getSession().getAttribute(key);
}
/**
* shiro session
* @param key
* @param value
*/
public static void setSessionValue(String key, String value) {
getSession().setAttribute(key, value);;
}
public static void logout() {
getSubject().logout();
}
/**
*
* @return
*/
public static ActiveUser getSessionUser() {
return (ActiveUser) getSubject().getPrincipals().getPrimaryPrincipal();
}
/**
*
* @return
*/
public static String getSessionUserName() {
ActiveUser user = getSessionUser();
return user.getUserName();
}
/**
* ID
* @return
*/
public static String getSessionUserId() {
ActiveUser user = getSessionUser();
return user.getId();
}
}

@ -0,0 +1,109 @@
package com.zhonghe.active4j.core.util;
import org.springframework.aop.framework.AopContext;
import org.springframework.beans.BeansException;
import org.springframework.beans.factory.NoSuchBeanDefinitionException;
import org.springframework.beans.factory.config.BeanFactoryPostProcessor;
import org.springframework.beans.factory.config.ConfigurableListableBeanFactory;
import org.springframework.stereotype.Component;
/**
*
* @title SpringUtils.java
* @description
spring 便springbean
* @time 20191210 2:19:38
* @author guyp
* @version 1.0
*/
@Component
public final class SpringUtils implements BeanFactoryPostProcessor {
/** Spring应用上下文环境 */
private static ConfigurableListableBeanFactory beanFactory;
@Override
public void postProcessBeanFactory(ConfigurableListableBeanFactory beanFactory) throws BeansException {
SpringUtils.beanFactory = beanFactory;
}
/**
*
*
* @param name
* @return Object bean
* @throws org.springframework.beans.BeansException
*
*/
@SuppressWarnings("unchecked")
public static <T> T getBean(String name) throws BeansException {
return (T) beanFactory.getBean(name);
}
/**
* requiredType
*
* @param clz
* @return
* @throws org.springframework.beans.BeansException
*
*/
public static <T> T getBean(Class<T> clz) throws BeansException {
T result = (T) beanFactory.getBean(clz);
return result;
}
/**
* BeanFactorybeantrue
*
* @param name
* @return boolean
*/
public static boolean containsBean(String name) {
return beanFactory.containsBean(name);
}
/**
* beansingletonprototype beanNoSuchBeanDefinitionException
*
* @param name
* @return boolean
* @throws org.springframework.beans.factory.NoSuchBeanDefinitionException
*
*/
public static boolean isSingleton(String name) throws NoSuchBeanDefinitionException {
return beanFactory.isSingleton(name);
}
/**
* @param name
* @return Class
* @throws org.springframework.beans.factory.NoSuchBeanDefinitionException
*
*/
public static Class<?> getType(String name) throws NoSuchBeanDefinitionException {
return beanFactory.getType(name);
}
/**
* beanbean
*
* @param name
* @return
* @throws org.springframework.beans.factory.NoSuchBeanDefinitionException
*
*/
public static String[] getAliases(String name) throws NoSuchBeanDefinitionException {
return beanFactory.getAliases(name);
}
/**
* aop
*
* @param invoker
* @return
*/
@SuppressWarnings("unchecked")
public static <T> T getAopProxy(T invoker) {
return (T) AopContext.currentProxy();
}
}

@ -0,0 +1,15 @@
package com.zhonghe.active4j.core.util;
import java.util.UUID;
public class UUIDUtil {
/**
* UUID
* @return
*/
public static String getUUID(){
UUID uuid = UUID.randomUUID();
return uuid.toString().replace("-", "");
}
}

@ -0,0 +1,37 @@
package com.zhonghe.active4j.demo.component.controller;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestMapping;
import com.zhonghe.active4j.common.controller.BaseController;
import lombok.extern.slf4j.Slf4j;
/**
* @title ComponentController.java
* @description
* @time 2019129 9:54:06
* @author
* @version 1.0
*/
@Controller
@RequestMapping("/comp")
@Slf4j
public class ComponentController extends BaseController {
public static final String prefix_url = "comps/";
@RequestMapping("/{comp}/{page}")
public String index(@PathVariable String comp, @PathVariable String page, Model model) {
log.info(prefix_url + comp + "/" + page);
return prefix_url + comp + "/" + page + ".html";
}
}

@ -0,0 +1,65 @@
package com.zhonghe.active4j.demo.main.controller;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.RequestMapping;
import com.zhonghe.active4j.common.controller.BaseController;
import com.zhonghe.active4j.core.annotation.Log;
import com.zhonghe.active4j.core.model.LogType;
import lombok.extern.slf4j.Slf4j;
/**
* @title ProjectController.java
* @description
* @time 2019123 10:09:32
* @author chenxl
* @version 1.0
*/
@Controller
@RequestMapping("/demo/main")
@Slf4j
public class ProjectController extends BaseController {
/**
*
*/
public static final String prefix_page = "home/";
/**
*
* @description
*
* @params
*
* @return String
* @author chenxl
* @time 2019123 10:55:55
*/
@RequestMapping("/index")
@Log(type = LogType.normal, name = "进入控制台", memo = "进入控制台")
public String index(Model model) {
return prefix_page + "console.html";
}
/**
*
* @description
*
* @params
*
* @return String
* @author chenxl
* @time 2019123 10:55:55
*/
@RequestMapping("/homepage1")
@Log(type = LogType.normal, name = "进入控制台", memo = "进入控制台")
public String homepage1(Model model) {
return prefix_page + "console.html";
}
}

@ -0,0 +1,87 @@
package com.zhonghe.active4j.func.captcha.config;
import java.util.Properties;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import com.google.code.kaptcha.impl.DefaultKaptcha;
import com.google.code.kaptcha.util.Config;
import static com.google.code.kaptcha.Constants.*;
/**
*
* @title CaptchaConfig.java
* @description
* @time 20191219 3:13:25
* @author guyp
* @version 1.0
*/
@Configuration
public class CaptchaConfig {
@Bean(name = "captchaProducer")
public DefaultKaptcha getKaptchaBean() {
DefaultKaptcha defaultKaptcha = new DefaultKaptcha();
Properties properties = new Properties();
// 是否有边框 默认为true 我们可以自己设置yesno
properties.setProperty(KAPTCHA_BORDER, "yes");
// 验证码文本字符颜色 默认为Color.BLACK
properties.setProperty(KAPTCHA_TEXTPRODUCER_FONT_COLOR, "black");
// 验证码图片宽度 默认为200
properties.setProperty(KAPTCHA_IMAGE_WIDTH, "160");
// 验证码图片高度 默认为50
properties.setProperty(KAPTCHA_IMAGE_HEIGHT, "60");
// 验证码文本字符大小 默认为40
properties.setProperty(KAPTCHA_TEXTPRODUCER_FONT_SIZE, "38");
// KAPTCHA_SESSION_KEY
properties.setProperty(KAPTCHA_SESSION_CONFIG_KEY, "kaptchaCode");
// 验证码文本字符长度 默认为5
properties.setProperty(KAPTCHA_TEXTPRODUCER_CHAR_LENGTH, "4");
// 验证码文本字体样式 默认为new Font("Arial", 1, fontSize), new Font("Courier", 1, fontSize)
properties.setProperty(KAPTCHA_TEXTPRODUCER_FONT_NAMES, "Arial,Courier");
// 图片样式 水纹com.google.code.kaptcha.impl.WaterRipple 鱼眼com.google.code.kaptcha.impl.FishEyeGimpy 阴影com.google.code.kaptcha.impl.ShadowGimpy
properties.setProperty(KAPTCHA_OBSCURIFICATOR_IMPL, "com.google.code.kaptcha.impl.ShadowGimpy");
Config config = new Config(properties);
defaultKaptcha.setConfig(config);
return defaultKaptcha;
}
@Bean(name = "captchaProducerMath")
public DefaultKaptcha getKaptchaBeanMath() {
DefaultKaptcha defaultKaptcha = new DefaultKaptcha();
Properties properties = new Properties();
// 是否有边框 默认为true 我们可以自己设置yesno
properties.setProperty(KAPTCHA_BORDER, "yes");
// 边框颜色 默认为Color.BLACK
properties.setProperty(KAPTCHA_BORDER_COLOR, "105,179,90");
// 验证码文本字符颜色 默认为Color.BLACK
properties.setProperty(KAPTCHA_TEXTPRODUCER_FONT_COLOR, "blue");
// 验证码图片宽度 默认为200
properties.setProperty(KAPTCHA_IMAGE_WIDTH, "160");
// 验证码图片高度 默认为50
properties.setProperty(KAPTCHA_IMAGE_HEIGHT, "60");
// 验证码文本字符大小 默认为40
properties.setProperty(KAPTCHA_TEXTPRODUCER_FONT_SIZE, "35");
// KAPTCHA_SESSION_KEY
properties.setProperty(KAPTCHA_SESSION_CONFIG_KEY, "kaptchaCodeMath");
// 验证码文本生成器
properties.setProperty(KAPTCHA_TEXTPRODUCER_IMPL, "com.zhonghe.active4j.func.captcha.config.KaptchaTextCreator");
// 验证码文本字符间距 默认为2
properties.setProperty(KAPTCHA_TEXTPRODUCER_CHAR_SPACE, "3");
// 验证码文本字符长度 默认为5
properties.setProperty(KAPTCHA_TEXTPRODUCER_CHAR_LENGTH, "6");
// 验证码文本字体样式 默认为new Font("Arial", 1, fontSize), new Font("Courier", 1, fontSize)
properties.setProperty(KAPTCHA_TEXTPRODUCER_FONT_NAMES, "Arial,Courier");
// 验证码噪点颜色 默认为Color.BLACK
properties.setProperty(KAPTCHA_NOISE_COLOR, "white");
// 干扰实现类
properties.setProperty(KAPTCHA_NOISE_IMPL, "com.google.code.kaptcha.impl.NoNoise");
// 图片样式 水纹com.google.code.kaptcha.impl.WaterRipple 鱼眼com.google.code.kaptcha.impl.FishEyeGimpy 阴影com.google.code.kaptcha.impl.ShadowGimpy
properties.setProperty(KAPTCHA_OBSCURIFICATOR_IMPL, "com.google.code.kaptcha.impl.ShadowGimpy");
Config config = new Config(properties);
defaultKaptcha.setConfig(config);
return defaultKaptcha;
}
}

@ -0,0 +1,72 @@
package com.zhonghe.active4j.func.captcha.config;
import java.security.SecureRandom;
import java.util.Random;
import com.google.code.kaptcha.text.impl.DefaultTextCreator;
/**
*
* @title KaptchaTextCreator.java
* @description
* @time 20191219 3:13:34
* @author guyp
* @version 1.0
*/
public class KaptchaTextCreator extends DefaultTextCreator {
private static final String[] CNUMBERS = "0,1,2,3,4,5,6,7,8,9,10".split(",");
@Override
public String getText() {
Integer result = 0;
Random random = new SecureRandom();
int x = random.nextInt(10);
int y = random.nextInt(10);
StringBuilder suChinese = new StringBuilder();
int randomoperands = (int) Math.round(Math.random() * 2);
if(randomoperands == 0) {
result = x * y;
suChinese.append(CNUMBERS[x]);
suChinese.append("*");
suChinese.append(CNUMBERS[y]);
}
else if(randomoperands == 1) {
if(!(x == 0) && y % x == 0) {
result = y / x;
suChinese.append(CNUMBERS[y]);
suChinese.append("/");
suChinese.append(CNUMBERS[x]);
}
else {
result = x + y;
suChinese.append(CNUMBERS[x]);
suChinese.append("+");
suChinese.append(CNUMBERS[y]);
}
}
else if(randomoperands == 2) {
if(x >= y) {
result = x - y;
suChinese.append(CNUMBERS[x]);
suChinese.append("-");
suChinese.append(CNUMBERS[y]);
}
else {
result = y - x;
suChinese.append(CNUMBERS[y]);
suChinese.append("-");
suChinese.append(CNUMBERS[x]);
}
}
else {
result = x + y;
suChinese.append(CNUMBERS[x]);
suChinese.append("+");
suChinese.append(CNUMBERS[y]);
}
suChinese.append("=?@" + result);
return suChinese.toString();
}
}

@ -0,0 +1,148 @@
package com.zhonghe.active4j.func.captcha.controller;
import java.awt.image.BufferedImage;
import java.io.IOException;
import javax.annotation.Resource;
import javax.imageio.ImageIO;
import javax.servlet.ServletOutputStream;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;
import org.apache.commons.lang3.StringUtils;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;
import com.google.code.kaptcha.Constants;
import com.google.code.kaptcha.Producer;
import com.zhonghe.active4j.common.controller.BaseController;
import com.zhonghe.active4j.core.model.AjaxJson;
import com.zhonghe.active4j.core.util.ShiroUtils;
import lombok.extern.slf4j.Slf4j;
/**
*
* @title CaptchaController.java
* @description
* @time 20191219 3:30:47
* @author guyp
* @version 1.0
*/
@Controller
@RequestMapping("/func/captcha")
@Slf4j
public class CaptchaController extends BaseController {
@Resource(name = "captchaProducer")
private Producer captchaProducer;
@Resource(name = "captchaProducerMath")
private Producer captchaProducerMath;
public static final String prefix_page = "func/captcha/";
/**
*
* @description
*
* @params
* @return String
* @author guyp
* @time 20191219 3:30:28
*/
@RequestMapping("/captcha")
public String captcha(Model model) {
return prefix_page + "captcha.html";
}
/**
*
* @description
*
* @params
* @return void
* @author guyp
* @time 20191219 4:49:57
*/
@RequestMapping("/captchaImage")
public void verCode(String type, HttpServletRequest request, HttpServletResponse response) {
ServletOutputStream out = null;
try {
HttpSession session = request.getSession();
response.setDateHeader("Expires", 0);
response.setHeader("Cache-Control", "no-store, no-cache, must-revalidate");
response.addHeader("Cache-Control", "post-check=0, pre-check=0");
response.setHeader("Pragma", "no-cache");
response.setContentType("image/jpeg");
String capStr = null;
String code = null;
BufferedImage bi = null;
//算数验证码
if(StringUtils.equals("math", type)) {
String capText = captchaProducerMath.createText();
capStr = capText.substring(0, capText.lastIndexOf("@"));
code = capText.substring(capText.lastIndexOf("@") + 1);
bi = captchaProducerMath.createImage(capStr);
}
//文字验证码
else if(StringUtils.equals("char", type)) {
capStr = code = captchaProducer.createText();
bi = captchaProducer.createImage(capStr);
}
session.setAttribute(Constants.KAPTCHA_SESSION_KEY, code);
out = response.getOutputStream();
ImageIO.write(bi, "jpg", out);
out.flush();
} catch (Exception e) {
log.error("获取验证码报错,错误信息:{}", e.getMessage());
e.printStackTrace();
} finally {
try {
if(out != null) {
out.close();
}
} catch (IOException e) {
log.error("获取验证码报错,错误信息:{}", e.getMessage());
e.printStackTrace();
}
}
}
/**
*
* @description
*
* @params
* @return AjaxJson
* @author guyp
* @time 20191219 5:21:09
*/
@RequestMapping("/verify")
@ResponseBody
public AjaxJson verify(String vercode, HttpServletRequest request, HttpServletResponse response) {
AjaxJson j = new AjaxJson();
try{
//获取缓存的验证码
Object obj = ShiroUtils.getSession().getAttribute(Constants.KAPTCHA_SESSION_KEY);
String code = String.valueOf(obj != null ? obj : "");
//校验输入的验证码
if (StringUtils.isEmpty(vercode) || !StringUtils.equalsIgnoreCase(code, vercode)) {
j.setSuccess(false);
}
} catch(Exception e) {
j.setSuccess(false);
log.error("校验验证码报错,错误信息:{}", e.getMessage());
e.printStackTrace();
}
return j;
}
}

@ -0,0 +1,103 @@
package com.zhonghe.active4j.func.email.controller;
import org.apache.commons.lang3.StringUtils;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;
import com.zhonghe.active4j.common.controller.BaseController;
import com.zhonghe.active4j.core.model.AjaxJson;
import com.zhonghe.active4j.func.email.service.SysEmailService;
import lombok.extern.slf4j.Slf4j;
/**
*
* @title SysEmailController.java
* @description
* @time 2019123 10:13:13
* @author chenxl
* @version 1.0
*/
@Controller
@RequestMapping("/sys/email")
@Slf4j
public class SysEmailController extends BaseController {
/**
*
*/
public static final String prefix_page = "sys/email/";
@Autowired
private SysEmailService sysEmailService;
/**
*
* @description
*
* @params
* model
* @return String
* @author mhm
* @time 2019129 3:52:37
*/
@RequestMapping("/form")
public String form(Model model) {
return prefix_page + "email_form.html";
}
/**
*
* @description
*
* @params
* mailbox
* subject
* content
* @return AjaxJson
* @author mhm
* @time 2019129 3:51:29
*/
@RequestMapping("/send")
@ResponseBody
public AjaxJson send(String mailbox, String subject, String content) {
AjaxJson j = new AjaxJson();
try{
//后端校验
if(StringUtils.isEmpty(mailbox)) {
j.setSuccess(false);
j.setMsg("收件人邮箱不能为空");
return j;
}
if(StringUtils.isEmpty(subject)) {
j.setSuccess(false);
j.setMsg("主题不能为空");
return j;
}
if(StringUtils.isEmpty(content)) {
j.setSuccess(false);
j.setMsg("内容不能为空");
return j;
}
//邮件发送html类型其余方法见sysEmailService
sysEmailService.sendHtmlMail(mailbox, subject, content);
}catch(Exception e) {
log.error("邮件发送报错,错误信息:" + e.getMessage());
e.printStackTrace();
}
return j;
}
}

@ -0,0 +1,64 @@
package com.zhonghe.active4j.func.email.service;
public interface SysEmailService{
/**
*
* @description
*
* @params
* to
* subject
* text
* @return void
* @author mhm
* @time 2019129 10:46:40
*/
public void sendTextMail(String to, String subject, String text);
/**
*
* @description
*
* @params
* to
* subject
* text
* path
* @return void
* @author mhm
* @time 2019129 2:10:10
*/
public void sendAttachmentMail(String to, String subject, String text, String path);
/**
*
* @description
* HTML
* @params
* to
* subject
* text HTML
* @return void
* @author mhm
* @time 2019129 2:54:50
*/
public void sendHtmlMail(String to, String subject, String text);
/**
*
* @description
*
* @params
* to
* subject
* text
* rscPath
* rscId
* @return void
* @author mhm
* @time 2019129 3:12:17
*/
public void sendInlineResourceMail(String to, String subject, String text, String rscPath, String rscId);
}

@ -0,0 +1,164 @@
package com.zhonghe.active4j.func.email.service.impl;
import java.io.File;
import javax.mail.MessagingException;
import javax.mail.internet.MimeMessage;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.core.io.FileSystemResource;
import org.springframework.mail.SimpleMailMessage;
import org.springframework.mail.javamail.JavaMailSender;
import org.springframework.mail.javamail.MimeMessageHelper;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;
import com.zhonghe.active4j.func.email.service.SysEmailService;
import lombok.extern.slf4j.Slf4j;
/**
* service
* @author mhm
*
*/
@Service("sysEmailService")
@Transactional
@Slf4j
public class SysEmailServiceImpl implements SysEmailService {
@Autowired
private JavaMailSender javaMailSender;
@Value("${spring.mail.username}")
private String from;
/**
*
* @description
*
* @params
* to
* subject
* text
* @return void
* @author mhm
* @time 2019129 10:46:40
*/
public void sendTextMail(String to, String subject, String text) {
SimpleMailMessage simpleMailMessage = new SimpleMailMessage();
simpleMailMessage.setFrom(from);
simpleMailMessage.setTo(to);
simpleMailMessage.setSubject(subject);
simpleMailMessage.setText(text);
try{
javaMailSender.send(simpleMailMessage);
}catch (Exception e){
log.error("邮件发送失败。" + e.getMessage());
}
}
/**
*
* @description
*
* @params
* to
* subject
* text
* path
* @return void
* @author mhm
* @time 2019129 2:10:10
*/
public void sendAttachmentMail(String to, String subject, String text, String path){
MimeMessage mimeMessage = javaMailSender.createMimeMessage();
try{
// 创建一个multipart格式的message
MimeMessageHelper messageHelper = new MimeMessageHelper(mimeMessage,true);
messageHelper.setFrom(from);
messageHelper.setTo(to);
messageHelper.setSubject(subject);
messageHelper.setText(text,true);
// 添加附件信息
FileSystemResource file = new FileSystemResource(new File(path));
String fileName = path.substring(path.lastIndexOf(File.separator));
messageHelper.addAttachment(fileName,file);
// 发送带附件的邮件
javaMailSender.send(mimeMessage);
}catch (Exception e){
log.error("带有附件的邮件发送失败。" + e.getMessage());
}
}
/**
*
* @description
* HTML
* @params
* to
* subject
* text HTML
* @return void
* @author mhm
* @time 2019129 2:54:50
*/
public void sendHtmlMail(String to, String subject, String text){
MimeMessage message = javaMailSender.createMimeMessage();
try {
//true 表⽰示需要创建⼀一个 multipart message
MimeMessageHelper helper = new MimeMessageHelper(message, true);
helper.setFrom(from);
helper.setTo(to);
helper.setSubject(subject);
helper.setText(text, true);
javaMailSender.send(message);
} catch (MessagingException e) {
e.printStackTrace();
log.error("带有HTML的邮件发送失败。" + e.getMessage());
}
}
/**
*
* @description
*
* @params
* to
* subject
* text
* rscPath
* rscId
* @return void
* @author mhm
* @time 2019129 3:12:17
*/
public void sendInlineResourceMail(String to, String subject, String text, String rscPath, String rscId){
MimeMessage message = javaMailSender.createMimeMessage();
try {
MimeMessageHelper helper = new MimeMessageHelper(message, true);
helper.setFrom(from);
helper.setTo(to);
helper.setSubject(subject);
helper.setText(text, true);
File file = new File(rscPath);
FileSystemResource res = new FileSystemResource(file);
helper.addInline(rscId, res);
javaMailSender.send(message);
} catch (MessagingException e) {
e.printStackTrace();
log.error("带图片的邮件发送失败。" + e.getMessage());
}
}
}

@ -0,0 +1,201 @@
package com.zhonghe.active4j.func.export.controller;
import java.io.InputStream;
import java.util.HashMap;
import java.util.Map;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.apache.commons.lang3.StringUtils;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;
import org.springframework.web.multipart.MultipartFile;
import org.springframework.web.multipart.MultipartHttpServletRequest;
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.baomidou.mybatisplus.core.metadata.IPage;
import com.zhonghe.active4j.common.controller.BaseController;
import com.zhonghe.active4j.core.model.AjaxJson;
import com.zhonghe.active4j.core.model.PageInfo;
import com.zhonghe.active4j.core.query.QueryUtils;
import com.zhonghe.active4j.core.util.ResponseUtil;
import com.zhonghe.active4j.func.export.entity.ExportExampleEntity;
import com.zhonghe.active4j.func.export.service.ExportExampleService;
import com.zhonghe.active4j.func.export.wrapper.ExportExampleWrapper;
import com.zhonghe.active4j.func.upload.util.FileUploadUtils;
import lombok.extern.slf4j.Slf4j;
/**
*
* @title ExportExampleController.java
* @description
* @time 20191217 10:14:33
* @author guyp
* @version 1.0
*/
@Controller
@RequestMapping("/func/export")
@Slf4j
public class ExportExampleController extends BaseController {
@Autowired
private ExportExampleService exportExampleService;
private static final String prefix_page = "func/export/";
/**
*
* @description
*
* @params
* @return String
* @author guyp
* @time 20191217 10:15:18
*/
@RequestMapping("/list")
public String list(Model model) {
return prefix_page + "index_list.html";
}
/**
*
* @description
*
* @params
* @return void
* @author guyp
* @time 20191217 10:52:46
*/
@RequestMapping("/datagrid")
@ResponseBody
public void datagrid(ExportExampleEntity exportExampleEntity, PageInfo<ExportExampleEntity> page, HttpServletRequest request, HttpServletResponse response) {
//拼接查询条件
QueryWrapper<ExportExampleEntity> queryWrapper = QueryUtils.installQueryWrapper(exportExampleEntity, request.getParameterMap());
//执行查询
IPage<ExportExampleEntity> lstResult = exportExampleService.page(page.getPageEntity(), queryWrapper);
//结果处理,直接写到客户端
ResponseUtil.write(response, new ExportExampleWrapper(lstResult).wrap());
}
/**
*
* @description
*
* @params
* @return AjaxJson
* @author guyp
* @time 20191217 4:20:37
*/
@RequestMapping("/upload")
@ResponseBody
public AjaxJson upload(MultipartHttpServletRequest request, HttpServletResponse response) {
AjaxJson j = new AjaxJson();
try {
log.info("进入导入接口");
Map<String, Object> attributesMap = new HashMap<String, Object>();
Map<String, MultipartFile> fileMap = request.getFileMap();
for(Map.Entry<String, MultipartFile> entity : fileMap.entrySet()) {
// 获取上传文件对象
MultipartFile mf = entity.getValue();
//获取文件后缀名
String extName = FileUploadUtils.getExtension(mf);
//获得文件输入流
InputStream inputStream = mf.getInputStream();
/*excel
xlsx104857616384
xls65536256*/
if(StringUtils.equals("xlsx", extName)) {
//保存xlsx的内容
exportExampleService.saveXlsx(inputStream);
}else if(StringUtils.equals("xls", extName)) {
//保存xls的内容
exportExampleService.saveXls(inputStream);
}else {
j.setSuccess(false);
j.setMsg("您上传的文件包含不支持的格式,请重新上传");
return j;
}
attributesMap.put("src", mf.getOriginalFilename());
j.setAttributes(attributesMap);
//关闭流
inputStream.close();
//单次上传,不需要再次进入循环
break;
}
}catch(Exception e) {
log.error("导入报错,错误信息:{}", e.getMessage());
j.setSuccess(false);
e.printStackTrace();
}
return j;
}
/**
*
* @description
* xls
* @params
* @return void
* @author guyp
* @time 20191218 10:03:09
*/
@RequestMapping("/xls")
public void xls(String name, HttpServletRequest request, HttpServletResponse response) {
try {
//导出xls文件
exportExampleService.exportXls(request, response, name);
} catch (Exception e) {
log.error("导出xls报错错误信息{}", e.getMessage());
e.printStackTrace();
}
}
/**
*
* @description
* xlsx
* @params
* @return void
* @author guyp
* @time 20191218 11:27:40
*/
@RequestMapping("/xlsx")
public void xlsx(String name, HttpServletRequest request, HttpServletResponse response) {
try {
//导出xlsx文件
exportExampleService.exportXlsx(request, response, name);
} catch (Exception e) {
log.error("导出xls报错错误信息{}", e.getMessage());
e.printStackTrace();
}
}
/**
*
* @description
* csv
* @params
* @return void
* @author guyp
* @time 20191218 10:52:30
*/
@RequestMapping("/csv")
public void csv(String name, HttpServletRequest request, HttpServletResponse response) {
try {
//导出csv
exportExampleService.exportCsv(request, response, name);
} catch (Exception e) {
log.error("导出csv报错错误信息{}", e.getMessage());
e.printStackTrace();
}
}
}

@ -0,0 +1,16 @@
package com.zhonghe.active4j.func.export.dao;
import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import com.zhonghe.active4j.func.export.entity.ExportExampleEntity;
/**
*
* @title ExportExampleDao.java
* @description
* @time 20191217 10:45:09
* @author guyp
* @version 1.0
*/
public interface ExportExampleDao extends BaseMapper<ExportExampleEntity>{
}

@ -0,0 +1,70 @@
package com.zhonghe.active4j.func.export.entity;
import java.util.Date;
import com.baomidou.mybatisplus.annotation.TableField;
import com.baomidou.mybatisplus.annotation.TableName;
import com.zhonghe.active4j.common.entity.BaseEntity;
import com.zhonghe.active4j.core.annotation.QueryField;
import com.zhonghe.active4j.core.model.QueryCondition;
import lombok.Getter;
import lombok.Setter;
/**
*
* @title ExportExampleEntity.java
* @description
* @time 20191217 9:43:50
* @author guyp
* @version 1.0
*/
@TableName("func_export_example")
@Setter
@Getter
public class ExportExampleEntity extends BaseEntity {
/**
*
*/
private static final long serialVersionUID = -8486583273348702746L;
/**
*
*/
@TableField("NAME")
@QueryField(queryColumn="NAME", condition=QueryCondition.eq)
private String name;
/**
*
*/
@TableField("SEX")
private String sex;
/**
*
*/
@TableField("AGE")
private int age;
/**
*
*/
@TableField("PHONE")
private String phone;
/**
*
*/
@TableField("BIRTHDAY")
private Date birthday;
/**
*
*/
@TableField("BALANCE")
private double balance;
}

@ -0,0 +1,77 @@
package com.zhonghe.active4j.func.export.service;
import java.io.InputStream;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import com.baomidou.mybatisplus.extension.service.IService;
import com.zhonghe.active4j.func.export.entity.ExportExampleEntity;
/**
*
* @title ExportExampleService.java
* @description
* @time 20191217 10:47:07
* @author guyp
* @version 1.0
*/
public interface ExportExampleService extends IService<ExportExampleEntity> {
/**
*
* @description
* xlsxexcel
* @params
* @return void
* @author guyp
* @time 20191217 1:33:40
*/
public void saveXlsx(InputStream in) throws Exception;
/**
*
* @description
* xlsexcel
* @params
* @return void
* @author guyp
* @time 20191217 1:37:53
*/
public void saveXls(InputStream in) throws Exception;
/**
*
* @description
* xlsx
* @params
* name
* @return HSSFWorkbook
* @author guyp
* @time 20191218 9:54:50
*/
public void exportXlsx(HttpServletRequest request, HttpServletResponse response, String name) throws Exception;
/**
*
* @description
* xls
* @params
* @return void
* @author guyp
* @time 20191218 11:22:57
*/
public void exportXls(HttpServletRequest request, HttpServletResponse response, String name) throws Exception;
/**
*
* @description
* csv
* @params
* @return void
* @author guyp
* @time 20191218 10:31:04
*/
public void exportCsv(HttpServletRequest request, HttpServletResponse response, String name) throws Exception;
}

@ -0,0 +1,343 @@
package com.zhonghe.active4j.func.export.service.impl;
import java.io.IOException;
import java.io.InputStream;
import java.io.UnsupportedEncodingException;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.LinkedHashMap;
import java.util.List;
import java.util.Map;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.apache.commons.lang3.StringUtils;
import org.apache.poi.ss.usermodel.Cell;
import org.apache.poi.ss.usermodel.Row;
import org.apache.poi.ss.usermodel.Sheet;
import org.apache.poi.ss.usermodel.Workbook;
import org.springframework.http.MediaType;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;
import org.springframework.util.FileCopyUtils;
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import com.zhonghe.active4j.core.util.DateUtils;
import com.zhonghe.active4j.func.export.dao.ExportExampleDao;
import com.zhonghe.active4j.func.export.entity.ExportExampleEntity;
import com.zhonghe.active4j.func.export.service.ExportExampleService;
import com.zhonghe.active4j.func.export.util.ExcelUtil;
import com.zhonghe.active4j.func.export.util.ExportUtil;
import lombok.extern.slf4j.Slf4j;
/**
*
* @title ExportExampleServiceImpl.java
* @description
* @time 20191217 10:48:51
* @author guyp
* @version 1.0
*/
@Service("exportExampleService")
@Transactional
@Slf4j
public class ExportExampleServiceImpl extends ServiceImpl<ExportExampleDao, ExportExampleEntity> implements ExportExampleService {
/**
*
* @description
* xlsxexcel
* @params
* @return void
* @author guyp
* @throws Exception
* @time 20191217 1:33:40
*/
public void saveXlsx(InputStream in) throws Exception {
List<ExportExampleEntity> lstExports = new ArrayList<ExportExampleEntity>();
//解析excel的内容
List<List<Object>> lstA = ExcelUtil.readBigFile2(in, -1);
//遍历行
for(int i = 1; i < lstA.size(); i++) {
List<Object> lstObj = lstA.get(i);
//创建示例实体
ExportExampleEntity export = new ExportExampleEntity();
//遍历列
for(int j = 0; j < lstObj.size(); j++) {
Object obj = lstObj.get(j);
//属性赋值
if(j == 0 && null != obj) {
export.setName(obj.toString());
}else if(j == 1 && null != obj) {
export.setSex(obj.toString());
}else if(j == 2 && null != obj) {
if(obj instanceof Integer) {
export.setAge(Integer.parseInt(obj.toString()));
}
}else if(j == 3 && null != obj) {
export.setPhone(obj.toString());
}else if(j == 4 && null != obj) {
export.setBirthday(DateUtils.parseDateObj(obj));
}else if(j == 5 && null != obj) {
if(obj instanceof Double) {
export.setBalance(Double.parseDouble(obj.toString()));
}
}
}
//实体不为空就假如集合
if(null != export) {
lstExports.add(export);
}
}
//批量保存
this.saveBatch(lstExports);
}
/**
*
* @description
* xlsexcel
* @params
* @return void
* @author guyp
* @time 20191217 1:37:53
*/
public void saveXls(InputStream in) throws Exception {
Workbook workbook = ExcelUtil.readExcel(".xls", in);
if(null != workbook) {
//获取第一个sheet
Sheet sheet = workbook.getSheetAt(0);
//获取起始行
int firstRowNum = sheet.getFirstRowNum();
//获取最后一行
int lastRowNum = sheet.getLastRowNum();
log.info("文件解析出起始行{}, 结束行{}", firstRowNum, lastRowNum);
if(lastRowNum >= firstRowNum) {
List<ExportExampleEntity> lstExports = new ArrayList<ExportExampleEntity>();
//由于示例excel这里直接读取第2行的数据
for(int i = 1; i <= lastRowNum; i++) {
//创建示例实体
ExportExampleEntity export = new ExportExampleEntity();
//获取行数据
Row row = sheet.getRow(i);
if(null != row) {
//属性赋值
//获取列下标从0开始
Cell cell0 = row.getCell(0);
if(null != cell0) {
export.setName(ExcelUtil.getCellValue(cell0));
}
Cell cell1 = row.getCell(1);
if(null != cell1) {
export.setSex(ExcelUtil.getCellValue(cell1));
}
Cell cell2 = row.getCell(2);
if(null != cell2) {
export.setAge(Integer.parseInt(ExcelUtil.getCellValue(cell2)));
}
Cell cell3 = row.getCell(3);
if(null != cell3) {
export.setPhone(ExcelUtil.getCellValue(cell3));
}
Cell cell4 = row.getCell(4);
if(null != cell4) {
export.setBirthday(DateUtils.parseDateObj(ExcelUtil.getCellValue(cell4)));
}
Cell cell5 = row.getCell(5);
if(null != cell5) {
export.setBalance(Double.parseDouble(ExcelUtil.getCellValue(cell5)));
}
}
//实体不为空就假如集合
if(null != export) {
lstExports.add(export);
}
}
//批量保存
this.saveBatch(lstExports);
}
}
}
/**
*
* @description
* xlsx
* @params
* @return HSSFWorkbook
* @author guyp
* @throws UnsupportedEncodingException
* @time 20191218 9:54:50
*/
public void exportXlsx(HttpServletRequest request, HttpServletResponse response, String name) throws Exception {
String fileName = getFileName(request, "测试数据.xlsx");
//写出数据定义
response.setContentType(MediaType.APPLICATION_OCTET_STREAM.toString());
response.setHeader("Content-Disposition", "attachment; filename=\"" + fileName + "\";");
List<LinkedHashMap<String, Object>> datas = new ArrayList<>();
LinkedHashMap<String, Object> data = new LinkedHashMap<>();
//定义列数据
data.put("0", "姓名");
data.put("1", "性别");
data.put("2", "年龄");
data.put("3", "手机号");
data.put("4", "生日");
data.put("5", "余额/元");
datas.add(data);
//根据条件查询实体集合
QueryWrapper<ExportExampleEntity> queryWrapper = new QueryWrapper<ExportExampleEntity>();
//查询条件添加
if(StringUtils.isNotEmpty(name)) {
queryWrapper.eq("NAME", name);
}
List<ExportExampleEntity> lstExamples = this.list(queryWrapper);
if(null != lstExamples) {
//实体给列赋值
for(ExportExampleEntity example : lstExamples) {
data = new LinkedHashMap<>();
data.put("0", StringUtils.isEmpty(example.getName()) ? "" : example.getName());
data.put("1", StringUtils.isEmpty(example.getSex()) ? "" : example.getSex());
data.put("2", example.getAge());
data.put("3", StringUtils.isEmpty(example.getPhone()) ? "" : example.getPhone());
data.put("4", null == example.getBirthday() ? "" : DateUtils.getDate2Str(example.getBirthday()));
data.put("5", example.getBalance());
datas.add(data);
}
}
Map<String, List<LinkedHashMap<String, Object>>> tableData = new HashMap<>();
tableData.put("测试1", datas);
//拷贝输出
FileCopyUtils.copy(ExportUtil.exportXlsx(tableData), response.getOutputStream());
}
/**
*
* @description
* csv
* @params
* @return void
* @author guyp
* @throws IOException
* @time 20191218 10:31:04
*/
public void exportCsv(HttpServletRequest request, HttpServletResponse response, String name) throws Exception {
String fileName = getFileName(request, "测试数据.csv");
//写出数据定义
response.setContentType(MediaType.APPLICATION_OCTET_STREAM.toString());
response.setHeader("Content-Disposition", "attachment; filename=\"" + fileName + "\";");
List<LinkedHashMap<String, Object>> datas = new ArrayList<>();
LinkedHashMap<String, Object> data = new LinkedHashMap<>();
//定义列数据
data.put("0", "姓名");
data.put("1", "性别");
data.put("2", "年龄");
data.put("3", "手机号");
data.put("4", "生日");
data.put("5", "余额/元");
datas.add(data);
//根据条件查询实体集合
QueryWrapper<ExportExampleEntity> queryWrapper = new QueryWrapper<ExportExampleEntity>();
//查询条件添加
if(StringUtils.isNotEmpty(name)) {
queryWrapper.eq("NAME", name);
}
List<ExportExampleEntity> lstExamples = this.list(queryWrapper);
if(null != lstExamples) {
//实体给列赋值
for(ExportExampleEntity example : lstExamples) {
data = new LinkedHashMap<>();
data.put("0", StringUtils.isEmpty(example.getName()) ? "" : example.getName());
data.put("1", StringUtils.isEmpty(example.getSex()) ? "" : example.getSex());
data.put("2", example.getAge());
data.put("3", StringUtils.isEmpty(example.getPhone()) ? "" : example.getPhone());
data.put("4", null == example.getBirthday() ? "" : DateUtils.getDate2Str(example.getBirthday()));
data.put("5", example.getBalance());
datas.add(data);
}
}
//拷贝输出
FileCopyUtils.copy(ExportUtil.exportCSV(datas), response.getOutputStream());
}
/**
*
* @description
* 使
* @params
* @return String
* @author guyp
* @time 20191218 10:56:31
*/
private String getFileName(HttpServletRequest request, String name) throws UnsupportedEncodingException {
String userAgent = request.getHeader("USER-AGENT");
return userAgent.contains("Mozilla") ? new String(name.getBytes(), "ISO8859-1") : name;
}
/**
*
* @description
* xls
* @params
* @return void
* @author guyp
* @time 20191218 11:22:57
*/
public void exportXls(HttpServletRequest request, HttpServletResponse response, String name) throws Exception {
String fileName = getFileName(request, "测试数据.xls");
//写出数据定义
response.setContentType(MediaType.APPLICATION_OCTET_STREAM.toString());
response.setHeader("Content-Disposition", "attachment; filename=\"" + fileName + "\";");
List<LinkedHashMap<String, Object>> datas = new ArrayList<>();
LinkedHashMap<String, Object> data = new LinkedHashMap<>();
//定义列数据
data.put("0", "姓名");
data.put("1", "性别");
data.put("2", "年龄");
data.put("3", "手机号");
data.put("4", "生日");
data.put("5", "余额/元");
datas.add(data);
//根据条件查询实体集合
QueryWrapper<ExportExampleEntity> queryWrapper = new QueryWrapper<ExportExampleEntity>();
//查询条件添加
if(StringUtils.isNotEmpty(name)) {
queryWrapper.eq("NAME", name);
}
List<ExportExampleEntity> lstExamples = this.list(queryWrapper);
if(null != lstExamples) {
//实体给列赋值
for(ExportExampleEntity example : lstExamples) {
data = new LinkedHashMap<>();
data.put("0", StringUtils.isEmpty(example.getName()) ? "" : example.getName());
data.put("1", StringUtils.isEmpty(example.getSex()) ? "" : example.getSex());
data.put("2", example.getAge());
data.put("3", StringUtils.isEmpty(example.getPhone()) ? "" : example.getPhone());
data.put("4", null == example.getBirthday() ? "" : DateUtils.getDate2Str(example.getBirthday()));
data.put("5", example.getBalance());
datas.add(data);
}
}
Map<String, List<LinkedHashMap<String, Object>>> tableData = new HashMap<>();
tableData.put("测试1", datas);
//拷贝输出
FileCopyUtils.copy(ExportUtil.exportXls(tableData), response.getOutputStream());
}
}

@ -0,0 +1,227 @@
package com.zhonghe.active4j.func.export.util;
import java.io.File;
import java.io.FileNotFoundException;
import java.io.IOException;
import java.io.InputStream;
import java.util.ArrayList;
import java.util.LinkedHashMap;
import java.util.List;
import java.util.Map;
import org.apache.commons.lang3.StringUtils;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.apache.poi.openxml4j.opc.OPCPackage;
import org.apache.poi.openxml4j.opc.PackageAccess;
import org.apache.poi.ss.usermodel.Cell;
import org.apache.poi.ss.usermodel.DataFormatter;
import org.apache.poi.ss.usermodel.Row;
import org.apache.poi.ss.usermodel.Sheet;
import org.apache.poi.ss.usermodel.Workbook;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;
import lombok.extern.slf4j.Slf4j;
/**
*
* @title ExcelUtil.java
* @description
2007excel
* @time 20191217 1:22:28
* @author guyp
* @version 1.0
*/
@Slf4j
public class ExcelUtil {
/**
* xlsx
*/
public static List<List<String>> read(String filePath) throws Exception {
List<List<String>> result = new ArrayList<>();
Workbook wb = new XSSFWorkbook(new File(filePath));
for (Sheet sheet : wb) {
for (Row row : sheet) {
List<String> rowData = getRowData(row);
result.add(rowData);
}
}
wb.close();
return result;
}
/**
* xlsx
*
* @return map: key->sheet name, value->rowData
*/
public static Map<String, List<List<String>>> readMultiSheet(String filePath)
throws Exception {
Map<String, List<List<String>>> result = new LinkedHashMap<>();
Workbook wb = new XSSFWorkbook(new File(filePath));
for (Sheet sheet : wb) {
List<List<String>> sheetResult = new ArrayList<>();
for (Row row : sheet) {
List<String> rowData = getRowData(row);
sheetResult.add(rowData);
}
result.put(sheet.getSheetName(), sheetResult);
}
wb.close();
return result;
}
/**
* SAXxlsx
*
* @param filePath
*
* @param minColumns
* -1
*/
public static List<List<Object>> readBigFile(String filePath, int minColumns)
throws Exception {
File xlsxFile = new File(filePath);
OPCPackage p = OPCPackage.open(xlsxFile.getPath(), PackageAccess.READ);
Xlsx2ListData xlsx2ListData = new Xlsx2ListData(p, minColumns, null);
List<List<Object>> result = xlsx2ListData.process();
p.close();
return result;
}
/**
* SAXxlsx
* @param in
* @param minColumns
* @return
* @throws Exception
*/
public static List<List<Object>> readBigFile2(InputStream in, int minColumns)
throws Exception {
OPCPackage p = OPCPackage.open(in);
Xlsx2ListData xlsx2ListData = new Xlsx2ListData(p, minColumns, null);
List<List<Object>> result = xlsx2ListData.process();
p.close();
return result;
}
/**
* SAXxlsxRowDataProcesser
*
* @param filePath
*
* @param minColumns
* -1
* @param rowDataProcesser
*
*/
public static void readBigFile(String filePath, int minColumns,
RowDataProcesser rowDataProcesser) throws Exception {
File xlsxFile = new File(filePath);
OPCPackage p = OPCPackage.open(xlsxFile.getPath(), PackageAccess.READ);
Xlsx2ListData xlsx2ListData = new Xlsx2ListData(p, minColumns,
rowDataProcesser);
xlsx2ListData.process();
p.close();
}
@SuppressWarnings("deprecation")
private static List<String> getRowData(Row row) {
List<String> rowData = new ArrayList<>();
int cellNum = row.getLastCellNum();
for (int i = 0; i < cellNum; i++) {
Cell cell = row.getCell(i);
if (cell == null) {
rowData.add("");
continue;
}
switch (cell.getCellType()) {
case Cell.CELL_TYPE_STRING:
rowData.add(cell.getRichStringCellValue().getString());
break;
case Cell.CELL_TYPE_NUMERIC:
rowData.add(new DataFormatter().formatCellValue(cell));
break;
case Cell.CELL_TYPE_BOOLEAN:
rowData.add(cell.getBooleanCellValue() + "");
break;
case Cell.CELL_TYPE_FORMULA:
rowData.add(cell.getCellFormula());
break;
case Cell.CELL_TYPE_BLANK:
case Cell.CELL_TYPE_ERROR:
default:
rowData.add("");
break;
}
}
return rowData;
}
/**
*
* @description
* inputstream workbook
* xlsxxls
* @params
* @return Workbook
* @author guyp
* @time 20191217 4:31:26
*/
public static Workbook readExcel(String extName, InputStream in) {
if (null == in) {
return null;
}
Workbook wb = null;
try {
if (StringUtils.endsWith(extName, ".xls")) {
wb = new HSSFWorkbook(in);
} else if (StringUtils.endsWith(extName, ".xlsx")) {
wb = new XSSFWorkbook(in);
} else {
wb = null;
}
} catch (FileNotFoundException e) {
log.error("读取excel文件{}报错,错误信息{}", extName, e.getMessage());
e.printStackTrace();
} catch (IOException e) {
log.error("读取excel文件{}报错,错误信息{}", extName, e.getMessage());
e.printStackTrace();
}
return wb;
}
@SuppressWarnings("deprecation")
public static String getCellValue(Cell cell) {
String cellValue = "";
if (cell != null) {
switch (cell.getCellType()) {
case Cell.CELL_TYPE_NUMERIC:
DataFormatter dataFormatter = new DataFormatter();
dataFormatter.addFormat("###########", null);
cellValue = dataFormatter.formatCellValue(cell);
break;
case Cell.CELL_TYPE_STRING:
cellValue = cell.getStringCellValue();
break;
case Cell.CELL_TYPE_BOOLEAN:
cellValue = String.valueOf(cell.getBooleanCellValue());
break;
case Cell.CELL_TYPE_FORMULA:
cellValue = String.valueOf(cell.getCellFormula());
break;
case Cell.CELL_TYPE_BLANK:
cellValue = "";
break;
case Cell.CELL_TYPE_ERROR:
cellValue = "";
break;
default:
cellValue = cell.toString().trim();
break;
}
}
return cellValue.trim();
}
}

@ -0,0 +1,219 @@
package com.zhonghe.active4j.func.export.util;
import java.io.BufferedWriter;
import java.io.ByteArrayOutputStream;
import java.io.IOException;
import java.io.OutputStreamWriter;
import java.nio.charset.StandardCharsets;
import java.util.Iterator;
import java.util.LinkedHashMap;
import java.util.List;
import java.util.Map;
import org.apache.poi.hssf.usermodel.HSSFCell;
import org.apache.poi.hssf.usermodel.HSSFRow;
import org.apache.poi.hssf.usermodel.HSSFSheet;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.apache.poi.xssf.usermodel.XSSFCell;
import org.apache.poi.xssf.usermodel.XSSFRow;
import org.apache.poi.xssf.usermodel.XSSFSheet;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;
/**
* @title ExportUtil.java
* @description
excel
* @time 20191218 10:25:20
* @author guyp
* @version 1.0
*/
public class ExportUtil {
/**
*
* @description
* csv
* @params
* @return byte[]
* @author guyp
* @time 20191218 10:27:09
*/
public static byte[] exportCSV(List<LinkedHashMap<String, Object>> exportData) {
ByteArrayOutputStream out = new ByteArrayOutputStream();
BufferedWriter buffCvsWriter = null;
try {
buffCvsWriter = new BufferedWriter(new OutputStreamWriter(out, StandardCharsets.UTF_8));
// 将body数据写入表格
for(Iterator<LinkedHashMap<String, Object>> iterator = exportData.iterator(); iterator.hasNext();) {
fillDataToCsv(buffCvsWriter, iterator.next());
if(iterator.hasNext()) {
buffCvsWriter.newLine();
}
}
// 刷新缓冲
buffCvsWriter.flush();
} catch (IOException e) {
e.printStackTrace();
} finally {
// 释放资源
if(buffCvsWriter != null) {
try {
buffCvsWriter.close();
} catch (IOException e) {
e.printStackTrace();
}
}
}
return out.toByteArray();
}
/**
*
* @description
* linkedHashMapcsv
* @params
* @return void
* @author guyp
* @time 20191218 10:27:38
*/
private static void fillDataToCsv(BufferedWriter buffCvsWriter, LinkedHashMap row) throws IOException {
Map.Entry propertyEntry;
for(Iterator<Map.Entry> propertyIterator = row.entrySet().iterator(); propertyIterator.hasNext();) {
propertyEntry = propertyIterator.next();
buffCvsWriter.write("\"" + propertyEntry.getValue().toString() + "\"");
if(propertyIterator.hasNext()) {
buffCvsWriter.write(",");
}
}
}
/**
*
* @description
* xlsx
* @params
* @return byte[]
* @author guyp
* @time 20191218 10:40:56
*/
public static byte[] exportXlsx(Map<String, List<LinkedHashMap<String, Object>>> tableData) {
ByteArrayOutputStream out = new ByteArrayOutputStream();
try {
XSSFWorkbook workbook = new XSSFWorkbook();
// 创建多个sheet
for(Map.Entry<String, List<LinkedHashMap<String, Object>>> entry : tableData.entrySet()) {
//数据写入xlsx表格中
fillDataToXlsx(workbook.createSheet(entry.getKey()), entry.getValue());
}
//写出
workbook.write(out);
} catch (IOException e) {
e.printStackTrace();
}
return out.toByteArray();
}
/**
*
* @description
* linkedHashMapxlsx
* @params
* @return void
* @author guyp
* @time 20191218 10:41:17
*/
private static void fillDataToXlsx(XSSFSheet sheet, List<LinkedHashMap<String, Object>> data) {
XSSFRow currRow;
XSSFCell cell;
LinkedHashMap row;
Map.Entry propertyEntry;
int rowIndex = 0;
int cellIndex = 0;
for(Iterator<LinkedHashMap<String, Object>> iterator = data.iterator(); iterator.hasNext();) {
row = iterator.next();
currRow = sheet.createRow(rowIndex++);
for(Iterator<Map.Entry> propertyIterator = row.entrySet().iterator(); propertyIterator.hasNext();) {
propertyEntry = propertyIterator.next();
if(propertyIterator.hasNext()) {
String value = String.valueOf(propertyEntry.getValue());
cell = currRow.createCell(cellIndex++);
cell.setCellValue(value);
}else {
String value = String.valueOf(propertyEntry.getValue());
cell = currRow.createCell(cellIndex++);
cell.setCellValue(value);
break;
}
}
if(iterator.hasNext()) {
cellIndex = 0;
}
}
}
/**
*
* @description
* xls
* @params
* @return byte[]
* @author guyp
* @time 20191218 11:26:01
*/
public static byte[] exportXls(Map<String, List<LinkedHashMap<String, Object>>> tableData) {
ByteArrayOutputStream out = new ByteArrayOutputStream();
try {
HSSFWorkbook workbook = new HSSFWorkbook();
// 创建多个sheet
for(Map.Entry<String, List<LinkedHashMap<String, Object>>> entry : tableData.entrySet()) {
//数据写入xls表格中
fillDataToXls(workbook.createSheet(entry.getKey()), entry.getValue());
}
//写出
workbook.write(out);
} catch (IOException e) {
e.printStackTrace();
}
return out.toByteArray();
}
/**
*
* @description
* linkedHashMapxls
* @params
* @return void
* @author guyp
* @time 20191218 11:24:57
*/
private static void fillDataToXls(HSSFSheet sheet, List<LinkedHashMap<String, Object>> data) {
HSSFRow currRow;
HSSFCell cell;
LinkedHashMap row;
Map.Entry propertyEntry;
int rowIndex = 0;
int cellIndex = 0;
for(Iterator<LinkedHashMap<String, Object>> iterator = data.iterator(); iterator.hasNext();) {
row = iterator.next();
currRow = sheet.createRow(rowIndex++);
for(Iterator<Map.Entry> propertyIterator = row.entrySet().iterator(); propertyIterator.hasNext();) {
propertyEntry = propertyIterator.next();
if(propertyIterator.hasNext()) {
String value = String.valueOf(propertyEntry.getValue());
cell = currRow.createCell(cellIndex++);
cell.setCellValue(value);
}else {
String value = String.valueOf(propertyEntry.getValue());
cell = currRow.createCell(cellIndex++);
cell.setCellValue(value);
break;
}
}
if(iterator.hasNext()) {
cellIndex = 0;
}
}
}
}

@ -0,0 +1,18 @@
package com.zhonghe.active4j.func.export.util;
import java.util.List;
public interface RowDataProcesser {
/**
*
* @description
*
* @params
* @return void
* @author guyp
* @time 20191217 1:24:37
*/
public void processRowData(List<Object> rowData);
}

@ -0,0 +1,193 @@
package com.zhonghe.active4j.func.export.util;
import java.io.IOException;
import java.io.InputStream;
import java.util.ArrayList;
import java.util.List;
import javax.xml.parsers.ParserConfigurationException;
import org.apache.poi.openxml4j.exceptions.OpenXML4JException;
import org.apache.poi.openxml4j.opc.OPCPackage;
import org.apache.poi.ss.usermodel.DataFormatter;
import org.apache.poi.ss.util.CellAddress;
import org.apache.poi.ss.util.CellReference;
import org.apache.poi.util.SAXHelper;
import org.apache.poi.xssf.eventusermodel.ReadOnlySharedStringsTable;
import org.apache.poi.xssf.eventusermodel.XSSFReader;
import org.apache.poi.xssf.eventusermodel.XSSFSheetXMLHandler;
import org.apache.poi.xssf.eventusermodel.XSSFSheetXMLHandler.SheetContentsHandler;
import org.apache.poi.xssf.model.StylesTable;
import org.apache.poi.xssf.usermodel.XSSFComment;
import org.xml.sax.ContentHandler;
import org.xml.sax.InputSource;
import org.xml.sax.SAXException;
import org.xml.sax.XMLReader;
public class Xlsx2ListData {
/**
* Uses the XSSF Event SAX helpers to do most of the work of parsing the
* Sheet XML, and outputs the contents as a List.
*/
private class SheetToList implements SheetContentsHandler {
private boolean firstCellOfRow = false;
private int currentRow = -1;
private int currentCol = -1;
private Object defaultValue = "";
List<Object> currRowData = new ArrayList<>();
private List<List<Object>> data = new ArrayList<>();
private void outputMissingRows(int number) {
for (int i = 0; i < number; i++) {
List<Object> rowData = new ArrayList<>();
for (int j = 0; j < minColumns; j++) {
rowData.add(defaultValue);
}
processRowData(rowData);
}
}
private void processRowData(List<Object> rowData) {
if (rowDataProcesser != null) {
rowDataProcesser.processRowData(rowData);
} else {
data.add(rowData);
}
currRowData = new ArrayList<>();
}
public List<List<Object>> getData() {
return data;
}
public void startRow(int rowNum) {
// If there were gaps, output the missing rows
outputMissingRows(rowNum - currentRow - 1);
// Prepare for this row
firstCellOfRow = true;
currentRow = rowNum;
currentCol = -1;
}
public void endRow(int rowNum) {
// Ensure the minimum number of columns
for (int i = currentCol; i < minColumns - 1; i++) {
currRowData.add(defaultValue);
}
processRowData(currRowData);
}
@Override
public void cell(String cellReference, String formattedValue,
XSSFComment comment) {
if (firstCellOfRow) {
firstCellOfRow = false;
}
// gracefully handle missing CellRef here in a similar way as
// XSSFCell does
if (cellReference == null) {
cellReference = new CellAddress(currentRow, currentCol)
.formatAsString();
}
// Did we miss any cells?
int thisCol = (new CellReference(cellReference)).getCol();
int missedCols = thisCol - currentCol - 1;
for (int i = 0; i < missedCols; i++) {
currRowData.add(defaultValue);
}
currentCol = thisCol;
currRowData.add(formattedValue);
}
public void headerFooter(String text, boolean isHeader, String tagName) {
// Skip, ignore headers or footers
}
}
// /////////////////////////////////////
private final OPCPackage xlsxPackage;
/**
* Number of columns to read starting with leftmost
*/
private final int minColumns;
private final RowDataProcesser rowDataProcesser;
/**
* Creates a new XLSX -> List converter
*
* @param pkg
* The XLSX package to process
* @param minColumns
* The minimum number of columns to output, or -1 for no minimum
* @param rowDataProcesser
* process row data
*/
public Xlsx2ListData(OPCPackage pkg, int minColumns,
RowDataProcesser rowDataProcesser) {
this.xlsxPackage = pkg;
this.minColumns = minColumns;
this.rowDataProcesser = rowDataProcesser;
}
/**
* Parses and shows the content of one sheet using the specified styles and
* shared-strings tables.
*
* @param styles
* @param strings
* @param sheetInputStream
*/
public void processSheet(StylesTable styles,
ReadOnlySharedStringsTable strings,
SheetContentsHandler sheetHandler, InputStream sheetInputStream)
throws IOException, ParserConfigurationException, SAXException {
DataFormatter formatter = new DataFormatter();
InputSource sheetSource = new InputSource(sheetInputStream);
try {
XMLReader sheetParser = SAXHelper.newXMLReader();
ContentHandler handler = new XSSFSheetXMLHandler(styles, null,
strings, sheetHandler, formatter, false);
sheetParser.setContentHandler(handler);
sheetParser.parse(sheetSource);
} catch (ParserConfigurationException e) {
throw new RuntimeException("SAX parser appears to be broken - "
+ e.getMessage());
}
}
/**
* Initiates the processing of the XLS workbook file to List.
*
* @throws IOException
* @throws OpenXML4JException
* @throws ParserConfigurationException
* @throws SAXException
*/
public List<List<Object>> process() throws IOException, OpenXML4JException,
ParserConfigurationException, SAXException {
ReadOnlySharedStringsTable strings = new ReadOnlySharedStringsTable(
this.xlsxPackage);
XSSFReader xssfReader = new XSSFReader(this.xlsxPackage);
StylesTable styles = xssfReader.getStylesTable();
XSSFReader.SheetIterator iter = (XSSFReader.SheetIterator) xssfReader
.getSheetsData();
List<List<Object>> result = new ArrayList<>();
while (iter.hasNext()) {
InputStream stream = iter.next();
SheetToList sheetToList = new SheetToList();
processSheet(styles, strings, sheetToList, stream);
result.addAll(sheetToList.getData());
stream.close();
}
return result;
}
}

@ -0,0 +1,23 @@
package com.zhonghe.active4j.func.export.wrapper;
import com.baomidou.mybatisplus.core.metadata.IPage;
import com.zhonghe.active4j.common.Wrapper.BaseWrapper;
import com.zhonghe.active4j.func.export.entity.ExportExampleEntity;
/**
*
* @title ExportExampleWrapper.java
* @description
* @time 20191217 10:50:34
* @author guyp
* @version 1.0
*/
public class ExportExampleWrapper extends BaseWrapper<ExportExampleEntity>{
public ExportExampleWrapper(IPage<ExportExampleEntity> pageResult) {
//父类中的方法初始化数据
super(pageResult);
}
}

Some files were not shown because too many files have changed in this diff Show More

Loading…
Cancel
Save