当前位置: 首页 > news >正文

javaweb文件上传:@MultipartConfig注解与Apache Commons FileUpload对比

在Java Web应用中处理文件上传时,可以选择使用@MultipartConfig注解或第三方库如Apache Commons FileUpload(通常简称为fileupload)。以下是两者的比较和建议:

  1. 使用 @MultipartConfig 注解
    简介:​
    @MultipartConfig 是Java Servlet规范中用于处理multipart/form-data请求(通常是文件上传)的注解。它简化了在Servlet中处理文件上传的过程,无需依赖额外的第三方库。

优点:​

​集成度高:与Servlet容器(如Tomcat、Jetty)紧密集成,配置简单。
​无需额外依赖:使用Java EE标准的一部分,不需要引入第三方库。
​易于使用:通过注解配置,代码简洁明了。
缺点:​

​功能有限:相比一些成熟的第三方库,@MultipartConfig 提供的功能较为基础,缺乏一些高级特性(如大文件分片上传、断点续传等)。
​灵活性不足:对于复杂的文件上传需求,可能需要更多的自定义代码。
适用场景:​

简单的文件上传需求。
不需要额外功能,只需要基本的文件处理能力。
希望减少项目依赖,保持轻量级。
2. 使用 Apache Commons FileUpload(fileupload)
简介:​
Apache Commons FileUpload 是一个功能强大的第三方库,专门用于处理HTTP文件上传。它提供了丰富的功能和灵活的配置选项。

优点:​

​功能丰富:支持大文件上传、分片上传、文件大小限制、文件类型验证等。
​灵活性高:可以根据需求进行高度定制,适应复杂的业务场景。
​社区支持:作为一个成熟的开源项目,拥有广泛的社区支持和文档资源。
缺点:​

​增加依赖:需要引入额外的库,增加项目的复杂性和维护成本。
​学习成本:相对于@MultipartConfig,使用FileUpload需要更多的配置和代码。
适用场景:​

需要处理复杂的文件上传需求,如大文件、多文件同时上传等。
需要高度定制化的文件处理逻辑。
现有项目已经使用了Apache Commons库,便于集成。
3. 推荐选择
对于简单的文件上传需求:​

​推荐使用 @MultipartConfig。它配置简单,无需额外依赖,适合快速实现基本的文件上传功能。
对于复杂的文件上传需求:​

​推荐使用 Apache Commons FileUpload。它提供了更多的功能和更高的灵活性,适合处理大文件、多文件上传以及复杂的验证逻辑。
4. 示例代码
使用 @MultipartConfig 的简单示例:​

import javax.servlet.annotation.MultipartConfig;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.*;
import java.io.IOException;

@WebServlet("/upload")
@MultipartConfig
public class FileUploadServlet extends HttpServlet {
    protected void doPost(HttpServletRequest request, HttpServletResponse response)
            throws IOException {
        Part filePart = request.getPart("painting");
		if (filePart == null) {
			response.getWriter().println("没有选择文件!");
			return;
		}

		// 1.获取原始文件名
		String originalFileName = Paths.get(filePart.getSubmittedFileName()).getFileName().toString();
		if (originalFileName == null || originalFileName.isEmpty()) {
			response.getWriter().println("文件名为空!");
			return;
		}
		// 2.生成随机唯一文件名
		String extension = "";
		int dotIndex = originalFileName.lastIndexOf('.');
		if (dotIndex > 0) {
			extension = originalFileName.substring(dotIndex);
		}
		// 生成一个32字符的随机UUID
		String randomUUID = base64Encoder.encodeToString(secureRandom.generateSeed(24));
		String uniqueFileName = randomUUID + extension;

		// 3.获取上传目录的实际路径
		String savePath = getServletContext().getRealPath("/upload") + File.separator + uniqueFileName;

		// 4.确保load目录存在
		File loadDir = new File(getServletContext().getRealPath("/upload"));
		if (!loadDir.exists()) {
			loadDir.mkdirs();
		}

		// 5.保存文件
		try {
			filePart.write(savePath);
			response.getWriter().println("文件上传成功!保存路径:" + savePath);
		} catch (IOException e) {
			response.getWriter().println("文件上传失败:" + e.getMessage());
		}
    }
}

使用 Apache Commons FileUpload 的示例(需提前引入commons-fileupload-1.4.jar和commons-io-2.6.jar,在前面提供了下载资源):​

import java.io.File;
import java.io.IOException;
import java.nio.file.Paths;
import java.security.SecureRandom;
import java.util.Base64;
import java.util.List;
import java.util.UUID;

import javax.servlet.ServletException;
import javax.servlet.annotation.MultipartConfig;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.Part;

import org.apache.commons.fileupload.FileItem;
import org.apache.commons.fileupload.FileItemFactory;
import org.apache.commons.fileupload.disk.DiskFileItemFactory;
import org.apache.commons.fileupload.servlet.ServletFileUpload;

import com.imooc.mgallery.service.PaintingService;
import com.imooc.mgallery.util.PageModel;

@WebServlet("/upload")
public class FileUploadServlet extends HttpServlet {
    protected void doPost(HttpServletRequest request, HttpServletResponse response)
            throws ServletException, IOException {
        //====1、初始化FileUpload组件====
		//1.1 FileItemFactory用于将前端的表单数据转换为一个个FileItem对象
		FileItemFactory factory= new DiskFileItemFactory();
		//1.2 ServletFileUpload则是为FileUpload组件提供JavaWeb的http请求解析
		ServletFileUpload sf = new ServletFileUpload(factory);	
		
		//====2、遍历所有fileItem====
		try {
			List<FileItem> formData = sf.parseRequest(request);
			for (FileItem fi : formData) {
				if(fi.isFormField()) {
					System.out.println("一般输入项:"+fi.getFieldName()+":"+fi.getString("UTF-8"));
				}else {
					//====3、文件保存到服务器目录(对应项目目录:webapp/upload)====					
					System.out.println("文件上传项:"+fi.getFieldName());
					String path=request.getServletContext().getRealPath("upload");
					String fileName = UUID.randomUUID().toString();
					String suffix = fi.getName().substring(fi.getName().lastIndexOf("."));
					fi.write(new File(path,fileName+suffix));					
				}				
			}			
		} catch (Exception e) {
			e.printStackTrace();
		}
    }
}

总结
​简单需求:使用 @MultipartConfig,配置简单,无需额外依赖。
​复杂需求:使用 Apache Commons FileUpload,功能丰富,灵活性高。
根据具体的项目需求和复杂度选择合适的文件上传处理方式,可以有效提升开发效率和代码质量。

http://www.dtcms.com/a/40778.html

相关文章:

  • 建筑兔零基础自学python记录32|学过的函数代码记录19-25
  • 判断一个文件中以三个#号开头有多少行的shell脚本怎么写
  • C语言(15)-------------->一维数组
  • Kubernetes (K8S) 核心原理深度剖析:从架构设计到运行机制
  • 【音视频】编解码相关概念总结
  • 什么是Ollama?什么是GGUF?二者之间有什么关系?
  • gRPG协议
  • 【已解决】JupyterLab:如何在JupyterLab中切换内核
  • 【Linux网络】数据链路层 其他常见的协议
  • 运算放大器噪声
  • nz-upload 手动上传 PDF预览
  • 树莓派简单操作系统制作之四:关于异常等级
  • 51c嵌入式~电路~合集13
  • 深度学习-135-LangGraph之应用实例(四)构建RAG问答系统同时对文档进行元数据增强
  • 游戏开发微信小程序--工具箱之父
  • 基于javaweb的SSM+Maven鲜花商城管理系统设计和实现(源码+文档+部署讲解)
  • Qt for Android下QMessageBox背景黑色、文字点击闪烁
  • 深入探讨Ceph:分布式存储架构的未来
  • 类和对象——拷贝对象时的一些编译器优化
  • AI绘画软件Stable Diffusion详解教程(3):Windows系统本地化部署操作方法(通用版)
  • Mybatis的分页插件
  • 视频级虚拟试衣技术在淘宝的产品化实践
  • 【Linux基础】Linux下的C编程指南
  • HAL库之是stm32cubemx安装
  • 定义数组存储3部汽车对象(class1)
  • 解决“ReadTimeoutError:HTTPSConnectionPool”pip安装超时问题
  • win11编译pytorch cuda128版本流程
  • wav格式的音频压缩,WAV 转 MP3 VBR 体积缩减比为 13.5%、多个 MP3 格式音频合并为一个、文件夹存在则删除重建,不存在则直接建立
  • 笔记:大模型Tokens是啥?为啥大模型按Tokens收费?
  • PyQt5入门教程和简单使用