中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

SpringMVC + servlet3.0 文件上傳的配置和實現代碼

發布時間:2020-09-21 07:00:06 來源:腳本之家 閱讀:149 作者:Clement-Xu 欄目:編程語言

簡單幾步,實現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:

復制代碼 代碼如下:

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

第三步:創建接收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

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持億速云。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

女性| 惠东县| 谢通门县| 万荣县| 鄱阳县| 南平市| 长兴县| 登封市| 百色市| 凤阳县| 南安市| 固原市| 靖西县| 屯留县| 合山市| 满城县| 仁化县| 昌吉市| 上饶县| 蕉岭县| 湘西| 南宫市| 新余市| 紫云| 饶阳县| 天镇县| 准格尔旗| 青阳县| 临泉县| 永康市| 石泉县| 靖远县| 库尔勒市| 昆明市| 阳春市| 贵溪市| 北辰区| 房山区| 清新县| 外汇| 武鸣县|