亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

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

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

SpringMVC文件上傳及查看的示例代碼

發布時間:2020-08-31 16:39:31 來源:腳本之家 閱讀:152 作者:fanyank 欄目:編程語言

寫在前面

談到文件上傳,首先要說業務邏輯,如果上傳的文件大家都可以看(比如廣告或者首頁的banner)等,那么我們就把圖片放在靜態資源區(與css,js一樣的位置)中,如果文件是受保護的(像用戶只能查看自己上傳的照片),那么我們就把它存放在服務器中的某個專門存放圖片的位置。

本例分別展示了存放在兩個位置的上傳文件的方法,上傳之后,作為延伸,還添加了查看上傳的文件以及下載已經上傳的文件的功能。

準備工作

配置SpringMVC,導入commons包

在mvc-servlet.xml中配置文件上傳解析器

<!--文件上傳解析器-->
 <bean id="multipartResolver"
  class="org.springframework.web.multipart.commons.CommonsMultipartResolver">
  <property name="maxUploadSize" value="1000000"/>
  <property name="defaultEncoding" value="UTF-8" />
 </bean>

存放在靜態資源區

1、存放位置:

存放在項目中,所以路徑為相對項目的路徑。

/{yourproject}/webapp/static/img

2、配置響應的handler

@Controller
public class UploadController {
 @GetMapping("/upload")
 public String UploadHandler() {
 return "upload";
 }

 @PostMapping("/upload/static")
 public void wriToStatic(HttpServletRequest request,
       RedirectAttributes redirectAttributes,
       @RequestParam("fileName") MultipartFile file) {
 if(!file.isEmpty()) {
  //獲取目標文件夾
  String path = request.getServletContext().getRealPath("/") + "static/img/";
  //獲取用戶上傳的源文件名
  String fileName = file.getOriginalFileName();
  //新建文件
  File file1 = new File(path, fileName);
  //將文件寫入
  file.transferTo(file1);

  redirectAttributes.addFlashAttribute("message","upload to static success");
  return "redirect:/upload";
 } else {
  redirectAttributes.addFlashAttribute("message","upload file can not be empty");
  return "redirect:/upload";
 }

 }
}

存放在服務器

1、本例存放位置:

存放在服務器某個位置,與項目無關,所以地址為絕對路徑。

/Users/mac/Desktop/imgtemp/, 為目錄的絕對路徑。

2、配置響應的handler

...
@PostMapping("/upload/disk")
public String writeToDisk(HttpServletRequest request,
       @RequestParam("fileName") MultipartFile file,
       RedirectAttributes redirectAttributes) {
 if(!file.isEmpty()) {
 //獲取源文件名
 String fileName = file.getOriginalFileName();
 //獲取保存文件文件夾路徑
 String path = "/Users/mac/Desktop/imgtemp/";
 //新建文件
 File file1 = new File(path,fileName);
 //寫入文件
 file.transferTo(file1);
 }

}
...

延伸部分(文件的查看及下載)

由于響應是要以流的形式傳遞文件,我們需要正確的設置響應的MIMIE類型才能被瀏覽器正確的解析,應用程序文件的默認MIMIE類型為 application/octet-stream,MIME設置為該值后,瀏覽器不會自動執行或詢問執行這類文件,會以對待附件的形式直接將文件下載至本地。

更多關于MIMIE的解讀請查看這篇文章

如果我們如果想自定義下載文件的名字,那么就需要設置Content-Disposition消息。
Content-Disposition 消息頭指示回復的內容該以何種形式展示,是以內聯的形式(即網頁或者頁面的一部分),還是以附件的形式下載并保存到本地。

更過關于Content-Disposition的解讀請查看這篇文章

...
@GetMapping("/download/byDefault")
public void getImgByDefault(@RequestParam String fileName,
       @RequestParam(required=false,defaultValue="") String saveName),
       HttpServletResponse response {
 if(StringUtils.isEmpty(fileName)) {
  response.sendError(404);
  return;
 }
 //文件存放的路徑
 String path = "/Users/mac/Desktop/imgtemp/";
 //新建文件
 File file = new File(path,fileName);

 if(!file.exists()) {
  response.sendError(404);
  return;
 }
 //如果請求參數saveName不為空,進行文件的下載
 if(!StringUtils.isEmpty(saveName)) {
  //設置響應長度
  response.setContentLength((int)file.length());
  //設置響應的MIME類型為application/octet-stream
  response.setContentType(MediaType.APPLICATION_OCTET_STREAM_VALUE);

  saveName = new String(saveName.getBytes("UTF-8"),"ISO8859-1");
  //設置content-disposition為attachment;fileName=saveName
  response.setHeader(HttpHeaders.CONTENT_DISPOSITION, "attachment; filename=\""+saveName+"\"");
 }
 //讀取文件
 InputStream is = new FileInputStream(file);
 OutputStream os = response.getOutputStream();
 //將文件以流的形式輸出
 IOUtils.copy(is,os);
 os.flush();
 os.close();
 is.close();

}

我們還可以使用SpringMVC自帶的 ByteArrayHttpMessageConverter 轉化器來將文件輸出,該轉換器實現 HttpMessageConverter 接口。可讀取所有MIME的請求信息,響應信息的MIME為 application/octet-stream

...
@GetMapping("/download/byConvert")
public HttpEntity<byte[]> getImgByConvert(@RequestParam String fileName,
           @RequestParam(required=false,defaultValue="") String saveName) {
 if(StringUtils.isEmpty(fileName)) {
  return new ResponseEntity<>(HttpStatus.NOT_FOUND);
 }

 String path = "/Users/mac/Desktop/imgtemp/";
 File file = new File(path,fileName);

 if(!file.exists()) {
  return new ResponseEntity<>(HttpStatus.NOT_FOUND);
 }

 HttpHeaders headers = new HttpHeaders();
 if(!StringUtils.isEmpty(saveName)) {
  headers.setContentType(MediaType.APPLICATION_OCTET_STREAM_VALUE);
  headers.setContentLength(file.length());

  saveName = new Sting(saveName.getBytes("UTF-8"),"ISO8859-1");
  headers.add(HttpHeaders.CONTENT_DISPOSITION,"attachment;fileName=\"" + saveName + "\"");
 } else {
  headers.setContentType(MediaType.IMAGE_PNG);
 }

 return new HttpEntity<>(FileCopyUtils.copyToByteArray(file),headers);

}

upload.jsp

<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<%@taglib prefix="form" uri="http://www.springframework.org/tags/form" %>
<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
<!doctype html>
<html>
<head>
 <meta charset="UTF-8">
 <meta name="viewport"
   content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0">
 <meta http-equiv="X-UA-Compatible" content="ie=edge">
 <title>Document</title>
 <link rel="stylesheet" href="/static/bootstrap-3.3.5-dist/css/bootstrap.css" rel="external nofollow" >
</head>
<body>
<div class="container">
 <h2 class="text-center">上傳文件撒</h2>
 <c:if test="${not empty message}">
  <h3>${message}</h3>
 </c:if>


 <form:form enctype="multipart/form-data" action="/upload/static">
  <p class="text-info">上傳至/web/static</p>
  <label for="">上傳文件:</label>
  <input type="file" name="uploadFile">

  <button class="btn btn-default">提交</button>
 </form:form>



 <form:form enctype="multipart/form-data" action="/upload/disk">
  <p class="text-info">上傳至Disk</p>
  <label for="">上傳文件</label>
  <input type="file" name="uploadFile">

  <button class="btn btn-default">提交</button>
 </form:form>

 <div class="container">
  <button class="btn btn-default">
   <a href="/download/byDefault?fileName=dubbo.png" rel="external nofollow" target="_blank">使用默認方式查看上傳至Disk的dubbo圖片</a>
  </button>
  <button class="btn btn-default">
   <a href="/download/byDefault?fileName=dubbo.png&saveName=dubb.png" rel="external nofollow" >使用默認方式下載dubbo圖片</a>
  </button>
 </div>

 <div class="container">
  <button class="btn btn-default">
   <a href="/download/byConvert?fileName=dubbo.png" rel="external nofollow" target="_blank">使用MVC轉化器查看上傳至Disk的dubbo圖片</a>
  </button>
  <button class="btn btn-default">
   <a href="/download/byConvert?fileName=dubbo.png&saveName=dub.png" rel="external nofollow" >使用MVC轉化器下載上傳至Disk的dubbo圖片</a>
  </button>

 </div>
</div>
</body>
</html>

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

向AI問一下細節

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

AI

汤原县| 益阳市| 锦屏县| 拉萨市| 阜康市| 侯马市| 高平市| 兴隆县| 兴文县| 云和县| 拉萨市| 彭泽县| 安多县| 台中市| 抚松县| 咸阳市| 晋中市| 信丰县| 樟树市| 凤庆县| 鄂温| 江山市| 广汉市| 黔西| 伊金霍洛旗| 宣恩县| 沐川县| 洪江市| 兴文县| 东阳市| 普兰店市| 黑河市| 鲜城| 屏山县| 虹口区| 廊坊市| 黔江区| 惠安县| 铜川市| 盱眙县| 从化市|