SpringMVC-文件上传

传统方式上传

必要前提

  1. form表单的enctype取值必须是multipart/form-data
    • enctype:是表单请求正文类型;
    • 默认值是application/x-www-form-urlencoded。
  2. method属性取值必须是post
  3. 提供一个文件选择域<input type=”file” />

原理

当form表单的enctype取值不是默认值后,request.getParameter()将失效

enctype=”application/x-www-form-urlencoded”时,form表单的正文内容是:

​ key=value&key=value&key=value

enctype=”multipart/form-data”时,请求正文内容就变成:

每一部分都是MIME类型描述的正文

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

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

代码

jsp页面代码:

1
2
3
4
5
6
<%--传统方式文件上传--%>
<form action="user/fileupload1" method="post" enctype="multipart/form-data">
选择文件:<input type="file" name="upload"/>
<br>
<input type="submit" value="上传">
</form>

控制器代码:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
/**
* 文件上传
*/
@RequestMapping(value = "fileupload1")
public String fileupload1(HttpServletRequest request) throws Exception {
System.out.println("文件上传。。。");
// 使用fileupload组件完成文件上传
// 上传位置
String realPath = request.getSession().getServletContext().getRealPath("/uploads");
// 判断,该路径是否存在
File file = new File(realPath);
if (!file.exists()){
// 创建文件夹
file.mkdirs();
}
// 解析request对象,获取文件上传项
DiskFileItemFactory factory= new DiskFileItemFactory();
ServletFileUpload upload = new ServletFileUpload(factory);
// 解析request
List<FileItem> fileItems = upload.parseRequest(request);
// 遍历
for (FileItem item : fileItems) {
//进行判断,当前item想是否是上传文件项
if(item.isFormField()){
//说明普通表单项
}else{
// 说明上传文件项
// 获取上传文件的名称
String filename = item.getName();
//完成文件上传
item.write(new File(realPath,filename));
//删除临时文件
item.delete();
}
}
return "success";
}

上传结果

上传结果

SpringMVC方式上传

SpringMVC提供了MultipartFile对象,该对象表示上传的文件,要求变量名必须和表单file标签的name属性名称相同

需要配置文件解析器

配置文件解析器

springmvc.xml配置:

1
2
3
4
5
<!--配置文件解析器 id值必须是multipartResolver  -->
<bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver">
<!--设置上传文件最大10M,即10*1024*1024=10485760-->
<property name="maxUploadSize" value="10485760"/>
</bean>

jsp页面代码:

1
2
3
4
5
6
7
<h3>SpringMVC方式文件上传</h3>
<%--SpringMVC方式文件上传--%>
<form action="user/fileupload2" method="post" enctype="multipart/form-data">
选择文件:<input type="file" name="upload"/>
<br>
<input type="submit" value="上传">
</form>

控制器代码:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
/**
* SpringMVC方式文件上传
*/
@RequestMapping(value = "fileupload2")
public String fileupload2(HttpServletRequest request, MultipartFile upload) throws Exception {
System.out.println("SpringMVC方式文件上传。。。");
// 上传位置
String realPath = request.getSession().getServletContext().getRealPath("/uploads");
// 判断,该路径是否存在
File file = new File(realPath);
if (!file.exists()){
// 创建文件夹
file.mkdirs();
}
// 获取上传文件的名称
String filename =upload.getOriginalFilename();
String uuid = UUID.randomUUID().toString().replace("-", "");
filename=uuid+"_"+filename;
//完成文件上传
upload.transferTo(new File(realPath,filename));
return "success";
}

SpringMVC跨服务器方式上传

搭建图片服务器:

​ 创建一个新的javaweb工程,使用tomcat启动就可以。

导入开发需要的jar包:

1
2
3
4
5
6
7
8
9
10
<dependency>
<groupId>com.sun.jersey</groupId>
<artifactId>jersey-core</artifactId>
<version>1.18.1</version>
</dependency>
<dependency>
<groupId>com.sun.jersey</groupId>
<artifactId>jersey-client</artifactId>
<version>1.18.1</version>
</dependency>

jsp页眉代码:

1
2
3
4
5
6
7
<h3>SpringMVC跨服务器方式文件上传</h3>
<%--SpringMVC跨服务器方式文件上传--%>
<form action="user/fileupload3" method="post" enctype="multipart/form-data">
选择文件:<input type="file" name="upload"/>
<br>
<input type="submit" value="上传">
</form>

控制器代码:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
/**
* SpringMVC跨服务器方式文件上传
*/
@RequestMapping(value = "fileupload3")
public String fileupload3(MultipartFile upload) throws Exception {
System.out.println("SpringMVC跨服务器方式文件上传。。。");
// 定义上传文件服务器路径
String realPath = "http://localhost:9090/fileupload_demo_war_exploded/uploads/";

// 获取上传文件的名称
String filename =upload.getOriginalFilename();
String uuid = UUID.randomUUID().toString().replace("-", "");
filename=uuid+"_"+filename;
//完成文件上传 跨服务器上传
//创建客户端对象
Client client = Client.create();
// 和图片服务器进行连接
WebResource webResource = client.resource(realPath + filename);
//上传文件
webResource.put(upload.getBytes());
return "success";
}

可能出现的问题:

关于跨服务器上传报500错误的,并且出现ClientHandlerException等等异常的。

1、先在tomcat文件下conf下的web.xml中添加

1
2
3
4
<init-param>
<param-name>readonly</param-name>
<param-value>false</param-value>
</init-param>

修改前:

1
2
3
4
5
6
7
8
9
10
11
12
13
<servlet>
<servlet-name>default</servlet-name>
<servlet-class>org.apache.catalina.servlets.DefaultServlet</servlet-class>
<init-param>
<param-name>debug</param-name>
<param-value>0</param-value>
</init-param>
<init-param>
<param-name>listings</param-name>
<param-value>false</param-value>
</init-param>
<load-on-startup>1</load-on-startup>
</servlet>

修改后:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
  <servlet>
<servlet-name>default</servlet-name>
<servlet-class>org.apache.catalina.servlets.DefaultServlet</servlet-class>
<init-param>
<param-name>debug</param-name>
<param-value>0</param-value>
</init-param>
<init-param>
<param-name>listings</param-name>
<param-value>false</param-value>
</init-param>
<init-param>
<param-name>readonly</param-name>
<param-value>false</param-value>
</init-param>
<load-on-startup>1</load-on-startup>
</servlet>

2.在fileupload Module(图片服务器)中,Target的uploads文件夹不能在idea中直接创建,需要打开存储目录下创建uploads文件夹

最后更新: 2020年07月10日 00:00

原始链接: http://ligangit.com/2020/07/06/SpringMVC-文件上传/

× 请我吃糖~
打赏二维码