SSM在表单中上传单个文件的处理办法

本文详细介绍如何在SpringMVC框架下实现文件上传功能,包括pom.xml依赖配置、springMVC配置、JSP页面表单设计、AJAX请求及文件上传控制器编写,通过实例演示了整个文件上传流程。

在pom.xml中引入依赖配置

<dependency>
			<groupId>commons-fileupload</groupId>
			<artifactId>commons-fileupload</artifactId>
			<version>1.3.2</version>
		</dependency>
		<dependency>
			<groupId>commons-io</groupId>
			<artifactId>commons-io</artifactId>
			<version>2.5</version>
		</dependency>

在springMVC配置文件中添加如下配置

<!-- springMVC文件上传 -->
	<!-- 定义文件上传解析器 --><bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver">
   <property name="defaultEncoding">
      <value>UTF-8</value>
   </property>
   <property name="maxUploadSize">
      <value>32505856</value><!-- 上传文件大小限制为31M,31*1024*1024 -->
   </property>
   <property name="maxInMemorySize">
      <value>4096</value>
   </property></bean>

在前面jsp页面中添加表单,包含文件上传控件

<form action="<%=editMemberUrl%>" id="myform" method="post"
		enctype="multipart/form-data" >
<div class="col-md-5">
<input class="" type="file" name="file" /> 
<input type="hidden"	name="pic1" id="coverImg1" value="${member.pic1 }" /> 
<input	type="button" value="上传" onclick="upload()" /> 
<img id="coverImg2" src="${member.pic1 }" style="width: 50px; height: 50px;" />
</div>
</form>

添加ajax请求

<script>		
		function upload() {
			alert("开始上传文件!")
			var formData = new FormData(document.getElementById("myform"));
			$.ajax({
				url : "${ctx}/file/upload.html",
				type : "post",
				data : formData,
				processData : false,
				contentType : false,
				success : function(data) {
					if (data != "0") {
						alert("上传成功:" + data);						
							$('#coverImg1').val(data);
							$('#coverImg2').attr("src", "${ctx}/" + data);		
					} else {
						alert("上传失败")
					}
				}
			});
		}
	</script>

添加文件上传控制类

@Controller
@RequestMapping("/file")
public class FileUploadController {
//ajax单个文件上传,返回json串
	@ResponseBody
	@RequestMapping("/upload")
	public String fileupload3(HttpServletRequest req, @RequestParam("file") MultipartFile myfile)
			throws IOException, ServletException {
		System.out.println("文件上传测试。。。" + myfile);
		if (!myfile.isEmpty()) {
			String name = myfile.getOriginalFilename();
			String suffix = name.substring(name.lastIndexOf("."), name.length());

			String filename = UUID.randomUUID() + suffix;
			System.out.println(filename);
			InputStream is = myfile.getInputStream();

			String serverpath = req.getSession().getServletContext().getRealPath("/upload");
			System.out.println("服务器路径:" + serverpath);
			FileOutputStream fos = new FileOutputStream(serverpath + File.separator + filename);

			byte[] bty = new byte[4096];
			int length = 0;
			while ((length = is.read(bty)) != -1) {
				fos.write(bty, 0, length);
			}
			fos.close();
			is.close();
			req.setAttribute("file", "upload" + File.separator + filename);
			//return  "upload/success";
			return "upload" + File.separator + filename;
		}
		//return "upload/fail";
		return "0";
	}
}
<think>嗯,用户的问题是关于SSM框架中,当没有上图片时,MultipartFile对象不为null的情况。他们想知道如何解决这个问题。首先,我需要回忆一下在Spring MVC中处理文件的相关知识。 首先,用户提到的MultipartFile对象不为null,可能是因为即使没有上文件表单中的文件字段仍然会被Spring MVC封装成MultipartFile对象,只不过它的内容为空。这时候,如果直接判断MultipartFile是否为null可能不起作用,因为即使没有上文件,这个对象仍然存在,但它的isEmpty()方法可能返回true。 我记得在Spring MVC中,处理文件需要配置MultipartResolver,通常是CommonsMultipartResolver。用户提供的引用[1]里提到了配置文件解析组件,其中设置了单个文件的最大大小。这可能和配置有关,但用户的问题不是文件大小的问题,而是如何处理未上文件的情况。 接下来,用户的需求是在没有上图片时,正确处理MultipartFile对象。可能的解决方案包括检查MultipartFile是否为空或者其原始文件名是否为空,或者在Controller层进行判空处理,或者在配置中设置是否解析所有请求为Multipart请求。 引用[3]提到了Spring MVC处理List的问题,可能和参数绑定有关,但这里的问题更直接是文件处理。引用[4]提到了SqlMapper接口的创建,可能和持久层无关,但需要集中解决上问题。 可能的解决步骤: 1. 在Controller中,检查MultipartFile是否为空或者其isEmpty()方法是否为true。即使用!file.isEmpty()来判断是否有文件。 2. 检查是否有原始文件名,因为当用户没有选择文件时,原始文件名可能为空字符串。可以通过判断file.getOriginalFilename()是否为空或空白字符串来处理。 3. 在Spring配置中,设置MultipartResolver的resolveLazily属性为true,这样可以延迟解析,只有当请求中确实有文件时才会解析,避免创建空的MultipartFile对象。用户提供的引用[1]中的配置可能需要添加这个属性。 4. 修改前端表单,确保文件字段是否正确设置,可能在没有文件时,前端仍然提交了一个空的文件部分,导致后端接收到非null对象。 另外,可能需要考虑的是,如果用户没有上文件,但是表单中有其他参数,这时候即使没有文件Spring MVC也会将请求视为Multipart请求,从而生成MultipartFile对象。因此,需要配置MultipartResolver的resolveLazily为true,这样只有实际存在文件时才会解析,从而避免生成空的MultipartFile对象。 例如,在配置文件中添加: <property name="resolveLazily" value="true"/> 这样,当请求中没有文件时,MultipartFile参数会为null,或者需要检查是否为空。 此外,可能还需要检查前端表单的enctype是否正确设置为multipart/form-data,不过这可能不会直接影响是否生成空的MultipartFile对象,而是影响是否能正确解析文件。 总结解决方案步骤: - 在Controller的方法中,先检查MultipartFile是否为空或者isEmpty(),或者原始文件名是否为空。 - 调整MultipartResolver的配置,启用延迟解析。 - 确保前端正确提交表单,避免不必要的空文件字段。 需要验证这些步骤是否正确,尤其是配置resolveLazily属性后,是否会导致其他问题,比如请求参数的获取。可能还需要测试这些配置的效果,确保在无文件时,MultipartFile对象为null或者isEmpty()为true。 另外,用户可能遇到的错误是,即使没有上文件,程序仍然试图处理该MultipartFile对象,导致不必要的异常,比如尝试获取文件名或内容时出错。因此,正确的判空逻辑是关键。 最后,生成相关问题,可能需要围绕文件的其他问题,比如配置其他属性,处理多个文件,异常处理等。</think>在SSM框架中解决未上图片时MultipartFile对象不为null的问题,可以通过以下步骤实现: ### 解决方案 1. **控制器层空值校验** ```java @RequestMapping("/upload") public String handleUpload(@RequestParam("file") MultipartFile file) { // 判断是否上有效文件(同时满足三个条件) if (file != null && !file.isEmpty() && !StringUtils.isEmpty(file.getOriginalFilename())) { // 执行上逻辑 } else { // 处理未上文件的情况 } } ``` 关键点说明: - `file != null`:确保参数绑定成功 - `!file.isEmpty()`:检测文件内容是否为空(需Spring 3.1+) - `StringUtils.isEmpty()`:检查原始文件名是否为空(Apache Commons Lang) 2. **配置延迟解析(关键配置)** ```xml <bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver"> <property name="resolveLazily" value="true"/> <!-- 启用延迟解析 --> <property name="maxInMemorySize" value="4096"/> <!-- 减少内存占用 --> </bean> ``` 配置说明: - `resolveLazily=true`:只有当实际访问MultipartFile对象时才会解析请求[^1] - 有效避免创建空文件对象 - 建议配合`maxInMemorySize`控制内存使用 3. **前端表单验证(防御性编程)** ```html <form enctype="multipart/form-data" onsubmit="return validateFile()"> <input type="file" id="fileInput" name="file"> <script> function validateFile() { const file = document.getElementById('fileInput').files[0]; if (!file) { alert('请选择上文件'); return false; } return true; } </script> </form> ``` ### 原理说明 当未上文件时,SpringMVC仍会创建MultipartFile对象但包含空内容。通过`resolveLazily=true`配置,只有在实际访问文件参数时才会进行请求解析,此时: - 未上文件时`file.getOriginalFilename()`返回空字符串 - `file.isEmpty()`返回true - 但对象引用仍不为null[^3] ### 扩展优化 - 统一异常处理: ```java @ControllerAdvice public class FileUploadAdvice { @ExceptionHandler(MultipartException.class) public ResponseEntity<String> handleUploadError() { return ResponseEntity.badRequest().body("文件异常"); } } ``` - 上配置建议值: ```xml <property name="maxUploadSize" value="10485760"/> <!-- 10MB总限制 --> <property name="defaultEncoding" value="UTF-8"/> <!-- 编码格式 --> ```
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值