核心代碼
由于HttpServletRequest不能直接取出文件數(shù)據(jù),所以將其強(qiáng)制轉(zhuǎn)換為MultipartHttpServletRequest
MultipartHttpServletRequest multipartRequest = (MultipartHttpServletRequest) request;
List<MultipartFile> files = multipartRequest.getFiles("files");
POST
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
|
/*提交表單*/ function myupload() { $.ajax({ url: "/exUploadController.do?uploadTest" , type : "POST" , async: false , cache: false , //此處設(shè)置false contentType: false , //必須設(shè)置false ,formupload1表單中必須設(shè)置enctype="multipart/form-data" processData: false , //必須設(shè)置fals data : new FormData(document.getElementById( "myForm" )), success: function (data) { alert(data); }, error: function (XMLHttpRequest, textStatus, errorThrown) { console.log(XMLHttpRequest); console.log(textStatus); console.log(errorThrown); } }) } |
Servlet
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
|
HttpServletRequest request; //獲取上傳圖片 MultipartHttpServletRequest mureq = (MultipartHttpServletRequest) request; Map<String, MultipartFile> files = mureq.getFileMap(); MultipartFile file = null ; if (files != null &&files.size()> 0) { Map.Entry<String, MultipartFile> f = files.entrySet().iterator().next(); file = f.getValue(); } //獲取項(xiàng)目部署的路徑 String rootPath = request.getSession().getServletContext().getRealPath( "/" ); //獲取上傳圖片的名稱 String fileName = file.getOriginalFilename(); //獲取上傳圖片的大小 float size = file.getSize() //在path路徑下創(chuàng)建一個(gè)文件 File newFile = new File(path); //判斷文件是否存在 if (!newFile.exists()) { newFile.mkdirs(); //不存在的話,就開辟一個(gè)空間 } //將上傳的文件存儲(chǔ) file.transferTo(newFile); |
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持服務(wù)器之家。
原文鏈接:https://www.cnblogs.com/effortfordream/p/13301839.html