From 30df94c05573a426d030510d4dd58ae1d93bfb7a Mon Sep 17 00:00:00 2001
From: tangzy <tangzy123456>
Date: Mon, 06 Dec 2021 14:03:37 +0800
Subject: [PATCH] 1.资格审查排序
---
src/main/java/org/springblade/modules/FTP/monitor.java | 135 +++++++++++++++++++++++++++++++++++----------
1 files changed, 105 insertions(+), 30 deletions(-)
diff --git a/src/main/java/org/springblade/modules/FTP/monitor.java b/src/main/java/org/springblade/modules/FTP/monitor.java
index 2058172..984a8f8 100644
--- a/src/main/java/org/springblade/modules/FTP/monitor.java
+++ b/src/main/java/org/springblade/modules/FTP/monitor.java
@@ -2,6 +2,7 @@
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.springframework.scheduling.annotation.Scheduled;
import org.springframework.stereotype.Component;
@@ -9,20 +10,16 @@
import java.io.IOException;
import java.io.InputStream;
+import static org.springblade.common.constant.FtpConstant.*;
+
@Component
public class monitor {
- //ftp服务器IP地址
- private static String ftpHost = "192.168.0.105";
- //ftp服务器端口
- private static int ftpPort = 21;
- //ftp服务器用户名
- private static String ftpUserName = "yly";
- //ftp服务器密码
- private static String ftpPassword = "Yly@123";
- //ftp服务器路径
- private static String ftpPath = "anbao/sql.json";
- @Scheduled(cron = "*/5 * * * * ?")
+ //文件名
+ //private static String fileName = "nsql.json";
+
+
+ //@Scheduled(cron = "*/30 * * * * ?")
public static boolean isFTPFileExist() {
FTPClient ftp = new FTPClient();
@@ -31,7 +28,7 @@
// 连接ftp服务器
- ftp.connect(ftpHost, ftpPort);
+ ftp.connect(ftpHost_dev, ftpPort);
// 登陆
@@ -56,41 +53,119 @@
// 设置编码格式
ftp.setControlEncoding("GBK");
-
// 提取绝对地址的目录以及文件名
- ftpPath = ftpPath.replace("ftp://" + ftpHost + ":" + ftpPort + "/", "");
+ //ftpPath = ftpPath.replace("ftp://" + ftpHost + ":" + ftpPort + "/", "");
- String dir = ftpPath.substring(0, ftpPath.lastIndexOf("/"));
+ //String dir = ftpPath.substring(0, ftpPath.lastIndexOf("/"));
- String file = ftpPath.substring(ftpPath.lastIndexOf("/") + 1);
+ // file = ftpPath.substring(ftpPath.lastIndexOf("/") + 1);
// 进入文件所在目录,注意编码格式,以能够正确识别中文目录
- ftp.changeWorkingDirectory(new String(dir.getBytes("GBK"), FTP.DEFAULT_CONTROL_ENCODING));
+ //ftp.changeWorkingDirectory(new String(dir.getBytes("GBK"), FTP.DEFAULT_CONTROL_ENCODING));
// 检验文件是否存在
-
- InputStream is = ftp.retrieveFileStream(new String(file.getBytes("GBK"), FTP.DEFAULT_CONTROL_ENCODING));
-
- if (is == null || ftp.getReplyCode() == FTPReply.FILE_UNAVAILABLE) {
- System.out.println(false);
+ ftp.changeWorkingDirectory(ftpPath);
+ 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, 1);
+ if (substring1.equals("w")) {
+ //把文件下载到本地
+ FtpUtil.downloadFtpFile(ftpHost_dev, ftpUserName, ftpPassword, 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.deletes(fileName);
+ MysqlCenlint.deletess(fileName);
+ FtpUtil.deleteFile(ftpHost_dev, ftpPort, ftpUserName, ftpPassword, "anbao/", fileName);
+ is.close();
+ ftp.completePendingCommand();
+ }
+ else {
+ //把文件下载到本地
+ FtpUtil.downloadFtpFile(ftpHost_dev, ftpUserName, ftpPassword, ftpPort, ftpPath, MinioPath, fileName);
+ //MysqlCenlint.deletess(fileName);
+ FtpUtil.deleteFile(ftpHost_dev, ftpPort, ftpUserName, ftpPassword, "anbao/", fileName);
+ is.close();
+ ftp.completePendingCommand();
+ }
+ }
+ }
+ return true;
}
- if (is != null) {
- System.out.println(true);
- is.close();
- ftp.completePendingCommand();
+ //InputStream is = ftp.retrieveFileStream(new String(file.getBytes("GBK"), FTP.DEFAULT_CONTROL_ENCODING));
- }
+// if (is == null || ftp.getReplyCode() == FTPReply.FILE_UNAVAILABLE) {
+// return false;
+//
+// }
+//
+// if (is != null) {
+// //把文件下载到本地
+// FtpUtil.downloadFtpFile(ftpHost, ftpUserName, ftpPassword, ftpPort, ftpPath, localPath, fileName);
+// //
+// String s = OutJson.TestJson();
+// //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.delete();
+// FtpUtil.deleteFile(ftpHost, ftpPort, ftpUserName, ftpPassword, "anbao/", "nsql.json");
+// is.close();
+// ftp.completePendingCommand();
+//
+// }
- return true;
} catch (Exception e) {
-
e.printStackTrace();
} finally {
--
Gitblit v1.9.3