update 固件上传到FTP服务器

This commit is contained in:
Guoqs
2024-06-03 14:36:49 +08:00
parent e6dc4d45d3
commit 5f2210ec79
3 changed files with 227 additions and 209 deletions

View File

@@ -6,8 +6,10 @@ import com.jsowell.common.exception.file.FileSizeLimitExceededException;
import com.jsowell.common.exception.file.InvalidExtensionException;
import com.jsowell.common.util.ServletUtils;
import com.jsowell.common.util.StringUtils;
import com.jsowell.common.util.id.IdUtils;
import com.jsowell.common.util.ip.IpUtils;
import org.apache.commons.io.FilenameUtils;
import org.apache.commons.net.ftp.FTPClient;
@@ -48,20 +50,22 @@ public class FtpUtils {
*/
public static String upLoad(String baseDir, MultipartFile file) throws Exception {
FTPClient ftp = new FTPClient();
baseDir = "/";
try {
/** 1. 检查文件大小和扩展名是否符合要求*/
assertFile(file);
/** 2. 产生新的文件名,目的使得文件名统一为英文字符加数字;fileName包含文件后缀名*/
String fileName = reBuildFileName(file);
/** 3. 连接ftp服务器*/
ftp.connect(ftpConfig.getIp(), ftpConfig.getPort());
String ip = IpUtils.getIpFormDomainName(ftpConfig.getIp());
ftp.connect(ip, ftpConfig.getPort());
ftp.login(ftpConfig.getUsername(), ftpConfig.getPassword());
if (!FTPReply.isPositiveCompletion(ftp.getReplyCode())) {
// 不合法时断开连接
ftp.disconnect();
throw new IOException("ftp连接异常异常码为:" + ftp.getReplyCode());
}
String path = ftpConfig.getUploadPath() + baseDir;
String path = baseDir;
String[] dirs = path.split("/");
ftp.changeWorkingDirectory("/");
/** 4. 判断ftp服务器目录是否存在 不存在则创建*/
@@ -221,7 +225,8 @@ public class FtpUtils {
public static final String reBuildFileName(MultipartFile file) {
String fileName = file.getOriginalFilename();
String extension = getExtension(file);
fileName = IdUtils.fastUUID() + "." + extension;
// 2024年6月3日14点29分修改 保持原名称
// fileName = IdUtils.fastUUID() + "." + extension;
return fileName;
}
@@ -246,7 +251,7 @@ public class FtpUtils {
* @return
*/
public static final boolean isAllowedExtension(String extension) {
for (String str : MimeTypeUtils.IMAGE_EXTENSION) {
for (String str : MimeTypeUtils.FIRMWARE_EXTENSION) {
if (str.equalsIgnoreCase(extension)) {
return true;
}