一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務(wù)器之家:專注于服務(wù)器技術(shù)及軟件下載分享
分類導(dǎo)航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術(shù)|正則表達(dá)式|C/C++|IOS|C#|Swift|Android|VB|R語(yǔ)言|JavaScript|易語(yǔ)言|vb.net|

服務(wù)器之家 - 編程語(yǔ)言 - Java教程 - SpringBoot 文件或圖片上傳與下載功能的實(shí)現(xiàn)

SpringBoot 文件或圖片上傳與下載功能的實(shí)現(xiàn)

2021-08-15 16:45風(fēng)青宇 Java教程

這篇文章主要介紹了SpringBoot 文件或圖片上傳與下載功能的實(shí)現(xiàn),本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下

導(dǎo)入依賴(pom.xml)

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
 <!-- 上傳下載需要設(shè)計(jì)到的jar包 -->
<dependency>
 <groupId>commons-io</groupId>
 <artifactId>commons-io</artifactId>
 <version>2.6</version>
</dependency>
<dependency>
 <groupId>commons-fileupload</groupId>
 <artifactId>commons-fileupload</artifactId>
 <version>1.3.3</version>
</dependency>
<!--servlet-api導(dǎo)入高版本的-->
<dependency>
 <groupId>javax.servlet</groupId>
 <artifactId>javax.servlet-api</artifactId>
 <version>4.0.1</version>
</dependency>
<!-- 圖片處理類 -->
<dependency>
 <groupId>net.coobird</groupId>
 <artifactId>thumbnailator</artifactId>
 <version>0.4.8</version>
</dependency>

全局配置 application.properties

?
1
2
3
# 上傳文件大小
spring.servlet.multipart.max-file-size=5MB
spring.servlet.multipart.max-request-size=5MB

創(chuàng)建 WebMvcConfig 配置類  靜態(tài)資源映射

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
@Configuration
public class WebMvcConfig implements WebMvcConfigurer {
 
 @Override
 public void addResourceHandlers(ResourceHandlerRegistry registry) {
  ApplicationHome h = new ApplicationHome(getClass());
  File jarF = h.getSource();
  String dirPath = jarF.getParentFile().toString()+"/upload/";
 
  String os = System.getProperty("os.name");
 
  if (os.toLowerCase().startsWith("win")) { //如果是Windows系統(tǒng)
   registry.addResourceHandler("/upload/**").addResourceLocations("file:"+dirPath);
  } else {
   registry.addResourceHandler("/upload/**").addResourceLocations("file:"+dirPath);
  }
 }
 
}

文件或圖片上傳

控制層

?
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
// 上傳文件
 @ResponseBody
 @RequestMapping("/upload")
 public String fileUpload(@RequestParam("files") MultipartFile files) throws IOException {
//  // win系統(tǒng) 上傳路徑保存設(shè)置
//  // 獲取項(xiàng)目路徑
//  File projectPath = new File(ResourceUtils.getURL("classpath:").getPath());
//  // 絕對(duì)路徑=項(xiàng)目路徑+自定義路徑
//  File pathFile = new File(projectPath.getAbsolutePath(), "static/upload/");
//  if (!pathFile.exists()) {
//   pathFile.mkdirs();
//  }
//  //上傳文件地址
//  UUID uuid = UUID.randomUUID();
//  File serverFile = new File(pathFile, uuid + "_" + files.getOriginalFilename());
//  files.transferTo(serverFile);
//
//  String imgPath = ("/upload/" + uuid + "_" + files.getOriginalFilename()).replace("\\", "/");
//
//  return imgPath;
 
  // Linux服務(wù)器 上傳路徑保存設(shè)置
  // 項(xiàng)目路徑 /home/www/
  File pathFile = new File("/home/www/upload/");
  if (!pathFile.exists()) {
   pathFile.mkdirs();
  }
  //上傳文件地址
  UUID uuid = UUID.randomUUID();
  File serverFile = new File(pathFile, uuid + "_" + files.getOriginalFilename());
  files.transferTo(serverFile);
 
  String imgPath = ("/upload/" + uuid + "_" + files.getOriginalFilename()).replace("\\", "/");
 
  return imgPath;
 }

HTML頁(yè)面   

Ajax 無刷新上傳

?
1
2
3
4
5
6
7
8
9
<form action="" class="layui-form" enctype="multipart/form-data" method="post">
  <input type="hidden" name="blogImg" id="imgPath" value="">
  <div class="form-group">
    <label>圖片上傳</label>
    <input type='file' style='margin: 5px;' name='files' required><br>
    <button type="button" class="layui-btn" id="img_upload">上傳圖片</button>
  </div>
  <input type="submit">
</form>

JS

?
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
//普通圖片上傳
  $('#img_upload').click(function () {
   var formData = new FormData();
   //獲取選擇的文件
   $.each($('input[name="files"]'),function (index,item) {
    formData.append("files",item.files[0])
   });
 
   //發(fā)送異步請(qǐng)求
   $.ajax({
    method:'post',
    url: '[[@{/user/upload}]]', // 文件上傳接口
    data:formData,
    processData: false,
    contentType:false,
    success:function (data) {
     //成功返回觸發(fā)的方法
     $('#imgPath').val(data);
     alert("上傳成功");
    },
    //請(qǐng)求失敗觸發(fā)的方法
    error:function () {
     alert("上傳失敗");
    }
   });
  });

文件或圖片下載

控制層

?
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
@RequestMapping(value="/download")
public String downloads(HttpServletResponse response ,HttpServletRequest request) throws Exception{
 //要下載的圖片地址
 String path = request.getServletContext().getRealPath("/upload");
 String fileName = "基礎(chǔ)語(yǔ)法.jpg";
 
 //1、設(shè)置response 響應(yīng)頭
 response.reset(); //設(shè)置頁(yè)面不緩存,清空buffer
 response.setCharacterEncoding("UTF-8"); //字符編碼
 response.setContentType("multipart/form-data"); //二進(jìn)制傳輸數(shù)據(jù)
 //設(shè)置響應(yīng)頭
 response.setHeader("Content-Disposition",
   "attachment;fileName="+URLEncoder.encode(fileName, "UTF-8"));
 
 File file = new File(path,fileName);
 //2、 讀取文件--輸入流
 InputStream input=new FileInputStream(file);
 //3、 寫出文件--輸出流
 OutputStream out = response.getOutputStream();
 
 byte[] buff =new byte[1024];
 int index=0;
 //4、執(zhí)行 寫出操作
 while((index= input.read(buff))!= -1){
  out.write(buff, 0, index);
  out.flush();
 }
 out.close();
 input.close();
 return null;
}

HTML頁(yè)面 

?
1
<a href="/download" rel="external nofollow" >點(diǎn)擊下載</a>

SpringBoot 文件或圖片上傳與下載就可以了

到此這篇關(guān)于SpringBoot 文件或圖片上傳與下載功能的實(shí)現(xiàn)的文章就介紹到這了,更多相關(guān)SpringBoot 文件上傳與下載內(nèi)容請(qǐng)搜索服務(wù)器之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持服務(wù)器之家!

原文鏈接:https://www.cnblogs.com/dmflysky/archive/2021/02/25/14450015.html

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 亚洲乱人伦在线 | 日韩在线资源 | 国产成人精品午夜在线播放 | porno18hd老师 | 国产精品va在线观看不 | 国产欧美另类久久精品91 | 精品一区二区三区在线视频观看 | 91色视| 2020国产精品永久在线观看 | 欧美成人一区二区 | 免费超级乱淫播放手机版 | 精品国产视频 | 久久这里有精品 | 日韩欧美一区二区三区视频 | 青草青草久热精品视频在线网站 | 福利一区二区在线观看 | 亚洲久草在线 | 日韩日韩日韩手机看片自拍 | 成人国产精品 | 欧美人体高清在线观看ggogo | 精品视频在线免费播放 | 亚洲欧美7777| 韩国三级 720p | 日韩在线a视频免费播放 | 肉文高h调教 | 日韩欧美中文字幕一区 | 日剧整部剧护妻狂魔免费观看全集 | 日韩亚洲人成在线综合 | ck7788免费视频 | 日韩精品高清自在线 | www.日日操 | 亚洲四虎 | 四虎免费在线观看 | 欧美一区二区三区在线观看不卡 | 男人边吃奶边做好爽视频免费 | 日韩天堂在线 | 九九99热 | 国产精自产拍久久久久久 | 好紧好爽的午夜寂寞视频 | 边摸边吃奶玩乳尖视频 | xxx美国|