From 8b375fe00a241b3a769b82fe3dac8d1c9dce8a02 Mon Sep 17 00:00:00 2001
From: Administrator <admin>
Date: Thu, 16 Jun 2022 14:36:07 +0800
Subject: [PATCH] 模拟考试修改

---
 src/main/java/org/springblade/modules/quartz/task/Task.java | 1109 ++++++++++++++++++++++++++++++++++++++++++++++++++-------
 1 files changed, 967 insertions(+), 142 deletions(-)

diff --git a/src/main/java/org/springblade/modules/quartz/task/Task.java b/src/main/java/org/springblade/modules/quartz/task/Task.java
index b1e4028..62a5861 100644
--- a/src/main/java/org/springblade/modules/quartz/task/Task.java
+++ b/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);
+				}
+			}
+		}
+	}
+
 
 }

--
Gitblit v1.9.3