轉載:
https://blog.csdn.net/weixin_39640122/article/details/80244527
轉載:
https://blog.csdn.net/weixin_30872157/article/details/98574513
首先呢,使用springMVC原生上傳文件方法,需要一些簡單的配置,不多說,上圖。
1.采用spring提供的上傳文件的方法
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
|
@RequestMapping
(
"springUpload"
)
public
String springUpload(HttpServletRequest request)
throws
IllegalStateException, IOException
{
long
startTime=System.currentTimeMillis();
//將當前上下文初始化給 CommonsMutipartResolver (多部分解析器)
CommonsMultipartResolver multipartResolver=
new
CommonsMultipartResolver(
request.getSession().getServletContext());
//檢查form中是否有enctype="multipart/form-data"
if
(multipartResolver.isMultipart(request))
{
//將request變成多部分request
MultipartHttpServletRequest multiRequest=(MultipartHttpServletRequest)request;
//獲取multiRequest 中所有的文件名
Iterator iter=multiRequest.getFileNames();
while
(iter.hasNext())
{
//一次遍歷所有文件
MultipartFile file=multiRequest.getFile(iter.next().toString());
if
(file!=
null
)
{
String path=
"E:/springUpload"
+file.getOriginalFilename();
//上傳
file.transferTo(
new
File(path));
}
}
}
long
endTime=System.currentTimeMillis();
System.out.println(
"Spring方法的運行時間:"
+String.valueOf(endTime-startTime)+
"ms"
);
return
"/success"
;
}
|
在這里故意加一個計時,待會就用它簡單的比較上傳時間問題(本人暫時還沒能力處理資源占用問題,所以這里也不做比較)
2.第二位選手,采用file.Transto 來保存上傳的文件,這是目前我認為最好的上傳方式,也是我最喜歡的上傳方式,代碼簡單,速度快。請看下面代碼。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
|
/*
* 采用file.Transto 來保存上傳的文件
*/
@RequestMapping
(
"fileUpload2"
)
public
String fileUpload2(
@RequestParam
(
"file"
) CommonsMultipartFile file)
throws
IOException {
long
startTime=System.currentTimeMillis();
System.out.println(
"fileName:"
+file.getOriginalFilename());
String path=
"E:/"
+
new
Date().getTime()+file.getOriginalFilename();
File newFile=
new
File(path);
//通過CommonsMultipartFile的方法直接寫文件(注意這個時候)
file.transferTo(newFile);
long
endTime=System.currentTimeMillis();
System.out.println(
"采用file.Transto的運行時間:"
+String.valueOf(endTime-startTime)+
"ms"
);
return
"/success"
;
}
|
3.第三種采用流的方式上傳,這種方法在新手學習的時候經常用到,但是我並不喜歡,因為它又慢又難寫,請看
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
|
@RequestMapping
(
"fileUpload"
)
public
String fileUpload(
@RequestParam
(
"file"
) CommonsMultipartFile file)
throws
IOException {
//用來檢測程序運行時間
long
startTime=System.currentTimeMillis();
System.out.println(
"fileName:"
+file.getOriginalFilename());
try
{
//獲取輸出流
OutputStream os=
new
FileOutputStream(
"E:/"
+
new
Date().getTime()+file.getOriginalFilename());
//獲取輸入流 CommonsMultipartFile 中可以直接得到文件的流
InputStream is=file.getInputStream();
byte
[] bts =
new
byte
[
1024
];
//一個一個字節的讀取並寫入
while
(is.read(bts)!=-
1
)
{
os.write(bts);
}
os.flush();
os.close();
is.close();
}
catch
(FileNotFoundException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
long
endTime=System.currentTimeMillis();
System.out.println(
"采用流上傳的方式的運行時間:"
+String.valueOf(endTime-startTime)+
"ms"
);
return
"/success"
;
}
|
方法寫好了,接下來,我們在本地做個簡單的評測,
1.寫個簡單的文件上傳頁面
2.分別選擇同一個文件,稍微大一點(我這里上傳的zookeeper3.3.6的安裝包,大小為11M),以區別處他們的耗時差異(最好不實用ie,很容易崩潰,親測)
3.統計耗時,請看下圖,結果一目了然。
在此補充說明一點,如果你認為采用流的方式上傳慢是因為我這里內存開辟小了,可以嘗試開大一點,但是依然不影響他的速度最慢的地位,如果內存開的過大,反倒影響速度。