智慧保安后台管理-外网
Administrator
2022-06-16 8b375fe00a241b3a769b82fe3dac8d1c9dce8a02
src/main/java/org/springblade/modules/quartz/task/Task.java
@@ -1,23 +1,41 @@
package org.springblade.modules.quartz.task;
import com.alibaba.fastjson.JSON;
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import org.apache.commons.lang3.StringUtils;
import org.apache.commons.net.ftp.FTP;
import org.apache.commons.net.ftp.FTPClient;
import org.apache.commons.net.ftp.FTPFile;
import org.apache.commons.net.ftp.FTPReply;
import org.springblade.common.utils.DesensitizedUtil;
import org.springblade.modules.FTP.*;
import org.springblade.modules.exam.entity.ExamAnswerRecord;
import org.springblade.modules.exam.entity.ExamScore;
import org.springblade.modules.exam.service.ExamAnswerRecordService;
import org.springblade.modules.exam.service.ExamScoreService;
import org.springblade.modules.log.entity.HandlerLog;
import org.springblade.modules.log.service.HandlerLogService;
import org.springblade.modules.system.entity.User;
import org.springblade.modules.system.service.IUserService;
import org.springblade.modules.system.service.MyAsyncService;
import org.springblade.modules.training.entity.TrainingRegistration;
import org.springblade.modules.training.service.TrainingRegistrationService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.scheduling.annotation.Scheduled;
import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.scheduling.annotation.Async;
import org.springframework.stereotype.Component;
import org.springframework.web.bind.annotation.GetMapping;
import java.io.IOException;
import java.io.InputStream;
import java.lang.reflect.Array;
import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.*;
import java.util.concurrent.atomic.AtomicInteger;
import static org.springblade.common.config.FtpConfig.*;
import static org.springblade.common.config.FtpConfig.ftpPath;
import static org.springblade.modules.FTP.DataHandler.handlerUserInfo;
/**
 * 定时任务
@@ -29,6 +47,26 @@
   @Autowired
   private TrainingRegistrationService trainingRegistrationService;
   @Autowired
   private IUserService userService;
   @Autowired
   private HandlerLogService handlerLogService;
   @Autowired
   private RedisTemplate redisTemplate;
   @Autowired
   private MyAsyncService myAsyncService;
   @Autowired
   private ExamAnswerRecordService examAnswerRecordService;
   @Autowired
   private ExamScoreService examScoreService;
   public void testTask(){
        System.out.println("测试定时任务执行-----------------");
@@ -56,15 +94,20 @@
   }
   /**
    * 读取内外推送的文件,每30秒读取一次
    * 读取内外推送的sql文件
    * @return
    */
//   @Scheduled(cron = "*/30 * * * * ?")
   public boolean readFile() {
      FTPClient ftp = new FTPClient();
      String fileName = null;
      try {
         //设置传输超时时间为60秒
         ftp.setDataTimeout(10000);
         //连接超时为60秒
         ftp.setConnectTimeout(10000);
         //连接
         ftp.connect(ftpHost, ftpPort);
         System.out.println("定时读取内网返回的 sql 文件!"+new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(new Date()));
         // 登陆
         ftp.login(ftpUserNameIn, ftpPasswordIn);
         // 检验登陆操作的返回码是否正确
@@ -73,7 +116,115 @@
            return false;
         }
         ftp.enterLocalActiveMode();
         //主动模式
//         ftp.enterLocalActiveMode();
         // 设置文件类型为二进制,与ASCII有区别
         ftp.setFileType(FTP.BINARY_FILE_TYPE);
         // 设置编码格式
         ftp.setControlEncoding("GBK");
         // 检验文件是否存在
         ftp.changeWorkingDirectory(ftpPath);
         // Use passive mode as default 被动模式
         ftp.enterLocalPassiveMode();
         FTPFile[] files = ftp.listFiles();
         if (files.length==0){
            return false;
         }
         else {
            for (int i = files.length-1; i >=0 ; i--) {
               fileName = files[i].getName();
               String substring1 = fileName.substring(0, 2);
               System.out.println(new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(new Date())+":读取到文件 = " + fileName);
               if (substring1.contains("nq")) {
                  //把文件下载到本地
                  long l = System.currentTimeMillis();
                  FtpUtil.downloadFtpFile(ftpHost, ftpUserNameIn, ftpPasswordIn, ftpPort, ftpPath, localPath, fileName);
                  long x = System.currentTimeMillis();
                  System.out.println("下载文件耗时 = " + (x-l)+" 毫秒");
                  //
                  String s = OutJson.TestJson(fileName);
                  //sql语句
                  String sql = OutJson.stringReplace(s);
                  //以逗号分割
                  String[] split = sql.split(";");
                  for (String sqls : split) {
                     //判断是否是新增,删除,修改
                     String substring = sqls.substring(0, 2);
                     //新增
                     if (substring.equals("in")) {
                        //运行sql语句
                        MysqlCenlint.inster(sqls);
                     }
                     //修改
                     else if (substring.equals("up")) {
                        MysqlCenlint.update(sqls);
                     }
                     //删除
                     else {
                        MysqlCenlint.delete(sqls);
                     }
                  }
                  //删除本地服务器文件
                  MysqlCenlint.deletess(fileName);
                  //删除 ftp 服务器文件
//                  ftp.dele(fileName);
                  FtpUtil.deleteFile(ftpHost, ftpPort, ftpUserNameIn, ftpPasswordIn, ftpPath, fileName);
                  System.out.println(new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(new Date())+":成功删除ftp文件 = " + fileName);
               }
            }
            //关闭流
//            ftp.completePendingCommand();
//            ftp.logout();
         }
      } catch (Exception e) {
         //发生异常删除文件,有可能是空文件
         FtpUtil.deleteFile(ftpHost, ftpPort, ftpUserNameIn, ftpPasswordIn, ftpPath, fileName);
         e.printStackTrace();
      } finally {
         try {
            ftp.logout();
         } catch (IOException e) {
            e.printStackTrace();
         }
         if (ftp.isConnected()) {
            try {
               ftp.disconnect();
            } catch (IOException e) {
               e.printStackTrace();
            }
         }
      }
      return false;
   }
   /**
    * 读取内外推送的保安员单个新增文件
    * @return
    */
   public boolean readOneSecurityFile() {
      FTPClient ftp = new FTPClient();
      try {
         //设置传输超时时间为60秒
         ftp.setDataTimeout(10000);
         //连接超时为60秒
         ftp.setConnectTimeout(10000);
         //连接
         ftp.connect(ftpHost, ftpPort);
         System.out.println("定时任务:处理单个用户新增文件,ftp 连接成功!"+new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(new Date()));
         // 登陆
         ftp.login(ftpUserNameIn, ftpPasswordIn);
         // 检验登陆操作的返回码是否正确
         if (!FTPReply.isPositiveCompletion(ftp.getReplyCode())) {
            ftp.disconnect();
            return false;
         }
//         ftp.enterLocalActiveMode();
         // 设置文件类型为二进制,与ASCII有区别
         ftp.setFileType(FTP.BINARY_FILE_TYPE);
@@ -88,59 +239,67 @@
         ftp.enterLocalPassiveMode();
         FTPFile[] files = ftp.listFiles();
         //文件个数大于10个时开始处理
//         if (files.length==0 || files.length<10){
         if (files.length==0){
//            ftp.logout();
            return false;
         }
         else {
            for (FTPFile file : files) {
               String fileName = file.getName();
               InputStream is = ftp.retrieveFileStream(new String(fileName.getBytes("GBK"), FTP.DEFAULT_CONTROL_ENCODING));
               if (null == is) {
                  return false;
               } else {
                  String substring1 = fileName.substring(0, 4);
                  if (substring1.equals("nsql")) {
                     //把文件下载到本地
                     FtpUtil.downloadFtpFile(ftpHost, ftpUserNameIn, ftpPasswordIn, ftpPort, ftpPath, localPath, fileName);
                     //
                     String s = OutJson.TestJson(fileName);
                     //sql语句
                     String sql = OutJson.stringReplace(s);
                     String[] split = sql.split(";");//以逗号分割
                     for (String sqls : split) {
                        //判断是否是新增,删除,修改
                        String substring = sqls.substring(0, 2);
                        //新增
                        if (substring.equals("in")) {
                           //运行sql语句
                           MysqlCenlint.inster(sqls);
                        }
                        //修改
                        else if (substring.equals("up")) {
                           MysqlCenlint.update(sqls);
                        }
                        //删除
                        else {
                           MysqlCenlint.delete(sqls);
                        }
                     }
                     //删除本地服务器文件
                     MysqlCenlint.deletess(fileName);
                     //删除 ftp 服务器文件
                     FtpUtil.deleteFile(ftpHost, ftpPort, ftpUserNameIn, ftpPasswordIn, ftpPath, fileName);
            for (int i = files.length-1; i >=0 ; i--) {
               String fileName = files[i].getName();
               String substring = fileName.substring(0, 2);
               System.out.println(new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(new Date())+":读取到文件 = " + fileName);
               if (substring.contains("ni")) {
//                  InputStream is = ftp.retrieveFileStream(new String(fileName.getBytes("GBK"), FTP.DEFAULT_CONTROL_ENCODING));
                  //把文件下载到本地
                  long l = System.currentTimeMillis();
                  FtpUtil.downloadFtpFile(ftpHost, ftpUserNameIn, ftpPasswordIn, ftpPort, ftpPath, localPath, fileName);
                  long x = System.currentTimeMillis();
                  System.out.println("下载文件耗时 = " + (x-l)+" 毫秒");
                  //数据转换
                  String json = OutJson.TestJson(fileName);
                  //取出map
                  Map<String,Object> map = JSON.parseObject(json, Map.class);
                  //取出 key/uuid,取出结果
                  String uuid = null;
                  Result result = new Result();
                  for (Map.Entry entry : map.entrySet()) {
                     uuid = entry.getKey().toString();
                     Object value = entry.getValue();
                     //转换
                     result = JSON.parseObject(value.toString(), Result.class);
                  }
                  //关闭流
                  is.close();
                  ftp.completePendingCommand();
                  //删除本地文件
                  MysqlCenlint.deletess(fileName);
                  //删除 ftp 文件
                  FtpUtil.deleteFile(ftpHost, ftpPort, ftpUserNameIn, ftpPasswordIn, ftpPath, fileName);
                  System.out.println(new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(new Date())+":成功删除ftp文件 = " + fileName);
                  if (null!=result) {
                     try {
                        userInfoHandler(uuid, result);
                     }catch (Exception e) {
                        //异步用户处理逻辑
                        e.printStackTrace();
                     }
                  }
               }
               return true;
            }
            //关闭流
//            ftp.completePendingCommand();
//            ftp.logout();
         }
      } catch (Exception e) {
         System.out.println("ftp连接失败");
         e.printStackTrace();
      } finally {
         if (ftp != null) {
         try {
            ftp.logout();
         } catch (IOException e) {
            e.printStackTrace();
         }
         if (ftp.isConnected()) {
            try {
               ftp.disconnect();
            } catch (IOException e) {
@@ -151,102 +310,768 @@
      return false;
   }
//   /**
//    * 读取文件(用户对象)单用户新增
//    * @return
//    */
//   public Result readFile() {
//      String uuid = "123-456";
//      //创建 ftp 对象
//      FTPClient ftp = new FTPClient();
//      boolean flag = false;
//      try {
//         //连接
//         ftp.connect(ftpHost, ftpPort);
//
//         // 登陆
//         ftp.login(ftpUserNameIn, ftpPasswordIn);
//         // 检验登陆操作的返回码是否正确
//         if (!FTPReply.isPositiveCompletion(ftp.getReplyCode())) {
//            ftp.disconnect();
//            return new Result(400,null,"ftp 连接失败",null);
//         }
//
   /**
    * 读取内外推送的保安员批量导入文件
    * @return
    */
   public boolean readSecurityListFile() {
      FTPClient ftp = new FTPClient();
      try {
         //设置传输超时时间为60秒
         ftp.setDataTimeout(10000);
         //连接超时为60秒
         ftp.setConnectTimeout(10000);
         //连接
         ftp.connect(ftpHost, ftpPort);
         System.out.println("定时任务:读取内外推送的保安员批量导入文件!"+new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(new Date()));
         // 登陆
         ftp.login(ftpUserNameIn, ftpPasswordIn);
         // 检验登陆操作的返回码是否正确
         if (!FTPReply.isPositiveCompletion(ftp.getReplyCode())) {
            ftp.disconnect();
            return false;
         }
//         ftp.enterLocalActiveMode();
//
//         // 设置文件类型为二进制,与ASCII有区别
//         ftp.setFileType(FTP.BINARY_FILE_TYPE);
//
//         // 设置编码格式
//         ftp.setControlEncoding("GBK");
//         // 检验文件是否存在
//         boolean ftpFile = ftp.changeWorkingDirectory(ftpPath);
//         System.out.println("检验文件是否存在 = " + ftpFile);
//
//         // Use passive mode as default
//         ftp.enterLocalPassiveMode();
//
//         FTPFile[] files = ftp.listFiles();
//         System.out.println("files = " + files);
//         System.out.println("开始读取内网回传消息");
//         if (files.length==0){
//            System.out.println("未读取到文件");
//            return new Result(400,null,"未读取到文件",null);
//         } else {
//            System.out.println("-----有读取到文件--------");
//            for (FTPFile file : files){
//               String fileName = file.getName();
//               System.out.println("fileName = " + fileName);
//               InputStream is = ftp.retrieveFileStream(new String(fileName.getBytes("GBK"), FTP.DEFAULT_CONTROL_ENCODING));
//               String substring1 = fileName.substring(0, 1);
//               System.out.println("substring1 = " + substring1);
//               if (substring1.equals("n")){
//                  System.out.println("-------接收到内网回传的文件: " + substring1);
//                  //把文件下载到本地
//                  FtpUtil.downloadFtpFile(ftpHost, ftpUserNameIn, ftpPasswordIn, ftpPort, ftpPath, localPath, fileName);
//                  // 解析数据
//                  String s = OutJson.TestJson(fileName);
//                  //数据处理
//                  Result result = DataHandler.handler(s,uuid);
//                  //删除本地文件
//                  MysqlCenlint.deletess(fileName);
//                  FtpUtil.deleteFile(ftpHost, ftpPort, ftpUserNameIn, ftpPasswordIn, ftpPath, fileName);
//                  is.close();
//                  ftp.completePendingCommand();
//                  if (result.getCode()==200) {
//                     //返回
//                     return new Result(200,null,"新增成功",null);
//                  }
//                  if (result.getCode()==201) {
//                     //返回
//                     return new Result(201,null,"修改成功",null);
//                  }
//                  if (result.getCode()==202) {
//                     //返回
//                     return new Result(202,null,result.getMsg(),null);
//                  }
//                  if (result.getCode()==203) {
//                     //返回
//                     return new Result(203,null,result.getMsg(),null);
//                  }
//               }
//            }
//            System.out.println("未读取到对应的文件");
//            return new Result(400,null,"未读取到对应的文件",null);
//         }
//      } catch (Exception e) {
//         System.out.println("ftp连接失败");
//         e.printStackTrace();
//      } finally {
//         if (ftp != null) {
//            try {
//               ftp.disconnect();
//            } catch (IOException e) {
//               e.printStackTrace();
//            }
//         }
//      }
//      return new Result(400,null,"失败",null);
//   }
         // 设置文件类型为二进制,与ASCII有区别
         ftp.setFileType(FTP.BINARY_FILE_TYPE);
         // 设置编码格式
         ftp.setControlEncoding("GBK");
         // 检验文件是否存在
         ftp.changeWorkingDirectory(ftpPath);
         // Use passive mode as default
         ftp.enterLocalPassiveMode();
         FTPFile[] files = ftp.listFiles();
         //文件个数大于10个时开始处理
         if (files.length==0){
            return false;
         }
         else {
            for (int i = files.length-1; i >=0 ; i--) {
               String fileName = files[i].getName();
               String substring = fileName.substring(0, 2);
               System.out.println(new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(new Date())+":读取到文件 = " + fileName);
               if (substring.contains("nl")) {
                  //把文件下载到本地
                  long l = System.currentTimeMillis();
                  FtpUtil.downloadFtpFile(ftpHost, ftpUserNameIn, ftpPasswordIn, ftpPort, ftpPath, localPath, fileName);
                  long x = System.currentTimeMillis();
                  System.out.println("下载文件耗时 = " + (x-l)+" 毫秒");
                  //数据转换
                  String json = OutJson.TestJson(fileName);
                  //取出map
                  Map<String,Object> map = JSON.parseObject(json, Map.class);
                  //取出 key/uuid,取出结果
                  String uuid = null;
                  Result result = new Result();
                  for (Map.Entry entry : map.entrySet()) {
                     Object value = entry.getValue();
                     //转换
                     result = JSON.parseObject(value.toString(), Result.class);
                  }
                  if (null!=result) {
                     try {
                        userListInfoHandler(result);
                     }catch (Exception e) {
                        //异步用户处理逻辑
                        e.printStackTrace();
                     }
                  }
                  //删除本地文件
                  MysqlCenlint.deletess(fileName);
                  //删除 ftp 文件
                  FtpUtil.deleteFile(ftpHost, ftpPort, ftpUserNameIn, ftpPasswordIn, ftpPath, fileName);
                  System.out.println(new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(new Date())+":成功删除ftp文件 = " + fileName);
               }
            }
            //关闭流
//            ftp.completePendingCommand();
//            ftp.logout();
         }
      } catch (Exception e) {
         System.out.println("ftp连接失败");
         e.printStackTrace();
      } finally {
         try {
            ftp.logout();
         } catch (IOException e) {
            e.printStackTrace();
         }
         if (ftp.isConnected()) {
            try {
               ftp.disconnect();
            } catch (IOException e) {
               e.printStackTrace();
            }
         }
      }
      return false;
   }
   /**
    * 读取内外推送的管理员导入的保安员返回文件(带保安证编号)
    * @return
    */
   public boolean readPaperListFile() {
      FTPClient ftp = new FTPClient();
      try {
         //设置传输超时时间为60秒
         ftp.setDataTimeout(10000);
         //连接超时为60秒
         ftp.setConnectTimeout(10000);
         //连接
         ftp.connect(ftpHost, ftpPort);
         System.out.println("定时任务:读取内外推送的管理员导入的保安员返回文件(带保安证编号)!"+new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(new Date()));
         // 登陆
         ftp.login(ftpUserNameIn, ftpPasswordIn);
         // 检验登陆操作的返回码是否正确
         if (!FTPReply.isPositiveCompletion(ftp.getReplyCode())) {
            ftp.disconnect();
            return false;
         }
         // 设置文件类型为二进制,与ASCII有区别
         ftp.setFileType(FTP.BINARY_FILE_TYPE);
         // 设置编码格式
         ftp.setControlEncoding("GBK");
         // 检验文件是否存在
         ftp.changeWorkingDirectory(ftpPath);
         // Use passive mode as default
         ftp.enterLocalPassiveMode();
         FTPFile[] files = ftp.listFiles();
         //文件处理
         if (files.length==0){
            return false;
         }
         else {
            for (int i = files.length-1; i >=0 ; i--) {
               String fileName = files[i].getName();
               String substring = fileName.substring(0, 2);
               System.out.println(new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(new Date())+":读取到文件 = " + fileName);
               if (substring.contains("np")) {
                  //把文件下载到本地
                  long l = System.currentTimeMillis();
                  FtpUtil.downloadFtpFile(ftpHost, ftpUserNameIn, ftpPasswordIn, ftpPort, ftpPath, localPath, fileName);
                  long x = System.currentTimeMillis();
                  System.out.println("下载文件耗时 = " + (x-l)+" 毫秒");
                  //数据转换
                  String json = OutJson.TestJson(fileName);
                  //取出map
                  Map<String,Object> map = JSON.parseObject(json, Map.class);
                  Result result = new Result();
                  for (Map.Entry entry : map.entrySet()) {
                     Object value = entry.getValue();
                     //转换
                     result = JSON.parseObject(value.toString(), Result.class);
                  }
                  if (null!=result) {
                     try {
                        paperListInfoHandler(result);
                     }catch (Exception e) {
                        //异步用户处理逻辑
                        e.printStackTrace();
                     }
                  }
                  //删除本地文件
                  MysqlCenlint.deletess(fileName);
                  //删除 ftp 文件
                  FtpUtil.deleteFile(ftpHost, ftpPort, ftpUserNameIn, ftpPasswordIn, ftpPath, fileName);
                  System.out.println(new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(new Date())+":成功删除ftp文件 = " + fileName);
               }
            }
         }
      } catch (Exception e) {
         System.out.println("ftp连接失败");
         e.printStackTrace();
      } finally {
         if (ftp.isConnected()) {
            try {
               ftp.logout();
            } catch (IOException e) {
               e.printStackTrace();
            }
            try {
               ftp.disconnect();
            } catch (IOException e) {
               e.printStackTrace();
            }
         }
      }
      return false;
   }
   /**
    * 用户集合信息处理
    * @param result
    */
   @Async
   public void userListInfoHandler(Result result) {
      //获取 result
      List<Result> data1 = result.getData();
      System.out.println("批量导入数据 = " + data1);
      if (data1.size()>0){
         for (Result result1 : data1) {
            // 取出 Msg ,此 msg 存的对应的 uuid
            String uuid = result1.getMsg();
            //从redis 中获取用户数据
            Object o1 = redisTemplate.opsForValue().get(uuid);
            User user0 = JSON.parseObject(o1.toString(), User.class);
            // 从redis 中获取对应的用户信息,脱敏处理过
            User user = handlerUserInfo(uuid);
            if (result1.getCode()==200){
               user.setId(result1.getUserId());
               boolean save = userService.save(user);
               if (save){
                  //数据异步同步到群防群控
                  myAsyncService.qfqkUserSave(user);
               }
            }
            //更新
            if (result1.getCode()==201){
               //先查询当前库是否有改用户?
               User user1 = userService.getById(result1.getUserId());
               if (null!=user1) {
                  //存在,更新
                  user.setId(result1.getUserId());
                  user.setCreateTime(null);
                  boolean update = userService.updateById(user);
                  if (update) {
                     //数据异步同步到群防群控
                     myAsyncService.updateUserByQfqk(user);
                  }
               }else {
                  //不存在,则新增
                  user.setId(result1.getUserId());
                  boolean save = userService.save(user);
                  if (save){
                     //数据异步同步到群防群控
                     myAsyncService.qfqkUserSave(user);
                  }
               }
            }
            if (result1.getCode()==202){
               //已在其他单位存在
               HandlerLog handlerLog = new HandlerLog();
               handlerLog.setCreateTime(new Date());
               handlerLog.setDeptId(user.getDeptId());
               handlerLog.setOperatorTime(user.getCreateTime());
               handlerLog.setRemark("用户["+DesensitizedUtil.desensitizedIdNumberBy4(user0.getCardid())+"]已在其他单位存在");
               handlerLog.setType(2);
               //插入记录
               handlerLogService.save(handlerLog);
            }
            if (result1.getCode()==203){
               //保安证编号不匹配,请核实!也可通过提供保安证件信息提交核实申请! 内网用户已存在情况
               user.setHold("2");
               user.setSecuritynumber("");
               user.setId(result1.getUserId());
               //先查询当前库是否有改用户?
               User user2 = userService.getById(result1.getUserId());
               //判断
               if (null != user2) {
                  //修改
                  //数据修改
                  boolean b = userService.updateById(user);
                  if (b) {
                     //异步同步到群防群控
                     myAsyncService.updateUserByQfqk(user);
                  }
               } else {
                  //新增
                  boolean save = userService.save(user);
                  if (save) {
                     //异步同步到群防群控
                     myAsyncService.qfqkUserSave(user);
                  }
               }
               //保安证编号不匹配
               HandlerLog handlerLog = new HandlerLog();
               handlerLog.setCreateTime(new Date());
               handlerLog.setDeptId(user.getDeptId());
               handlerLog.setOperatorTime(user.getCreateTime());
               handlerLog.setRemark("用户["+DesensitizedUtil.desensitizedIdNumberBy4(user0.getCardid())+"]保安证编号不匹配,请核实!");
               handlerLog.setType(2);
               //插入记录
               handlerLogService.save(handlerLog);
            }
         }
      }
   }
   /**
    * 管理员导入用户集合信息处理
    * @param result
    */
   @Async
   public void paperListInfoHandler(Result result) {
      //获取 result
      List<Result> data1 = result.getData();
      System.out.println("批量导入数据 = " + data1);
      if (data1.size()>0){
         for (Result result1 : data1) {
            // 取出 Msg ,此 msg 存的对应的 uuid
            String[] split = result1.getMsg().split(",");
            String uuid = split[0];
            //从redis 中获取用户数据
            Object o1 = redisTemplate.opsForValue().get(uuid);
            User user0 = JSON.parseObject(o1.toString(), User.class);
            // 从redis 中获取对应的用户信息,脱敏处理过
            User user = handlerUserInfo(uuid);
            if (result1.getCode()==200){
               user.setId(result1.getUserId());
               user.setSecuritynumber(split[1]);
               user.setHold("1");
               user.setExaminationType("0");
               boolean save = userService.save(user);
               if (save){
                  //数据异步同步到群防群控
                  myAsyncService.qfqkUserSave(user);
               }
            }
            if (result1.getCode()==202){
               //已在其他单位存在
               HandlerLog handlerLog = new HandlerLog();
               handlerLog.setCreateTime(new Date());
               handlerLog.setDeptId(user.getDeptId());
               handlerLog.setOperatorTime(user.getCreateTime());
               handlerLog.setRemark("用户["+DesensitizedUtil.desensitizedIdNumberBy4(user0.getCardid())+"]已在其他单位存在");
               handlerLog.setType(2);
               //插入记录
               handlerLogService.save(handlerLog);
            }
            if (result1.getCode()==205){
               //审查异常
               HandlerLog handlerLog = new HandlerLog();
               handlerLog.setCreateTime(new Date());
               handlerLog.setDeptId(user.getDeptId());
               handlerLog.setOperatorTime(user.getCreateTime());
               handlerLog.setRemark("用户["+DesensitizedUtil.desensitizedIdNumberBy4(user0.getCardid())+"]导入失败,该人员审查异常!");
               handlerLog.setType(2);
               //插入记录
               handlerLogService.save(handlerLog);
            }
         }
      }
   }
   /**
    * 读取内外推送的保安员报名信息
    * @return
    */
   public boolean readSecurityApplyFile() {
      FTPClient ftp = new FTPClient();
      try {
         //设置传输超时时间为60秒
         ftp.setDataTimeout(10000);
         //连接超时为60秒
         ftp.setConnectTimeout(10000);
         //连接
         ftp.connect(ftpHost, ftpPort);
         System.out.println("读取内外推送的保安员报名信息!"+new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(new Date()));
         // 登陆
         ftp.login(ftpUserNameIn, ftpPasswordIn);
         // 检验登陆操作的返回码是否正确
         if (!FTPReply.isPositiveCompletion(ftp.getReplyCode())) {
            ftp.disconnect();
            return false;
         }
//         ftp.enterLocalActiveMode();
         // 设置文件类型为二进制,与ASCII有区别
         ftp.setFileType(FTP.BINARY_FILE_TYPE);
         // 设置编码格式
         ftp.setControlEncoding("GBK");
         // 检验文件是否存在
//         ftp.changeWorkingDirectory(ftpPath);
         // Use passive mode as default
         ftp.enterLocalPassiveMode();
         FTPFile[] files = ftp.listFiles();
         //文件个数大于10个时开始处理
         if (files.length==0){
//            ftp.logout();
            return false;
         }
         else {
            for (int i = files.length-1; i >=0 ; i--) {
               String fileName = files[i].getName();
               String substring = fileName.substring(0, 2);
               System.out.println(new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(new Date())+":读取到文件 = " + fileName);
               if (substring.contains("nt")) {
                  //把文件下载到本地
                  long l = System.currentTimeMillis();
                  FtpUtil.downloadFtpFile(ftpHost, ftpUserNameIn, ftpPasswordIn, ftpPort, ftpPath, localPath, fileName);
                  long x = System.currentTimeMillis();
                  System.out.println("下载文件耗时 = " + (x-l)+" 毫秒");
                  //数据转换
                  String json = OutJson.TestJson(fileName);
                  //取出map
                  Map<String,Object> map = JSON.parseObject(json, Map.class);
                  //取出 key/uuid,取出结果
                  String uuid = null;
                  Result result = new Result();
                  for (Map.Entry entry : map.entrySet()) {
                     uuid = entry.getKey().toString();
                     Object value = entry.getValue();
                     //转换
                     result = JSON.parseObject(value.toString(), Result.class);
                  }
                  if (null!=result) {
                     applyHandler(uuid,result);
                  }
                  //删除本地文件
                  MysqlCenlint.deletess(fileName);
                  //删除 ftp 文件
                  FtpUtil.deleteFile(ftpHost, ftpPort, ftpUserNameIn, ftpPasswordIn, ftpPath, fileName);
                  System.out.println(new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(new Date())+":成功删除ftp文件 = " + fileName);
               }
            }
            //关闭流
//            ftp.completePendingCommand();
//            ftp.logout();
         }
      } catch (Exception e) {
         System.out.println("ftp连接失败");
         e.printStackTrace();
      } finally {
         try {
            ftp.logout();
         } catch (IOException e) {
            e.printStackTrace();
         }
         if (ftp.isConnected()) {
            try {
               ftp.disconnect();
            } catch (IOException e) {
               e.printStackTrace();
            }
         }
      }
      return false;
   }
   /**
    * 报名信息处理
    * @param result
    */
   @Async
   public void applyHandler(String uuid,Result result) {
      //取出培训学校id
      //从redis 中获取用户数据
      String s = redisTemplate.opsForValue().get(uuid).toString();
      //删除
      redisTemplate.delete(uuid);
      if (null!=s && !s.equals("")) {
         //创建集合,存年龄符合要求
         List<String> ageList = new ArrayList<>();
         //创建年龄不符合集合
         List<User> errorList = new ArrayList<>();
         AtomicInteger number = new AtomicInteger();
         if (null != result) {
            //获取 result
            List<Result> data1 = result.getData();
            if (data1.size() > 0) {
               for (Result result1 : data1) {
                  // 取出 Msg ,此 msg 存的对应的 uuid
                  Long userId = result1.getUserId();
                  if (result1.getCode() == 200) {
                     //加入新增集合
                     ageList.add(userId.toString());
                  }
                  //年龄不符合要求
                  if (result1.getCode() == 201) {
                     //number ++
                     number.getAndIncrement();
                     //查询用户信息
                     User user = userService.getById(userId);
                     //加入更新集合
                     errorList.add(user);
                  }
               }
            }
         }
         if (ageList.size() > 0) {
            //遍历
            ageList.forEach(userId -> {
               User user = userService.getUserById(userId);
               //未报名的新增,已报名的不做处理
               if (null == user.getIsTrain()) {
                  TrainingRegistration trainingRegistration1 = new TrainingRegistration();
                  trainingRegistration1.setCancel(1);
                  //默认为未考试状态
                  trainingRegistration1.setIsExam(1);
                  //未提交考试审核
                  trainingRegistration1.setAuditStatus(4);
                  trainingRegistration1.setTrainingTime(new Date());
                  trainingRegistration1.setUserId(userId);
                  trainingRegistration1.setTrainingUnitId(s);
                  trainingRegistrationService.save(trainingRegistration1);
                  //修改保安报名状态
                  user.setIsTrain(1);
                  userService.updateById(user);
                  //数据同步
                  saveTrainingRegistration(trainingRegistration1, user);
               } else {
                  if (user.getIsTrain() != 1) {
                     TrainingRegistration trainingRegistration1 = new TrainingRegistration();
                     trainingRegistration1.setCancel(1);
                     //默认为未考试状态
                     trainingRegistration1.setIsExam(1);
                     //未提交考试审核
                     trainingRegistration1.setAuditStatus(4);
                     trainingRegistration1.setTrainingTime(new Date());
                     trainingRegistration1.setUserId(userId);
                     trainingRegistration1.setTrainingUnitId(s);
                     trainingRegistrationService.save(trainingRegistration1);
                     //修改保安报名状态
                     user.setIsTrain(1);
                     userService.updateById(user);
                     //数据同步
                     saveTrainingRegistration(trainingRegistration1, user);
                  }
               }
            });
         }
         //如果存在年龄不符的,则抛出异常
         if (number.get()>0){
            String deptId = errorList.get(0).getDeptId();
            List<String> arrayList = new ArrayList<>();
            errorList.forEach(user -> {
               arrayList.add(user.getAccount());
            });
            //已在其他单位存在
            HandlerLog handlerLog = new HandlerLog();
            handlerLog.setCreateTime(new Date());
            handlerLog.setDeptId(deptId);
            handlerLog.setOperatorTime(new Date());
            handlerLog.setType(3);
            String errorAccount = StringUtils.join(arrayList, "\\\n");
            handlerLog.setRemark("保安员:[" + errorAccount + "]报名失败!年龄不符,报名年龄为[18-60]周岁!");
            //插入记录
            handlerLogService.save(handlerLog);
         }
      }
   }
   /**
    * 报名
    */
   private void saveTrainingRegistration(TrainingRegistration trainingRegistration,User user1){
      String formatStr = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(new Date());
      Long id = trainingRegistration.getId();
      String sql = "insert into sys_training_registration(id,training_unit_id,training_time,cancel,user_id,is_exam,audit_status) " +
         "values(" + "'" + id + "'"
         + "," + "'" + trainingRegistration.getTrainingUnitId() +"'"
         + "," + "'" + formatStr +"'"
         + "," + "'" + trainingRegistration.getCancel() + "'"
         + "," + "'" + trainingRegistration.getUserId() + "'"
         + "," + "'" + trainingRegistration.getIsExam() + "'"
         + "," +"'" + trainingRegistration.getAuditStatus() + "'" + ");" +
         "update blade_user set is_train = " + user1.getIsTrain() + " " +"where id = " + "'" + user1.getId() + "'";
      myAsyncService.FTP(sql);
   }
   /**
    * 用户信息处理
    * @param uuid
    * @param result
    */
   @Async
   public void userInfoHandler(String uuid, Result result){
      //从redis 中获取用户数据
      Object o1 = redisTemplate.opsForValue().get(uuid);
      User user0 = JSON.parseObject(o1.toString(), User.class);
      //用户数处理
      User users = handlerUserInfo(uuid);
      if (null!=users) {
         System.out.println("用户数据 = " + users);
         //判断结果
         if (result.getCode() == 200) {
            //新增
            users.setId(result.getUserId());
            users.setStatus(1);
            //插入数据库
            boolean save = userService.save(users);
            if (save) {
               //异步同步到群防群控
               myAsyncService.qfqkUserSave(users);
            }
         } else if (result.getCode() == 201) {
            //修改
            users.setId(result.getUserId());
            //先查询当前库是否有改用户?
            User user2 = userService.getById(result.getUserId());
            if (null != user2) {
               //数据修改
               boolean b = userService.updateById(users);
               if (b) {
                  //异步同步到群防群控
                  myAsyncService.updateUserByQfqk(users);
               }
            } else {
               //新增
               boolean save = userService.save(users);
               if (save) {
                  //异步同步到群防群控
                  myAsyncService.qfqkUserSave(users);
               }
            }
         } else if (result.getCode() == 203) {
            //保安证编号不匹配,请核实!也可通过提供保安证件信息提交核实申请! 用户为新增
            users.setHold("2");
            users.setSecuritynumber("");
            //新增
            users.setId(result.getUserId());
            //插入数据库
            boolean save = userService.save(users);
            if (save) {
               //异步同步到群防群控
               myAsyncService.qfqkUserSave(users);
            }
            //保安证编号不匹配
            HandlerLog handlerLog = new HandlerLog();
            handlerLog.setCreateTime(new Date());
            handlerLog.setDeptId(user0.getDeptId());
            handlerLog.setOperatorTime(user0.getCreateTime());
            handlerLog.setRemark("用户["+DesensitizedUtil.desensitizedIdNumberBy4(user0.getCardid())+"]保安证编号不匹配,请核实!");
            handlerLog.setType(1);
            //插入记录
            handlerLogService.save(handlerLog);
         } else if (result.getCode() == 204) {
            //保安证编号不匹配,请核实!也可通过提供保安证件信息提交核实申请! 内网用户已存在情况
            users.setHold("2");
            users.setSecuritynumber("");
            users.setId(result.getUserId());
            //先查询当前库是否有改用户?
            User user2 = userService.getById(result.getUserId());
            //判断
            if (null != user2) {
               //修改
               //数据修改
               boolean b = userService.updateById(users);
               if (b) {
                  //异步同步到群防群控
                  myAsyncService.updateUserByQfqk(users);
               }
            } else {
               //新增
               boolean save = userService.save(users);
               if (save) {
                  //异步同步到群防群控
                  myAsyncService.qfqkUserSave(users);
               }
            }
            //保安证编号不匹配
            HandlerLog handlerLog = new HandlerLog();
            handlerLog.setCreateTime(new Date());
            handlerLog.setDeptId(user0.getDeptId());
            handlerLog.setOperatorTime(user0.getCreateTime());
            handlerLog.setRemark("用户["+DesensitizedUtil.desensitizedIdNumberBy4(user0.getCardid())+"]保安证编号不匹配,请核实!");
            handlerLog.setType(1);
            //插入记录
            handlerLogService.save(handlerLog);
         }else {
            //已在其他单位存在
            HandlerLog handlerLog = new HandlerLog();
            handlerLog.setCreateTime(new Date());
            handlerLog.setDeptId(user0.getDeptId());
            handlerLog.setOperatorTime(user0.getCreateTime());
            handlerLog.setRemark("用户["+DesensitizedUtil.desensitizedIdNumberBy4(user0.getCardid())+"]已在其他单位存在");
            handlerLog.setType(1);
            //插入记录
            handlerLogService.save(handlerLog);
         }
      }
   }
   /**
    *  用户审查
    * @return
    */
   public void userExamine() {
      System.out.println("用户审查任务发起"+new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(new Date()));
      //查询审查状态为未审查的保安员
      User user = new User();
      user.setStatus(1);
      user.setIsDeleted(0);
      user.setRoleId("1412226235153731586");
      //未审查
      user.setExaminationType("2");
      //查询
      List<User> users = userService.list(new QueryWrapper<>(user));
      //遍历
      if (users.size()>0){
         users.forEach(user1 -> {
            myAsyncService.userExamineFTP(user1);
         });
      }
   }
   /**
    * 考试成绩同步
    * @return
    */
   public void examScoreSync() {
      System.out.println("考试成绩同步"+new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(new Date()));
      //查询当天的考试成绩
      List<ExamScore> examScoreList = examScoreService.getExamScoreList();
      if (examScoreList.size()>0) {
         //遍历计算成绩
         for (ExamScore examScore : examScoreList) {
            ExamAnswerRecord record = new ExamAnswerRecord();
            record.setScoreId(examScore.getId());
            List<ExamAnswerRecord> list = examAnswerRecordService.list(new QueryWrapper<>(record));
            if (list.size()>0){
               int num = 0;
               for (ExamAnswerRecord examAnswerRecord : list) {
                  num = num + examAnswerRecord.getAnswerScore();
                  examScore.setExamEndTime(examAnswerRecord.getAnswerTime());
               }
               examScore.setTheoryGrade(num);
               examScore.setAllGrade(Math.round(num/2));
               //设置状态
               if (num >= 60) {
                  examScore.setQualified(2);
               } else {
                  examScore.setQualified(1);
               }
               String s1 =
                  "update exam_score set exam_id = " + examScore.getExamId() +
                     ",theory_grade = " + "'" + examScore.getTheoryGrade() + "'" +
                     ",all_grade = " + "'" + examScore.getAllGrade() + "'" +
                     ",exam_end_time = " + "'" + new SimpleDateFormat("yyyy-MM-dd HH:mm:dd").format(examScore.getExamEndTime()) + "'" +
                     ",qualified = " + "'" + examScore.getQualified() + "'" +
                     " " + "where id = " + "'" + examScore.getId() + "'";
               myAsyncService.FTP(s1);
            }
         }
      }
   }
}