博主最近在做一個內網項目,內部可以訪問外部數據,但是外部訪問不了內部數據,這也就造成了可能文件無法上傳,所以博主另辟蹊徑,在本地服務器上建立一個文件夾專門用來存儲上傳數據。
環境:jdk,tomcat
一、前臺上傳文件(ajax上傳)
1
|
< input type = "file" name = "annexUrl" id = "annexUrl" multiple = "multiple" /> |
其中multiple=“multiple”,設置文件多上傳
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
|
function uploadFile() { var files = document.getElementById( "annexUrl" ).files; if (files.length != 0 ) { var formData = new FormData(); for (var i = 0 ; i < files.length; i++) { var file = files[i]; formData.append(file.name, file); } $.ajax({ url: 'cdc/public/saveFiles' , type: 'POST' , cache: false , data: formData, //這個參數是jquery特有的,不進行序列化,因為我們不是json格式的字符串,而是要傳文件 processData: false , //注意這里一定要設置contentType:false,不然會默認為傳的是字符串,這樣文件就傳不過去了 contentType: false , success: function (data) { save(data.data); } }); } else { save(); } } |
這里需要使用到formData對象用來封裝file文件對象,save()方法是用來保存上傳之后返回過來的文件路徑,保存到數據庫,便于下載。
二、后臺接收文件,并上傳至服務器
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
|
// 多文件上傳,返回一個對象集合(附件地址,名稱) @RequestMapping (value = "saveFiles" , method = RequestMethod.POST) @ResponseBody public JSONObject saveFiles(HttpServletRequest request, HttpServletResponse response) { JSONObject jsonObject = new JSONObject(); try { request.setCharacterEncoding( "UTF-8" ); } catch (UnsupportedEncodingException e) { e.printStackTrace(); } Collection<Part> parts = null ; try { parts = request.getParts(); } catch (IOException e) { e.printStackTrace(); } catch (ServletException e) { e.printStackTrace(); } Iterator<Part> iterator = parts.iterator(); // 名稱集合,返回給前臺 List<String> list = new ArrayList<>(); while (iterator.hasNext()) { Part part = iterator.next(); // 生成實際存儲的真實文件名(唯一) // 不知道為什么,文件上傳必須得包含獲取到的文件名,否則報文件名、目錄名或卷標語法不正確,圖片上傳沒有這種限制 // 文件名,保存導數據庫,用來界面顯示 String name = part.getName(); String realName = UUID.randomUUID().toString() + name; list.add(name + "&&" + realName); ///home/tomcat/apache-tomcat-9.0.1/files String realPath = "D:" + File.separator + "apache-tomcat-8.5.15" + File.separator + "files" ; // String realPath = "C:" + File.separator + "XHJ224" + File.separator + "software" + File.separator + "apache-tomcat-9.0.1" + File.separator + "files"; // String realPath = File.separator + "home" + File.separator + "tomcat" + File.separator + "apache-tomcat-9.0.1" + File.separator + "files"; File file = new File(realPath); //如果目錄不存在 if (!file.isDirectory()) { //創建文件上傳目錄 file.mkdirs(); } // 文件存放的真實路徑 String filePath = realPath + File.separator + realName; try { part.write(filePath); } catch (IOException e) { e.printStackTrace(); } } jsonObject.put( "data" , list); return jsonObject; } |
其中list集合添加了一個由文件名和真實文件名拼接的字符串,后期save需要。realName是為了防止多上傳文件名沖突,realPath是文件保存路徑,不同的操作系統有不同的路徑,realPath最好放在tomcat下,便于項目移植。
其中File.separator為路徑分隔符,他能自動識別是哪個操作系統而使用不同的路徑分隔符(windows是‘\',linux是‘/')。最后將list返回給前臺。
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持服務器之家。
原文鏈接:http://blog.csdn.net/KKKun_Joe/article/details/78338552