yaozhixue před 2 roky
revize
21d42bb4cf
100 změnil soubory, kde provedl 3711 přidání a 0 odebrání
  1. 40 0
      .gitignore
  2. 8 0
      .idea/.gitignore
  3. 11 0
      .idea/misc.xml
  4. 8 0
      .idea/modules.xml
  5. 6 0
      .idea/vcs.xml
  6. 310 0
      mvnw
  7. 182 0
      mvnw.cmd
  8. 371 0
      pom.xml
  9. 30 0
      src/main/java/com/zfire/jiasm/syncdata/ManagerApplication.java
  10. 68 0
      src/main/java/com/zfire/jiasm/syncdata/SwaggerConfig.java
  11. 10 0
      src/main/java/com/zfire/jiasm/syncdata/annotations/ApiNotAuth.java
  12. 8 0
      src/main/java/com/zfire/jiasm/syncdata/api/IResultCode.java
  13. 26 0
      src/main/java/com/zfire/jiasm/syncdata/config/CorsConfiguration.java
  14. 74 0
      src/main/java/com/zfire/jiasm/syncdata/config/GlobalDefaultExceptionHandler.java
  15. 39 0
      src/main/java/com/zfire/jiasm/syncdata/config/MpMetaObjectHandler.java
  16. 64 0
      src/main/java/com/zfire/jiasm/syncdata/config/MyBatisPlusConfig.java
  17. 110 0
      src/main/java/com/zfire/jiasm/syncdata/config/RedisConfig.java
  18. 17 0
      src/main/java/com/zfire/jiasm/syncdata/config/RedisLockConfiguration.java
  19. 21 0
      src/main/java/com/zfire/jiasm/syncdata/config/ScheduleConfig.java
  20. 66 0
      src/main/java/com/zfire/jiasm/syncdata/config/TheaderPoolConfig.java
  21. 33 0
      src/main/java/com/zfire/jiasm/syncdata/config/WebSocketConfig.java
  22. 84 0
      src/main/java/com/zfire/jiasm/syncdata/config/aop/ApiAspect.java
  23. 43 0
      src/main/java/com/zfire/jiasm/syncdata/config/filter/WebsocketFilter.java
  24. 50 0
      src/main/java/com/zfire/jiasm/syncdata/constant/Constant.java
  25. 161 0
      src/main/java/com/zfire/jiasm/syncdata/constant/DictTypeEnum.java
  26. 160 0
      src/main/java/com/zfire/jiasm/syncdata/constant/InterFaceTypeEnum.java
  27. 43 0
      src/main/java/com/zfire/jiasm/syncdata/data/Token.java
  28. 23 0
      src/main/java/com/zfire/jiasm/syncdata/exception/FeignServiceException.java
  29. 38 0
      src/main/java/com/zfire/jiasm/syncdata/exception/RemoteServiceException.java
  30. 68 0
      src/main/java/com/zfire/jiasm/syncdata/exception/RoleResultCode.java
  31. 33 0
      src/main/java/com/zfire/jiasm/syncdata/helper/FeignResponseObject.java
  32. 78 0
      src/main/java/com/zfire/jiasm/syncdata/helper/ResponseHelper.java
  33. 21 0
      src/main/java/com/zfire/jiasm/syncdata/plus/controller/AdminFastEntryPlusTempController.java
  34. 21 0
      src/main/java/com/zfire/jiasm/syncdata/plus/controller/AdminFieldPlusTempController.java
  35. 21 0
      src/main/java/com/zfire/jiasm/syncdata/plus/controller/AdminModuleFavoritesPlusTempController.java
  36. 21 0
      src/main/java/com/zfire/jiasm/syncdata/plus/controller/AdminModulePlusTempController.java
  37. 21 0
      src/main/java/com/zfire/jiasm/syncdata/plus/controller/AdminRolePlusTempController.java
  38. 21 0
      src/main/java/com/zfire/jiasm/syncdata/plus/controller/AdminUserModuleRelaPlusTempController.java
  39. 21 0
      src/main/java/com/zfire/jiasm/syncdata/plus/controller/AdminUserPlusTempController.java
  40. 21 0
      src/main/java/com/zfire/jiasm/syncdata/plus/controller/AdminUserRoleRelaPlusTempController.java
  41. 21 0
      src/main/java/com/zfire/jiasm/syncdata/plus/controller/AdminWebsitPlusTempController.java
  42. 21 0
      src/main/java/com/zfire/jiasm/syncdata/plus/controller/AdminWebsitProductTypeRelaPlusTempController.java
  43. 21 0
      src/main/java/com/zfire/jiasm/syncdata/plus/controller/AdminWebsitSlavePlusTempController.java
  44. 21 0
      src/main/java/com/zfire/jiasm/syncdata/plus/controller/AreaPlusTempController.java
  45. 21 0
      src/main/java/com/zfire/jiasm/syncdata/plus/controller/BrandLbsRelatePlusTempController.java
  46. 21 0
      src/main/java/com/zfire/jiasm/syncdata/plus/controller/BrandPlusTempController.java
  47. 21 0
      src/main/java/com/zfire/jiasm/syncdata/plus/controller/BrandWebsitPlusTempController.java
  48. 21 0
      src/main/java/com/zfire/jiasm/syncdata/plus/controller/CityPlusTempController.java
  49. 21 0
      src/main/java/com/zfire/jiasm/syncdata/plus/controller/ComDetailLogPlusTempController.java
  50. 21 0
      src/main/java/com/zfire/jiasm/syncdata/plus/controller/ComDetailPlusTempController.java
  51. 21 0
      src/main/java/com/zfire/jiasm/syncdata/plus/controller/ComListPlusTempController.java
  52. 21 0
      src/main/java/com/zfire/jiasm/syncdata/plus/controller/CommonFilePlusTempController.java
  53. 21 0
      src/main/java/com/zfire/jiasm/syncdata/plus/controller/CompanyCaAuthPlusTempController.java
  54. 21 0
      src/main/java/com/zfire/jiasm/syncdata/plus/controller/CompanyRecordManagePlusTempController.java
  55. 21 0
      src/main/java/com/zfire/jiasm/syncdata/plus/controller/ContractTemplatePlusTempController.java
  56. 21 0
      src/main/java/com/zfire/jiasm/syncdata/plus/controller/CustomerInformationCategoryPlusTempController.java
  57. 21 0
      src/main/java/com/zfire/jiasm/syncdata/plus/controller/CustomerInformationPlusTempController.java
  58. 21 0
      src/main/java/com/zfire/jiasm/syncdata/plus/controller/CustomerInformationWebsitPlusTempController.java
  59. 21 0
      src/main/java/com/zfire/jiasm/syncdata/plus/controller/ImgCarouselManagePlusTempController.java
  60. 21 0
      src/main/java/com/zfire/jiasm/syncdata/plus/controller/InstallChargeConfigPlusTempController.java
  61. 21 0
      src/main/java/com/zfire/jiasm/syncdata/plus/controller/InsureAgreePlusTempController.java
  62. 21 0
      src/main/java/com/zfire/jiasm/syncdata/plus/controller/InsureEmailPlusTempController.java
  63. 21 0
      src/main/java/com/zfire/jiasm/syncdata/plus/controller/InsureEmailRecordPlusTempController.java
  64. 21 0
      src/main/java/com/zfire/jiasm/syncdata/plus/controller/InsurePlusTempController.java
  65. 21 0
      src/main/java/com/zfire/jiasm/syncdata/plus/controller/InsureRangePlusTempController.java
  66. 21 0
      src/main/java/com/zfire/jiasm/syncdata/plus/controller/InsureWorkerCommercialFilePlusTempController.java
  67. 21 0
      src/main/java/com/zfire/jiasm/syncdata/plus/controller/InsureWorkerCommercialPlusTempController.java
  68. 21 0
      src/main/java/com/zfire/jiasm/syncdata/plus/controller/InsureWorkerRecordPlusTempController.java
  69. 21 0
      src/main/java/com/zfire/jiasm/syncdata/plus/controller/IntegralDoublePlusTempController.java
  70. 21 0
      src/main/java/com/zfire/jiasm/syncdata/plus/controller/IntegralGradeConfigurePlusTempController.java
  71. 21 0
      src/main/java/com/zfire/jiasm/syncdata/plus/controller/IntegralGradeExplainPlusTempController.java
  72. 21 0
      src/main/java/com/zfire/jiasm/syncdata/plus/controller/IntegralGradeSkillPlusTempController.java
  73. 21 0
      src/main/java/com/zfire/jiasm/syncdata/plus/controller/IntegralOffsetPlusTempController.java
  74. 21 0
      src/main/java/com/zfire/jiasm/syncdata/plus/controller/IntegralScorePlusTempController.java
  75. 21 0
      src/main/java/com/zfire/jiasm/syncdata/plus/controller/IntegralSkillLabelPlusTempController.java
  76. 21 0
      src/main/java/com/zfire/jiasm/syncdata/plus/controller/IntegralWorkerApplyPlusTempController.java
  77. 21 0
      src/main/java/com/zfire/jiasm/syncdata/plus/controller/ItfGreeToFaDownloadTaskPlusTempController.java
  78. 21 0
      src/main/java/com/zfire/jiasm/syncdata/plus/controller/ItfTblAssignGzdmDowloadPlusTempController.java
  79. 21 0
      src/main/java/com/zfire/jiasm/syncdata/plus/controller/ItfTblAssignXqxlDowloadPlusTempController.java
  80. 21 0
      src/main/java/com/zfire/jiasm/syncdata/plus/controller/ItfTblAssignXxlbDowloadPlusTempController.java
  81. 21 0
      src/main/java/com/zfire/jiasm/syncdata/plus/controller/ItfTblAssignXxlyDowloadPlusTempController.java
  82. 21 0
      src/main/java/com/zfire/jiasm/syncdata/plus/controller/ItfTblAssignXxqdDowloadPlusTempController.java
  83. 21 0
      src/main/java/com/zfire/jiasm/syncdata/plus/controller/ItfTblAssignYhsxWxDowloadPlusTempController.java
  84. 21 0
      src/main/java/com/zfire/jiasm/syncdata/plus/controller/ItfTblAzAssignXslxDowloadPlusTempController.java
  85. 21 0
      src/main/java/com/zfire/jiasm/syncdata/plus/controller/ItfTblCityDownloadPlusTempController.java
  86. 21 0
      src/main/java/com/zfire/jiasm/syncdata/plus/controller/ItfTblCityJdxzDownloadPlusTempController.java
  87. 21 0
      src/main/java/com/zfire/jiasm/syncdata/plus/controller/ItfTblCountyDownloadPlusTempController.java
  88. 21 0
      src/main/java/com/zfire/jiasm/syncdata/plus/controller/ItfTblProvinceDownloadPlusTempController.java
  89. 21 0
      src/main/java/com/zfire/jiasm/syncdata/plus/controller/ItfTblSplbDaleiDownloadPlusTempController.java
  90. 21 0
      src/main/java/com/zfire/jiasm/syncdata/plus/controller/ItfTblSplbJixinDownloadPlusTempController.java
  91. 21 0
      src/main/java/com/zfire/jiasm/syncdata/plus/controller/ItfTblSplbXiaoleiDownloadPlusTempController.java
  92. 21 0
      src/main/java/com/zfire/jiasm/syncdata/plus/controller/ItfTblSplbXilieDownloadPlusTempController.java
  93. 21 0
      src/main/java/com/zfire/jiasm/syncdata/plus/controller/ItfTblWangdianWxgDownloadPlusTempController.java
  94. 21 0
      src/main/java/com/zfire/jiasm/syncdata/plus/controller/ItfTblXinWangdianDownloadPlusTempController.java
  95. 21 0
      src/main/java/com/zfire/jiasm/syncdata/plus/controller/ItfTblYhsxViprankDowloadPlusTempController.java
  96. 21 0
      src/main/java/com/zfire/jiasm/syncdata/plus/controller/LabelCurrencyPlusTempController.java
  97. 21 0
      src/main/java/com/zfire/jiasm/syncdata/plus/controller/LabelPlusTempController.java
  98. 21 0
      src/main/java/com/zfire/jiasm/syncdata/plus/controller/LbsAmapPlusTempController.java
  99. 21 0
      src/main/java/com/zfire/jiasm/syncdata/plus/controller/NoticePlusTempController.java
  100. 21 0
      src/main/java/com/zfire/jiasm/syncdata/plus/controller/NoticeRecordPlusTempController.java

+ 40 - 0
.gitignore

@@ -0,0 +1,40 @@
+HELP.md
+target/
+!.mvn/wrapper/maven-wrapper.jar
+!**/src/main/**/target/
+!**/src/test/**/target/
+
+### STS ###
+.apt_generated
+.classpath
+.factorypath
+.project
+.settings
+.springBeans
+.sts4-cache
+
+### IntelliJ IDEA ###
+.idea
+*.iws
+*.iml
+*.ipr
+*.log
+
+### NetBeans ###
+/nbproject/private/
+/nbbuild/
+/dist/
+/nbdist/
+/.nb-gradle/
+build/
+!**/src/main/**/build/
+!**/src/test/**/build/
+
+### VS Code ###
+.vscode/
+/src/main/java/com.zfire.mall/manager/plus/
+/src/test/
+.DS_Store
+logs/
+src/main/java/com/zfire/jiasm/syncdata/plus/
+.mvn/

+ 8 - 0
.idea/.gitignore

@@ -0,0 +1,8 @@
+# Default ignored files
+/shelf/
+/workspace.xml
+# Datasource local storage ignored files
+/dataSources/
+/dataSources.local.xml
+# Editor-based HTTP Client requests
+/httpRequests/

+ 11 - 0
.idea/misc.xml

@@ -0,0 +1,11 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<project version="4">
+  <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>

+ 8 - 0
.idea/modules.xml

@@ -0,0 +1,8 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<project version="4">
+  <component name="ProjectModuleManager">
+    <modules>
+      <module fileurl="file://$PROJECT_DIR$/.idea/jiasm-syncdata.iml" filepath="$PROJECT_DIR$/.idea/jiasm-syncdata.iml" />
+    </modules>
+  </component>
+</project>

+ 6 - 0
.idea/vcs.xml

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

+ 310 - 0
mvnw

@@ -0,0 +1,310 @@
+#!/bin/sh
+# ----------------------------------------------------------------------------
+# Licensed to the Apache Software Foundation (ASF) under one
+# or more contributor license agreements.  See the NOTICE file
+# distributed with this work for additional information
+# regarding copyright ownership.  The ASF licenses this file
+# to you under the Apache License, Version 2.0 (the
+# "License"); you may not use this file except in compliance
+# with the License.  You may obtain a copy of the License at
+#
+#    https://www.apache.org/licenses/LICENSE-2.0
+#
+# Unless required by applicable law or agreed to in writing,
+# software distributed under the License is distributed on an
+# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
+# KIND, either express or implied.  See the License for the
+# specific language governing permissions and limitations
+# under the License.
+# ----------------------------------------------------------------------------
+
+# ----------------------------------------------------------------------------
+# Maven Start Up Batch script
+#
+# Required ENV vars:
+# ------------------
+#   JAVA_HOME - location of a JDK home dir
+#
+# Optional ENV vars
+# -----------------
+#   M2_HOME - location of maven2's installed home dir
+#   MAVEN_OPTS - parameters passed to the Java VM when running Maven
+#     e.g. to debug Maven itself, use
+#       set MAVEN_OPTS=-Xdebug -Xrunjdwp:transport=dt_socket,server=y,suspend=y,address=8000
+#   MAVEN_SKIP_RC - flag to disable loading of mavenrc files
+# ----------------------------------------------------------------------------
+
+if [ -z "$MAVEN_SKIP_RC" ] ; then
+
+  if [ -f /etc/mavenrc ] ; then
+    . /etc/mavenrc
+  fi
+
+  if [ -f "$HOME/.mavenrc" ] ; then
+    . "$HOME/.mavenrc"
+  fi
+
+fi
+
+# OS specific support.  $var _must_ be set to either true or false.
+cygwin=false;
+darwin=false;
+mingw=false
+case "`uname`" in
+  CYGWIN*) cygwin=true ;;
+  MINGW*) mingw=true;;
+  Darwin*) darwin=true
+    # Use /usr/libexec/java_home if available, otherwise fall back to /Library/Java/Home
+    # See https://developer.apple.com/library/mac/qa/qa1170/_index.html
+    if [ -z "$JAVA_HOME" ]; then
+      if [ -x "/usr/libexec/java_home" ]; then
+        export JAVA_HOME="`/usr/libexec/java_home`"
+      else
+        export JAVA_HOME="/Library/Java/Home"
+      fi
+    fi
+    ;;
+esac
+
+if [ -z "$JAVA_HOME" ] ; then
+  if [ -r /etc/gentoo-release ] ; then
+    JAVA_HOME=`java-config --jre-home`
+  fi
+fi
+
+if [ -z "$M2_HOME" ] ; then
+  ## resolve links - $0 may be a link to maven's home
+  PRG="$0"
+
+  # need this for relative symlinks
+  while [ -h "$PRG" ] ; do
+    ls=`ls -ld "$PRG"`
+    link=`expr "$ls" : '.*-> \(.*\)$'`
+    if expr "$link" : '/.*' > /dev/null; then
+      PRG="$link"
+    else
+      PRG="`dirname "$PRG"`/$link"
+    fi
+  done
+
+  saveddir=`pwd`
+
+  M2_HOME=`dirname "$PRG"`/..
+
+  # make it fully qualified
+  M2_HOME=`cd "$M2_HOME" && pwd`
+
+  cd "$saveddir"
+  # echo Using m2 at $M2_HOME
+fi
+
+# For Cygwin, ensure paths are in UNIX format before anything is touched
+if $cygwin ; then
+  [ -n "$M2_HOME" ] &&
+    M2_HOME=`cygpath --unix "$M2_HOME"`
+  [ -n "$JAVA_HOME" ] &&
+    JAVA_HOME=`cygpath --unix "$JAVA_HOME"`
+  [ -n "$CLASSPATH" ] &&
+    CLASSPATH=`cygpath --path --unix "$CLASSPATH"`
+fi
+
+# For Mingw, ensure paths are in UNIX format before anything is touched
+if $mingw ; then
+  [ -n "$M2_HOME" ] &&
+    M2_HOME="`(cd "$M2_HOME"; pwd)`"
+  [ -n "$JAVA_HOME" ] &&
+    JAVA_HOME="`(cd "$JAVA_HOME"; pwd)`"
+fi
+
+if [ -z "$JAVA_HOME" ]; then
+  javaExecutable="`which javac`"
+  if [ -n "$javaExecutable" ] && ! [ "`expr \"$javaExecutable\" : '\([^ ]*\)'`" = "no" ]; then
+    # readlink(1) is not available as standard on Solaris 10.
+    readLink=`which readlink`
+    if [ ! `expr "$readLink" : '\([^ ]*\)'` = "no" ]; then
+      if $darwin ; then
+        javaHome="`dirname \"$javaExecutable\"`"
+        javaExecutable="`cd \"$javaHome\" && pwd -P`/javac"
+      else
+        javaExecutable="`readlink -f \"$javaExecutable\"`"
+      fi
+      javaHome="`dirname \"$javaExecutable\"`"
+      javaHome=`expr "$javaHome" : '\(.*\)/bin'`
+      JAVA_HOME="$javaHome"
+      export JAVA_HOME
+    fi
+  fi
+fi
+
+if [ -z "$JAVACMD" ] ; then
+  if [ -n "$JAVA_HOME"  ] ; then
+    if [ -x "$JAVA_HOME/jre/sh/java" ] ; then
+      # IBM's JDK on AIX uses strange locations for the executables
+      JAVACMD="$JAVA_HOME/jre/sh/java"
+    else
+      JAVACMD="$JAVA_HOME/bin/java"
+    fi
+  else
+    JAVACMD="`which java`"
+  fi
+fi
+
+if [ ! -x "$JAVACMD" ] ; then
+  echo "Error: JAVA_HOME is not defined correctly." >&2
+  echo "  We cannot execute $JAVACMD" >&2
+  exit 1
+fi
+
+if [ -z "$JAVA_HOME" ] ; then
+  echo "Warning: JAVA_HOME environment variable is not set."
+fi
+
+CLASSWORLDS_LAUNCHER=org.codehaus.plexus.classworlds.launcher.Launcher
+
+# traverses directory structure from process work directory to filesystem root
+# first directory with .mvn subdirectory is considered project base directory
+find_maven_basedir() {
+
+  if [ -z "$1" ]
+  then
+    echo "Path not specified to find_maven_basedir"
+    return 1
+  fi
+
+  basedir="$1"
+  wdir="$1"
+  while [ "$wdir" != '/' ] ; do
+    if [ -d "$wdir"/.mvn ] ; then
+      basedir=$wdir
+      break
+    fi
+    # workaround for JBEAP-8937 (on Solaris 10/Sparc)
+    if [ -d "${wdir}" ]; then
+      wdir=`cd "$wdir/.."; pwd`
+    fi
+    # end of workaround
+  done
+  echo "${basedir}"
+}
+
+# concatenates all lines of a file
+concat_lines() {
+  if [ -f "$1" ]; then
+    echo "$(tr -s '\n' ' ' < "$1")"
+  fi
+}
+
+BASE_DIR=`find_maven_basedir "$(pwd)"`
+if [ -z "$BASE_DIR" ]; then
+  exit 1;
+fi
+
+##########################################################################################
+# Extension to allow automatically downloading the maven-wrapper.jar from Maven-central
+# This allows using the maven wrapper in projects that prohibit checking in binary data.
+##########################################################################################
+if [ -r "$BASE_DIR/.mvn/wrapper/maven-wrapper.jar" ]; then
+    if [ "$MVNW_VERBOSE" = true ]; then
+      echo "Found .mvn/wrapper/maven-wrapper.jar"
+    fi
+else
+    if [ "$MVNW_VERBOSE" = true ]; then
+      echo "Couldn't find .mvn/wrapper/maven-wrapper.jar, downloading it ..."
+    fi
+    if [ -n "$MVNW_REPOURL" ]; then
+      jarUrl="$MVNW_REPOURL/io/takari/maven-wrapper/0.5.6/maven-wrapper-0.5.6.jar"
+    else
+      jarUrl="https://repo.maven.apache.org/maven2/io/takari/maven-wrapper/0.5.6/maven-wrapper-0.5.6.jar"
+    fi
+    while IFS="=" read key value; do
+      case "$key" in (wrapperUrl) jarUrl="$value"; break ;;
+      esac
+    done < "$BASE_DIR/.mvn/wrapper/maven-wrapper.properties"
+    if [ "$MVNW_VERBOSE" = true ]; then
+      echo "Downloading from: $jarUrl"
+    fi
+    wrapperJarPath="$BASE_DIR/.mvn/wrapper/maven-wrapper.jar"
+    if $cygwin; then
+      wrapperJarPath=`cygpath --path --windows "$wrapperJarPath"`
+    fi
+
+    if command -v wget > /dev/null; then
+        if [ "$MVNW_VERBOSE" = true ]; then
+          echo "Found wget ... using wget"
+        fi
+        if [ -z "$MVNW_USERNAME" ] || [ -z "$MVNW_PASSWORD" ]; then
+            wget "$jarUrl" -O "$wrapperJarPath"
+        else
+            wget --http-user=$MVNW_USERNAME --http-password=$MVNW_PASSWORD "$jarUrl" -O "$wrapperJarPath"
+        fi
+    elif command -v curl > /dev/null; then
+        if [ "$MVNW_VERBOSE" = true ]; then
+          echo "Found curl ... using curl"
+        fi
+        if [ -z "$MVNW_USERNAME" ] || [ -z "$MVNW_PASSWORD" ]; then
+            curl -o "$wrapperJarPath" "$jarUrl" -f
+        else
+            curl --user $MVNW_USERNAME:$MVNW_PASSWORD -o "$wrapperJarPath" "$jarUrl" -f
+        fi
+
+    else
+        if [ "$MVNW_VERBOSE" = true ]; then
+          echo "Falling back to using Java to download"
+        fi
+        javaClass="$BASE_DIR/.mvn/wrapper/MavenWrapperDownloader.java"
+        # For Cygwin, switch paths to Windows format before running javac
+        if $cygwin; then
+          javaClass=`cygpath --path --windows "$javaClass"`
+        fi
+        if [ -e "$javaClass" ]; then
+            if [ ! -e "$BASE_DIR/.mvn/wrapper/MavenWrapperDownloader.class" ]; then
+                if [ "$MVNW_VERBOSE" = true ]; then
+                  echo " - Compiling MavenWrapperDownloader.java ..."
+                fi
+                # Compiling the Java class
+                ("$JAVA_HOME/bin/javac" "$javaClass")
+            fi
+            if [ -e "$BASE_DIR/.mvn/wrapper/MavenWrapperDownloader.class" ]; then
+                # Running the downloader
+                if [ "$MVNW_VERBOSE" = true ]; then
+                  echo " - Running MavenWrapperDownloader.java ..."
+                fi
+                ("$JAVA_HOME/bin/java" -cp .mvn/wrapper MavenWrapperDownloader "$MAVEN_PROJECTBASEDIR")
+            fi
+        fi
+    fi
+fi
+##########################################################################################
+# End of extension
+##########################################################################################
+
+export MAVEN_PROJECTBASEDIR=${MAVEN_BASEDIR:-"$BASE_DIR"}
+if [ "$MVNW_VERBOSE" = true ]; then
+  echo $MAVEN_PROJECTBASEDIR
+fi
+MAVEN_OPTS="$(concat_lines "$MAVEN_PROJECTBASEDIR/.mvn/jvm.config") $MAVEN_OPTS"
+
+# For Cygwin, switch paths to Windows format before running java
+if $cygwin; then
+  [ -n "$M2_HOME" ] &&
+    M2_HOME=`cygpath --path --windows "$M2_HOME"`
+  [ -n "$JAVA_HOME" ] &&
+    JAVA_HOME=`cygpath --path --windows "$JAVA_HOME"`
+  [ -n "$CLASSPATH" ] &&
+    CLASSPATH=`cygpath --path --windows "$CLASSPATH"`
+  [ -n "$MAVEN_PROJECTBASEDIR" ] &&
+    MAVEN_PROJECTBASEDIR=`cygpath --path --windows "$MAVEN_PROJECTBASEDIR"`
+fi
+
+# Provide a "standardized" way to retrieve the CLI args that will
+# work with both Windows and non-Windows executions.
+MAVEN_CMD_LINE_ARGS="$MAVEN_CONFIG $@"
+export MAVEN_CMD_LINE_ARGS
+
+WRAPPER_LAUNCHER=org.apache.maven.wrapper.MavenWrapperMain
+
+exec "$JAVACMD" \
+  $MAVEN_OPTS \
+  -classpath "$MAVEN_PROJECTBASEDIR/.mvn/wrapper/maven-wrapper.jar" \
+  "-Dmaven.home=${M2_HOME}" "-Dmaven.multiModuleProjectDirectory=${MAVEN_PROJECTBASEDIR}" \
+  ${WRAPPER_LAUNCHER} $MAVEN_CONFIG "$@"

+ 182 - 0
mvnw.cmd

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

+ 371 - 0
pom.xml

@@ -0,0 +1,371 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
+         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
+    <modelVersion>4.0.0</modelVersion>
+    <parent>
+        <groupId>org.springframework.boot</groupId>
+        <artifactId>spring-boot-starter-parent</artifactId>
+        <version>2.3.3.RELEASE</version>
+        <relativePath/> <!-- lookup parent from repository -->
+    </parent>
+    <groupId>com.gree.manager</groupId>
+    <artifactId>jiasm-syncdata</artifactId>
+    <version>0.0.1-SNAPSHOT</version>
+    <name>jiasm-syncdata</name>
+    <description>Demo project for Spring Boot</description>
+
+    <properties>
+        <java.version>1.8</java.version>
+    </properties>
+
+    <dependencies>
+        <dependency>
+            <groupId>org.springframework.boot</groupId>
+            <artifactId>spring-boot-starter-web</artifactId>
+            <exclusions>
+                <exclusion>
+                    <groupId>org.springframework.boot</groupId>
+                    <artifactId>spring-boot-starter-tomcat</artifactId>
+                </exclusion>
+            </exclusions>
+        </dependency>
+        <dependency>
+            <groupId>org.springframework.boot</groupId>
+            <artifactId>spring-boot-starter-data-redis</artifactId>
+        </dependency>
+        <dependency>
+            <groupId>org.springframework.integration</groupId>
+            <artifactId>spring-integration-redis</artifactId>
+<!--            <version>RELEASE</version>-->
+        </dependency>
+
+        <dependency>
+            <groupId>org.springframework.boot</groupId>
+            <artifactId>spring-boot-devtools</artifactId>
+            <scope>runtime</scope>
+            <optional>true</optional>
+        </dependency>
+        <dependency>
+            <groupId>org.springframework.boot</groupId>
+            <artifactId>spring-boot-starter-test</artifactId>
+            <scope>test</scope>
+        </dependency>
+        <dependency>
+            <groupId>com.aliyun.oss</groupId>
+            <artifactId>aliyun-sdk-oss</artifactId>
+            <version>3.8.1</version>
+        </dependency>
+
+        <dependency>
+            <groupId>org.mybatis.spring.boot</groupId>
+            <artifactId>mybatis-spring-boot-starter</artifactId>
+            <version>2.1.0</version>
+        </dependency>
+        <dependency>
+            <groupId>com.baomidou</groupId>
+            <artifactId>mybatis-plus-boot-starter</artifactId>
+            <version>3.1.2</version>
+        </dependency>
+        <dependency>
+            <groupId>com.baomidou</groupId>
+            <artifactId>mybatis-plus-generator</artifactId>
+            <version>3.1.2</version>
+        </dependency>
+        <dependency>
+            <groupId>org.apache.velocity</groupId>
+            <artifactId>velocity-engine-core</artifactId>
+            <version>2.1</version>
+        </dependency>
+        <dependency>
+            <groupId>org.projectlombok</groupId>
+            <artifactId>lombok</artifactId>
+            <version>1.18.8</version>
+            <scope>provided</scope>
+        </dependency>
+        <dependency>
+            <groupId>org.mybatis.spring.boot</groupId>
+            <artifactId>mybatis-spring-boot-autoconfigure</artifactId>
+            <version>2.1.0</version>
+        </dependency>
+
+        <!--mysql驱动-->
+        <dependency>
+            <groupId>mysql</groupId>
+            <artifactId>mysql-connector-java</artifactId>
+            <version>8.0.17</version>
+        </dependency>
+
+        <dependency>
+            <groupId>com.aliyun</groupId>
+            <artifactId>alibaba-dingtalk-service-sdk</artifactId>
+            <version>2.0.0</version>
+        </dependency>
+
+        <dependency>
+            <groupId>com.alibaba</groupId>
+            <artifactId>druid-spring-boot-starter</artifactId>
+            <version>1.1.21</version>
+        </dependency>
+
+        <dependency>
+            <groupId>org.apache.commons</groupId>
+            <artifactId>commons-pool2</artifactId>
+            <version>2.8.0</version>
+        </dependency>
+        <!--fastjson-->
+        <dependency>
+            <groupId>com.alibaba</groupId>
+            <artifactId>fastjson</artifactId>
+            <version>1.2.59</version>
+        </dependency>
+        <!--okhttp3-->
+        <dependency>
+            <groupId>com.squareup.okhttp3</groupId>
+            <artifactId>okhttp</artifactId>
+            <version>4.0.1</version>
+        </dependency>
+        <!--swagger接口文档框架-->
+        <dependency>
+            <groupId>io.springfox</groupId>
+            <artifactId>springfox-swagger2</artifactId>
+            <version>2.9.2</version>
+        </dependency>
+        <dependency>
+            <groupId>io.springfox</groupId>
+            <artifactId>springfox-swagger-ui</artifactId>
+            <version>2.9.2</version>
+        </dependency>
+        <dependency>
+            <groupId>com.github.xiaoymin</groupId>
+            <artifactId>swagger-bootstrap-ui</artifactId>
+            <version>1.9.4</version>
+        </dependency>
+        <!-- 支持 @ConfigurationProperties 注解 -->
+        <dependency>
+            <groupId>org.springframework.boot</groupId>
+            <artifactId>spring-boot-configuration-processor</artifactId>
+            <optional>true</optional>
+        </dependency>
+        <!-- fix swagger input报错-->
+        <dependency>
+            <groupId>io.swagger</groupId>
+            <artifactId>swagger-annotations</artifactId>
+            <version>1.5.22</version>
+        </dependency>
+        <dependency>
+            <groupId>io.swagger</groupId>
+            <artifactId>swagger-models</artifactId>
+            <version>1.5.22</version>
+        </dependency>
+        <!--更换undertow容器-->
+        <dependency>
+            <groupId>org.springframework.boot</groupId>
+            <artifactId>spring-boot-starter-undertow</artifactId>
+        </dependency>
+        <dependency>
+            <groupId>org.bouncycastle</groupId>
+            <artifactId>bcprov-jdk15on</artifactId>
+            <version>1.60</version>
+            <scope>compile</scope>
+        </dependency>
+
+        <dependency>
+            <groupId>org.apache.poi</groupId>
+            <artifactId>poi</artifactId>
+            <version>4.1.2</version>
+        </dependency>
+
+        <dependency>
+            <groupId>eu.bitwalker</groupId>
+            <artifactId>UserAgentUtils</artifactId>
+            <version>1.21</version>
+        </dependency>
+
+        <dependency>
+            <groupId>io.jsonwebtoken</groupId>
+            <artifactId>jjwt</artifactId>
+            <version>0.6.0</version>
+        </dependency>
+
+        <dependency>
+            <groupId>com.aliyun.oss</groupId>
+            <artifactId>aliyun-sdk-oss</artifactId>
+            <version>3.8.1</version>
+        </dependency>
+
+        <dependency>
+            <groupId>org.springframework</groupId>
+            <artifactId>spring-mock</artifactId>
+            <version>2.0.8</version>
+        </dependency>
+
+        <dependency>
+            <groupId>org.apache.httpcomponents</groupId>
+            <artifactId>httpclient</artifactId>
+            <version>4.4</version>
+        </dependency>
+        <dependency>
+            <groupId>org.apache.httpcomponents</groupId>
+            <artifactId>httpmime</artifactId>
+            <version>4.4</version>
+        </dependency>
+
+        <!--模板组件-->
+        <dependency>
+            <groupId>org.springframework.boot</groupId>
+            <artifactId>spring-boot-starter-thymeleaf</artifactId>
+            <version>2.2.6.RELEASE</version>
+        </dependency>
+        <!--模板组件END-->
+
+        <!-- https://mvnrepository.com/artifact/commons-codec/commons-codec -->
+        <dependency>
+            <groupId>commons-codec</groupId>
+            <artifactId>commons-codec</artifactId>
+            <version>1.9</version>
+        </dependency>
+
+        <dependency>
+            <groupId>com.aliyun</groupId>
+            <artifactId>aliyun-java-sdk-core</artifactId>
+            <version>4.0.3</version>
+        </dependency>
+
+        <dependency>
+            <groupId>org.springframework.cloud</groupId>
+            <artifactId>spring-cloud-starter-openfeign</artifactId>
+            <version>2.1.3.RELEASE</version>
+        </dependency>
+
+        <dependency>
+            <groupId>net.logstash.logback</groupId>
+            <artifactId>logstash-logback-encoder</artifactId>
+            <version>6.3</version>
+        </dependency>
+
+        <dependency>
+            <groupId>io.github.biezhi</groupId>
+            <artifactId>TinyPinyin</artifactId>
+            <version>2.0.3.RELEASE</version>
+        </dependency>
+        <dependency>
+            <groupId>com.belerweb</groupId>
+            <artifactId>pinyin4j</artifactId>
+            <version>2.5.1</version>
+        </dependency>
+        <dependency>
+            <groupId>com.github.stuxuhai</groupId>
+            <artifactId>jpinyin</artifactId>
+            <version>1.1.8</version>
+        </dependency>
+
+        <!-- hutool工具 -->
+        <dependency>
+            <groupId>cn.hutool</groupId>
+            <artifactId>hutool-all</artifactId>
+            <version>5.8.0.M4</version>
+        </dependency>
+
+        <!-- 校验工具 -->
+        <dependency>
+            <groupId>org.hibernate</groupId>
+            <artifactId>hibernate-validator</artifactId>
+            <version>6.1.6.Final</version>
+        </dependency>
+
+        <!--websocket-->
+        <dependency>
+            <groupId>org.springframework.boot</groupId>
+            <artifactId>spring-boot-starter-websocket</artifactId>
+        </dependency>
+
+        <!--freemarker制作Html邮件模板依赖包-->
+        <dependency>
+            <groupId>org.springframework.boot</groupId>
+            <artifactId>spring-boot-starter-freemarker</artifactId>
+        </dependency>
+
+        <!--企业微信api-->
+        <dependency>
+            <groupId>com.github.binarywang</groupId>
+            <artifactId>weixin-java-cp</artifactId>
+            <version>4.1.0</version>
+        </dependency>
+
+    </dependencies>
+
+    <profiles>
+        <profile>
+            <!-- 本地开发环境 -->
+            <id>dev</id>
+            <properties>
+                <profiles.active>dev</profiles.active>
+            </properties>
+            <activation>
+                <!-- 设置默认激活这个配置 -->
+                <activeByDefault>true</activeByDefault>
+            </activation>
+        </profile>
+        <profile>
+            <!-- 测试环境 -->
+            <id>test</id>
+            <properties>
+                <profiles.active>test</profiles.active>
+            </properties>
+        </profile>
+        <profile>
+            <!-- 正式环境 -->
+            <id>prd</id>
+            <properties>
+                <profiles.active>prd</profiles.active>
+            </properties>
+        </profile>
+    </profiles>
+
+
+    <build>
+        <plugins>
+            <plugin>
+                <groupId>org.springframework.boot</groupId>
+                <artifactId>spring-boot-maven-plugin</artifactId>
+                <version>2.3.10.RELEASE</version>
+            </plugin>
+            <plugin>
+                <groupId>com.plus.plugin</groupId>
+                <artifactId>plus-maven-plugin</artifactId>
+                <version>5.0.0-SNAPSHOT</version>
+                <configuration>
+                    <configPath>src/main/resources/generator-${profiles.active}.properties</configPath>
+                </configuration>
+            </plugin>
+        </plugins>
+    </build>
+
+    <repositories>
+        <repository>
+            <id>nexus</id>
+            <name>Releases</name>
+            <url>http://121.43.111.127:8081/repository/maven-public</url>
+            <releases>
+                <enabled>true</enabled>
+            </releases>
+            <!--snapshots默认是关闭的,需要开启  -->
+            <snapshots>
+                <enabled>true</enabled>
+            </snapshots>
+        </repository>
+        <repository>
+            <id>com.e-iceblue</id>
+            <name>e-iceblue</name>
+            <url>https://repo.e-iceblue.cn/repository/maven-public/</url>
+        </repository>
+    </repositories>
+    <pluginRepositories>
+        <pluginRepository>
+            <id>nexus</id>
+            <name>Releases</name>
+            <url>http://121.43.111.127:8081/repository/maven-public</url>
+        </pluginRepository>
+    </pluginRepositories>
+
+</project>

+ 30 - 0
src/main/java/com/zfire/jiasm/syncdata/ManagerApplication.java

@@ -0,0 +1,30 @@
+package com.zfire.jiasm.syncdata;
+
+import com.zfire.jiasm.syncdata.utils.ApplicationContextUtils;
+import org.mybatis.spring.annotation.MapperScan;
+import org.springframework.boot.SpringApplication;
+import org.springframework.boot.autoconfigure.SpringBootApplication;
+import org.springframework.boot.web.servlet.ServletComponentScan;
+import org.springframework.cache.annotation.EnableCaching;
+import org.springframework.context.ApplicationContext;
+import org.springframework.scheduling.annotation.EnableAsync;
+import org.springframework.scheduling.annotation.EnableScheduling;
+
+
+@EnableScheduling
+@SpringBootApplication
+@ServletComponentScan(basePackages = {"com.zfire.jiasm.syncdata"})
+@EnableAsync
+@EnableCaching
+@MapperScan(basePackages = {
+        "com.zfire.jiasm.syncdata.plus.mapper",
+        "com.zfire.jiasm.syncdata.dao.*"
+})
+public class ManagerApplication {
+
+    public static void main(String[] args) {
+        ApplicationContext context = SpringApplication.run(ManagerApplication.class, args);
+        ApplicationContextUtils.setApplicationContext(context);
+    }
+
+}

+ 68 - 0
src/main/java/com/zfire/jiasm/syncdata/SwaggerConfig.java

@@ -0,0 +1,68 @@
+package com.zfire.jiasm.syncdata;
+
+/**
+ *
+ */
+
+import org.springframework.context.annotation.Bean;
+import org.springframework.context.annotation.Configuration;
+import org.springframework.context.annotation.Profile;
+import springfox.documentation.builders.ApiInfoBuilder;
+import springfox.documentation.builders.ParameterBuilder;
+import springfox.documentation.builders.PathSelectors;
+import springfox.documentation.builders.RequestHandlerSelectors;
+import springfox.documentation.schema.ModelRef;
+import springfox.documentation.service.ApiInfo;
+import springfox.documentation.service.Contact;
+import springfox.documentation.service.Parameter;
+import springfox.documentation.spi.DocumentationType;
+import springfox.documentation.spring.web.plugins.Docket;
+import springfox.documentation.swagger2.annotations.EnableSwagger2;
+
+import java.util.ArrayList;
+import java.util.List;
+
+
+/**
+ * API文档设置
+ * com.qichuan.sugar.minaapi.SwaggerConfig
+ */
+@Profile({"dev","test"})
+@Configuration
+@EnableSwagger2
+public class SwaggerConfig {
+    @Bean
+    public Docket statisticsApi() {
+        return new Docket(DocumentationType.SWAGGER_2)
+                .pathMapping("/")
+                .groupName("运营后台API")
+                .select()
+                .apis(RequestHandlerSelectors.basePackage("com.zfire.jiasm.syncdata.controller"))
+                .paths(PathSelectors.regex("/.*"))
+                .build()
+                .apiInfo(apiBInfo())
+                .globalOperationParameters(setHeaderToken());
+    }
+
+    private ApiInfo apiBInfo() {
+
+        return new ApiInfoBuilder()
+                .title("jiasm工单系统API")
+                .description("jiasm工单系统API")
+                .contact(new Contact("众炬", "http://zfire", "zfire@zfire.com"))
+                .version("1.0")
+                .build();
+    }
+
+    /**
+     * 设置公共header参数
+     * @return
+     */
+    private List<Parameter> setHeaderToken() {
+        ParameterBuilder tokenPar = new ParameterBuilder();
+        List<Parameter> pars = new ArrayList<>();
+        tokenPar.name("x-token").description("校验TOKEN").modelRef(new ModelRef("string")).defaultValue("1111").parameterType("header").required(false).build();
+        pars.add(tokenPar.build());
+        return pars;
+    }
+}

+ 10 - 0
src/main/java/com/zfire/jiasm/syncdata/annotations/ApiNotAuth.java

@@ -0,0 +1,10 @@
+package com.zfire.jiasm.syncdata.annotations;
+
+import java.lang.annotation.*;
+
+@Target(value = ElementType.METHOD)
+@Retention(value = RetentionPolicy.RUNTIME)
+@Documented
+public @interface ApiNotAuth {
+
+}

+ 8 - 0
src/main/java/com/zfire/jiasm/syncdata/api/IResultCode.java

@@ -0,0 +1,8 @@
+package com.zfire.jiasm.syncdata.api;
+
+import java.io.Serializable;
+
+public interface IResultCode extends Serializable {
+    String getMessage();
+    int getCode();
+}

+ 26 - 0
src/main/java/com/zfire/jiasm/syncdata/config/CorsConfiguration.java

@@ -0,0 +1,26 @@
+package com.zfire.jiasm.syncdata.config;
+
+import org.slf4j.LoggerFactory;
+import org.springframework.context.annotation.Bean;
+import org.springframework.context.annotation.Configuration;
+import org.springframework.web.cors.UrlBasedCorsConfigurationSource;
+import org.springframework.web.filter.CorsFilter;
+
+
+@Configuration
+public class CorsConfiguration {
+    @Bean
+    public CorsFilter corsFilter() {
+
+        LoggerFactory.getLogger(this.getClass()).info("CorsFilter 启动运行");
+
+        final UrlBasedCorsConfigurationSource urlBasedCorsConfigurationSource = new UrlBasedCorsConfigurationSource();
+        final org.springframework.web.cors.CorsConfiguration corsConfiguration = new org.springframework.web.cors.CorsConfiguration();
+        corsConfiguration.setAllowCredentials(true);
+        corsConfiguration.addAllowedOrigin("*");
+        corsConfiguration.addAllowedHeader("*");
+        corsConfiguration.addAllowedMethod("*");
+        urlBasedCorsConfigurationSource.registerCorsConfiguration("/**", corsConfiguration);
+        return new CorsFilter(urlBasedCorsConfigurationSource);
+    }
+}

+ 74 - 0
src/main/java/com/zfire/jiasm/syncdata/config/GlobalDefaultExceptionHandler.java

@@ -0,0 +1,74 @@
+package com.zfire.jiasm.syncdata.config;
+
+import cn.hutool.core.util.ReUtil;
+import com.alibaba.fastjson.JSONObject;
+import com.zfire.jiasm.syncdata.helper.ResponseHelper;
+import com.zfire.jiasm.syncdata.exception.RemoteServiceException;
+import lombok.extern.slf4j.Slf4j;
+import org.springframework.validation.BindingResult;
+import org.springframework.web.bind.MethodArgumentNotValidException;
+import org.springframework.web.bind.annotation.ControllerAdvice;
+import org.springframework.web.bind.annotation.ExceptionHandler;
+import org.springframework.web.bind.annotation.ResponseBody;
+
+import javax.servlet.http.HttpServletRequest;
+import java.util.HashMap;
+import java.util.Map;
+
+@ControllerAdvice
+@ResponseBody
+@Slf4j
+public class GlobalDefaultExceptionHandler {
+
+
+    @ExceptionHandler(value = Exception.class)
+    public ResponseHelper<Object> defaultErrorHandler(HttpServletRequest req, Exception ex) {
+
+        if(ex instanceof RemoteServiceException){
+            //自定义错误就不抛出栈异常
+            //log.error("网络异常:",ex);
+            log.error("网络异常:"+ex.getMessage()+req.getRequestURI()+JSONObject.toJSONString(this.bodyParam(req)));
+            return ResponseHelper.error(((RemoteServiceException) ex).getCode(),ex.getMessage());
+        }
+
+        if (ex instanceof MethodArgumentNotValidException) {
+            MethodArgumentNotValidException methodArgumentNotValidException = (MethodArgumentNotValidException) ex;
+            BindingResult bindingResult = methodArgumentNotValidException.getBindingResult();
+            StringBuilder sb = new StringBuilder();
+            bindingResult.getFieldErrors().forEach( item -> {
+                if (ReUtil.isMatch("^\\w+\\[\\d+\\]\\.\\w+", item.getField())) {
+                    String field = item.getField();
+                    int rowCount = Integer.parseInt(field.substring(field.indexOf("[") + 1, field.indexOf("]"))) + 1;
+                    sb.append("第").append(rowCount).append("行 ");
+                }
+                sb.append(item.getDefaultMessage()).append(",");
+            });
+            sb.deleteCharAt(sb.length() - 1);
+            log.error("bean验证有误:" + ex.getMessage() + sb);
+            return ResponseHelper.error(ResponseHelper.ResponseCode_VALIDATION_ERROR, sb.toString());
+        }
+
+        log.error("系统错误:"+ex.getMessage()+req.getRequestURI()+JSONObject.toJSONString(this.bodyParam(req)),ex);
+        return ResponseHelper.error(ResponseHelper.ResponseCode_COMMON,"系统异常");
+    }
+
+    private Map<String,Object> bodyParam(HttpServletRequest request){
+        Map<String,Object> params = new HashMap<String, Object>();
+//        BufferedReader br;
+//        try {
+//            br = request.getReader();
+//            String str, wholeStr = "";
+//            while((str = br.readLine()) != null){
+//                wholeStr += str;
+//            }
+//            if(StringUtils.isNotEmpty(wholeStr)){
+//                params = JSON.parseObject(wholeStr,Map.class);
+//            }
+//        } catch (IOException e1) {
+//            log.error(""+e1);
+//        }
+        return params;
+    }
+
+
+}

+ 39 - 0
src/main/java/com/zfire/jiasm/syncdata/config/MpMetaObjectHandler.java

@@ -0,0 +1,39 @@
+package com.zfire.jiasm.syncdata.config;
+
+import com.baomidou.mybatisplus.core.handlers.MetaObjectHandler;
+import com.zfire.jiasm.syncdata.utils.CommonUtils;
+import lombok.extern.slf4j.Slf4j;
+import org.apache.ibatis.reflection.MetaObject;
+import org.springframework.stereotype.Component;
+
+import java.util.Date;
+
+
+/**
+ * 自动补充插入或更新时的值
+ */
+@Slf4j
+@Component
+public class MpMetaObjectHandler implements MetaObjectHandler {
+    /**
+     * 插入时的填充策略
+     * @param metaObject
+     */
+    @Override
+    public void insertFill(MetaObject metaObject) {
+        //this.setFieldValByName("createBy", CommonUtils.getUserId(),metaObject);
+        //this.setFieldValByName("createTime", new Date(), metaObject);
+        //this.setFieldValByName("updateBy",  CommonUtils.getUserId(),metaObject);
+        // this.setFieldValByName("updateTime", new Date(), metaObject);
+    }
+
+    /**
+     * 更新时的填充策略
+     * @param metaObject
+     */
+    @Override
+    public void updateFill(MetaObject metaObject) {
+        // this.setFieldValByName("updateBy", CommonUtils.getUserId(), metaObject);
+        //this.setFieldValByName("updateTime", new Date(), metaObject);
+    }
+}

+ 64 - 0
src/main/java/com/zfire/jiasm/syncdata/config/MyBatisPlusConfig.java

@@ -0,0 +1,64 @@
+package com.zfire.jiasm.syncdata.config;
+
+import com.baomidou.mybatisplus.core.injector.ISqlInjector;
+import com.baomidou.mybatisplus.core.parser.ISqlParser;
+import com.baomidou.mybatisplus.extension.injector.LogicSqlInjector;
+import com.baomidou.mybatisplus.extension.parsers.BlockAttackSqlParser;
+import com.baomidou.mybatisplus.extension.plugins.PaginationInterceptor;
+import org.slf4j.Logger;
+import org.slf4j.LoggerFactory;
+import org.springframework.context.annotation.Bean;
+import org.springframework.context.annotation.Configuration;
+
+import java.util.ArrayList;
+import java.util.List;
+
+
+@Configuration
+public class MyBatisPlusConfig {
+    private final static Logger logger = LoggerFactory.getLogger(MyBatisPlusConfig.class);
+
+    /**
+     * @description: 配置分页插件
+     *
+     * @author: gradual
+     * @date: 2019/1/15 10:17
+     * @param: []
+     * @return: com.baomidou.mybatisplus.extension.plugins.PaginationInterceptor
+     */
+    @Bean
+    public PaginationInterceptor paginationInterceptor() {
+        logger.debug("注册分页插件");
+        PaginationInterceptor paginationInterceptor = new PaginationInterceptor();
+
+
+        // 攻击 SQL 阻断解析器、加入解析链,阻止恶意的全表更新删除
+        List<ISqlParser> sqlParserList = new ArrayList<>();
+        sqlParserList.add(new BlockAttackSqlParser());
+        paginationInterceptor.setSqlParserList(sqlParserList);
+
+        return paginationInterceptor;
+    }
+
+
+    /**
+     * @description: SQL执行效率插件
+     *
+     * @author: gradual
+     * @date: 19-1-24 下午4:59
+     * @param: []
+     * @return: com.baomidou.mybatisplus.extension.plugins.PerformanceInterceptor
+     */
+
+    /**
+     * 逻辑删除用,3.1.1之后的版本可不需要配置该bean,但项目这里用的是3.1.0的
+     *
+     * @author David Hong
+     *
+     * @return com.baomidou.mybatisplus.core.injector.ISqlInjector
+     */
+    @Bean
+    public ISqlInjector sqlInjector() {
+        return new LogicSqlInjector();
+    }
+}

+ 110 - 0
src/main/java/com/zfire/jiasm/syncdata/config/RedisConfig.java

@@ -0,0 +1,110 @@
+package com.zfire.jiasm.syncdata.config;
+
+import com.fasterxml.jackson.annotation.JsonAutoDetect;
+import com.fasterxml.jackson.annotation.JsonTypeInfo;
+import com.fasterxml.jackson.annotation.PropertyAccessor;
+import com.fasterxml.jackson.databind.ObjectMapper;
+import com.fasterxml.jackson.databind.jsontype.impl.LaissezFaireSubTypeValidator;
+import com.zfire.jiasm.syncdata.utils.RedisUtil;
+import lombok.extern.slf4j.Slf4j;
+import org.springframework.boot.autoconfigure.condition.ConditionalOnClass;
+import org.springframework.boot.autoconfigure.data.redis.RedisProperties;
+import org.springframework.boot.context.properties.EnableConfigurationProperties;
+import org.springframework.cache.CacheManager;
+import org.springframework.cache.annotation.EnableCaching;
+import org.springframework.cache.interceptor.KeyGenerator;
+import org.springframework.context.annotation.Bean;
+import org.springframework.context.annotation.Configuration;
+import org.springframework.data.redis.cache.RedisCacheConfiguration;
+import org.springframework.data.redis.cache.RedisCacheManager;
+import org.springframework.data.redis.cache.RedisCacheWriter;
+import org.springframework.data.redis.connection.RedisConnectionFactory;
+import org.springframework.data.redis.connection.lettuce.LettuceConnectionFactory;
+import org.springframework.data.redis.core.RedisOperations;
+import org.springframework.data.redis.core.RedisTemplate;
+import org.springframework.data.redis.listener.RedisMessageListenerContainer;
+import org.springframework.data.redis.serializer.Jackson2JsonRedisSerializer;
+import org.springframework.data.redis.serializer.StringRedisSerializer;
+
+import java.lang.reflect.Method;
+import java.time.Duration;
+
+
+@Configuration
+@EnableCaching
+@ConditionalOnClass(RedisOperations.class)
+@EnableConfigurationProperties(RedisProperties.class)
+@Slf4j
+public class RedisConfig {
+
+    @Bean
+    public RedisTemplate<String, Object> redisTemplate(LettuceConnectionFactory factory) {
+        Jackson2JsonRedisSerializer jackson2JsonRedisSerializer = new Jackson2JsonRedisSerializer(Object.class);
+        ObjectMapper om = new ObjectMapper();
+        om.setVisibility(PropertyAccessor.ALL, JsonAutoDetect.Visibility.ANY);
+        //om.enableDefaultTyping(ObjectMapper.DefaultTyping.NON_FINAL);
+        om.activateDefaultTyping(LaissezFaireSubTypeValidator.instance ,
+                ObjectMapper.DefaultTyping.NON_FINAL, JsonTypeInfo.As.PROPERTY);
+        jackson2JsonRedisSerializer.setObjectMapper(om);
+
+        StringRedisSerializer stringRedisSerializer = new StringRedisSerializer();
+        RedisTemplate template = new RedisTemplate();
+        template.setConnectionFactory(factory);
+        template.setValueSerializer(jackson2JsonRedisSerializer);
+        template.setKeySerializer(stringRedisSerializer);
+        template.setHashKeySerializer(stringRedisSerializer);
+        template.setHashValueSerializer(jackson2JsonRedisSerializer);
+        template.afterPropertiesSet();
+        return template;
+    }
+
+    @Bean
+    public CacheManager cacheManager(RedisConnectionFactory connectionFactory) {
+        RedisCacheWriter redisCacheWriter = RedisCacheWriter.nonLockingRedisCacheWriter(connectionFactory);
+        RedisCacheConfiguration defaultCacheConfig = RedisCacheConfiguration.defaultCacheConfig();
+        //设置默认超过期时间是30秒
+        defaultCacheConfig.entryTtl(Duration.ofSeconds(30));
+        //初始化RedisCacheManager
+        RedisCacheManager cacheManager = new RedisCacheManager(redisCacheWriter, defaultCacheConfig);
+        return cacheManager;
+    }
+
+    @Bean
+    RedisMessageListenerContainer container(RedisConnectionFactory connectionFactory) {
+        RedisMessageListenerContainer container = new RedisMessageListenerContainer();
+        container.setConnectionFactory(connectionFactory);
+       // container.addMessageListener(listenerAdapter, new PatternTopic("__keyevent@0__:expired"));
+        return container;
+    }
+
+
+    /**
+     * 注入封装RedisTemplate
+     * @Title: redisUtil
+     * @return RedisUtil
+     * @throws
+     */
+    @Bean(name = "redisUtil")
+    public RedisUtil redisUtilSingle(RedisTemplate<String, Object> redisTemplate) {
+        RedisUtil redisUtil = new RedisUtil();
+        redisUtil.setRedisTemplate(redisTemplate);
+        return redisUtil;
+    }
+
+    @Bean
+    public KeyGenerator keyGenerator() {
+        return new KeyGenerator() {
+            @Override
+            public Object generate(Object target, Method method, Object... params) {
+                StringBuilder sb = new StringBuilder();
+                sb.append(target.getClass().getName());
+                sb.append(":" + method.getName());
+                for (Object obj : params) {
+                    sb.append(":" + obj.toString());
+                }
+                return sb.toString();
+            }
+        };
+    }
+
+}

+ 17 - 0
src/main/java/com/zfire/jiasm/syncdata/config/RedisLockConfiguration.java

@@ -0,0 +1,17 @@
+package com.zfire.jiasm.syncdata.config;
+
+import org.springframework.context.annotation.Bean;
+import org.springframework.context.annotation.Configuration;
+import org.springframework.data.redis.connection.RedisConnectionFactory;
+import org.springframework.integration.redis.util.RedisLockRegistry;
+
+
+@Configuration
+public class RedisLockConfiguration {
+
+    @Bean
+    public RedisLockRegistry redisLockRegistry(RedisConnectionFactory redisConnectionFactory) {
+        return new RedisLockRegistry(redisConnectionFactory, "splock");
+    }
+
+}

+ 21 - 0
src/main/java/com/zfire/jiasm/syncdata/config/ScheduleConfig.java

@@ -0,0 +1,21 @@
+package com.zfire.jiasm.syncdata.config;
+
+import org.springframework.context.annotation.Configuration;
+import org.springframework.scheduling.annotation.SchedulingConfigurer;
+import org.springframework.scheduling.config.ScheduledTaskRegistrar;
+
+import java.util.concurrent.Executors;
+
+/**
+ * schedule定时任务多线程
+ * 2019-02-21
+ */
+
+@Configuration
+public class ScheduleConfig implements SchedulingConfigurer {
+
+    @Override
+    public void configureTasks(ScheduledTaskRegistrar scheduledTaskRegistrar) {
+        scheduledTaskRegistrar.setScheduler(Executors.newScheduledThreadPool(10));
+    }
+}

+ 66 - 0
src/main/java/com/zfire/jiasm/syncdata/config/TheaderPoolConfig.java

@@ -0,0 +1,66 @@
+package com.zfire.jiasm.syncdata.config;
+
+import org.springframework.context.annotation.Bean;
+import org.springframework.context.annotation.Configuration;
+import org.springframework.scheduling.annotation.EnableAsync;
+import org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor;
+
+import java.util.concurrent.ExecutorService;
+import java.util.concurrent.Executors;
+import java.util.concurrent.ThreadPoolExecutor;
+
+@Configuration
+@EnableAsync
+public class TheaderPoolConfig {
+
+
+    /**
+     *   默认情况下,在创建了线程池后,线程池中的线程数为0,当有任务来之后,就会创建一个线程去执行任务,
+     *	当线程池中的线程数目达到corePoolSize后,就会把到达的任务放到缓存队列当中;
+     *  当队列满了,就继续创建线程,当线程数量大于等于maxPoolSize后,开始使用拒绝策略拒绝
+     */
+
+    /** 核心线程数(默认线程数) */
+    private static final int corePoolSize = 4;
+    /** 最大线程数 */
+    private static final int maxPoolSize = 8;
+    /** 允许线程空闲时间(单位:默认为秒) */
+    private static final int keepAliveTime = 5;
+    /** 缓冲队列大小 */
+    private static final int queueCapacity = 200;
+    /** 线程池名前缀 */
+    private static final String threadNamePrefix = "Async-ManagerService-";
+
+    @Bean("taskExecutor") // bean的名称,默认为首字母小写的方法名
+    public ThreadPoolTaskExecutor taskExecutor(){
+        ThreadPoolTaskExecutor executor = new ThreadPoolTaskExecutor();
+        executor.setCorePoolSize(corePoolSize);
+        executor.setMaxPoolSize(maxPoolSize);
+        executor.setQueueCapacity(queueCapacity);
+        executor.setKeepAliveSeconds(keepAliveTime);
+        executor.setThreadNamePrefix(threadNamePrefix);
+
+        // 线程池对拒绝任务的处理策略
+        // CallerRunsPolicy:由调用线程(提交任务的线程)处理该任务
+        executor.setRejectedExecutionHandler(new ThreadPoolExecutor.CallerRunsPolicy());
+        // 初始化
+        executor.initialize();
+        return executor;
+    }
+    @Bean("singleTaskExecutor") // bean的名称,默认为首字母小写的方法名
+    public ThreadPoolTaskExecutor singleTaskExecutor(){
+        ThreadPoolTaskExecutor executor = new ThreadPoolTaskExecutor();
+        executor.setCorePoolSize(1);
+        executor.setMaxPoolSize(1);
+        executor.setQueueCapacity(1);
+        executor.setKeepAliveSeconds(0);
+        executor.setThreadNamePrefix(threadNamePrefix);
+        // 线程池对拒绝任务的处理策略
+        // CallerRunsPolicy:由调用线程(提交任务的线程)处理该任务
+        executor.setRejectedExecutionHandler(new ThreadPoolExecutor.CallerRunsPolicy());
+        // 初始化
+        executor.initialize();
+        return executor;
+    }
+
+}

+ 33 - 0
src/main/java/com/zfire/jiasm/syncdata/config/WebSocketConfig.java

@@ -0,0 +1,33 @@
+package com.zfire.jiasm.syncdata.config;
+
+import com.zfire.jiasm.syncdata.config.filter.WebsocketFilter;
+import org.springframework.boot.web.servlet.FilterRegistrationBean;
+import org.springframework.context.annotation.Bean;
+import org.springframework.context.annotation.Configuration;
+import org.springframework.web.socket.server.standard.ServerEndpointExporter;
+
+@Configuration
+public class WebSocketConfig {
+
+    /**
+     * 	注入ServerEndpointExporter,
+     * 	这个bean会自动注册使用了@ServerEndpoint注解声明的Websocket endpoint
+     */
+    @Bean
+    public ServerEndpointExporter serverEndpointExporter() {
+        return new ServerEndpointExporter();
+    }
+
+    @Bean
+    public WebsocketFilter websocketFilter(){
+        return new WebsocketFilter();
+    }
+
+    @Bean
+    public FilterRegistrationBean getFilterRegistrationBean(){
+        FilterRegistrationBean bean = new FilterRegistrationBean();
+        bean.setFilter(websocketFilter());
+        bean.addUrlPatterns("/supply/websocket/*");
+        return bean;
+    }
+}

+ 84 - 0
src/main/java/com/zfire/jiasm/syncdata/config/aop/ApiAspect.java

@@ -0,0 +1,84 @@
+package com.zfire.jiasm.syncdata.config.aop;
+
+import com.aliyuncs.utils.StringUtils;
+import com.zfire.jiasm.syncdata.annotations.ApiNotAuth;
+import com.zfire.jiasm.syncdata.constant.Constant;
+import com.zfire.jiasm.syncdata.exception.RemoteServiceException;
+import com.zfire.jiasm.syncdata.helper.ResponseHelper;
+import com.zfire.jiasm.syncdata.utils.CommonUtils;
+import com.zfire.jiasm.syncdata.utils.RedisUtil;
+import lombok.extern.slf4j.Slf4j;
+import org.aspectj.lang.JoinPoint;
+import org.aspectj.lang.annotation.Aspect;
+import org.aspectj.lang.annotation.Before;
+import org.aspectj.lang.annotation.Pointcut;
+import org.aspectj.lang.reflect.MethodSignature;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.beans.factory.annotation.Value;
+import org.springframework.core.annotation.Order;
+import org.springframework.stereotype.Component;
+import org.springframework.web.context.request.RequestContextHolder;
+import org.springframework.web.context.request.ServletRequestAttributes;
+
+import javax.servlet.http.HttpServletRequest;
+import java.lang.reflect.Method;
+
+@Aspect
+@Component
+@Slf4j
+@Order(1)
+public class ApiAspect {
+
+    @Value("${spring.profiles.active}")
+    private String profiles;
+    @Autowired
+    RedisUtil redisUtil;
+//    @Autowired
+//    AdminRoleService adminRoleService;
+
+    @Pointcut("@annotation(io.swagger.annotations.ApiOperation)")
+    public void auth() {}
+
+    @Before("auth()")
+    public void doBefore(JoinPoint joinPoint) throws RemoteServiceException {
+            start(joinPoint);
+    }
+
+    private void start(JoinPoint joinPoint) throws RemoteServiceException {
+        ServletRequestAttributes attributes = (ServletRequestAttributes) RequestContextHolder.getRequestAttributes();
+        Method sourceMethod = getSourceMethod(joinPoint);
+        HttpServletRequest request = attributes.getRequest();
+        ApiNotAuth apiNotAuth = sourceMethod.getAnnotation(ApiNotAuth.class);
+
+        String userId = CommonUtils.getUserId(request);
+
+        if(apiNotAuth != null){
+            return;
+        }
+        if(!profiles.equals("prd")){
+            if(request.getHeader(Constant.TOKEN_NAME) != null && request.getHeader(Constant.TOKEN_NAME).equals("1111")){
+                return;
+            }
+            if(request.getParameter(Constant.TOKEN_NAME) != null && request.getParameter(Constant.TOKEN_NAME).equals("1111")){
+                return;
+            }
+        }
+        if (StringUtils.isEmpty(userId)) {
+            throw new RemoteServiceException(ResponseHelper.ResponseCode_AUTH_ERROR, "请求不合法");
+        }
+
+    }
+
+    private Method getSourceMethod(JoinPoint jp) {
+        Method proxyMethod = ((MethodSignature) jp.getSignature()).getMethod();
+        try {
+            return jp.getTarget().getClass().getMethod(proxyMethod.getName(), proxyMethod.getParameterTypes());
+        } catch (NoSuchMethodException e) {
+            e.printStackTrace();
+        } catch (SecurityException e) {
+            e.printStackTrace();
+        }
+        return null;
+    }
+
+}

+ 43 - 0
src/main/java/com/zfire/jiasm/syncdata/config/filter/WebsocketFilter.java

@@ -0,0 +1,43 @@
+package com.zfire.jiasm.syncdata.config.filter;
+
+import com.zfire.jiasm.syncdata.utils.ApplicationContextUtils;
+import com.zfire.jiasm.syncdata.utils.RedisUtil;
+import lombok.extern.slf4j.Slf4j;
+
+import javax.servlet.*;
+import javax.servlet.http.HttpServletRequest;
+import javax.servlet.http.HttpServletResponse;
+import java.io.IOException;
+
+@Slf4j
+public class WebsocketFilter implements Filter {
+
+    private static final String TOKEN_KEY = "Sec-WebSocket-Protocol";
+
+    RedisUtil redisUtil;
+
+    @Override
+    public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException {
+        if (redisUtil == null) {
+            redisUtil = ApplicationContextUtils.getBean(RedisUtil.class);
+        }
+        HttpServletRequest request = (HttpServletRequest)servletRequest;
+        String token = request.getHeader(TOKEN_KEY);
+
+        log.info("websocket连接 Token安全校验,Path = {},token:{}", request.getRequestURI(), token);
+
+        try {
+            // 校验用户token
+//            AdminUserCom adminUserCom = (AdminUserCom) redisUtil.get(Constant.RedisPrefix.TOKEN_MGR + token);
+//            if(Objects.isNull(adminUserCom)) {
+//                throw new RemoteException("token非法无效!");
+//            }
+        } catch (Exception exception) {
+            log.error("websocket连接校验失败,{},token:{}", exception.getMessage(), token);
+            return;
+        }
+        HttpServletResponse response = (HttpServletResponse)servletResponse;
+        response.setHeader(TOKEN_KEY, token);
+        filterChain.doFilter(servletRequest, servletResponse);
+    }
+}

+ 50 - 0
src/main/java/com/zfire/jiasm/syncdata/constant/Constant.java

@@ -0,0 +1,50 @@
+package com.zfire.jiasm.syncdata.constant;
+
+public class Constant {
+
+    //会话存档大小
+    public static final String HHCD_FILE_SIZE = "5000000";
+
+    //登录方式 1.账号 2.扫码
+    public static final String LOGIN_TYPE_ACCOUNT = "account";
+    public static final String LOGIN_TYPE_SCAN = "scan";
+
+    //校验的token
+    public static final String TOKEN_NAME = "x-token";
+
+
+
+    public class RedisPrefix {
+        public final static String WORK_MINI_ACCESS_TOKEN = "konwledge:work:mini:access:token";
+        //验证码
+        public final static String VERIFICATION = "konwledge:verification:";
+
+        //管理后台登录会话
+        public final static String TOKEN_MGR = "konwledge:token:mgr:";
+    }
+
+    public class WXUrl {
+        public final static String WX_PUSH_MSG_URL = "https://qyapi.weixin.qq.com/cgi-bin/externalcontact/add_msg_template?access_token=";
+
+
+    }
+
+    public class Ali {
+        public final static String ACCESS_KEY_ID = "LTAI5tN5RSgMtdGDrNDAqMLT";
+        public final static String ACCESS_KEY_SECERT = "mvWc8VtBFOj10DIa9E1eKiw3F0NRxf";
+        public final static String OSS_BUCKET_NAME="zfire-supply";
+        public final static String OSS_ENDPOINT_WW = "oss-cn-guangzhou.aliyuncs.com/";
+        public final static String OSS_ENDPOINT = "oss-cn-guangzhou-internal.aliyuncs.com/";
+        public final static String OSS_TYPE_PIC = "uploadfile/";
+    }
+
+    public class Ali_DEV {
+        public final static String ACCESS_KEY_ID = "LTAI4GK1q4mnpCFbonMd1pji";
+        public final static String ACCESS_KEY_SECERT = "E5LW0V1H8HBxqjKkExIxaXUgSyex6C";
+        public final static String OSS_BUCKET_NAME="zfiresupply";
+        public final static String OSS_ENDPOINT_WW = "oss-cn-hangzhou.aliyuncs.com/";
+        public final static String OSS_ENDPOINT = "oss-cn-hangzhou-internal.aliyuncs.com/";
+        public final static String OSS_TYPE_PIC = "uploadfile/";
+    }
+
+}

+ 161 - 0
src/main/java/com/zfire/jiasm/syncdata/constant/DictTypeEnum.java

@@ -0,0 +1,161 @@
+package com.zfire.jiasm.syncdata.constant;
+
+import lombok.Getter;
+
+/**
+ * 字典类型
+ * @author yaozx
+ * @version 1.0
+ * @date 2022-12-28
+ */
+@Getter
+public enum DictTypeEnum {
+
+    /**
+     * 商品大类
+     */
+    DICT_TYPE_MAIN_TYPE("MAIN_TYPE","商品大类"),
+    /**
+     * 商品小类
+     */
+    DICT_TYPE_SMALL_TYPE("SMALL_TYPE","商品小类"),
+    /**
+     * 系列
+     */
+    DICT_TYPE_SERIES("SERIES","系列"),
+    /**
+     * 用户属性
+     */
+    DICT_TYPE_USER_ATTR("USER_ATTR","用户属性"),
+    /**
+     * 用户等级
+     */
+    DICT_TYPE_USER_LEVEL("USER_LEVEL","用户等级"),
+    /**
+     * 消息渠道
+     */
+    DICT_TYPE_XXQD_CHANNEL("CHANNEL","消息渠道"),
+    /**
+     * 消息来源
+     */
+    DICT_TYPE_XXQD_SOURCE("SOURCE","消息来源"),
+    /**
+     * 销售类型
+     */
+    DICT_TYPE_SALE_TYPE("SALE_TYPE","销售类型"),
+    /**
+     * 需求大类
+     */
+    DICT_TYPE_DEMAND_TYPE("DEMAND_TYPE","需求大类"),
+    /**
+     * 需求小类
+     */
+    DICT_TYPE_DEMAND_SMALL_TYPE("DEMAND_SMALL_TYPE","需求小类"),
+
+
+
+
+
+
+
+
+    /**
+     * 有效
+     */
+    DICT_TYPE_ON("ON","有效"),
+    /**
+     * 无效
+     */
+    DICT_TYPE_OFF("OFF","无效"),
+    /**
+     * 有效
+     */
+    DICT_TYPE_FLAG_ON("有效","有效"),
+    /**
+     * 无效
+     */
+    DICT_TYPE_FLAG_OFF("无效","无效"),
+    /**
+     * 商用
+     */
+    DICT_TYPE_FLAG_SY("商用","商用"),
+    /**
+     * 商用
+     */
+    DICT_TYPE_FLAG_JY("家用","家用"),
+    /**
+     * 商用
+     */
+    DICT_TYPE_SY_102("102","商用"),
+    /**
+     * 商用
+     */
+    DICT_TYPE_SY_109("109","商用"),
+    /**
+     * 是否需要短信提醒
+     */
+    RECEIVE_TYPE_YES("YES","需要"),
+    /**
+     * 是否需要短信提醒
+     */
+    RECEIVE_TYPE_NO("NO","不需要"),
+    /**
+     * 是否开通掌上通
+     */
+    ZST_TYPE_YES("YES","开通"),
+    /**
+     * 是否开通掌上通
+     */
+    ZST_TYPE_NO("NO","不开通"),
+    /**
+     * 是否在黑名单
+     */
+    HMD_TYPE_YES("YES","是"),
+    /**
+     * 是否在黑名单
+     */
+    HMD_TYPE_NO("NO","否"),
+
+    ;
+
+
+
+
+    /**
+     * 编码
+     */
+    private final String code;
+
+
+    private final String text;
+
+    DictTypeEnum(String code, String text) {
+        this.code = code;
+        this.text = text;
+    }
+
+    public static DictTypeEnum getByCode(String code) {
+        for (DictTypeEnum item : values()) {
+            if (code.equals(item.getCode())) {
+                return item;
+            }
+        }
+        return null;
+    }
+
+    /**
+     * 通过code获取枚举
+     * @param code: code
+     * @return 对应枚举
+     **/
+    public static String getMessageByCode(String code) {
+        String result = null;
+        for (DictTypeEnum item : values()) {
+            if (code.equals(item.getCode())) {
+                result = item.getText();
+                break;
+            }
+        }
+        return result;
+    }
+}

+ 160 - 0
src/main/java/com/zfire/jiasm/syncdata/constant/InterFaceTypeEnum.java

@@ -0,0 +1,160 @@
+package com.zfire.jiasm.syncdata.constant;
+
+import lombok.Getter;
+
+/**
+ * 接口表类型
+ * @author yaozx
+ * @version 1.0
+ * @date 2022-12-23
+ */
+@Getter
+public enum InterFaceTypeEnum {
+
+    /**
+     * 格力品牌省份信息接口
+     */
+    TBL_PROVINCE("tblProvince","省份信息接口"),
+    /**
+     * 格力品牌市信息接口
+     */
+    TBL_CITY("tblCity","市信息接口"),
+    /**
+     * 格力品牌区信息接口
+     */
+    TBL_COUNTY("tblCounty","区信息接口"),
+    /**
+     * 乡镇信息接口
+     */
+    TBL_CITY_JDXZ("tblCityJdxz","乡镇信息接口"),
+    /**
+     * 格力品牌销售售后网点下载接口
+     */
+    GLXSSH_WEBSIT("tblXinWangdian","佛山销售网点下载接口"),
+    /**
+     * 格力品牌销售网点类型
+     */
+    XS_WEBSIT_TYPE("X","销售网点类型"),
+    /**
+     * 格力品牌售后网点类型
+     */
+    SH_WEBSIT_TYPE("S","售后网点类型"),
+    /**
+     * X2300000 格力品牌佛山销售
+     */
+    FSXS_WEBSIT_CODE("X2300000","佛山销售网点"),
+    /**
+     * X2100000 格力品牌广州销售
+     */
+    GZXS_WEBSIT_CODE("X2100000","广州销售网点"),
+    /**
+     * S9219807 格力品牌佛山售后
+     */
+    FSSH_WEBSIT_CODE("S9219807","佛山售后网点"),
+    /**
+     * S9219801 格力品牌广州售后网点
+     */
+    GSSH_WEBSIT_CODE("S9219801","广州售后网点"),
+    /**
+     * 格力品牌大类信息接口
+     */
+    GELI_DL("tblSplbDalei","格力大类信息接口"),
+    /**
+     * 格力品牌小类信息接口
+     */
+    GELI_XL("tblSplbXiaolei","格力小类信息接口"),
+    /**
+     * 格力品牌系列信息接口
+     */
+    GELI_PPXL("tblSplbXilie","格力品牌系列信息接口"),
+    /**
+     * 格力品牌机型信息接口
+     */
+    GELI_PPJX("tblSplbJixin","格力品牌机型信息接口"),
+    /**
+     * 格力品牌销售售后网点维修工下载接口
+     */
+    GLXSSH_WEBSIT_WORK("tblWangdianWxg","格力销售售后网点维修工下载接口"),
+    /**
+     * 格力品牌用户属性下载接口
+     */
+    GLPP_YHSX("tblAssignYhsxWx","格力品牌用户属性下载接口"),
+    /**
+     * 格力品牌用户等级下载接口
+     */
+    GLPP_YHDJ("tblYhsxViprank","格力品牌用户等级下载接口"),
+    /**
+     * 格力品牌信息渠道下载接口
+     */
+    GLPP_XXQD("tblAssignXxqd","格力品牌信息渠道下载接口"),
+    /**
+     * 格力品牌信息来源下载接口
+     */
+    GLPP_XXLY("tblAssignXxly","格力品牌信息来源下载接口"),
+    /**
+     * 格力品牌安装销售类型下载接口
+     */
+    GLPP_XSLX("tblAzAssignXslx","格力品牌安装销售类型下载接口"),
+    /**
+     * 格力品牌需求大类信息接口
+     */
+    GELI_XQDL("tblAssignXxlb","格力品牌需求大类信息接口"),
+    /**
+     * 格力品牌需求小类信息接口
+     */
+    GELI_XQXL("tblAssignXqxl","格力品牌需求小类信息接口"),
+    /**
+     * 格力品牌固障代码信息接口
+     */
+    GELI_GZDM("tblAssignGzdm","格力品牌固障代码信息接口"),
+
+
+
+    ;
+
+
+
+
+
+
+
+
+
+
+    /**
+     * 编码
+     */
+    private final String code;
+
+
+    private final String text;
+
+    InterFaceTypeEnum(String code, String text) {
+        this.code = code;
+        this.text = text;
+    }
+
+    public static InterFaceTypeEnum getByCode(String code) {
+        for (InterFaceTypeEnum item : values()) {
+            if (code.equals(item.getCode())) {
+                return item;
+            }
+        }
+        return null;
+    }
+
+    /**
+     * @param code: code
+     * @return 对应枚举
+     **/
+    public static String getMessageByCode(String code) {
+        String result = null;
+        for (InterFaceTypeEnum item : values()) {
+            if (code.equals(item.getCode())) {
+                result = item.getText();
+                break;
+            }
+        }
+        return result;
+    }
+}

+ 43 - 0
src/main/java/com/zfire/jiasm/syncdata/data/Token.java

@@ -0,0 +1,43 @@
+package com.zfire.jiasm.syncdata.data;
+
+public class Token {
+
+	private String accessToken;
+
+	public String getAccessToken() {
+		return accessToken;
+	}
+
+	public long getExpiresIn() {
+		return expiresIn;
+	}
+
+	public String getRefreshToken() {
+		return refreshToken;
+	}
+
+	public long getRefreshExpiresIn() {
+		return refreshExpiresIn;
+	}
+
+	private long expiresIn;
+
+	private String refreshToken;
+
+	private long refreshExpiresIn;
+	
+	private long createTime;
+
+	public long getCreateTime() {
+		return createTime;
+	}
+
+	public Token(String accessToken, long expiresIn, String refreshToken, long refreshExpiresIn) {
+		this.accessToken = accessToken;
+		this.expiresIn = expiresIn;
+		this.refreshToken = refreshToken;
+		this.refreshExpiresIn = refreshExpiresIn;
+		this.createTime=System.currentTimeMillis();
+	}
+
+}

+ 23 - 0
src/main/java/com/zfire/jiasm/syncdata/exception/FeignServiceException.java

@@ -0,0 +1,23 @@
+package com.zfire.jiasm.syncdata.exception;
+
+import lombok.Getter;
+import lombok.Setter;
+
+import java.util.List;
+
+/**
+ * @author wy
+ */
+@Getter
+@Setter
+public class FeignServiceException extends RemoteServiceException {
+
+    private String serviceName;
+    private String requestUrl;
+    private List<String> serviceStackTrace;
+
+    public FeignServiceException(int status, String message) {
+        super(status, message);
+    }
+
+}

+ 38 - 0
src/main/java/com/zfire/jiasm/syncdata/exception/RemoteServiceException.java

@@ -0,0 +1,38 @@
+package com.zfire.jiasm.syncdata.exception;
+
+
+import com.zfire.jiasm.syncdata.helper.ResponseHelper;
+
+public class RemoteServiceException extends RuntimeException {
+    private int status;
+    private String message;
+
+    public RemoteServiceException(String message){
+        this.status = ResponseHelper.ResponseCode_COMMON;
+        this.message = message;
+    }
+
+    public RemoteServiceException(int status, String message) {
+
+        this.status = status;
+        this.message = message;
+
+    }
+
+    @Override
+    public String getMessage() {
+        return this.message;
+    }
+
+    public void setMessage(String message) {
+        this.message = message;
+    }
+
+    public int getCode() {
+        return this.status;
+    }
+
+    public ResponseHelper toResponse(){
+        return ResponseHelper.error(this.status,this.message);
+    }
+}

+ 68 - 0
src/main/java/com/zfire/jiasm/syncdata/exception/RoleResultCode.java

@@ -0,0 +1,68 @@
+package com.zfire.jiasm.syncdata.exception;
+
+import com.zfire.jiasm.syncdata.api.IResultCode;
+
+/**
+ * 产品分类相关统一错误
+ * @author yaozx
+ * @version 1.0
+ * @description 介绍
+ * @date 2022-10-04
+ */
+public class RoleResultCode implements IResultCode {
+    /**
+     * 错误 code
+     */
+    private Integer code;
+    /**
+     * 描述信息
+     */
+    private String message;
+
+    public RoleResultCode (final int code, final String message) {
+        this.code = code;
+        this.message = message;
+    }
+
+
+    @Override
+    public String getMessage() {
+        return this.message;
+    }
+    @Override
+    public int getCode() {
+        return this.code;
+    }
+
+    /**
+     * 角色不存在
+     */
+    public static final RoleResultCode ROLE_NOT_EXIT = new RoleResultCode(1101, "要删除的角色不存在,请与信息部人员联系!");
+
+    /**
+     * 删除角色失败
+     */
+    public static final  RoleResultCode ROLE_DELETE_ERROR = new RoleResultCode(1002, "删除角色失败,请重试或与信息部人员联系!");
+
+    /**
+     * 名称不能相同
+     */
+    public static final  RoleResultCode PARENT_ROLE_NAME_ERROR = new RoleResultCode(1003, "已存在相同名称的角色,请核实角色名称!");
+
+    /**
+     * 修改失败
+     */
+    public static final  RoleResultCode UPDATE_ROLE_ERROR = new RoleResultCode(1004, "角色名称修改失败,请重试!");
+
+    /**
+     * 新增失败
+     */
+    public static final  RoleResultCode ADD_ROLE_ERROR = new RoleResultCode(1005, "新增角色失败,请重试!");
+
+    /**
+     * 部分不存在
+     */
+    public static final  RoleResultCode DEPARTMENT_ROLE_NOT_EXIT = new RoleResultCode(1006, "部分不存在,请与信息部人员联系!");
+
+
+}

+ 33 - 0
src/main/java/com/zfire/jiasm/syncdata/helper/FeignResponseObject.java

@@ -0,0 +1,33 @@
+package com.zfire.jiasm.syncdata.helper;
+
+
+import com.zfire.jiasm.syncdata.exception.RemoteServiceException;
+import lombok.Data;
+import lombok.extern.slf4j.Slf4j;
+
+import java.util.Arrays;
+import java.util.List;
+
+
+@Data
+@Slf4j
+public class FeignResponseObject<T> {
+
+    public List<Integer> responseSuccessCodes = Arrays.asList(1,200);
+
+    private int code;
+    private T data;
+    private String msg;
+    private String serviceName;
+    private String requestUrl;
+    private List<String> stackTrace;
+
+    public T checkOutData()throws RemoteServiceException {
+        if (responseSuccessCodes.contains(code)) {
+            return this.data;
+        }
+        throw new RemoteServiceException(this.code,this.msg);
+    }
+
+
+}

+ 78 - 0
src/main/java/com/zfire/jiasm/syncdata/helper/ResponseHelper.java

@@ -0,0 +1,78 @@
+package com.zfire.jiasm.syncdata.helper;
+
+import io.swagger.annotations.ApiModel;
+
+@ApiModel
+public class ResponseHelper<T> {
+
+
+    public static int ResponseCode_Success = 200;
+    public static int ResponseCode_COMMON = 501;//通用拦截提示
+    public static int ResponseCode_AUTH_ERROR = 1001;//非法请求
+    public static int ResponseCode_VALIDATION_ERROR = 4005;// 校验拦截提示
+
+    private T data;
+    private String message;
+    private int code;
+
+
+    public static ResponseHelper success() {
+        ResponseHelper object = new ResponseHelper(ResponseCode_Success, "success");
+        return object;
+    }
+
+    public static ResponseHelper success(Object data) {
+        ResponseHelper object = new ResponseHelper(ResponseCode_Success, "success");
+        object.setData(data);
+        return object;
+    }
+
+    public static ResponseHelper success(int code,Object data,String message) {
+        ResponseHelper object = new ResponseHelper(ResponseCode_Success, "success");
+        object.setData(data);
+        object.setCode(code);
+        object.setMessage(message);
+        return object;
+    }
+
+    public static ResponseHelper error(String msg) {
+        ResponseHelper object = new ResponseHelper(ResponseCode_COMMON, msg);
+        return object;
+    }
+
+    public static ResponseHelper error(int code, String msg) {
+        ResponseHelper object = new ResponseHelper(code, msg);
+        return object;
+    }
+
+
+    public T getData() {
+        return data;
+    }
+
+    public void setData(Object data) {
+        this.data = (T)data;
+    }
+
+    public ResponseHelper(int code, String message) {
+        this.code = code;
+        this.message = message;
+    }
+    public int getCode() {
+        return code;
+    }
+
+    public void setCode(int status) {
+        this.code = status;
+    }
+
+
+    public String getMessage() {
+        return message;
+    }
+
+    public void setMessage(String message) {
+        this.message = message;
+    }
+
+}

+ 21 - 0
src/main/java/com/zfire/jiasm/syncdata/plus/controller/AdminFastEntryPlusTempController.java

@@ -0,0 +1,21 @@
+package com.zfire.jiasm.syncdata.plus.controller;
+
+
+import org.springframework.web.bind.annotation.RequestMapping;
+
+import org.springframework.stereotype.Controller;
+
+/**
+ * <p>
+ * 快捷入口 前端控制器
+ * </p>
+ *
+ * @author gejiang
+ * @since 2023-01-09
+ */
+@Controller
+@RequestMapping("/plus/admin-fast-entry")
+public class AdminFastEntryPlusTempController {
+
+}
+

+ 21 - 0
src/main/java/com/zfire/jiasm/syncdata/plus/controller/AdminFieldPlusTempController.java

@@ -0,0 +1,21 @@
+package com.zfire.jiasm.syncdata.plus.controller;
+
+
+import org.springframework.web.bind.annotation.RequestMapping;
+
+import org.springframework.stereotype.Controller;
+
+/**
+ * <p>
+ *  前端控制器
+ * </p>
+ *
+ * @author gejiang
+ * @since 2023-01-09
+ */
+@Controller
+@RequestMapping("/plus/admin-field")
+public class AdminFieldPlusTempController {
+
+}
+

+ 21 - 0
src/main/java/com/zfire/jiasm/syncdata/plus/controller/AdminModuleFavoritesPlusTempController.java

@@ -0,0 +1,21 @@
+package com.zfire.jiasm.syncdata.plus.controller;
+
+
+import org.springframework.web.bind.annotation.RequestMapping;
+
+import org.springframework.stereotype.Controller;
+
+/**
+ * <p>
+ * 菜单收藏(用户常用菜单) 前端控制器
+ * </p>
+ *
+ * @author gejiang
+ * @since 2023-01-09
+ */
+@Controller
+@RequestMapping("/plus/admin-module-favorites")
+public class AdminModuleFavoritesPlusTempController {
+
+}
+

+ 21 - 0
src/main/java/com/zfire/jiasm/syncdata/plus/controller/AdminModulePlusTempController.java

@@ -0,0 +1,21 @@
+package com.zfire.jiasm.syncdata.plus.controller;
+
+
+import org.springframework.web.bind.annotation.RequestMapping;
+
+import org.springframework.stereotype.Controller;
+
+/**
+ * <p>
+ * 菜单功能 前端控制器
+ * </p>
+ *
+ * @author gejiang
+ * @since 2023-01-09
+ */
+@Controller
+@RequestMapping("/plus/admin-module")
+public class AdminModulePlusTempController {
+
+}
+

+ 21 - 0
src/main/java/com/zfire/jiasm/syncdata/plus/controller/AdminRolePlusTempController.java

@@ -0,0 +1,21 @@
+package com.zfire.jiasm.syncdata.plus.controller;
+
+
+import org.springframework.web.bind.annotation.RequestMapping;
+
+import org.springframework.stereotype.Controller;
+
+/**
+ * <p>
+ * 角色 前端控制器
+ * </p>
+ *
+ * @author gejiang
+ * @since 2023-01-09
+ */
+@Controller
+@RequestMapping("/plus/admin-role")
+public class AdminRolePlusTempController {
+
+}
+

+ 21 - 0
src/main/java/com/zfire/jiasm/syncdata/plus/controller/AdminUserModuleRelaPlusTempController.java

@@ -0,0 +1,21 @@
+package com.zfire.jiasm.syncdata.plus.controller;
+
+
+import org.springframework.web.bind.annotation.RequestMapping;
+
+import org.springframework.stereotype.Controller;
+
+/**
+ * <p>
+ * 角色菜单关系表 前端控制器
+ * </p>
+ *
+ * @author gejiang
+ * @since 2023-01-09
+ */
+@Controller
+@RequestMapping("/plus/admin-user-module-rela")
+public class AdminUserModuleRelaPlusTempController {
+
+}
+

+ 21 - 0
src/main/java/com/zfire/jiasm/syncdata/plus/controller/AdminUserPlusTempController.java

@@ -0,0 +1,21 @@
+package com.zfire.jiasm.syncdata.plus.controller;
+
+
+import org.springframework.web.bind.annotation.RequestMapping;
+
+import org.springframework.stereotype.Controller;
+
+/**
+ * <p>
+ * 用户表 前端控制器
+ * </p>
+ *
+ * @author gejiang
+ * @since 2023-01-09
+ */
+@Controller
+@RequestMapping("/plus/admin-user")
+public class AdminUserPlusTempController {
+
+}
+

+ 21 - 0
src/main/java/com/zfire/jiasm/syncdata/plus/controller/AdminUserRoleRelaPlusTempController.java

@@ -0,0 +1,21 @@
+package com.zfire.jiasm.syncdata.plus.controller;
+
+
+import org.springframework.web.bind.annotation.RequestMapping;
+
+import org.springframework.stereotype.Controller;
+
+/**
+ * <p>
+ *  前端控制器
+ * </p>
+ *
+ * @author gejiang
+ * @since 2023-01-09
+ */
+@Controller
+@RequestMapping("/plus/admin-user-role-rela")
+public class AdminUserRoleRelaPlusTempController {
+
+}
+

+ 21 - 0
src/main/java/com/zfire/jiasm/syncdata/plus/controller/AdminWebsitPlusTempController.java

@@ -0,0 +1,21 @@
+package com.zfire.jiasm.syncdata.plus.controller;
+
+
+import org.springframework.web.bind.annotation.RequestMapping;
+
+import org.springframework.stereotype.Controller;
+
+/**
+ * <p>
+ * 网点,部门表 前端控制器
+ * </p>
+ *
+ * @author gejiang
+ * @since 2023-01-09
+ */
+@Controller
+@RequestMapping("/plus/admin-websit")
+public class AdminWebsitPlusTempController {
+
+}
+

+ 21 - 0
src/main/java/com/zfire/jiasm/syncdata/plus/controller/AdminWebsitProductTypeRelaPlusTempController.java

@@ -0,0 +1,21 @@
+package com.zfire.jiasm.syncdata.plus.controller;
+
+
+import org.springframework.web.bind.annotation.RequestMapping;
+
+import org.springframework.stereotype.Controller;
+
+/**
+ * <p>
+ * 部门业务线关系表 前端控制器
+ * </p>
+ *
+ * @author gejiang
+ * @since 2023-01-09
+ */
+@Controller
+@RequestMapping("/plus/admin-websit-product-type-rela")
+public class AdminWebsitProductTypeRelaPlusTempController {
+
+}
+

+ 21 - 0
src/main/java/com/zfire/jiasm/syncdata/plus/controller/AdminWebsitSlavePlusTempController.java

@@ -0,0 +1,21 @@
+package com.zfire.jiasm.syncdata.plus.controller;
+
+
+import org.springframework.web.bind.annotation.RequestMapping;
+
+import org.springframework.stereotype.Controller;
+
+/**
+ * <p>
+ * 网点的附属网点 前端控制器
+ * </p>
+ *
+ * @author gejiang
+ * @since 2023-01-09
+ */
+@Controller
+@RequestMapping("/plus/admin-websit-slave")
+public class AdminWebsitSlavePlusTempController {
+
+}
+

+ 21 - 0
src/main/java/com/zfire/jiasm/syncdata/plus/controller/AreaPlusTempController.java

@@ -0,0 +1,21 @@
+package com.zfire.jiasm.syncdata.plus.controller;
+
+
+import org.springframework.web.bind.annotation.RequestMapping;
+
+import org.springframework.stereotype.Controller;
+
+/**
+ * <p>
+ *  前端控制器
+ * </p>
+ *
+ * @author gejiang
+ * @since 2023-01-09
+ */
+@Controller
+@RequestMapping("/plus/area")
+public class AreaPlusTempController {
+
+}
+

+ 21 - 0
src/main/java/com/zfire/jiasm/syncdata/plus/controller/BrandLbsRelatePlusTempController.java

@@ -0,0 +1,21 @@
+package com.zfire.jiasm.syncdata.plus.controller;
+
+
+import org.springframework.web.bind.annotation.RequestMapping;
+
+import org.springframework.stereotype.Controller;
+
+/**
+ * <p>
+ * 高德地图与品牌定位对应关系 前端控制器
+ * </p>
+ *
+ * @author gejiang
+ * @since 2023-01-09
+ */
+@Controller
+@RequestMapping("/plus/brand-lbs-relate")
+public class BrandLbsRelatePlusTempController {
+
+}
+

+ 21 - 0
src/main/java/com/zfire/jiasm/syncdata/plus/controller/BrandPlusTempController.java

@@ -0,0 +1,21 @@
+package com.zfire.jiasm.syncdata.plus.controller;
+
+
+import org.springframework.web.bind.annotation.RequestMapping;
+
+import org.springframework.stereotype.Controller;
+
+/**
+ * <p>
+ * 品牌表 前端控制器
+ * </p>
+ *
+ * @author gejiang
+ * @since 2023-01-09
+ */
+@Controller
+@RequestMapping("/plus/brand")
+public class BrandPlusTempController {
+
+}
+

+ 21 - 0
src/main/java/com/zfire/jiasm/syncdata/plus/controller/BrandWebsitPlusTempController.java

@@ -0,0 +1,21 @@
+package com.zfire.jiasm.syncdata.plus.controller;
+
+
+import org.springframework.web.bind.annotation.RequestMapping;
+
+import org.springframework.stereotype.Controller;
+
+/**
+ * <p>
+ * 各个品牌的网点信息 前端控制器
+ * </p>
+ *
+ * @author gejiang
+ * @since 2023-01-09
+ */
+@Controller
+@RequestMapping("/plus/brand-websit")
+public class BrandWebsitPlusTempController {
+
+}
+

+ 21 - 0
src/main/java/com/zfire/jiasm/syncdata/plus/controller/CityPlusTempController.java

@@ -0,0 +1,21 @@
+package com.zfire.jiasm.syncdata.plus.controller;
+
+
+import org.springframework.web.bind.annotation.RequestMapping;
+
+import org.springframework.stereotype.Controller;
+
+/**
+ * <p>
+ *  前端控制器
+ * </p>
+ *
+ * @author gejiang
+ * @since 2023-01-09
+ */
+@Controller
+@RequestMapping("/plus/city")
+public class CityPlusTempController {
+
+}
+

+ 21 - 0
src/main/java/com/zfire/jiasm/syncdata/plus/controller/ComDetailLogPlusTempController.java

@@ -0,0 +1,21 @@
+package com.zfire.jiasm.syncdata.plus.controller;
+
+
+import org.springframework.web.bind.annotation.RequestMapping;
+
+import org.springframework.stereotype.Controller;
+
+/**
+ * <p>
+ * 万能通用列表 前端控制器
+ * </p>
+ *
+ * @author gejiang
+ * @since 2023-01-09
+ */
+@Controller
+@RequestMapping("/plus/com-detail-log")
+public class ComDetailLogPlusTempController {
+
+}
+

+ 21 - 0
src/main/java/com/zfire/jiasm/syncdata/plus/controller/ComDetailPlusTempController.java

@@ -0,0 +1,21 @@
+package com.zfire.jiasm.syncdata.plus.controller;
+
+
+import org.springframework.web.bind.annotation.RequestMapping;
+
+import org.springframework.stereotype.Controller;
+
+/**
+ * <p>
+ * 万能通用列表 前端控制器
+ * </p>
+ *
+ * @author gejiang
+ * @since 2023-01-09
+ */
+@Controller
+@RequestMapping("/plus/com-detail")
+public class ComDetailPlusTempController {
+
+}
+

+ 21 - 0
src/main/java/com/zfire/jiasm/syncdata/plus/controller/ComListPlusTempController.java

@@ -0,0 +1,21 @@
+package com.zfire.jiasm.syncdata.plus.controller;
+
+
+import org.springframework.web.bind.annotation.RequestMapping;
+
+import org.springframework.stereotype.Controller;
+
+/**
+ * <p>
+ * 万能通用列表 前端控制器
+ * </p>
+ *
+ * @author gejiang
+ * @since 2023-01-09
+ */
+@Controller
+@RequestMapping("/plus/com-list")
+public class ComListPlusTempController {
+
+}
+

+ 21 - 0
src/main/java/com/zfire/jiasm/syncdata/plus/controller/CommonFilePlusTempController.java

@@ -0,0 +1,21 @@
+package com.zfire.jiasm.syncdata.plus.controller;
+
+
+import org.springframework.web.bind.annotation.RequestMapping;
+
+import org.springframework.stereotype.Controller;
+
+/**
+ * <p>
+ * 文件库 前端控制器
+ * </p>
+ *
+ * @author gejiang
+ * @since 2023-01-09
+ */
+@Controller
+@RequestMapping("/plus/common-file")
+public class CommonFilePlusTempController {
+
+}
+

+ 21 - 0
src/main/java/com/zfire/jiasm/syncdata/plus/controller/CompanyCaAuthPlusTempController.java

@@ -0,0 +1,21 @@
+package com.zfire.jiasm.syncdata.plus.controller;
+
+
+import org.springframework.web.bind.annotation.RequestMapping;
+
+import org.springframework.stereotype.Controller;
+
+/**
+ * <p>
+ *  前端控制器
+ * </p>
+ *
+ * @author gejiang
+ * @since 2023-01-09
+ */
+@Controller
+@RequestMapping("/plus/company-ca-auth")
+public class CompanyCaAuthPlusTempController {
+
+}
+

+ 21 - 0
src/main/java/com/zfire/jiasm/syncdata/plus/controller/CompanyRecordManagePlusTempController.java

@@ -0,0 +1,21 @@
+package com.zfire.jiasm.syncdata.plus.controller;
+
+
+import org.springframework.web.bind.annotation.RequestMapping;
+
+import org.springframework.stereotype.Controller;
+
+/**
+ * <p>
+ *  前端控制器
+ * </p>
+ *
+ * @author gejiang
+ * @since 2023-01-09
+ */
+@Controller
+@RequestMapping("/plus/company-record-manage")
+public class CompanyRecordManagePlusTempController {
+
+}
+

+ 21 - 0
src/main/java/com/zfire/jiasm/syncdata/plus/controller/ContractTemplatePlusTempController.java

@@ -0,0 +1,21 @@
+package com.zfire.jiasm.syncdata.plus.controller;
+
+
+import org.springframework.web.bind.annotation.RequestMapping;
+
+import org.springframework.stereotype.Controller;
+
+/**
+ * <p>
+ *  前端控制器
+ * </p>
+ *
+ * @author gejiang
+ * @since 2023-01-09
+ */
+@Controller
+@RequestMapping("/plus/contract-template")
+public class ContractTemplatePlusTempController {
+
+}
+

+ 21 - 0
src/main/java/com/zfire/jiasm/syncdata/plus/controller/CustomerInformationCategoryPlusTempController.java

@@ -0,0 +1,21 @@
+package com.zfire.jiasm.syncdata.plus.controller;
+
+
+import org.springframework.web.bind.annotation.RequestMapping;
+
+import org.springframework.stereotype.Controller;
+
+/**
+ * <p>
+ *  前端控制器
+ * </p>
+ *
+ * @author gejiang
+ * @since 2023-01-09
+ */
+@Controller
+@RequestMapping("/plus/customer-information-category")
+public class CustomerInformationCategoryPlusTempController {
+
+}
+

+ 21 - 0
src/main/java/com/zfire/jiasm/syncdata/plus/controller/CustomerInformationPlusTempController.java

@@ -0,0 +1,21 @@
+package com.zfire.jiasm.syncdata.plus.controller;
+
+
+import org.springframework.web.bind.annotation.RequestMapping;
+
+import org.springframework.stereotype.Controller;
+
+/**
+ * <p>
+ * 服务商表 前端控制器
+ * </p>
+ *
+ * @author gejiang
+ * @since 2023-01-09
+ */
+@Controller
+@RequestMapping("/plus/customer-information")
+public class CustomerInformationPlusTempController {
+
+}
+

+ 21 - 0
src/main/java/com/zfire/jiasm/syncdata/plus/controller/CustomerInformationWebsitPlusTempController.java

@@ -0,0 +1,21 @@
+package com.zfire.jiasm.syncdata.plus.controller;
+
+
+import org.springframework.web.bind.annotation.RequestMapping;
+
+import org.springframework.stereotype.Controller;
+
+/**
+ * <p>
+ * 商户标识 前端控制器
+ * </p>
+ *
+ * @author gejiang
+ * @since 2023-01-09
+ */
+@Controller
+@RequestMapping("/plus/customer-information-websit")
+public class CustomerInformationWebsitPlusTempController {
+
+}
+

+ 21 - 0
src/main/java/com/zfire/jiasm/syncdata/plus/controller/ImgCarouselManagePlusTempController.java

@@ -0,0 +1,21 @@
+package com.zfire.jiasm.syncdata.plus.controller;
+
+
+import org.springframework.web.bind.annotation.RequestMapping;
+
+import org.springframework.stereotype.Controller;
+
+/**
+ * <p>
+ *  前端控制器
+ * </p>
+ *
+ * @author gejiang
+ * @since 2023-01-09
+ */
+@Controller
+@RequestMapping("/plus/img-carousel-manage")
+public class ImgCarouselManagePlusTempController {
+
+}
+

+ 21 - 0
src/main/java/com/zfire/jiasm/syncdata/plus/controller/InstallChargeConfigPlusTempController.java

@@ -0,0 +1,21 @@
+package com.zfire.jiasm.syncdata.plus.controller;
+
+
+import org.springframework.web.bind.annotation.RequestMapping;
+
+import org.springframework.stereotype.Controller;
+
+/**
+ * <p>
+ * 安装收费标准配置 前端控制器
+ * </p>
+ *
+ * @author gejiang
+ * @since 2023-01-09
+ */
+@Controller
+@RequestMapping("/plus/install-charge-config")
+public class InstallChargeConfigPlusTempController {
+
+}
+

+ 21 - 0
src/main/java/com/zfire/jiasm/syncdata/plus/controller/InsureAgreePlusTempController.java

@@ -0,0 +1,21 @@
+package com.zfire.jiasm.syncdata.plus.controller;
+
+
+import org.springframework.web.bind.annotation.RequestMapping;
+
+import org.springframework.stereotype.Controller;
+
+/**
+ * <p>
+ * 保障协议 前端控制器
+ * </p>
+ *
+ * @author gejiang
+ * @since 2023-01-09
+ */
+@Controller
+@RequestMapping("/plus/insure-agree")
+public class InsureAgreePlusTempController {
+
+}
+

+ 21 - 0
src/main/java/com/zfire/jiasm/syncdata/plus/controller/InsureEmailPlusTempController.java

@@ -0,0 +1,21 @@
+package com.zfire.jiasm.syncdata.plus.controller;
+
+
+import org.springframework.web.bind.annotation.RequestMapping;
+
+import org.springframework.stereotype.Controller;
+
+/**
+ * <p>
+ * 保险邮箱配置 前端控制器
+ * </p>
+ *
+ * @author gejiang
+ * @since 2023-01-09
+ */
+@Controller
+@RequestMapping("/plus/insure-email")
+public class InsureEmailPlusTempController {
+
+}
+

+ 21 - 0
src/main/java/com/zfire/jiasm/syncdata/plus/controller/InsureEmailRecordPlusTempController.java

@@ -0,0 +1,21 @@
+package com.zfire.jiasm.syncdata.plus.controller;
+
+
+import org.springframework.web.bind.annotation.RequestMapping;
+
+import org.springframework.stereotype.Controller;
+
+/**
+ * <p>
+ *  前端控制器
+ * </p>
+ *
+ * @author gejiang
+ * @since 2023-01-09
+ */
+@Controller
+@RequestMapping("/plus/insure-email-record")
+public class InsureEmailRecordPlusTempController {
+
+}
+

+ 21 - 0
src/main/java/com/zfire/jiasm/syncdata/plus/controller/InsurePlusTempController.java

@@ -0,0 +1,21 @@
+package com.zfire.jiasm.syncdata.plus.controller;
+
+
+import org.springframework.web.bind.annotation.RequestMapping;
+
+import org.springframework.stereotype.Controller;
+
+/**
+ * <p>
+ * 保险合同 前端控制器
+ * </p>
+ *
+ * @author gejiang
+ * @since 2023-01-09
+ */
+@Controller
+@RequestMapping("/plus/insure")
+public class InsurePlusTempController {
+
+}
+

+ 21 - 0
src/main/java/com/zfire/jiasm/syncdata/plus/controller/InsureRangePlusTempController.java

@@ -0,0 +1,21 @@
+package com.zfire.jiasm.syncdata.plus.controller;
+
+
+import org.springframework.web.bind.annotation.RequestMapping;
+
+import org.springframework.stereotype.Controller;
+
+/**
+ * <p>
+ * 保障范围 前端控制器
+ * </p>
+ *
+ * @author gejiang
+ * @since 2023-01-09
+ */
+@Controller
+@RequestMapping("/plus/insure-range")
+public class InsureRangePlusTempController {
+
+}
+

+ 21 - 0
src/main/java/com/zfire/jiasm/syncdata/plus/controller/InsureWorkerCommercialFilePlusTempController.java

@@ -0,0 +1,21 @@
+package com.zfire.jiasm.syncdata.plus.controller;
+
+
+import org.springframework.web.bind.annotation.RequestMapping;
+
+import org.springframework.stereotype.Controller;
+
+/**
+ * <p>
+ *  前端控制器
+ * </p>
+ *
+ * @author gejiang
+ * @since 2023-01-09
+ */
+@Controller
+@RequestMapping("/plus/insure-worker-commercial-file")
+public class InsureWorkerCommercialFilePlusTempController {
+
+}
+

+ 21 - 0
src/main/java/com/zfire/jiasm/syncdata/plus/controller/InsureWorkerCommercialPlusTempController.java

@@ -0,0 +1,21 @@
+package com.zfire.jiasm.syncdata.plus.controller;
+
+
+import org.springframework.web.bind.annotation.RequestMapping;
+
+import org.springframework.stereotype.Controller;
+
+/**
+ * <p>
+ * 师傅的商用保单 前端控制器
+ * </p>
+ *
+ * @author gejiang
+ * @since 2023-01-09
+ */
+@Controller
+@RequestMapping("/plus/insure-worker-commercial")
+public class InsureWorkerCommercialPlusTempController {
+
+}
+

+ 21 - 0
src/main/java/com/zfire/jiasm/syncdata/plus/controller/InsureWorkerRecordPlusTempController.java

@@ -0,0 +1,21 @@
+package com.zfire.jiasm.syncdata.plus.controller;
+
+
+import org.springframework.web.bind.annotation.RequestMapping;
+
+import org.springframework.stereotype.Controller;
+
+/**
+ * <p>
+ * 工程师保险列表(家用) 前端控制器
+ * </p>
+ *
+ * @author gejiang
+ * @since 2023-01-09
+ */
+@Controller
+@RequestMapping("/plus/insure-worker-record")
+public class InsureWorkerRecordPlusTempController {
+
+}
+

+ 21 - 0
src/main/java/com/zfire/jiasm/syncdata/plus/controller/IntegralDoublePlusTempController.java

@@ -0,0 +1,21 @@
+package com.zfire.jiasm.syncdata.plus.controller;
+
+
+import org.springframework.web.bind.annotation.RequestMapping;
+
+import org.springframework.stereotype.Controller;
+
+/**
+ * <p>
+ * 分值翻倍设置 前端控制器
+ * </p>
+ *
+ * @author gejiang
+ * @since 2023-01-09
+ */
+@Controller
+@RequestMapping("/plus/integral-double")
+public class IntegralDoublePlusTempController {
+
+}
+

+ 21 - 0
src/main/java/com/zfire/jiasm/syncdata/plus/controller/IntegralGradeConfigurePlusTempController.java

@@ -0,0 +1,21 @@
+package com.zfire.jiasm.syncdata.plus.controller;
+
+
+import org.springframework.web.bind.annotation.RequestMapping;
+
+import org.springframework.stereotype.Controller;
+
+/**
+ * <p>
+ * 积分等级配置 前端控制器
+ * </p>
+ *
+ * @author gejiang
+ * @since 2023-01-09
+ */
+@Controller
+@RequestMapping("/plus/integral-grade-configure")
+public class IntegralGradeConfigurePlusTempController {
+
+}
+

+ 21 - 0
src/main/java/com/zfire/jiasm/syncdata/plus/controller/IntegralGradeExplainPlusTempController.java

@@ -0,0 +1,21 @@
+package com.zfire.jiasm.syncdata.plus.controller;
+
+
+import org.springframework.web.bind.annotation.RequestMapping;
+
+import org.springframework.stereotype.Controller;
+
+/**
+ * <p>
+ * 工程师等级说明配置 前端控制器
+ * </p>
+ *
+ * @author gejiang
+ * @since 2023-01-09
+ */
+@Controller
+@RequestMapping("/plus/integral-grade-explain")
+public class IntegralGradeExplainPlusTempController {
+
+}
+

+ 21 - 0
src/main/java/com/zfire/jiasm/syncdata/plus/controller/IntegralGradeSkillPlusTempController.java

@@ -0,0 +1,21 @@
+package com.zfire.jiasm.syncdata.plus.controller;
+
+
+import org.springframework.web.bind.annotation.RequestMapping;
+
+import org.springframework.stereotype.Controller;
+
+/**
+ * <p>
+ * 工程师技能标签 前端控制器
+ * </p>
+ *
+ * @author gejiang
+ * @since 2023-01-09
+ */
+@Controller
+@RequestMapping("/plus/integral-grade-skill")
+public class IntegralGradeSkillPlusTempController {
+
+}
+

+ 21 - 0
src/main/java/com/zfire/jiasm/syncdata/plus/controller/IntegralOffsetPlusTempController.java

@@ -0,0 +1,21 @@
+package com.zfire.jiasm.syncdata.plus.controller;
+
+
+import org.springframework.web.bind.annotation.RequestMapping;
+
+import org.springframework.stereotype.Controller;
+
+/**
+ * <p>
+ * 街道冲单量配置 前端控制器
+ * </p>
+ *
+ * @author gejiang
+ * @since 2023-01-09
+ */
+@Controller
+@RequestMapping("/plus/integral-offset")
+public class IntegralOffsetPlusTempController {
+
+}
+

+ 21 - 0
src/main/java/com/zfire/jiasm/syncdata/plus/controller/IntegralScorePlusTempController.java

@@ -0,0 +1,21 @@
+package com.zfire.jiasm.syncdata.plus.controller;
+
+
+import org.springframework.web.bind.annotation.RequestMapping;
+
+import org.springframework.stereotype.Controller;
+
+/**
+ * <p>
+ * 分值配置 前端控制器
+ * </p>
+ *
+ * @author gejiang
+ * @since 2023-01-09
+ */
+@Controller
+@RequestMapping("/plus/integral-score")
+public class IntegralScorePlusTempController {
+
+}
+

+ 21 - 0
src/main/java/com/zfire/jiasm/syncdata/plus/controller/IntegralSkillLabelPlusTempController.java

@@ -0,0 +1,21 @@
+package com.zfire.jiasm.syncdata.plus.controller;
+
+
+import org.springframework.web.bind.annotation.RequestMapping;
+
+import org.springframework.stereotype.Controller;
+
+/**
+ * <p>
+ * 技能标签 前端控制器
+ * </p>
+ *
+ * @author gejiang
+ * @since 2023-01-09
+ */
+@Controller
+@RequestMapping("/plus/integral-skill-label")
+public class IntegralSkillLabelPlusTempController {
+
+}
+

+ 21 - 0
src/main/java/com/zfire/jiasm/syncdata/plus/controller/IntegralWorkerApplyPlusTempController.java

@@ -0,0 +1,21 @@
+package com.zfire.jiasm.syncdata.plus.controller;
+
+
+import org.springframework.web.bind.annotation.RequestMapping;
+
+import org.springframework.stereotype.Controller;
+
+/**
+ * <p>
+ * 积分申请变动记录 前端控制器
+ * </p>
+ *
+ * @author gejiang
+ * @since 2023-01-09
+ */
+@Controller
+@RequestMapping("/plus/integral-worker-apply")
+public class IntegralWorkerApplyPlusTempController {
+
+}
+

+ 21 - 0
src/main/java/com/zfire/jiasm/syncdata/plus/controller/ItfGreeToFaDownloadTaskPlusTempController.java

@@ -0,0 +1,21 @@
+package com.zfire.jiasm.syncdata.plus.controller;
+
+
+import org.springframework.web.bind.annotation.RequestMapping;
+
+import org.springframework.stereotype.Controller;
+
+/**
+ * <p>
+ * 数据下载规则表 前端控制器
+ * </p>
+ *
+ * @author gejiang
+ * @since 2022-12-26
+ */
+@Controller
+@RequestMapping("/plus/itf-gree-to-fa-download-task")
+public class ItfGreeToFaDownloadTaskPlusTempController {
+
+}
+

+ 21 - 0
src/main/java/com/zfire/jiasm/syncdata/plus/controller/ItfTblAssignGzdmDowloadPlusTempController.java

@@ -0,0 +1,21 @@
+package com.zfire.jiasm.syncdata.plus.controller;
+
+
+import org.springframework.web.bind.annotation.RequestMapping;
+
+import org.springframework.stereotype.Controller;
+
+/**
+ * <p>
+ * 故障现象类别下载记录 前端控制器
+ * </p>
+ *
+ * @author gejiang
+ * @since 2023-01-09
+ */
+@Controller
+@RequestMapping("/plus/itf-tbl-assign-gzdm-dowload")
+public class ItfTblAssignGzdmDowloadPlusTempController {
+
+}
+

+ 21 - 0
src/main/java/com/zfire/jiasm/syncdata/plus/controller/ItfTblAssignXqxlDowloadPlusTempController.java

@@ -0,0 +1,21 @@
+package com.zfire.jiasm.syncdata.plus.controller;
+
+
+import org.springframework.web.bind.annotation.RequestMapping;
+
+import org.springframework.stereotype.Controller;
+
+/**
+ * <p>
+ * 需求小类下载记录 前端控制器
+ * </p>
+ *
+ * @author gejiang
+ * @since 2023-01-09
+ */
+@Controller
+@RequestMapping("/plus/itf-tbl-assign-xqxl-dowload")
+public class ItfTblAssignXqxlDowloadPlusTempController {
+
+}
+

+ 21 - 0
src/main/java/com/zfire/jiasm/syncdata/plus/controller/ItfTblAssignXxlbDowloadPlusTempController.java

@@ -0,0 +1,21 @@
+package com.zfire.jiasm.syncdata.plus.controller;
+
+
+import org.springframework.web.bind.annotation.RequestMapping;
+
+import org.springframework.stereotype.Controller;
+
+/**
+ * <p>
+ * 信息类别 前端控制器
+ * </p>
+ *
+ * @author gejiang
+ * @since 2023-01-09
+ */
+@Controller
+@RequestMapping("/plus/itf-tbl-assign-xxlb-dowload")
+public class ItfTblAssignXxlbDowloadPlusTempController {
+
+}
+

+ 21 - 0
src/main/java/com/zfire/jiasm/syncdata/plus/controller/ItfTblAssignXxlyDowloadPlusTempController.java

@@ -0,0 +1,21 @@
+package com.zfire.jiasm.syncdata.plus.controller;
+
+
+import org.springframework.web.bind.annotation.RequestMapping;
+
+import org.springframework.stereotype.Controller;
+
+/**
+ * <p>
+ * 信息来源 前端控制器
+ * </p>
+ *
+ * @author gejiang
+ * @since 2023-01-09
+ */
+@Controller
+@RequestMapping("/plus/itf-tbl-assign-xxly-dowload")
+public class ItfTblAssignXxlyDowloadPlusTempController {
+
+}
+

+ 21 - 0
src/main/java/com/zfire/jiasm/syncdata/plus/controller/ItfTblAssignXxqdDowloadPlusTempController.java

@@ -0,0 +1,21 @@
+package com.zfire.jiasm.syncdata.plus.controller;
+
+
+import org.springframework.web.bind.annotation.RequestMapping;
+
+import org.springframework.stereotype.Controller;
+
+/**
+ * <p>
+ * 信息渠道 前端控制器
+ * </p>
+ *
+ * @author gejiang
+ * @since 2023-01-09
+ */
+@Controller
+@RequestMapping("/plus/itf-tbl-assign-xxqd-dowload")
+public class ItfTblAssignXxqdDowloadPlusTempController {
+
+}
+

+ 21 - 0
src/main/java/com/zfire/jiasm/syncdata/plus/controller/ItfTblAssignYhsxWxDowloadPlusTempController.java

@@ -0,0 +1,21 @@
+package com.zfire.jiasm.syncdata.plus.controller;
+
+
+import org.springframework.web.bind.annotation.RequestMapping;
+
+import org.springframework.stereotype.Controller;
+
+/**
+ * <p>
+ * 用户属性表 前端控制器
+ * </p>
+ *
+ * @author gejiang
+ * @since 2023-01-09
+ */
+@Controller
+@RequestMapping("/plus/itf-tbl-assign-yhsx-wx-dowload")
+public class ItfTblAssignYhsxWxDowloadPlusTempController {
+
+}
+

+ 21 - 0
src/main/java/com/zfire/jiasm/syncdata/plus/controller/ItfTblAzAssignXslxDowloadPlusTempController.java

@@ -0,0 +1,21 @@
+package com.zfire.jiasm.syncdata.plus.controller;
+
+
+import org.springframework.web.bind.annotation.RequestMapping;
+
+import org.springframework.stereotype.Controller;
+
+/**
+ * <p>
+ * (新)安装销售类型表下载记录 前端控制器
+ * </p>
+ *
+ * @author gejiang
+ * @since 2023-01-09
+ */
+@Controller
+@RequestMapping("/plus/itf-tbl-az-assign-xslx-dowload")
+public class ItfTblAzAssignXslxDowloadPlusTempController {
+
+}
+

+ 21 - 0
src/main/java/com/zfire/jiasm/syncdata/plus/controller/ItfTblCityDownloadPlusTempController.java

@@ -0,0 +1,21 @@
+package com.zfire.jiasm.syncdata.plus.controller;
+
+
+import org.springframework.web.bind.annotation.RequestMapping;
+
+import org.springframework.stereotype.Controller;
+
+/**
+ * <p>
+ * 市信息下载记录 前端控制器
+ * </p>
+ *
+ * @author gejiang
+ * @since 2023-01-09
+ */
+@Controller
+@RequestMapping("/plus/itf-tbl-city-download")
+public class ItfTblCityDownloadPlusTempController {
+
+}
+

+ 21 - 0
src/main/java/com/zfire/jiasm/syncdata/plus/controller/ItfTblCityJdxzDownloadPlusTempController.java

@@ -0,0 +1,21 @@
+package com.zfire.jiasm.syncdata.plus.controller;
+
+
+import org.springframework.web.bind.annotation.RequestMapping;
+
+import org.springframework.stereotype.Controller;
+
+/**
+ * <p>
+ * 乡镇信息下载记录 前端控制器
+ * </p>
+ *
+ * @author gejiang
+ * @since 2023-01-09
+ */
+@Controller
+@RequestMapping("/plus/itf-tbl-city-jdxz-download")
+public class ItfTblCityJdxzDownloadPlusTempController {
+
+}
+

+ 21 - 0
src/main/java/com/zfire/jiasm/syncdata/plus/controller/ItfTblCountyDownloadPlusTempController.java

@@ -0,0 +1,21 @@
+package com.zfire.jiasm.syncdata.plus.controller;
+
+
+import org.springframework.web.bind.annotation.RequestMapping;
+
+import org.springframework.stereotype.Controller;
+
+/**
+ * <p>
+ * 区信息下载记录 前端控制器
+ * </p>
+ *
+ * @author gejiang
+ * @since 2023-01-09
+ */
+@Controller
+@RequestMapping("/plus/itf-tbl-county-download")
+public class ItfTblCountyDownloadPlusTempController {
+
+}
+

+ 21 - 0
src/main/java/com/zfire/jiasm/syncdata/plus/controller/ItfTblProvinceDownloadPlusTempController.java

@@ -0,0 +1,21 @@
+package com.zfire.jiasm.syncdata.plus.controller;
+
+
+import org.springframework.web.bind.annotation.RequestMapping;
+
+import org.springframework.stereotype.Controller;
+
+/**
+ * <p>
+ * 省份信息下载记录 前端控制器
+ * </p>
+ *
+ * @author gejiang
+ * @since 2023-01-09
+ */
+@Controller
+@RequestMapping("/plus/itf-tbl-province-download")
+public class ItfTblProvinceDownloadPlusTempController {
+
+}
+

+ 21 - 0
src/main/java/com/zfire/jiasm/syncdata/plus/controller/ItfTblSplbDaleiDownloadPlusTempController.java

@@ -0,0 +1,21 @@
+package com.zfire.jiasm.syncdata.plus.controller;
+
+
+import org.springframework.web.bind.annotation.RequestMapping;
+
+import org.springframework.stereotype.Controller;
+
+/**
+ * <p>
+ * 格力商品大类 前端控制器
+ * </p>
+ *
+ * @author gejiang
+ * @since 2023-01-09
+ */
+@Controller
+@RequestMapping("/plus/itf-tbl-splb-dalei-download")
+public class ItfTblSplbDaleiDownloadPlusTempController {
+
+}
+

+ 21 - 0
src/main/java/com/zfire/jiasm/syncdata/plus/controller/ItfTblSplbJixinDownloadPlusTempController.java

@@ -0,0 +1,21 @@
+package com.zfire.jiasm.syncdata.plus.controller;
+
+
+import org.springframework.web.bind.annotation.RequestMapping;
+
+import org.springframework.stereotype.Controller;
+
+/**
+ * <p>
+ * 机型表 前端控制器
+ * </p>
+ *
+ * @author gejiang
+ * @since 2023-01-09
+ */
+@Controller
+@RequestMapping("/plus/itf-tbl-splb-jixin-download")
+public class ItfTblSplbJixinDownloadPlusTempController {
+
+}
+

+ 21 - 0
src/main/java/com/zfire/jiasm/syncdata/plus/controller/ItfTblSplbXiaoleiDownloadPlusTempController.java

@@ -0,0 +1,21 @@
+package com.zfire.jiasm.syncdata.plus.controller;
+
+
+import org.springframework.web.bind.annotation.RequestMapping;
+
+import org.springframework.stereotype.Controller;
+
+/**
+ * <p>
+ * 格力商品小类 前端控制器
+ * </p>
+ *
+ * @author gejiang
+ * @since 2023-01-09
+ */
+@Controller
+@RequestMapping("/plus/itf-tbl-splb-xiaolei-download")
+public class ItfTblSplbXiaoleiDownloadPlusTempController {
+
+}
+

+ 21 - 0
src/main/java/com/zfire/jiasm/syncdata/plus/controller/ItfTblSplbXilieDownloadPlusTempController.java

@@ -0,0 +1,21 @@
+package com.zfire.jiasm.syncdata.plus.controller;
+
+
+import org.springframework.web.bind.annotation.RequestMapping;
+
+import org.springframework.stereotype.Controller;
+
+/**
+ * <p>
+ * 格力系列表 前端控制器
+ * </p>
+ *
+ * @author gejiang
+ * @since 2023-01-09
+ */
+@Controller
+@RequestMapping("/plus/itf-tbl-splb-xilie-download")
+public class ItfTblSplbXilieDownloadPlusTempController {
+
+}
+

+ 21 - 0
src/main/java/com/zfire/jiasm/syncdata/plus/controller/ItfTblWangdianWxgDownloadPlusTempController.java

@@ -0,0 +1,21 @@
+package com.zfire.jiasm.syncdata.plus.controller;
+
+
+import org.springframework.web.bind.annotation.RequestMapping;
+
+import org.springframework.stereotype.Controller;
+
+/**
+ * <p>
+ * 服务人员 前端控制器
+ * </p>
+ *
+ * @author gejiang
+ * @since 2023-01-09
+ */
+@Controller
+@RequestMapping("/plus/itf-tbl-wangdian-wxg-download")
+public class ItfTblWangdianWxgDownloadPlusTempController {
+
+}
+

+ 21 - 0
src/main/java/com/zfire/jiasm/syncdata/plus/controller/ItfTblXinWangdianDownloadPlusTempController.java

@@ -0,0 +1,21 @@
+package com.zfire.jiasm.syncdata.plus.controller;
+
+
+import org.springframework.web.bind.annotation.RequestMapping;
+
+import org.springframework.stereotype.Controller;
+
+/**
+ * <p>
+ * 网点基础下载记录 前端控制器
+ * </p>
+ *
+ * @author gejiang
+ * @since 2023-01-09
+ */
+@Controller
+@RequestMapping("/plus/itf-tbl-xin-wangdian-download")
+public class ItfTblXinWangdianDownloadPlusTempController {
+
+}
+

+ 21 - 0
src/main/java/com/zfire/jiasm/syncdata/plus/controller/ItfTblYhsxViprankDowloadPlusTempController.java

@@ -0,0 +1,21 @@
+package com.zfire.jiasm.syncdata.plus.controller;
+
+
+import org.springframework.web.bind.annotation.RequestMapping;
+
+import org.springframework.stereotype.Controller;
+
+/**
+ * <p>
+ * 用户属性vip等级表 前端控制器
+ * </p>
+ *
+ * @author gejiang
+ * @since 2023-01-09
+ */
+@Controller
+@RequestMapping("/plus/itf-tbl-yhsx-viprank-dowload")
+public class ItfTblYhsxViprankDowloadPlusTempController {
+
+}
+

+ 21 - 0
src/main/java/com/zfire/jiasm/syncdata/plus/controller/LabelCurrencyPlusTempController.java

@@ -0,0 +1,21 @@
+package com.zfire.jiasm.syncdata.plus.controller;
+
+
+import org.springframework.web.bind.annotation.RequestMapping;
+
+import org.springframework.stereotype.Controller;
+
+/**
+ * <p>
+ *  前端控制器
+ * </p>
+ *
+ * @author gejiang
+ * @since 2023-01-09
+ */
+@Controller
+@RequestMapping("/plus/label-currency")
+public class LabelCurrencyPlusTempController {
+
+}
+

+ 21 - 0
src/main/java/com/zfire/jiasm/syncdata/plus/controller/LabelPlusTempController.java

@@ -0,0 +1,21 @@
+package com.zfire.jiasm.syncdata.plus.controller;
+
+
+import org.springframework.web.bind.annotation.RequestMapping;
+
+import org.springframework.stereotype.Controller;
+
+/**
+ * <p>
+ *  前端控制器
+ * </p>
+ *
+ * @author gejiang
+ * @since 2023-01-09
+ */
+@Controller
+@RequestMapping("/plus/label")
+public class LabelPlusTempController {
+
+}
+

+ 21 - 0
src/main/java/com/zfire/jiasm/syncdata/plus/controller/LbsAmapPlusTempController.java

@@ -0,0 +1,21 @@
+package com.zfire.jiasm.syncdata.plus.controller;
+
+
+import org.springframework.web.bind.annotation.RequestMapping;
+
+import org.springframework.stereotype.Controller;
+
+/**
+ * <p>
+ *  前端控制器
+ * </p>
+ *
+ * @author gejiang
+ * @since 2023-01-09
+ */
+@Controller
+@RequestMapping("/plus/lbs-amap")
+public class LbsAmapPlusTempController {
+
+}
+

+ 21 - 0
src/main/java/com/zfire/jiasm/syncdata/plus/controller/NoticePlusTempController.java

@@ -0,0 +1,21 @@
+package com.zfire.jiasm.syncdata.plus.controller;
+
+
+import org.springframework.web.bind.annotation.RequestMapping;
+
+import org.springframework.stereotype.Controller;
+
+/**
+ * <p>
+ * 通知消息表 前端控制器
+ * </p>
+ *
+ * @author gejiang
+ * @since 2023-01-09
+ */
+@Controller
+@RequestMapping("/plus/notice")
+public class NoticePlusTempController {
+
+}
+

+ 21 - 0
src/main/java/com/zfire/jiasm/syncdata/plus/controller/NoticeRecordPlusTempController.java

@@ -0,0 +1,21 @@
+package com.zfire.jiasm.syncdata.plus.controller;
+
+
+import org.springframework.web.bind.annotation.RequestMapping;
+
+import org.springframework.stereotype.Controller;
+
+/**
+ * <p>
+ * 通知消息表 前端控制器
+ * </p>
+ *
+ * @author gejiang
+ * @since 2023-01-09
+ */
+@Controller
+@RequestMapping("/plus/notice-record")
+public class NoticeRecordPlusTempController {
+
+}
+

Některé soubory nejsou zobrazeny, neboť je v těchto rozdílových datech změněno mnoho souborů