feat:【infra 基础设施】ftp、sftp 库升级与兼容
This commit is contained in:
@@ -129,7 +129,7 @@
|
|||||||
<artifactId>commons-net</artifactId> <!-- 文件客户端:解决 ftp 连接 -->
|
<artifactId>commons-net</artifactId> <!-- 文件客户端:解决 ftp 连接 -->
|
||||||
</dependency>
|
</dependency>
|
||||||
<dependency>
|
<dependency>
|
||||||
<groupId>com.jcraft</groupId>
|
<groupId>com.github.mwiede</groupId>
|
||||||
<artifactId>jsch</artifactId> <!-- 文件客户端:解决 sftp 连接 -->
|
<artifactId>jsch</artifactId> <!-- 文件客户端:解决 sftp 连接 -->
|
||||||
</dependency>
|
</dependency>
|
||||||
<dependency>
|
<dependency>
|
||||||
|
|||||||
@@ -4,6 +4,7 @@ import cn.hutool.core.io.FileUtil;
|
|||||||
import cn.hutool.core.util.CharsetUtil;
|
import cn.hutool.core.util.CharsetUtil;
|
||||||
import cn.hutool.core.util.StrUtil;
|
import cn.hutool.core.util.StrUtil;
|
||||||
import cn.hutool.extra.ftp.Ftp;
|
import cn.hutool.extra.ftp.Ftp;
|
||||||
|
import cn.hutool.extra.ftp.FtpConfig;
|
||||||
import cn.hutool.extra.ftp.FtpException;
|
import cn.hutool.extra.ftp.FtpException;
|
||||||
import cn.hutool.extra.ftp.FtpMode;
|
import cn.hutool.extra.ftp.FtpMode;
|
||||||
import cn.iocoder.yudao.module.infra.framework.file.core.client.AbstractFileClient;
|
import cn.iocoder.yudao.module.infra.framework.file.core.client.AbstractFileClient;
|
||||||
@@ -18,6 +19,15 @@ import java.io.ByteArrayOutputStream;
|
|||||||
*/
|
*/
|
||||||
public class FtpFileClient extends AbstractFileClient<FtpFileClientConfig> {
|
public class FtpFileClient extends AbstractFileClient<FtpFileClientConfig> {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 连接超时时间,单位:毫秒
|
||||||
|
*/
|
||||||
|
private static final Long CONNECTION_TIMEOUT = 3000L;
|
||||||
|
/**
|
||||||
|
* 读写超时时间,单位:毫秒
|
||||||
|
*/
|
||||||
|
private static final Long SO_TIMEOUT = 10000L;
|
||||||
|
|
||||||
private Ftp ftp;
|
private Ftp ftp;
|
||||||
|
|
||||||
public FtpFileClient(Long id, FtpFileClientConfig config) {
|
public FtpFileClient(Long id, FtpFileClientConfig config) {
|
||||||
@@ -26,11 +36,11 @@ public class FtpFileClient extends AbstractFileClient<FtpFileClientConfig> {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected void doInit() {
|
protected void doInit() {
|
||||||
// 初始化 Ftp 对象
|
// 初始化 Ftp 对象:https://gitee.com/zhijiantianya/yudao-cloud/pulls/207/
|
||||||
FtpConfig ftpConfig = new FtpConfig(config.getHost(), config.getPort(), config.getUsername(), config.getPassword(),
|
FtpConfig ftpConfig = new FtpConfig(config.getHost(), config.getPort(), config.getUsername(), config.getPassword(),
|
||||||
CharsetUtil.CHARSET_UTF_8, null, null);
|
CharsetUtil.CHARSET_UTF_8, null, null);
|
||||||
ftpConfig.setConnectionTimeout(3000L);
|
ftpConfig.setConnectionTimeout(CONNECTION_TIMEOUT);
|
||||||
ftpConfig.setSoTimeout(10000L);
|
ftpConfig.setSoTimeout(SO_TIMEOUT);
|
||||||
this.ftp = new Ftp(ftpConfig, FtpMode.valueOf(config.getMode()));
|
this.ftp = new Ftp(ftpConfig, FtpMode.valueOf(config.getMode()));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -2,10 +2,13 @@ package cn.iocoder.yudao.module.infra.framework.file.core.client.sftp;
|
|||||||
|
|
||||||
import cn.hutool.core.io.FileUtil;
|
import cn.hutool.core.io.FileUtil;
|
||||||
import cn.hutool.core.util.CharsetUtil;
|
import cn.hutool.core.util.CharsetUtil;
|
||||||
|
import cn.hutool.core.util.StrUtil;
|
||||||
import cn.hutool.extra.ftp.FtpConfig;
|
import cn.hutool.extra.ftp.FtpConfig;
|
||||||
|
import cn.hutool.extra.ssh.JschRuntimeException;
|
||||||
import cn.hutool.extra.ssh.Sftp;
|
import cn.hutool.extra.ssh.Sftp;
|
||||||
import cn.iocoder.yudao.framework.common.util.io.FileUtils;
|
import cn.iocoder.yudao.framework.common.util.io.FileUtils;
|
||||||
import cn.iocoder.yudao.module.infra.framework.file.core.client.AbstractFileClient;
|
import cn.iocoder.yudao.module.infra.framework.file.core.client.AbstractFileClient;
|
||||||
|
import com.jcraft.jsch.JSch;
|
||||||
|
|
||||||
import java.io.File;
|
import java.io.File;
|
||||||
|
|
||||||
@@ -16,8 +19,17 @@ import java.io.File;
|
|||||||
*/
|
*/
|
||||||
public class SftpFileClient extends AbstractFileClient<SftpFileClientConfig> {
|
public class SftpFileClient extends AbstractFileClient<SftpFileClientConfig> {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 连接超时时间,单位:毫秒
|
||||||
|
*/
|
||||||
|
private static final Long CONNECTION_TIMEOUT = 3000L;
|
||||||
|
/**
|
||||||
|
* 读写超时时间,单位:毫秒
|
||||||
|
*/
|
||||||
|
private static final Long SO_TIMEOUT = 10000L;
|
||||||
|
|
||||||
static {
|
static {
|
||||||
// 某些旧的sftp服务器仅支持ssh-dss协议,该协议并不安全,默认不支持该协议,按需添加
|
// 某些旧的 sftp 服务器仅支持 ssh-dss 协议,该协议并不安全,默认不支持该协议,按需添加
|
||||||
JSch.setConfig("server_host_key", JSch.getConfig("server_host_key") + ",ssh-dss");
|
JSch.setConfig("server_host_key", JSch.getConfig("server_host_key") + ",ssh-dss");
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -29,11 +41,11 @@ public class SftpFileClient extends AbstractFileClient<SftpFileClientConfig> {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected void doInit() {
|
protected void doInit() {
|
||||||
// 初始化 Ftp 对象
|
// 初始化 Sftp 对象
|
||||||
FtpConfig ftpConfig = new FtpConfig(config.getHost(), config.getPort(), config.getUsername(), config.getPassword(),
|
FtpConfig ftpConfig = new FtpConfig(config.getHost(), config.getPort(), config.getUsername(), config.getPassword(),
|
||||||
CharsetUtil.CHARSET_UTF_8, null, null);
|
CharsetUtil.CHARSET_UTF_8, null, null);
|
||||||
ftpConfig.setConnectionTimeout(3000L);
|
ftpConfig.setConnectionTimeout(CONNECTION_TIMEOUT);
|
||||||
ftpConfig.setSoTimeout(10000L);
|
ftpConfig.setSoTimeout(SO_TIMEOUT);
|
||||||
this.sftp = new Sftp(ftpConfig);
|
this.sftp = new Sftp(ftpConfig);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -125,7 +125,7 @@ public class IotMqttConnectionManager {
|
|||||||
*/
|
*/
|
||||||
public IotMqttConnectionManager.ConnectionInfo getConnectionInfoByDeviceId(Long deviceId) {
|
public IotMqttConnectionManager.ConnectionInfo getConnectionInfoByDeviceId(Long deviceId) {
|
||||||
// 通过设备 ID 获取连接端点
|
// 通过设备 ID 获取连接端点
|
||||||
var endpoint = getDeviceEndpoint(deviceId);
|
MqttEndpoint endpoint = getDeviceEndpoint(deviceId);
|
||||||
if (endpoint == null) {
|
if (endpoint == null) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user