From 222e998b6c4bb0e745223f8866eb4d2398376461 Mon Sep 17 00:00:00 2001
From: "youHong.ai" <774495953@qq.com>
Date: Tue, 22 Nov 2022 18:48:25 +0800
Subject: [PATCH] =?UTF-8?q?sftp=E5=B7=A5=E5=85=B7=E7=B1=BB=E7=BC=96?=
=?UTF-8?q?=E5=86=99?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
.../utils/fileUtil/sftp/SftpConnectUtil.java | 141 -----
.../youhong/ai/sftp/SftpConnectUtil.java | 571 ++++++++++++++++++
.../hrorganization/sftp/FetchDataUtil.java | 9 +-
.../java/youhong/ai/pcn/TestOrganization.java | 6 +-
4 files changed, 576 insertions(+), 151 deletions(-)
delete mode 100644 src/main/java/aiyh/utils/fileUtil/sftp/SftpConnectUtil.java
create mode 100644 src/main/java/ebu7common/youhong/ai/sftp/SftpConnectUtil.java
diff --git a/src/main/java/aiyh/utils/fileUtil/sftp/SftpConnectUtil.java b/src/main/java/aiyh/utils/fileUtil/sftp/SftpConnectUtil.java
deleted file mode 100644
index 7af9199..0000000
--- a/src/main/java/aiyh/utils/fileUtil/sftp/SftpConnectUtil.java
+++ /dev/null
@@ -1,141 +0,0 @@
-package aiyh.utils.fileUtil.sftp;
-
-import aiyh.utils.excention.CustomerException;
-import com.jcraft.jsch.*;
-import lombok.Getter;
-import lombok.NoArgsConstructor;
-
-import java.util.Properties;
-
-/**
- *
sftp连接工具类
- *
- * create: 2022-11-22 11:00
- *
- * @author youHong.ai
- */
-
-@Getter
-@NoArgsConstructor
-public class SftpConnectUtil extends ChannelSftp {
-
- /**
- * sftp对象
- */
- private ChannelSftp sftp;
- /**
- * 会话对象
- */
- private Session session;
- /**
- * 用户名
- */
- private String userName;
-
- /**
- * 密码
- */
- private String password;
-
- /**
- * 密钥地址
- */
- private String prvKeyFilePath;
-
- /**
- * 是否成功
- */
- private boolean success;
-
- /**
- * sftp地址
- */
- private String sftpIp;
-
- /**
- * 端口
- */
- private Integer port;
-
- /**
- * 超时事件
- */
- private Integer sftpTimeOut;
-
-
- public SftpConnectUtil(String userName, String prvKeyFilePath,String password, String sftpIp,
- Integer port, Integer sftpTimeOut) {
- this.userName = userName;
- this.prvKeyFilePath = prvKeyFilePath;
- this.sftpIp = sftpIp;
- this.port = port;
- this.password = password;
- this.sftpTimeOut = sftpTimeOut;
- // this.login();
- }
-
-
- /**
- * 登陆sftp
- *
- * @author youHong.ai
- */
-
- public ChannelSftp login() {
-
- JSch jSch = new JSch();
- try {
- if (prvKeyFilePath != null && !"".equals(prvKeyFilePath)) {
- if (password != null && !"".equals(password)) {
- jSch.addIdentity(prvKeyFilePath, password);
- } else {
- jSch.addIdentity(prvKeyFilePath);
- }
- } else {
- throw new RuntimeException("从sftp下载需要的ppk文件未找到");
- }
- if (port != null && port > 0) {
- this.session = jSch.getSession(userName, sftpIp, port);
- } else {
- this.session = jSch.getSession(userName, sftpIp);
- }
- Properties config = new Properties();
- config.put("StrictHostKeyChecking", "no");
- this.session.setConfig(config);
- this.session.setTimeout(sftpTimeOut);
- this.session.connect();
- Channel channel = this.session.openChannel("sftp");
- channel.connect();
- this.sftp = (ChannelSftp) channel;
- this.success = true;
- return sftp;
- } catch (JSchException e) {
- throw new CustomerException("SFTP链接失败!", e);
- }
- }
-
- /**
- * 关闭连接 server
- *
- * @author youHong.ai
- */
- private void logout() {
- if (sftp != null) {
- if (sftp.isConnected()) {
- sftp.disconnect();
- }
- }
- if (session != null) {
- if (session.isConnected()) {
- session.disconnect();
- }
- }
- }
-
- /**
- * 关闭链接释放资源
- */
- public void close(){
- this.login();
- }
-}
diff --git a/src/main/java/ebu7common/youhong/ai/sftp/SftpConnectUtil.java b/src/main/java/ebu7common/youhong/ai/sftp/SftpConnectUtil.java
new file mode 100644
index 0000000..3395123
--- /dev/null
+++ b/src/main/java/ebu7common/youhong/ai/sftp/SftpConnectUtil.java
@@ -0,0 +1,571 @@
+package ebu7common.youhong.ai.sftp;
+
+import aiyh.utils.excention.CustomerException;
+import com.jcraft.jsch.*;
+import lombok.Getter;
+import lombok.NoArgsConstructor;
+
+import java.io.IOException;
+import java.io.InputStream;
+import java.io.OutputStream;
+import java.util.Hashtable;
+import java.util.Properties;
+import java.util.Vector;
+
+/**
+ * sftp连接工具类
+ *
+ * create: 2022-11-22 11:00
+ *
+ * @author youHong.ai
+ */
+
+@Getter
+@NoArgsConstructor
+public class SftpConnectUtil extends ChannelSftp {
+
+ /**
+ * sftp对象
+ */
+ private ChannelSftp sftp;
+ /**
+ * 会话对象
+ */
+ private Session session;
+ /**
+ * 用户名
+ */
+ private String userName;
+
+ /**
+ * 密码
+ */
+ private String password;
+
+ /**
+ * 密钥地址
+ */
+ private String prvKeyFilePath;
+
+ /**
+ * 是否成功
+ */
+ private boolean success;
+
+ /**
+ * sftp地址
+ */
+ private String sftpIp;
+
+ /**
+ * 端口
+ */
+ private Integer port;
+
+ /**
+ * 超时事件
+ */
+ private Integer sftpTimeOut;
+
+
+ public SftpConnectUtil(String userName, String prvKeyFilePath,String password, String sftpIp,
+ Integer port, Integer sftpTimeOut) {
+ this.userName = userName;
+ this.prvKeyFilePath = prvKeyFilePath;
+ this.sftpIp = sftpIp;
+ this.port = port;
+ this.password = password;
+ this.sftpTimeOut = sftpTimeOut;
+ this.login();
+ }
+
+
+ /**
+ * 登陆sftp
+ *
+ * @author youHong.ai
+ */
+
+ private void login() {
+
+ JSch jSch = new JSch();
+ try {
+ if (prvKeyFilePath != null && !"".equals(prvKeyFilePath)) {
+ if (password != null && !"".equals(password)) {
+ jSch.addIdentity(prvKeyFilePath, password);
+ } else {
+ jSch.addIdentity(prvKeyFilePath);
+ }
+ } else {
+ throw new RuntimeException("从sftp下载需要的ppk文件未找到");
+ }
+ if (port != null && port > 0) {
+ this.session = jSch.getSession(userName, sftpIp, port);
+ } else {
+ this.session = jSch.getSession(userName, sftpIp);
+ }
+ Properties config = new Properties();
+ config.put("StrictHostKeyChecking", "no");
+ this.session.setConfig(config);
+ this.session.setTimeout(sftpTimeOut);
+ this.session.connect();
+ Channel channel = this.session.openChannel("sftp");
+ channel.connect();
+ this.sftp = (ChannelSftp) channel;
+ this.success = true;
+ } catch (JSchException e) {
+ throw new CustomerException("SFTP链接失败!", e);
+ }
+ }
+
+ /**
+ * 关闭连接 server
+ *
+ * @author youHong.ai
+ */
+ private void logout() {
+ if (sftp != null) {
+ if (sftp.isConnected()) {
+ sftp.disconnect();
+ }
+ }
+ if (session != null) {
+ if (session.isConnected()) {
+ session.disconnect();
+ }
+ }
+ }
+
+ /**
+ * 关闭链接释放资源
+ */
+ public void close(){
+ this.login();
+ }
+
+ @Override
+ public boolean isClosed() {
+ return this.sftp.isClosed();
+ }
+
+ @Override
+ public void setBulkRequests(int bulk_requests) throws JSchException {
+ this.sftp.setBulkRequests(bulk_requests);
+ }
+
+ @Override
+ public int getBulkRequests() {
+ return this.sftp.getBulkRequests();
+ }
+
+ @Override
+ public void start() throws JSchException {
+ this.sftp.start();
+ }
+
+ @Override
+ public boolean isEOF() {
+ return this.sftp.isEOF();
+ }
+
+ @Override
+ public void setInputStream(InputStream in) {
+ this.sftp.setInputStream(in);
+ }
+
+ @Override
+ public void setInputStream(InputStream in, boolean dontclose) {
+ this.sftp.setInputStream(in, dontclose);
+ }
+
+ @Override
+ public void setOutputStream(OutputStream out) {
+ this.sftp.setOutputStream(out);
+ }
+
+ @Override
+ public void setOutputStream(OutputStream out, boolean dontclose) {
+ this.sftp.setOutputStream(out, dontclose);
+ }
+
+ @Override
+ public void setExtOutputStream(OutputStream out) {
+ this.sftp.setExtOutputStream(out);
+ }
+
+ @Override
+ public void setExtOutputStream(OutputStream out, boolean dontclose) {
+ this.sftp.setExtOutputStream(out, dontclose);
+ }
+
+ @Override
+ public InputStream getInputStream() throws IOException {
+ return this.sftp.getInputStream();
+ }
+
+ @Override
+ public InputStream getExtInputStream() throws IOException {
+ return this.sftp.getExtInputStream();
+ }
+
+ @Override
+ public OutputStream getOutputStream() throws IOException {
+ return this.sftp.getOutputStream();
+ }
+
+ @Override
+ public void quit() {
+ this.sftp.quit();
+ }
+
+ @Override
+ public void exit() {
+ this.sftp.exit();
+ }
+
+ @Override
+ public void lcd(String path) throws SftpException {
+ this.sftp.lcd(path);
+ }
+
+ @Override
+ public void cd(String path) throws SftpException {
+ this.sftp.cd(path);
+ }
+
+ @Override
+ public void put(String src, String dst) throws SftpException {
+ this.sftp.put(src, dst);
+ }
+
+ @Override
+ public void put(String src, String dst, int mode) throws SftpException {
+ this.sftp.put(src, dst, mode);
+ }
+
+ @Override
+ public void put(String src, String dst, SftpProgressMonitor monitor) throws SftpException {
+ this.sftp.put(src, dst, monitor);
+ }
+
+ @Override
+ public void put(String src, String dst, SftpProgressMonitor monitor, int mode) throws SftpException {
+ this.sftp.put(src, dst, monitor, mode);
+ }
+
+ @Override
+ public void put(InputStream src, String dst) throws SftpException {
+ this.sftp.put(src, dst);
+ }
+
+ @Override
+ public void put(InputStream src, String dst, int mode) throws SftpException {
+ this.sftp.put(src, dst, mode);
+ }
+
+ @Override
+ public void put(InputStream src, String dst, SftpProgressMonitor monitor) throws SftpException {
+ this.sftp.put(src, dst, monitor);
+ }
+
+ @Override
+ public void put(InputStream src, String dst, SftpProgressMonitor monitor, int mode) throws SftpException {
+ this.sftp.put(src, dst, monitor, mode);
+ }
+
+ @Override
+ public void _put(InputStream src, String dst, SftpProgressMonitor monitor, int mode) throws SftpException {
+ this.sftp._put(src, dst, monitor, mode);
+ }
+
+ @Override
+ public OutputStream put(String dst) throws SftpException {
+ return this.sftp.put(dst);
+ }
+
+ @Override
+ public OutputStream put(String dst, int mode) throws SftpException {
+ return this.sftp.put(dst, mode);
+ }
+
+ @Override
+ public OutputStream put(String dst, SftpProgressMonitor monitor, int mode) throws SftpException {
+ return this.sftp.put(dst, monitor, mode);
+ }
+
+ @Override
+ public OutputStream put(String dst, SftpProgressMonitor monitor, int mode, long offset) throws SftpException {
+ return this.sftp.put(dst, monitor, mode, offset);
+ }
+
+ @Override
+ public void get(String src, String dst) throws SftpException {
+ this.sftp.get(src, dst);
+ }
+
+ @Override
+ public void get(String src, String dst, SftpProgressMonitor monitor) throws SftpException {
+ this.sftp.get(src, dst, monitor);
+ }
+
+ @Override
+ public void get(String src, String dst, SftpProgressMonitor monitor, int mode) throws SftpException {
+ this.sftp.get(src, dst, monitor, mode);
+ }
+
+ @Override
+ public void get(String src, OutputStream dst) throws SftpException {
+ this.sftp.get(src, dst);
+ }
+
+ @Override
+ public void get(String src, OutputStream dst, SftpProgressMonitor monitor) throws SftpException {
+ this.sftp.get(src, dst, monitor);
+ }
+
+ @Override
+ public void get(String src, OutputStream dst, SftpProgressMonitor monitor, int mode, long skip) throws SftpException {
+ this.sftp.get(src, dst, monitor, mode, skip);
+ }
+
+ @Override
+ public InputStream get(String src) throws SftpException {
+ return this.sftp.get(src);
+ }
+
+ @Override
+ public InputStream get(String src, SftpProgressMonitor monitor) throws SftpException {
+ return this.sftp.get(src, monitor);
+ }
+
+ @Override
+ public InputStream get(String src, int mode) throws SftpException {
+ return this.sftp.get(src, mode);
+ }
+
+ @Override
+ public InputStream get(String src, SftpProgressMonitor monitor, int mode) throws SftpException {
+ return this.sftp.get(src, monitor, mode);
+ }
+
+ @Override
+ public InputStream get(String src, SftpProgressMonitor monitor, long skip) throws SftpException {
+ return this.sftp.get(src, monitor, skip);
+ }
+
+ @Override
+ public Vector ls(String path) throws SftpException {
+ return this.sftp.ls(path);
+ }
+
+ @Override
+ public void ls(String path, LsEntrySelector selector) throws SftpException {
+ this.sftp.ls(path, selector);
+ }
+
+ @Override
+ public String readlink(String path) throws SftpException {
+ return this.sftp.readlink(path);
+ }
+
+ @Override
+ public void symlink(String oldpath, String newpath) throws SftpException {
+ this.sftp.symlink(oldpath, newpath);
+ }
+
+ @Override
+ public void hardlink(String oldpath, String newpath) throws SftpException {
+ this.sftp.hardlink(oldpath, newpath);
+ }
+
+ @Override
+ public void rename(String oldpath, String newpath) throws SftpException {
+ this.sftp.rename(oldpath, newpath);
+ }
+
+ @Override
+ public void rm(String path) throws SftpException {
+ this.sftp.rm(path);
+ }
+
+ @Override
+ public void chgrp(int gid, String path) throws SftpException {
+ this.sftp.chgrp(gid, path);
+ }
+
+ @Override
+ public void chown(int uid, String path) throws SftpException {
+ this.sftp.chown(uid, path);
+ }
+
+ @Override
+ public void chmod(int permissions, String path) throws SftpException {
+ this.sftp.chmod(permissions, path);
+ }
+
+ @Override
+ public void setMtime(String path, int mtime) throws SftpException {
+ this.sftp.setMtime(path, mtime);
+ }
+
+ @Override
+ public void rmdir(String path) throws SftpException {
+ this.sftp.rmdir(path);
+ }
+
+ @Override
+ public void mkdir(String path) throws SftpException {
+ this.sftp.mkdir(path);
+ }
+
+ @Override
+ public SftpATTRS stat(String path) throws SftpException {
+ return this.sftp.stat(path);
+ }
+
+ @Override
+ public SftpStatVFS statVFS(String path) throws SftpException {
+ return this.sftp.statVFS(path);
+ }
+
+ @Override
+ public SftpATTRS lstat(String path) throws SftpException {
+ return this.sftp.lstat(path);
+ }
+
+ @Override
+ public void setStat(String path, SftpATTRS attr) throws SftpException {
+ this.sftp.setStat(path, attr);
+ }
+
+ @Override
+ public String pwd() throws SftpException {
+ return this.sftp.pwd();
+ }
+
+ @Override
+ public String lpwd() {
+ return this.sftp.lpwd();
+ }
+
+ @Override
+ public String version() {
+ return this.sftp.version();
+ }
+
+ @Override
+ public String getHome() throws SftpException {
+ return this.sftp.getHome();
+ }
+
+ @Override
+ public void disconnect() {
+ this.sftp.disconnect();
+ }
+
+ @Override
+ public boolean isConnected() {
+ return this.sftp.isConnected();
+ }
+
+ @Override
+ public void sendSignal(String signal) throws Exception {
+ this.sftp.sendSignal(signal);
+ }
+
+ @Override
+ public int getExitStatus() {
+ return this.sftp.getExitStatus();
+ }
+
+ @Override
+ public int getId() {
+ return this.sftp.getId();
+ }
+
+ @Override
+ public int getServerVersion() throws SftpException {
+ return this.sftp.getServerVersion();
+ }
+
+ @Override
+ public void setFilenameEncoding(String encoding) throws SftpException {
+ this.sftp.setFilenameEncoding(encoding);
+ }
+
+ @Override
+ public String getExtension(String key) {
+ return this.sftp.getExtension(key);
+ }
+
+ @Override
+ public String realpath(String path) throws SftpException {
+ return this.sftp.realpath(path);
+ }
+
+ @Override
+ public void setAgentForwarding(boolean enable) {
+ this.sftp.setAgentForwarding(enable);
+ }
+
+ @Override
+ public void connect() throws JSchException {
+ this.sftp.connect();
+ }
+
+ @Override
+ public void connect(int connectTimeout) throws JSchException {
+ this.sftp.connect(connectTimeout);
+ }
+
+ @Override
+ public void setXForwarding(boolean enable) {
+ this.sftp.setXForwarding(enable);
+ }
+
+ @Override
+ public void setEnv(Hashtable env) {
+ this.sftp.setEnv(env);
+ }
+
+ @Override
+ public void setEnv(String name, String value) {
+ this.sftp.setEnv(name, value);
+ }
+
+ @Override
+ public void setEnv(byte[] name, byte[] value) {
+ this.sftp.setEnv(name, value);
+ }
+
+ @Override
+ public void setPty(boolean enable) {
+ this.sftp.setPty(enable);
+ }
+
+ @Override
+ public void setTerminalMode(byte[] terminal_mode) {
+ this.sftp.setTerminalMode(terminal_mode);
+ }
+
+ @Override
+ public void setPtySize(int col, int row, int wp, int hp) {
+ this.sftp.setPtySize(col, row, wp, hp);
+ }
+
+ @Override
+ public void setPtyType(String ttype) {
+ this.sftp.setPtyType(ttype);
+ }
+
+ @Override
+ public void setPtyType(String ttype, int col, int row, int wp, int hp) {
+ this.sftp.setPtyType(ttype, col, row, wp, hp);
+ }
+
+
+ @Override
+ public void run() {
+ this.sftp.run();
+ }
+}
diff --git a/src/main/java/weaver/youhong/ai/pcn/hrorganization/sftp/FetchDataUtil.java b/src/main/java/weaver/youhong/ai/pcn/hrorganization/sftp/FetchDataUtil.java
index b7a9e48..713f78e 100644
--- a/src/main/java/weaver/youhong/ai/pcn/hrorganization/sftp/FetchDataUtil.java
+++ b/src/main/java/weaver/youhong/ai/pcn/hrorganization/sftp/FetchDataUtil.java
@@ -1,13 +1,10 @@
package weaver.youhong.ai.pcn.hrorganization.sftp;
-import aiyh.utils.excention.CustomerException;
-import aiyh.utils.fileUtil.sftp.SftpConnectUtil;
-import cn.hutool.core.io.IoUtil;
+import ebu7common.youhong.ai.sftp.SftpConnectUtil;
import com.jcraft.jsch.ChannelSftp;
import com.jcraft.jsch.SftpException;
import java.io.*;
-import java.util.Vector;
/**
* 获取数据工具
@@ -32,7 +29,7 @@ public class FetchDataUtil {
- public void downloadFile(ChannelSftp sftp,SftpConnectUtil sftpConnectUtil,
+ public void downloadFile(SftpConnectUtil sftpConnectUtil,
String fileName, String targetFile){
try {
// sftpConnectUtil.lcd(".");
@@ -45,7 +42,7 @@ public class FetchDataUtil {
if (!file.exists()) {
file.getParentFile().mkdirs();
}
- sftp.get(fileName,new FileOutputStream(targetFile));
+ sftpConnectUtil.get(fileName,new FileOutputStream(targetFile));
} catch (SftpException e) {
diff --git a/src/test/java/youhong/ai/pcn/TestOrganization.java b/src/test/java/youhong/ai/pcn/TestOrganization.java
index 48ff058..21963cd 100644
--- a/src/test/java/youhong/ai/pcn/TestOrganization.java
+++ b/src/test/java/youhong/ai/pcn/TestOrganization.java
@@ -1,8 +1,7 @@
package youhong.ai.pcn;
-import aiyh.utils.fileUtil.sftp.SftpConnectUtil;
+import ebu7common.youhong.ai.sftp.SftpConnectUtil;
import baseTest.BaseTest;
-import com.api.doc.detail.util.SFTPUtils;
import com.jcraft.jsch.ChannelSftp;
import org.junit.Test;
import weaver.general.GCONST;
@@ -26,9 +25,8 @@ public class TestOrganization extends BaseTest {
"/Users/aoey.oct.22/company/Fan_wei/ssl/pcn/HR_Digital_PROD.pem",null,"222.73.197.242",
null,1000 * 100
);
- ChannelSftp login = sftpConnectUtil.login();
FetchDataUtil fetchDataUtil = new FetchDataUtil();
- fetchDataUtil.downloadFile(login, sftpConnectUtil,
+ fetchDataUtil.downloadFile(sftpConnectUtil,
"HRIS_PositionExport20221120", GCONST.getSysFilePath() + "HRIS_PositionExport20221120.csv");
}
}