使用springMVC进行文件的上传

本文详细介绍了如何在Spring MVC框架中实现文件上传功能,包括配置文件解析器、使用form表单上传文件、编写控制器处理上传请求及文件保存过程。通过具体代码示例,展示了文件上传的完整流程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

  1. 导入jar包
  2. 配置文件的视图视图解析器
    1. <!-- 配置文件的视图解析器 (id必须写成multipartResolver)-->                                                            
      <bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver">
      	<!-- 上传文件的大小 -->                                                                                
      	<property name="maxUploadSize" value="50000"></property>                                            
      </bean>                                                                                                 
       
  3. 使用form表单进行文件的上传
    1. <%@ page language="java" contentType="text/html; charset=UTF-8"
      	pageEncoding="UTF-8"%>
      <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
      <html>
      <head>
      <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
      <title>Insert title here</title>
      <script type="text/javascript" src="static/js/jquery-3.3.1.js"></script>
      <!-- 显示缩略图的javascript插件 -->
      <script type="text/javascript" src="static/js/uploadPreview.js"></script>
      </head>
      <body>
      	<form action="up/upload" method="post" enctype="multipart/form-data">
      		文件名:<input type="text" name="myFileName" /><br /> 
      		文件:<input type="file" name="myFile" id="up_img_a" /><br/>
      			<!-- 用于显示浏览的图片(缩略图) -->
      			<img id="imgShow_a" width="100px" height="100px">
      			 <input type="submit" value="上传" />
      	</form>
      	<!-- 显示缩略图的javascript代码 -->
      	<script type="text/javascript">
      		function file_click() {
      			new uploadPreview({
      				UpBtn : "up_img_a",
      				ImgShow : "imgShow_a"
      			});
      		}
      		window.onload = file_click;
      	</script>
      </body>
      </html>
       
  4. 编写controller类
    1. package com.controller;
      
      
      
      import java.io.File;
      import java.io.UnsupportedEncodingException;
      import java.text.SimpleDateFormat;
      import java.util.Date;
      import java.util.UUID;
      
      import javax.servlet.http.HttpServletRequest;
      import javax.servlet.http.HttpServletResponse;
      import javax.servlet.http.HttpSession;
      
      import org.springframework.stereotype.Controller;
      import org.springframework.web.bind.annotation.RequestMapping;
      import org.springframework.web.multipart.MultipartFile;
      
      @Controller
      @RequestMapping("/up")
      public class UploadController {
      	
      	@RequestMapping("/upload")
      	public String upload(String myFileName,MultipartFile myFile,HttpSession session){
      		//获取文件保存的地址(文件夹)
      		String realPath = session.getServletContext().getRealPath("upload");
      		File file=new File(realPath);
      		//判断文件夹是否在(不存在就创建一个)
      		if (!file.exists()) {
      			file.mkdir();//创建文件夹
      		}
      		String fileName = myFile.getOriginalFilename();//获取文件名
      		String date = new SimpleDateFormat("yyyy-MM-dd-HH-mm-ss").format(new Date());//获取当前时间
      		//使用一个唯一的编码 uuid拼接也可以(把所有的-都替换为空)
      		String uuid = UUID.randomUUID().toString().replace("-", "");
      	
      		fileName=date+fileName;//拼接文件名(日期+文件名)
      		try {
      			myFile.transferTo(new File(realPath,fileName));//保存文件(参数一:文件夹,参数二:文件)
      		} catch (Exception e) {
      			e.printStackTrace();
      		} 
      		session.setAttribute("smg", myFileName+"保存成功!");
      		return "main";//跳转的view
      	}
      }
      
       

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值