From 25d2a49ecb07ad13a5e223f033547d8dbdb95132 Mon Sep 17 00:00:00 2001
From: zhongrj <123456>
Date: Mon, 05 Dec 2022 15:00:51 +0800
Subject: [PATCH] ftp 文件上传修改
---
src/main/java/org/springblade/modules/FTP/FtpUtil.java | 15 ++-
src/main/java/org/springblade/modules/FTP/monitor.java | 155 ++++++++++----------------------------
src/main/resources/application-dev.yml | 3
src/main/resources/application-test.yml | 14 +++
src/main/java/org/springblade/common/config/FtpConfig.java | 20 +++-
src/main/resources/application.yml | 1
6 files changed, 79 insertions(+), 129 deletions(-)
diff --git a/src/main/java/org/springblade/common/config/FtpConfig.java b/src/main/java/org/springblade/common/config/FtpConfig.java
index 647719d..2d76d97 100644
--- a/src/main/java/org/springblade/common/config/FtpConfig.java
+++ b/src/main/java/org/springblade/common/config/FtpConfig.java
@@ -42,15 +42,21 @@
/**
- * ftp服务器路径
+ * ftp服务器基础路径
*/
- public static String ftpPath;
+ public static String ftpBasePath;
+
+ /**
+ * ftp服务器文件路径
+ */
+ public static String ftpFilePath;
+
+
/**
* 本地路径
*/
public static String localPath;
-
/**
* minio内网ip
@@ -81,8 +87,12 @@
FtpConfig.ftpPassword = ftpPassword;
}
- public void setFtpPath(String ftpPath) {
- FtpConfig.ftpPath = ftpPath;
+ public void setFtpBasePath(String ftpBasePath) {
+ FtpConfig.ftpBasePath = ftpBasePath;
+ }
+
+ public void setFtpFilePath(String ftpFilePath) {
+ FtpConfig.ftpFilePath = ftpFilePath;
}
public void setLocalPath(String localPath) {
diff --git a/src/main/java/org/springblade/modules/FTP/FtpUtil.java b/src/main/java/org/springblade/modules/FTP/FtpUtil.java
index 303fe4f..a13d9ce 100644
--- a/src/main/java/org/springblade/modules/FTP/FtpUtil.java
+++ b/src/main/java/org/springblade/modules/FTP/FtpUtil.java
@@ -147,10 +147,11 @@
if (!ftpClient.changeWorkingDirectory(basePath + filePath)) {
// 如果目录不存在创建目录
String[] dirs = filePath.split("/");
- String tempPath = basePath;
+ String tempPath = "";
for (String dir : dirs) {
- if (null == dir || "".equals(dir))
+ if (null == dir || "".equals(dir)) {
continue;
+ }
tempPath += "/" + dir;
if (!ftpClient.changeWorkingDirectory(tempPath)) {
if (!ftpClient.makeDirectory(tempPath)) {
@@ -166,8 +167,10 @@
LOCAL_CHARSET = "UTF-8";
}
ftpClient.setControlEncoding(LOCAL_CHARSET);
- ftpClient.enterLocalPassiveMode();// 设置被动模式
- ftpClient.setFileType(FTP.BINARY_FILE_TYPE);// 设置传输的模式
+ // 设置被动模式
+ ftpClient.enterLocalPassiveMode();
+ // 设置传输的模式
+ ftpClient.setFileType(FTP.BINARY_FILE_TYPE);
// 上传文件
filename = new String(filename.getBytes(LOCAL_CHARSET), SERVER_CHARSET);
if (!ftpClient.storeFile(filename, input)) {
@@ -301,7 +304,7 @@
} catch (FileNotFoundException e) {
e.printStackTrace();
}
- FtpUtil.uploadFile(ftpHost, ftpPort, ftpUserName, ftpPassword, ftpPath, "/", "q"+response1+".json", in1);
+ FtpUtil.uploadFile(ftpHost, ftpPort, ftpUserName, ftpPassword, ftpBasePath, ftpFilePath, "q"+response1+".json", in1);
MysqlCenlint.deletess("q"+response1+".json");
}
@@ -319,7 +322,7 @@
} catch (FileNotFoundException e) {
e.printStackTrace();
}
- FtpUtil.uploadFile(ftpHost, ftpPort, ftpUserName, ftpPassword, ftpPath, "/", "w"+response1+".json", in1);
+ FtpUtil.uploadFile(ftpHost, ftpPort, ftpUserName, ftpPassword, ftpBasePath, "/", "w"+response1+".json", in1);
MysqlCenlint.deletess("w"+response1+".json");
}
diff --git a/src/main/java/org/springblade/modules/FTP/monitor.java b/src/main/java/org/springblade/modules/FTP/monitor.java
index 67b6324..7ac446d 100644
--- a/src/main/java/org/springblade/modules/FTP/monitor.java
+++ b/src/main/java/org/springblade/modules/FTP/monitor.java
@@ -6,10 +6,8 @@
import org.apache.commons.net.ftp.FTPReply;
import org.springframework.scheduling.annotation.Scheduled;
import org.springframework.stereotype.Component;
-
import java.io.IOException;
import java.io.InputStream;
-
import static org.springblade.common.config.FtpConfig.*;
@@ -20,160 +18,87 @@
public static boolean isFTPFileExist() {
FTPClient ftp = new FTPClient();
-
+ String fileName = null;
try {
- // 连接ftp服务器
-// System.out.println("ftpHost = " + ftpHost);
-
ftp.connect(ftpHost, ftpPort);
-
// 登陆
-
ftp.login(ftpUserName, ftpPassword);
-
// 检验登陆操作的返回码是否正确
-
if (!FTPReply.isPositiveCompletion(ftp.getReplyCode())) {
-
ftp.disconnect();
-
return false;
-
}
-
ftp.enterLocalActiveMode();
-
// 设置文件类型为二进制,与ASCII有区别
-
ftp.setFileType(FTP.BINARY_FILE_TYPE);
-
// 设置编码格式
-
ftp.setControlEncoding("GBK");
- // 提取绝对地址的目录以及文件名
-
- //ftpPath = ftpPath.replace("ftp://" + ftpHost + ":" + ftpPort + "/", "");
-
- //String dir = ftpPath.substring(0, ftpPath.lastIndexOf("/"));
-
- // file = ftpPath.substring(ftpPath.lastIndexOf("/") + 1);
-
- // 进入文件所在目录,注意编码格式,以能够正确识别中文目录
-
- //ftp.changeWorkingDirectory(new String(dir.getBytes("GBK"), FTP.DEFAULT_CONTROL_ENCODING));
-
- // 检验文件是否存在
- ftp.changeWorkingDirectory(ftpPath);
+ // 切换到 ftpFilePath 文件目录
+ boolean directory = ftp.changeWorkingDirectory(ftpFilePath);
FTPFile[] files = ftp.listFiles();
+
if (files.length==0){
return false;
}
else {
for (FTPFile file : files){
- String fileName = file.getName();
+ fileName = file.getName();
InputStream is = ftp.retrieveFileStream(new String(fileName.getBytes("GBK"), FTP.DEFAULT_CONTROL_ENCODING));
String substring1 = fileName.substring(0, 1);
- if (substring1.equals("n")){
+ if (substring1.equals("q")){
//把文件下载到本地
- FtpUtil.downloadFtpFile(ftpHost, ftpUserName, ftpPassword, ftpPort, ftpPath, localPath, fileName);
- //
+ FtpUtil.downloadFtpFile(ftpHost, ftpUserName, ftpPassword, ftpPort, ftpFilePath, 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);
+ if (!sql.isEmpty()) {
+ //以逗号分割
+ 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, ftpPort, ftpUserName, ftpPassword, ftpPath, fileName);
+ FtpUtil.deleteFile(ftpHost, ftpPort, ftpUserName, ftpPassword, ftpFilePath, fileName);
is.close();
ftp.completePendingCommand();
}
}
return true;
}
-
- //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();
-//
-// }
-
-
} catch (Exception e) {
- System.out.println("ftp连接失败");
- e.printStackTrace();
-
- } finally {
-
- if (ftp != null) {
-
- try {
-
- ftp.disconnect();
-
- } catch (IOException e) {
-
- e.printStackTrace();
-
- }
-
+ if (null!= fileName) {
+ MysqlCenlint.deletess(fileName);
+ FtpUtil.deleteFile(ftpHost, ftpPort, ftpUserName, ftpPassword, ftpFilePath, fileName);
}
-
+ e.printStackTrace();
+ } finally {
+ if (ftp != null) {
+ try {
+ ftp.disconnect();
+ } catch (IOException e) {
+ e.printStackTrace();
+ }
+ }
}
-
return false;
}
diff --git a/src/main/resources/application-dev.yml b/src/main/resources/application-dev.yml
index 9504af4..af98ac6 100644
--- a/src/main/resources/application-dev.yml
+++ b/src/main/resources/application-dev.yml
@@ -54,7 +54,8 @@
ftpPort: 21
ftpUserName: zhbain
ftpPassword: zhbain@123
- ftpPath: yly/qfqk/
+ ftpBasePath: yly
+ ftpFilePath: qfqk
localPath: /home/zhongsong/qfqk/
ip: http://47.49.21.216:9000
jsonUrl: /home/zhongsong/qfqk/
diff --git a/src/main/resources/application-test.yml b/src/main/resources/application-test.yml
index fa6a84a..1937c6a 100644
--- a/src/main/resources/application-test.yml
+++ b/src/main/resources/application-test.yml
@@ -54,10 +54,20 @@
ftpPort: 21
ftpUserName: arsn
ftpPassword: 123456
- ftpPath: anbao/
+ ftpBasePath: anbao
+ ftpFilePath: qfqk
localPath: D:\\anbao\\
ip: http://47.49.21.216:9000
- jsonUrl: /home/zhongsong/qfqk/
+ jsonUrl: D:\\anbao\\
+# ftpHost: 117.40.91.118
+# ftpPort: 21
+# ftpUserName: zhbain
+# ftpPassword: zhbain@123
+# ftpBasePath: yly
+# ftpFilePath: qfqk
+# localPath: /home/zhongsong/qfqk/
+# ip: http://47.49.21.216:9000
+# jsonUrl: /home/zhongsong/qfqk/
#第三方登陆
social:
diff --git a/src/main/resources/application.yml b/src/main/resources/application.yml
index 54a3252..9b6181b 100644
--- a/src/main/resources/application.yml
+++ b/src/main/resources/application.yml
@@ -196,6 +196,7 @@
skip-url:
- /blade-test/**
- /blade-user/import-users
+ - /zc/**
#授权认证配置
auth:
- method: ALL
--
Gitblit v1.9.3