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/FTP/Monitor.java |  222 +++++++++++++++++-------------------------------------
 1 files changed, 71 insertions(+), 151 deletions(-)

diff --git a/src/main/java/org/springblade/modules/FTP/Monitor.java b/src/main/java/org/springblade/modules/FTP/Monitor.java
index 513e91f..d326a2b 100644
--- a/src/main/java/org/springblade/modules/FTP/Monitor.java
+++ b/src/main/java/org/springblade/modules/FTP/Monitor.java
@@ -1,5 +1,6 @@
 package org.springblade.modules.FTP;
 
+import com.alibaba.fastjson.JSON;
 import org.apache.commons.net.ftp.FTP;
 import org.apache.commons.net.ftp.FTPClient;
 import org.apache.commons.net.ftp.FTPFile;
@@ -12,7 +13,9 @@
 import java.io.InputStream;
 import java.io.UnsupportedEncodingException;
 import java.net.SocketException;
+import java.util.ArrayList;
 import java.util.List;
+import java.util.Map;
 
 import static org.springblade.common.config.FtpConfig.*;
 
@@ -31,11 +34,15 @@
 	 * @return
 	 */
 	public static Result isFTPFileExist(String uuid) {
-		System.out.println("uuid = " + uuid);
+		String name = "ni"+uuid;
+//		System.out.println("uuid = " + uuid);
 		//创建 ftp 对象
 		FTPClient ftp = new FTPClient();
-		boolean flag = false;
 		try {
+			//设置超时时间
+			ftp.setDataTimeout(60000);
+			//连接超时为60秒
+			ftp.setConnectTimeout(60000);
 			//连接
 			ftp.connect(ftpHost, ftpPort);
 
@@ -57,63 +64,50 @@
 			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);
-					    //把文件下载到本地
+					if (fileName.equals(name)){
+						System.out.println("-------接收到内网回传的文件: " + fileName);
+						//把文件下载到本地
 						FtpUtil.downloadFtpFile(ftpHost, ftpUserNameIn, ftpPasswordIn, ftpPort, ftpPath, localPath, fileName);
 						// 解析数据
-						String s = OutJson.TestJson(fileName);
+						String json = 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) {
+						Map map = JSON.parseObject(json, Map.class);
+						//获取结果
+						Object o = map.get(uuid);
+						if (null!= o || !o.equals("")){
+							Result result = JSON.parseObject(o.toString(), Result.class);
+							System.out.println("读取返回结果 result = " + result);
+							//删除本地文件
+							MysqlCenlint.deletess(fileName);
+							//删除 ftp 文件
+							FtpUtil.deleteFile(ftpHost, ftpPort, ftpUserNameIn, ftpPasswordIn, ftpPath, fileName);
+//							ftp.dele(fileName);
+							List<Result> list = new ArrayList<>();
+							list.add(result);
 							//返回
-							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);
+							return new Result(200,null,list);
 						}
 					}
 				}
-				System.out.println("未读取到对应的文件");
+				ftp.completePendingCommand();
+				ftp.logout();
 				return new Result(400,null,"未读取到对应的文件",null);
 			}
 		} catch (Exception e) {
 			System.out.println("ftp连接失败");
 			e.printStackTrace();
 		} finally {
-			if (ftp != null) {
+			if (ftp.isConnected()) {
 				try {
 					ftp.disconnect();
 				} catch (IOException e) {
@@ -132,8 +126,11 @@
 	public static Result getFtpDataByUuidList(String uuid) {
 		//创建 ftp 对象
 		FTPClient ftp = new FTPClient();
-		boolean flag = false;
 		try {
+			//设置超时时间
+			ftp.setDataTimeout(60000);
+			//连接超时为60秒
+			ftp.setConnectTimeout(60000);
 			//连接
 			ftp.connect(ftpHost, ftpPort);
 			// 登陆
@@ -162,11 +159,10 @@
 			if (files.length==0){
 				return new Result(400,null,"未读取到文件",null);
 			} else {
+				boolean flag = false;
 				for (FTPFile file : files){
 					String fileName = file.getName();
-					InputStream is = ftp.retrieveFileStream(new String(fileName.getBytes("GBK"), FTP.DEFAULT_CONTROL_ENCODING));
-					String substring1 = fileName.substring(0, 2);
-					if (substring1.equals("nl")){
+					if (fileName.contains("nl")){
 						//把文件下载到本地
 						FtpUtil.downloadFtpFile(ftpHost, ftpUserNameIn, ftpPasswordIn, ftpPort, ftpPath, localPath, fileName);
 						// 解析数据
@@ -175,24 +171,29 @@
 						Result result = DataHandler.handlerList(s,uuid);
 						//匹配上了删除文件
 						if (result.getCode()==200) {
+							flag = true;
 							//删除本地文件
 							MysqlCenlint.deletess(fileName);
 							//删除 ftp 文件
 							FtpUtil.deleteFile(ftpHost, ftpPort, ftpUserNameIn, ftpPasswordIn, ftpPath, fileName);
+//							ftp.dele(fileName);
 							//返回
 							return result;
 						}
-						is.close();
 						ftp.completePendingCommand();
+						ftp.logout();
 					}
 				}
+//				if (!flag){
+//					ftp.logout();
+//				}
 				return new Result(400,null,"未读取到对应的文件",null);
 			}
 		} catch (Exception e) {
 			System.out.println("ftp连接失败");
 			e.printStackTrace();
 		} finally {
-			if (ftp != null) {
+			if (ftp.isConnected()) {
 				try {
 					ftp.disconnect();
 				} catch (IOException e) {
@@ -211,8 +212,11 @@
 	public static Result getFtpDataByUuidListTrain(String uuid) {
 		//创建 ftp 对象
 		FTPClient ftp = new FTPClient();
-		boolean flag = false;
 		try {
+			//设置超时时间
+			ftp.setDataTimeout(60000);
+			//连接超时为60秒
+			ftp.setConnectTimeout(60000);
 			//连接
 			ftp.connect(ftpHost, ftpPort);
 			// 登陆
@@ -241,11 +245,10 @@
 			if (files.length==0){
 				return new Result(400,null,"未读取到文件",null);
 			} else {
+				boolean flag = false;
 				for (FTPFile file : files){
 					String fileName = file.getName();
-					InputStream is = ftp.retrieveFileStream(new String(fileName.getBytes("GBK"), FTP.DEFAULT_CONTROL_ENCODING));
-					String substring1 = fileName.substring(0, 2);
-					if (substring1.equals("nt")){
+					if (fileName.contains("nt")){
 						//把文件下载到本地
 						FtpUtil.downloadFtpFile(ftpHost, ftpUserNameIn, ftpPasswordIn, ftpPort, ftpPath, localPath, fileName);
 						// 解析数据
@@ -254,24 +257,29 @@
 						Result result = DataHandler.handlerList(s,uuid);
 						//匹配上了删除文件
 						if (result.getCode()==200) {
+							flag = true;
 							//删除本地文件
 							MysqlCenlint.deletess(fileName);
 							//删除 ftp 文件
+//							ftp.dele(fileName);
 							FtpUtil.deleteFile(ftpHost, ftpPort, ftpUserNameIn, ftpPasswordIn, ftpPath, fileName);
 							//返回
 							return result;
 						}
-						is.close();
 						ftp.completePendingCommand();
+						ftp.logout();
 					}
 				}
+//				if (!flag){
+//					ftp.logout();
+//				}
 				return new Result(400,null,"未读取到对应的文件",null);
 			}
 		} catch (Exception e) {
 			System.out.println("ftp连接失败");
 			e.printStackTrace();
 		} finally {
-			if (ftp != null) {
+			if (ftp.isConnected()) {
 				try {
 					ftp.disconnect();
 				} catch (IOException e) {
@@ -283,102 +291,6 @@
 	}
 
 	/**
-	 * 读取内外推送的文件,每30秒读取一次
-	 * @return
-	 */
-	@Scheduled(cron = "*/30 * * * * ?")
-	public static boolean isFTPFileExist() {
-		FTPClient ftp = new FTPClient();
-		try {
-			//连接
-			ftp.connect(ftpHost, ftpPort);
-			// 登陆
-			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();
-			if (files.length==0){
-				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);
-						}
-						//关闭流
-						is.close();
-						ftp.completePendingCommand();
-					}
-					return true;
-				}
-			}
-		} catch (Exception e) {
-			System.out.println("ftp连接失败");
-			e.printStackTrace();
-		} finally {
-			if (ftp != null) {
-				try {
-					ftp.disconnect();
-				} catch (IOException e) {
-					e.printStackTrace();
-				}
-			}
-		}
-		return false;
-	}
-
-	/**
 	 * 获取保安证编号位数
 	 * @param uuid 随机数
 	 * @return
@@ -386,8 +298,11 @@
 	public static Result getSecurityNumberBit(String uuid) {
 		//创建 ftp 对象
 		FTPClient ftp = new FTPClient();
-		boolean flag = false;
 		try {
+			//设置超时时间
+			ftp.setDataTimeout(60000);
+			//连接超时为60秒
+			ftp.setConnectTimeout(60000);
 			//连接
 			ftp.connect(ftpHost, ftpPort);
 			// 登陆
@@ -416,11 +331,10 @@
 			if (files.length==0){
 				return new Result(400,null,"未读取到文件",null);
 			} else {
+				boolean flag = false;
 				for (FTPFile file : files){
 					String fileName = file.getName();
-					InputStream is = ftp.retrieveFileStream(new String(fileName.getBytes("GBK"), FTP.DEFAULT_CONTROL_ENCODING));
-					String substring1 = fileName.substring(0, 2);
-					if (substring1.equals("ns")){
+					if (fileName.contains("ns")){
 						//把文件下载到本地
 						FtpUtil.downloadFtpFile(ftpHost, ftpUserNameIn, ftpPasswordIn, ftpPort, ftpPath, localPath, fileName);
 						// 解析数据
@@ -429,24 +343,30 @@
 						Result result = DataHandler.handlerSecurityNumberBit(s,uuid);
 						//匹配上了删除文件
 						if (result.getCode()==200) {
+							flag = true;
 							//删除本地文件
 							MysqlCenlint.deletess(fileName);
 							//删除 ftp 文件
+//							ftp.dele(fileName);
 							FtpUtil.deleteFile(ftpHost, ftpPort, ftpUserNameIn, ftpPasswordIn, ftpPath, fileName);
+
 							//返回
 							return result;
 						}
-						is.close();
 						ftp.completePendingCommand();
+						ftp.logout();
 					}
 				}
+//				if (!flag){
+//					ftp.logout();
+//				}
 				return new Result(400,null,"未读取到对应的文件",null);
 			}
 		} catch (Exception e) {
 			System.out.println("ftp连接失败");
 			e.printStackTrace();
 		} finally {
-			if (ftp != null) {
+			if (ftp.isConnected()) {
 				try {
 					ftp.disconnect();
 				} catch (IOException e) {

--
Gitblit v1.9.3