spring boot 连接FTP实现文件上传
spring boot 连接FTP实现文件上传
maven:
<!--ftp--><dependency><groupId>commons-net</groupId><artifactId>commons-net</artifactId><version>3.8.0</version></dependency>
接口示例:
@ApiOperation(value="上传文件到FTP")@PostMapping("/fileUploadFTP")public Boolean uploadFileToFtp(@RequestParam("file") MultipartFile file) {boolean flag = uploadFile("192.168.2.128",21,file,"user","123456","/");return false;}
方法:
public static boolean uploadFile(String url, int port, MultipartFile file,String username,String password, String path) {FTPClient ftpClient = new FTPClient();boolean result = false;try {String filename = file.getOriginalFilename();// 连接到FTP服务器ftpClient.connect(url, port);// 登录boolean login = ftpClient.login(username, password);if (!login) {System.out.println("FTP 登录失败");return result;}// 设置控制编码(处理中文文件名)ftpClient.setControlEncoding("UTF-8");// 检查是否成功连接int replyCode = ftpClient.getReplyCode();if (!FTPReply.isPositiveCompletion(replyCode)) {System.out.println("连接失败,FTP 服务器返回错误:" + replyCode);return result;}// 切换到指定的目录boolean changeDir = ftpClient.changeWorkingDirectory(path);if (!changeDir) {System.out.println("目标目录不存在或没有权限:" + path);// 尝试创建目标目录if (ftpClient.makeDirectory(path)) {System.out.println("创建目录成功:" + path);} else {System.out.println("无法创建目录:" + path);return false;}}// 设置文件类型(二进制文件类型,适用于所有类型的文件)ftpClient.setFileType(FTP.BINARY_FILE_TYPE);try (InputStream fis = file.getInputStream()) {// 上传文件String encodedFilename = new String(filename.getBytes("UTF-8"), "ISO-8859-1");result = ftpClient.storeFile(encodedFilename, fis);if (result) {System.out.println("文件上传成功!");} else {replyCode = ftpClient.getReplyCode();String replyMessage = ftpClient.getReplyString();System.out.println("上传失败,FTP 回复: " + replyCode + " " + replyMessage);}}// 退出ftpClient.logout();} catch (IOException e) {e.printStackTrace();} finally {try {// 断开与服务器的连接if (ftpClient.isConnected()) {ftpClient.disconnect();}} catch (IOException e) {e.printStackTrace();}}return result;}
相关文章:
spring boot 连接FTP实现文件上传
spring boot 连接FTP实现文件上传 maven: <!--ftp--><dependency><groupId>commons-net</groupId><artifactId>commons-net</artifactId><version>3.8.0</version></dependency>接口示例: ApiO…...
怎么进行mysql的优化?
MySQL 的优化是一个系统性的工作,涉及多个层面,包括查询优化、索引优化、配置优化、架构优化等。以下是一些常见的 MySQL 优化方法: 查询优化 避免全表扫描:确保查询能够使用索引,避免 SELECT *,只选择需要…...
Octave3D 关卡设计插件
课程参考链接 这位大佬有在视频合集中有详细的讲解,个人体验过,感觉功能很强大 https://www.bilibili.com/video/BV1Kq4y1C72P/?share_sourcecopy_web&vd_source0a41d8122353e3e841ae0a39908c2181 Prefab资源管理 第一步 在场景中创建一个空物体…...
【论文笔记-TPAMI 2024】FreqFusion:用于密集图像预测的频率感知特征融合
Frequency-aware Feature Fusion for Dense Image Prediction 用于密集图像预测的频率感知特征融合 Abstract:密集图像预测任务要求具有强类别信息和高分辨率精确空间边界细节的特征。为了实现这一点,现代分层模型通常利用特征融合,直接添加…...
DeepBI成单关键词管理策略:提升转化与曝光,助力电商业绩双增长
在电商竞争愈发激烈的市场环境中,优化广告投放的关键词管理是提升产品转化率和曝光量的关键。特别是对于那些已经证明其转化能力的成单关键词,如何更好地管理和优化,成为了卖家们亟需解决的问题。DeepBI通过一套智能化的管理方案,…...
ai-3、机器学习之逻辑回归
机器学习之逻辑回归 1、分类问题2、逻辑回归2.1、二分类问题线性回归2.2、二分类问题逻辑回归 1、分类问题 分类问题常用的算法:逻辑回归 y0 :垃圾邮件 y1:正常邮件 准确来说是分类任务与线性回归任务的区别 2、逻辑回归 2.1、二分类问题线性回归 分类…...
在kubernetes集群中持续压测 SpringCloud 应用,pod 的 memory cache 持续增长问题
问题描述 在kubernetes集群中压测 SpringCloud 应用,持续压测, pod 的 memory cache 持续增长,导致 pod 最终挂了。上图看看效果吧~pod的资源配置 cpu: 1~2 core内存:1~3 G pod 数:1分析思路 1)pod 级的 Memory Cache ,显示的为当前 pod 的 linux 系统的 cache 内存的…...
金融赋能绍兴纺织 民生银行助力外贸中小微企业“走出去”
在浙江绍兴,纺织业作为一张熠熠生辉的产业名片,承载着深厚的历史底蕴与蓬勃的发展活力。这里依傍长三角经济圈,交通网络纵横交错,将原材料产地与广阔市场紧密相连;产业集群高度成熟,上下游产业链完备&#…...
ubuntu:换源安装docker-ce和docker-compose
更新apt源 apt换源:ubuntu:更新阿里云apt源-CSDN博客 安装docker-ce 1、更新软件源 sudo apt update2、安装基本软件 sudo apt-get install apt-transport-https ca-certificates curl software-properties-common lrzsz -y3、指定使用阿里云镜像 su…...
基于 Elasticsearch 和 Milvus 的 RAG 运维知识库的架构设计和部署落地实现指南
最近在整理一些业务场景的架构设计和部署落地实现指南 先放一个 【基于RAG的运维知识库 (ElasticSearch + Milvus) 的详细实现指南】,其中包含了详尽的技术实现细节、可运行的示例代码、原理分析、优缺点分析和应用场景分析。 架构描述: 基于RAG的运维知识库 (ElasticSearch…...
基于Python的web漏洞挖掘,漏洞扫描系统(附源码,部署)
本次技术通过利用Python技术来开发一款针对web漏洞挖掘扫描的技术,通过web漏洞的挖掘扫描来实现对网站URL的漏洞检测,通过高中低风险的判断来实现对一款网站中存在的漏洞进行可视化的分析,从而能够找到问题并且尽快的实现问题的解决。 博主介…...
Spring Boot全局异常处理:“危机公关”团队
目录 一、全局异常处理的作用二、Spring Boot 实现全局异常处理(附上代码实例)三、总结: 🌟我的其他文章也讲解的比较有趣😁,如果喜欢博主的讲解方式,可以多多支持一下,感谢…...
Wireshark:自定义类型帧解析
文章目录 1. 前言2. 背景3. 开发 Lua 插件 1. 前言 限于作者能力水平,本文可能存在谬误,因此而给读者带来的损失,作者不做任何承诺。 2. 背景 Wireshark 不认识用 tcpdump 抓取的数据帧,仔细分析相关代码和数据帧后,…...
Redis7——进阶篇(一)
前言:此篇文章系本人学习过程中记录下来的笔记,里面难免会有不少欠缺的地方,诚心期待大家多多给予指教。 基础篇: Redis(一)Redis(二)Redis(三)Redis&#x…...
word转换为pdf后图片失真解决办法、高质量PDF转换方法
1、安装Adobe Acrobat Pro DC 自行安装 2、配置Acrobat PDFMaker (1)点击word选项卡上的Acrobat插件,(2)点击“首选项”按钮,(3)点击“高级配置”按钮(4)点…...
Kafka零拷贝
Kafka为什么适用零拷贝,其他存储结构不适用? Kafka 采用的是日志存储模型,数据通常是顺序写入、顺序读取,并且它的消费模式是 “读完即走”(一次性读取并发送给消费者),这与零拷贝的特性完美匹…...
鸿蒙应用开发入门教程
鸿蒙应用开发入门教程 基础准备与环境搭建 1. 了解鸿蒙系统 1.1 核心理念学习 HarmonyOS(鸿蒙系统)是华为推出的全场景分布式操作系统,其核心特点如下: 分布式能力 设备协同:手机、平板、智能手表、IoT设备等可无…...
【2022——暴力DP / 优雅背包】
题目 代码 #include <bits/stdc.h> using namespace std; using ll long long;const int N 2023;ll f[2][2023][2023];int main() {f[0][0][0] 1;for(int i 1; i < 10; i) //次数{for(int j 0; j< 2022; j)for(int k 0; k < 2022; k)f[i&1][j][k] 0…...
AI智能体与大语言模型:重塑SaaS系统的未来航向
在数字化转型的浪潮中,软件即服务(SaaS)系统一直是企业提升效率、优化业务流程的重要工具。随着AI智能体和大语言模型(LLMs)的迅速发展,SaaS系统正迎来前所未有的变革契机。本文将从AI智能体和大语言模型对…...
绕过密码卸载360终端安全管理系统
一不小心在电脑上安装了360终端安全管理系统,就会发现没有密码,就无法退出无法卸载360,很容易成为一个心病,360终端安全管理系统,没有密码,进程无法退出,软件无法卸载,前不久听同事说…...
哪款头戴式蓝牙耳机性价比高?十大热门平价头戴式耳机品牌推荐!
2026年头戴耳机市场新老品牌争奇斗艳,从入门到高端让人目不暇接。作为一名经历过选择困难的音频爱好者,我完全理解这种幸福的烦恼:参数术语堆砌、营销话术包装,让人难辨虚实。在实测过多款产品后,我发现关键要避开这些…...
C++的constinit常量初始化与静态存储期变量的启动时间优化
C的constinit常量初始化与静态存储期变量的启动时间优化 在现代C开发中,程序的启动性能优化是一个不可忽视的课题。尤其是静态存储期变量(如全局变量或静态局部变量)的初始化,往往会导致程序启动时间延长。为了解决这一问题&…...
紧急预警:Mojo v1.1.3+ 版本Python插件存在ABI不兼容漏洞!立即执行这3条命令规避崩溃风险
第一章:紧急预警:Mojo v1.1.3 版本Python插件存在ABI不兼容漏洞!立即执行这3条命令规避崩溃风险近期安全审计发现,Mojo 编译器 v1.1.3 及后续版本(含 v1.1.4、v1.1.5)中内置的 Python 插件(mojo…...
中文近义词工具包Synonyms的终极发展蓝图:AI时代如何重塑自然语言处理
中文近义词工具包Synonyms的终极发展蓝图:AI时代如何重塑自然语言处理 【免费下载链接】Synonyms :herb: 中文近义词:聊天机器人,智能问答工具包 项目地址: https://gitcode.com/gh_mirrors/sy/Synonyms Synonyms是一款强大的中文近义…...
终极指南:如何避免和解决Android项目中的技术债务问题
终极指南:如何避免和解决Android项目中的技术债务问题 【免费下载链接】XUI 💍A simple and elegant Android native UI framework, free your hands! (一个简洁而优雅的Android原生UI框架,解放你的双手!) 项目地址: https://gi…...
Skija与现有Java图形库对比:为什么选择Skija?
Skija与现有Java图形库对比:为什么选择Skija? 【免费下载链接】skija Java bindings for Skia 项目地址: https://gitcode.com/gh_mirrors/sk/skija Skija是一个高质量的Java绑定库,为Java开发者提供了强大的2D图形渲染能力。作为Skia…...
室内无人机自主定位:融合Mid360激光雷达与光流传感器的无GPS导航实践
1. 室内无人机定位的挑战与解决方案 在仓库巡检、隧道勘测等室内场景中,无人机最头疼的问题就是失去GPS信号后的定位难题。传统光流传感器虽然能提供相对运动信息,但在长距离飞行时误差会不断累积;而激光雷达虽然精度高,但单独使用…...
革新星露谷体验:SMAPI全栈模组加载技术指南
革新星露谷体验:SMAPI全栈模组加载技术指南 【免费下载链接】SMAPI The modding API for Stardew Valley. 项目地址: https://gitcode.com/gh_mirrors/smap/SMAPI SMAPI(Stardew Modding API)作为《星露谷物语》的官方模组加载框架&am…...
拉普拉斯变换:从傅里叶到复频域的系统分析利器
1. 从傅里叶到拉普拉斯:为什么我们需要复频域? 第一次接触傅里叶变换时,你可能被它"时域转频域"的魔法惊艳到了——直到遇到一个尴尬问题:当信号不满足绝对可积条件时(比如指数增长的信号e^t)&am…...
快速上手Jimeng LoRA:Streamlit可视化界面,无需代码基础
快速上手Jimeng LoRA:Streamlit可视化界面,无需代码基础 你是否对AI绘画感兴趣,想尝试不同的艺术风格,却被复杂的命令行和代码部署劝退?你是否下载了多个不同训练阶段的LoRA模型,却苦于每次测试都要重新加…...
