0

0

Java文件上传与下载的基本语法操作

P粉602998670

P粉602998670

发布时间:2026-01-07 15:30:02

|

761人浏览过

|

来源于php中文网

原创

java web文件上传核心是multipartfile接口,需用transferto()安全落盘,禁用getbytes()和手动流操作;下载须设content-disposition和content-type响应头;生产环境应使用独立路径或对象存储。

java文件上传与下载的基本语法操作

Java Web 中文件上传的核心是 MultipartFile

Spring Boot 项目里,MultipartFile 是处理 HTTP 文件上传事实上的标准接口。它不是 Java 标准库类,而是 Spring MVC 提供的抽象,底层依赖 Servlet 3.0+ 的 Part 接口。你不能直接 new 它,必须由框架在接收请求时自动注入。

常见错误:试图用 File file = multipartFile.getResource().getFile() 拿到真实路径——这在多数部署环境(如 jar 包运行、Docker)会抛 FileNotFoundException,因为文件可能根本没落地为磁盘文件,而是在内存中流转。

  • 上传接口必须使用 POST 方法,且 Content-Type 必须是 multipart/form-data
  • Controller 方法参数要加 @RequestParam("file") MultipartFile file,其中 "file" 必须和 HTML 表单中 <input type="file" name="file">name 属性一致
  • 务必检查 file.isEmpty(),否则用户未选文件就提交会导致空指针或异常
  • 大文件上传需提前配置:spring.servlet.multipart.max-file-size=10MBmax-request-size=10MB(application.yml)

保存上传文件别硬写 FileOutputStream,优先用 transferTo()

MultipartFile.transferTo(File dest) 是最安全、最简洁的落盘方式。它内部自动处理内存/临时文件切换,兼容不同容器(Tomcat、Undertow、Jetty),也避免了手动流操作容易遗漏的 close 问题。

别用 file.getBytes() 全量读入内存再写——上传 500MB 文件会直接 OOM;也别用 file.getInputStream() + FileOutputStream 手动 copy——出错时流没关干净,临时文件可能残留。

立即学习Java免费学习笔记(深入)”;

物流公司网站源码1.0
物流公司网站源码1.0

一款WordPress内核的物流公司网站主题,适合各大物流公司企业建站用,商业主题,免费分享,本主题分享目的旨在学习参考之用,无任何收费行为。 wordpress官方网站上下载并安装wordpress3.32及以上版本。安装方法:上传后进者wp主题至wp-content\themes文件夹,进入后台"外观-主题-选择主题-启用"激活本主题。此为作者在Chinaz投稿第三版,请保

下载
Path uploadDir = Paths.get("uploads");
Files.createDirectories(uploadDir);
File dest = uploadDir.resolve(file.getOriginalFilename());
file.transferTo(dest); // 一行搞定,自动清理临时资源

文件下载必须设对 Content-DispositionContent-Type

浏览器能否触发下载、文件名是否正确、中文名是否乱码,全靠两个响应头:

  • Content-Disposition: attachment; filename="abc.pdf" —— 触发下载行为;filename* 用于支持 UTF-8 编码的中文名(如 filename*=UTF-8''%E6%96%87%E4%BB%B6.pdf
  • Content-Type 决定浏览器是否尝试在线打开。不确定类型时用 application/octet-stream 最稳妥
  • 千万别用 response.getOutputStream().write(bytes) 直接写,漏设 header 会导致文件名丢失或页面显示乱码内容
String fileName = "报告_2024.pdf";
response.setContentType("application/pdf");
response.setHeader("Content-Disposition", 
    "attachment; filename*=UTF-8''" + URLEncoder.encode(fileName, "UTF-8"));
Files.copy(Paths.get("data/", fileName), response.getOutputStream());

生产环境绕不开的路径与权限问题

本地开发时 uploads/ 放项目根目录没问题,但上线后:Linux 上应用通常以非 root 用户运行,对 /var/www/opt/app 下目录默认无写权限;Windows 服务也可能因 UAC 被拦截。更关键的是,上传目录绝不能放在 Web 根路径下(如 src/main/resources/static/uploads),否则用户可通过 URL 直接访问,造成敏感文件泄露。

解决方案只有两个:一是用独立可写路径(如 /data/app/uploads),并在启动脚本里 chown appuser:appgroup /data/app;二是走对象存储(OSS/S3),上传后返回外链,彻底规避本地文件系统权限和容量问题。

容易被忽略的一点:Files.createDirectories(path) 只创建末级目录,如果父目录不存在且无权限,它不会报错,而是静默失败——必须在创建后立刻 Files.exists(path) 校验。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
如何配置Tomcat环境变量
如何配置Tomcat环境变量

配置Tomcat环境变量需要在系统中添加CATALINA_HOME变量,并将Tomcat的安装路径添加到PATH变量中。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

117

2023.10.26

idea如何集成Tomcat
idea如何集成Tomcat

idea集成Tomcat的步骤:1、添加Tomcat服务器配置;2、配置项目部署;3、运行Tomcat服务器;4、访问项目;5、注意事项;6、关闭Tomcat服务器。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

173

2024.02.23

怎么查看Tomcat源代码
怎么查看Tomcat源代码

查看Tomcat源代码的步骤:1、下载Tomcat源代码;2、在IDEA中导入Tomcat源代码;3、查看源代码;4、理解Tomcat的工作原理;5、参与社区和贡献;6、注意事项;7、持续学习和更新;8、使用工具和插件。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

98

2024.02.23

常见的tomcat漏洞有哪些
常见的tomcat漏洞有哪些

常见的tomcat漏洞有:1、跨站脚本攻击;2、跨站请求伪造;3、目录遍历漏洞;4、缓冲区溢出漏洞;5、配置漏洞;6、第三方组件漏洞。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

170

2024.02.23

tomcat日志乱码怎么解决
tomcat日志乱码怎么解决

tomcat日志乱码的解决办法:1、修改tomcat的日志编码设置;2、检查ide的编码设置;3、检查操作系统的编码设置;4、使用过滤器处理日志;5、检查外部系统的编码设置;6、检查文件编码方式等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

158

2024.02.23

weblogic和tomcat有哪些区别
weblogic和tomcat有哪些区别

weblogic和tomcat的区别:1、功能;2、性能;3、规模;4、价格;5、安全性;6、配置和管理;7、社区支持;8、集成能力;9、升级和更新;10、可靠性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

200

2024.02.23

tomcat和nginx有哪些区别
tomcat和nginx有哪些区别

tomcat和nginx的区别:1、应用领域;2、性能;3、功能;4、配置;5、安全性;6、扩展性;7、部署复杂性;8、社区支持;9、成本;10、日志管理。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

244

2024.02.23

tomcat启动闪退怎么解决
tomcat启动闪退怎么解决

tomcat启动闪退的解决办法:1、检查java环境;2、检查环境变量配置;3、检查端口被占用;4、检查配置文件编码;5、检查启动时需要的配置文件;6、检查相关文件是否丢失;7、检查防火墙和杀毒软件设置。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

169

2024.02.23

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

76

2026.03.11

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 10.5万人学习

Git 教程
Git 教程

共21课时 | 4.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号