一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務(wù)器之家:專注于服務(wù)器技術(shù)及軟件下載分享
分類導(dǎo)航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術(shù)|正則表達(dá)式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務(wù)器之家 - 編程語言 - Java教程 - SpringMVC + servlet3.0 文件上傳的配置和實(shí)現(xiàn)代碼

SpringMVC + servlet3.0 文件上傳的配置和實(shí)現(xiàn)代碼

2020-09-08 10:46Clement-Xu Java教程

本篇文章主要介紹了SpringMVC + servlet3.0 文件上傳的配置和實(shí)現(xiàn)代碼,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下。

簡(jiǎn)單幾步,實(shí)現(xiàn)SpringMVC+servlet3.0文件上傳功能:

第一步:配置web.xml文件中的servlet,添加multipart-config:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
<!-- SpringMVC -->
<servlet>
 <servlet-name>myWeb</servlet-name>
 <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
 <init-param>
  <param-name>contextConfigLocation</param-name>
  <param-value>classpath:springmvc/servlet.xml</param-value>
 </init-param>
 <load-on-startup>1</load-on-startup>
 <multipart-config>
  <!-- <location>/</location> -->
  <max-file-size>5242880</max-file-size> <!--單個(gè)文件最大大小:5MB-->
  <max-request-size>20971520</max-request-size> <!--所有文件最大大小:20MB-->
  <file-size-threshold>0</file-size-threshold> <!-- 超過這個(gè)大小直接存硬盤,而不是內(nèi)存 -->
 </multipart-config>
</servlet>
 
<servlet-mapping>
 <servlet-name>myWeb</servlet-name>
 <url-pattern>/</url-pattern>
</servlet-mapping>

第二步:在servlet.xml中配置MultipartResolver:

 

復(fù)制代碼 代碼如下:

<bean id="multipartResolver" class="org.springframework.web.multipart.support.StandardServletMultipartResolver"/> 

 

第三步:創(chuàng)建接收form表單的Controller:

?
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
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
package com.xjj.web.controller;
 
import java.io.File;
import java.io.IOException;
import java.util.Map;
 
import javax.servlet.ServletException;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.Part;
 
import org.springframework.stereotype.Controller;
import org.springframework.util.StringUtils;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.ResponseBody;
 
import com.xjj.json.JsonResult;
 
/**
 * 文件上傳
 * @author XuJijun
 *
 */
@Controller
@RequestMapping("/servlet/file")
public class FileUploadController {
  
 /**
  * 保存文件的目錄,放在web目錄、或一個(gè)指定的絕對(duì)目錄下
  */
  private static final String SAVE_DIR = "uploadFiles";
  
 @RequestMapping("/upload")
 public @ResponseBody JsonResult upload(HttpServletRequest request, HttpServletResponse response, @RequestParam Map<String, Object> p)
   throws ServletException, IOException {
 
  // 獲取 web application的絕對(duì)路徑
  String appPath = request.getServletContext().getRealPath("");
   
  // 構(gòu)造文件存放的路徑
  String savePath = appPath + File.separator + SAVE_DIR;
 
  // 如果文件存放路徑不存在,則mkdir一個(gè)
  File fileSaveDir = new File(savePath);
  if (!fileSaveDir.exists()) {
   fileSaveDir.mkdir();
  }
 
  for (Part part : request.getParts()) {
   String fileName = extractFileName(part);
   if(!StringUtils.isEmpty(fileName)){
    part.write(savePath + File.separator + fileName);
   }
  }
 
  return new JsonResult("200", "文件上傳成功!", savePath);
 }
  
 /**
  * 從content-disposition頭中獲取源文件名
  *
  * content-disposition頭的格式如下:
  * form-data; name="dataFile"; filename="PHOTO.JPG"
  *
  * @param part
  * @return
  */
 private String extractFileName(Part part) {
  String contentDisp = part.getHeader("content-disposition");
  String[] items = contentDisp.split(";");
  for (String s : items) {
   if (s.trim().startsWith("filename")) {
    return s.substring(s.indexOf("=") + 2, s.length()-1);
   }
  }
  return "";
 }
 
}

其中,request.getParts()用來獲取multipart,其中就包括文件。其他<input type="text">參數(shù)由@RequestParam Map<String, Object> p接收。

第四步:form表單提交文件以及其他數(shù)據(jù):

?
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
<html>
<head>
<meta charset="UTF-8">
 <link href="../resources/css/common.css" rel="external nofollow" rel="stylesheet" />
 <script src="../resources/js/jquery-2.1.4.js"></script>
  
</head>
 
<body>
<h2>File Upload</h2>
 <form method="post" enctype="multipart/form-data">
  <input type="text" name="aaa"/><br/>
  選擇要上傳的文件:<input type="file" name="file" size="60" /><br/>
  <input type="file" name="file" size="60" /><br/>
  <br/> <!-- <input type="submit" value="開始上傳" /> -->
 </form>
  
 <input type="button" value="上傳吧" onclick="upload()"/>
</body>
 
<script>
 function upload(){
  $("form").attr('action', "http://localhost:8080/MyJavaStudio/servlet/file/upload");
  $("form").submit();
 }
</script>
 
</html>

注:通過jQuery來submit表單,以自由拼裝action url,自由定義提交按鈕。

github:https://github.com/xujijun/MyJavaStudio

完整代碼下載:MyJavaStudio.rar

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持服務(wù)器之家。

原文鏈接:http://blog.csdn.net/clementad/article/details/49533189

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 天堂8在线天堂bt | 美女胸又大又黄又www小说 | 荷兰精品女人性hd | 欧美成人影院免费观 | 亚洲精品国产福利片 | 国产精品福利 | 国产目拍亚洲精品一区二区三区 | 亚洲毛片免费看 | 我和子伦系列小说 | 无限资源在线观看高清 | 成人123| 国产hd老头老太婆 | 色综合久久综精品 | 全色黄大色黄大片爽一次 | 成人免费网站视频ww | 国产精品国产香蕉在线观看网 | 91tv破解版不限次数 | 国产精品资源在线观看网站 | 含羞草国产亚洲精品岁国产精品 | 色菇凉天天综合网 | 按摩师他揉我奶好爽捏我奶 | 成人资源影音先锋久久资源网 | 国产精品视频第一区二区三区 | 国产精品拍拍拍福利在线观看 | 成人免费高清视频 | 性欧美13处丶14处 | 日本天堂影院在线播放 | 偷偷狠狠的日日高清完整视频 | 亚洲精品一区在线观看 | 亚洲色图丝袜 | 国产91免费 | 国产一区精品视频 | 日本久久啪啪婷婷激情五月 | 国语精彩对白2021 | 波多野结衣被绝伦强在线观看 | 能看的毛片网站 | 高清在线免费 | 2021最新国产成人精品免费 | 日本在线视频网 | 精品国产自在在线在线观看 | 亚洲激情一区 |