快速学习-SpringMVC 实现文件上传

2020-04-08 11:26:04 浏览数 (1)

第2章 SpringMVC 实现文件上传

2.1文件上传的回顾

2.1.1 文件上传的必要前提

A form 表单的 enctype 取值必须是:multipart/form-data(默认值是:application/x-www-form-urlencoded) enctype:是表单请求正文的类型 B method 属性取值必须是 Post C 提供一个文件选择域<input type=”file” />

2.1.2 文件上传的原理分析

当 form 表单的 enctype 取值不是默认值后,request.getParameter()将失效。enctype=”application/x-www-form-urlencoded”时,form 表单的正文内容是:

代码语言:javascript复制
key=value&key=value&key=value

当 form 表单的 enctype 取值为 Mutilpart/form-data 时,请求正文内容就变成:每一部分都是 MIME 类型描述的正文

代码语言:javascript复制
-----------------------------7de1a433602ac 分界符
Content-Disposition: form-data; name="userName" 协议头
aaa 协议的正文
-----------------------------7de1a433602ac
Content-Disposition: form-data; name="file"; 
filename="C:UserszhyDesktopfileupload_demofileb.txt"
Content-Type: text/plain 协议的类型(MIME 类型)
bbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbb
-----------------------------7de1a433602ac--

2.1.3 借助第三方组件实现文件上传

使用 Commons-fileupload 组件实现文件上传,需要导入该组件相应的支撑 jar 包:Commons-fileuploadcommons-iocommons-io 不属于文件上传组件的开发 jar 文件,但Commons-fileupload 组件从 1.1 版本开始,它工作时需要 commons-io 包的支持。

2.2 springmvc 传统方式的文件上传

2.2.1 说明

传统方式的文件上传,指的是我们上传的文件和访问的应用存在于同一台服务器上。并且上传完成之后,浏览器可能跳转。

2.2.2 实现步骤

2.2.2.1 第一步:拷贝文件上传的 jar 包到工程的 lib 目录
2.2.2.2 第二步:编写 jsp 页面
代码语言:javascript复制
<form action="/fileUpload" method="post" enctype="multipart/form-data">
	名称:
	<input type="text" name="picname" />
	<br/>
	图片:
	<input type="file" name="uploadFile" />
	<br/>
	<input type="submit" value="上传" />
</form>
2.2.2.3 第三步:编写控制器
代码语言:javascript复制
@Controller("fileUploadController")
public class FileUploadController {
	/**
	 * 文件上传
	 */
	@RequestMapping("/fileUpload")
	public String testResponseJson(String picname, MultipartFile uploadFile, HttpServletRequest request) throws Exception {
		//定义文件名
		String fileName = "";
		//1.获取原始文件名
		String uploadFileName = uploadFile.getOriginalFilename();
		//2.截取文件扩展名
		String extendName =
			uploadFileName.substring(uploadFileName.lastIndexOf(".")   1,
				uploadFileName.length());
		//3.把文件加上随机数,防止文件重复
		String uuid = UUID.randomUUID().toString().replace("-", "").toUpperCase();
		//4.判断是否输入了文件名
		if (!StringUtils.isEmpty(picname)) {
			fileName = uuid   "_"   picname   "."   extendName;
		} else {
			fileName = uuid   "_"   uploadFileName;
		}
		System.out.println(fileName);
		//2.获取文件路径ServletContext context = request.getServletContext();
		String basePath = context.getRealPath("/uploads");
		//3.解决同一文件夹中文件过多问题
		String datePath = new SimpleDateFormat("yyyy-MM-dd").format(new Date());
		//4.判断路径是否存在
		File file = new File(basePath   "/"   datePath);
		if (!file.exists()) {
			file.mkdirs();
		}
		//5.使用 MulitpartFile 接口中方法,把上传的文件写到指定位置
		uploadFile.transferTo(new File(file, fileName));
		return "success";
	}
}
2.2.2.4 第四步:配置文件解析器
代码语言:javascript复制
<!-- 配置文件上传解析器 -->
<bean id="multipartResolver" 
    <!-- id 的值是固定的-->
class="org.springframework.web.multipart.commons.CommonsMultipartResolver">
    <!-- 设置上传文件的最大尺寸为 5MB -->
    <property name="maxUploadSize">
        <value>5242880</value>
    </property>
</bean>

注意: 文件上传的解析器 id 是固定的,不能起别的名称,否则无法实现请求参数的绑定。(不光是文件,其他字段也将无法绑定)

2.3 springmvc 跨服务器方式的文件上传

2.3.1 分服务器的目的

在实际开发中,我们会有很多处理不同功能的服务器。例如: 应用服务器:负责部署我们的应用 数据库服务器:运行我们的数据库 缓存和消息服务器:负责处理大并发访问的缓存和消息 文件服务器:负责存储用户上传文件的服务器。

(注意:此处说的不是服务器集群)

分服务器处理的目的是让服务器各司其职,从而提高我们项目的运行效率。

2.3.2 准备两个 tomcat 服务器,并创建一个用于存放图片的 web 工程

在文件服务器的 tomcat 配置中加入,允许读写操作。文件位置:

加入内容:

加入此行的含义是:接收文件的目标服务器可以支持写入操作。

2.3.3 拷贝 jar 包

在我们负责处理文件上传的项目中拷贝文件上传的必备 jar 包

.

2.3.4 编写控制器实现上传图片

代码语言:javascript复制
@Controller("fileUploadController2")
public class FileUploadController2 {
	public static final String FILESERVERURL =
		"http://localhost:9090/day06_spring_image/uploads/";
	/**
	 * 文件上传,保存文件到不同服务器
	 */
	@RequestMapping("/fileUpload2")
	public String testResponseJson(String picname, MultipartFile uploadFile) throwsException {
		//定义文件名
		String fileName = "";
		//1.获取原始文件名
		String uploadFileName = uploadFile.getOriginalFilename();
		//2.截取文件扩展名
		String extendName =
			uploadFileName.substring(uploadFileName.lastIndexOf(".")   1,
				uploadFileName.length());
		//3.把文件加上随机数,防止文件重复
		String uuid = UUID.randomUUID().toString().replace("-", "").toUpperCase();
		//4.判断是否输入了文件名
		if (!StringUtils.isEmpty(picname)) {
			fileName = uuid   "_"   picname   "."   extendName;
		} else {
			fileName = uuid   "_"   uploadFileName;
		}
		System.out.println(fileName);
		//5.创建 sun 公司提供的 jersey 包中的 Client 对象
		Client client = Client.create();
		//6.指定上传文件的地址,该地址是 web 路径
		WebResource resource = client.resource(FILESERVERURL   fileName);
		//7.实现上传
		String result = resource.put(String.class, uploadFile.getBytes());
		System.out.println(result);
		return "success";
	}
}

2.3.5 编写 jsp 页面

代码语言:javascript复制
<form action="fileUpload2" method="post" enctype="multipart/form-data">
	名称:
	<input type="text" name="picname" />
	<br/>
	图片:
	<input type="file" name="uploadFile" />
	<br/>
	<input type="submit" value="上传" />
</form>

2.3.6 配置解析器

代码语言:javascript复制
<!-- 配置文件上传解析器 -->
<bean id="multipartResolver"
class="org.springframework.web.multipart.commons.CommonsMultipartResolver">
    <!-- 设置上传文件的最大尺寸为 5MB -->
    <property name="maxUploadSize">
        <value>5242880</value>
    </property>
</bean>

0 人点赞