您好,登錄后才能下訂單哦!
簡單幾步,實現SpringMVC+servlet3.0文件上傳功能:
第一步:配置web.xml文件中的servlet,添加multipart-config:
<!-- 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> <!--單個文件最大大小:5MB--> <max-request-size>20971520</max-request-size> <!--所有文件最大大小:20MB--> <file-size-threshold>0</file-size-threshold> <!-- 超過這個大小直接存硬盤,而不是內存 --> </multipart-config> </servlet> <servlet-mapping> <servlet-name>myWeb</servlet-name> <url-pattern>/</url-pattern> </servlet-mapping>
第二步:在servlet.xml中配置MultipartResolver:
第三步:創建接收form表單的Controller:
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目錄、或一個指定的絕對目錄下 */ 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的絕對路徑 String appPath = request.getServletContext().getRealPath(""); // 構造文件存放的路徑 String savePath = appPath + File.separator + SAVE_DIR; // 如果文件存放路徑不存在,則mkdir一個 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">參數由@RequestParam Map<String, Object> p接收。
第四步:form表單提交文件以及其他數據:
<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> <h3>File Upload</h3> <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_jb51.rar
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持億速云。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。