這篇文章主要講解了Spring Boot如何整合web層,內(nèi)容清晰明了,對(duì)此有興趣的小伙伴可以學(xué)習(xí)一下,相信大家閱讀完之后會(huì)有幫助。
專注于為中小企業(yè)提供網(wǎng)站設(shè)計(jì)、成都網(wǎng)站制作服務(wù),電腦端+手機(jī)端+微信端的三站合一,更高效的管理,為中小企業(yè)恩陽(yáng)免費(fèi)做網(wǎng)站提供優(yōu)質(zhì)的服務(wù)。我們立足成都,凝聚了一批互聯(lián)網(wǎng)行業(yè)人才,有力地推動(dòng)了成百上千企業(yè)的穩(wěn)健成長(zhǎng),幫助中小企業(yè)通過(guò)網(wǎng)站建設(shè)實(shí)現(xiàn)規(guī)模擴(kuò)充和轉(zhuǎn)變。
Spring Boot中對(duì)Spring MVC的文件上傳是一脈相傳的,我們雙擊shift去搜CommonsMultipartResolver這個(gè)類,它是文件上傳的一個(gè)實(shí)現(xiàn)類。我們先看一下源碼:
我們可以看到它是MultipartResolver的實(shí)現(xiàn)類,我們?cè)貱trl+H,就可以看到右側(cè)MultipartResolver的兩個(gè)實(shí)現(xiàn)類。第一個(gè)實(shí)現(xiàn)類在servlet3.0之后,什么都不用加,就可以直接使用。第二個(gè)實(shí)現(xiàn)類的兼容性要好一些,早期的servlet也可以使用,但需要自己額外的加依賴。那么在Spring Boot中,我們就可以直接使用第一個(gè)實(shí)現(xiàn)類去完成文件上傳。
只需要一個(gè)controller和一個(gè)靜態(tài)html文件,就可以,先看一下代碼
package com.zl.upload; import org.springframework.web.bind.annotation.PostMapping; import org.springframework.web.bind.annotation.RestController; import org.springframework.web.multipart.MultipartFile; import javax.servlet.http.HttpServletRequest; import java.io.File; import java.io.IOException; import java.text.SimpleDateFormat; import java.util.Date; import java.util.UUID; import java.util.logging.SimpleFormatter; @RestController public class UploadController { SimpleDateFormat ss=new SimpleDateFormat("yyyy/MM/dd/"); @PostMapping("/upload") //HttpServletRequest request獲取緩存地址,一般這里使用圖片服務(wù)器 public String upload(MultipartFile multipartFile , HttpServletRequest request){ //圖片保存在項(xiàng)目的運(yùn)行路徑下 String format = ss.format(new Date()); String realpath = request.getServletContext().getRealPath("img") + format; //創(chuàng)建保存的文件夾 File f = new File(realpath); if(!f.exists()){ f.mkdirs(); } //因?yàn)槲募赡軙?huì)重復(fù),所以要對(duì)文件名進(jìn)行修改 String oldName = multipartFile.getOriginalFilename(); System.out.println(oldName); String newName = UUID.randomUUID().toString() + oldName.substring(oldName.lastIndexOf(".")); //保存圖片 try { multipartFile.transferTo(new File(f,newName)); //獲取路徑,動(dòng)態(tài)獲取,因?yàn)橛锌赡苁莌ttp,也有可能是HTTPS String path = request.getScheme() + "://" + request.getServerName() + ":" + request.getServerPort() + "/img" + format + newName; return path ; } catch (IOException e) { e.printStackTrace(); } return "error"; } }
第一步,創(chuàng)建文件的存放地址,和路徑
第二步,修改文件名
第三步,保存文件(文件件,和文件名)
后端的處理就完了,我們看一下前臺(tái)如何處理
文件上傳
前端處理很簡(jiǎn)單,就是開(kāi)啟文件上傳通道就可以了。
但是這種做法在前后端分離開(kāi)發(fā)中很少使用,接下來(lái)我們看一下用ajax如何實(shí)現(xiàn)。
后端的不用變,前端的改成ajax的:
ajax文件上傳
這個(gè)是單文件上傳,如果是多文件上傳,改如何處理呢?
后端處理
@PostMapping("/uploads") //HttpServletRequest request獲取緩存地址,一般這里使用圖片服務(wù)器 public String uploads(MultipartFile [] multipartFiles , HttpServletRequest request){ //圖片保存在項(xiàng)目的運(yùn)行路徑下 String format = ss.format(new Date()); String realpath = request.getServletContext().getRealPath("img") + format; //創(chuàng)建保存的文件夾 File f = new File(realpath); if(!f.exists()){ f.mkdirs(); } //用for循環(huán)獲取每個(gè)文件 for (MultipartFile file: multipartFiles){ String oldName = file.getOriginalFilename(); String newName = UUID.randomUUID().toString() + oldName.substring(oldName.lastIndexOf(".")); //保存圖片 try { file.transferTo(new File(f,newName)); //獲取路徑,動(dòng)態(tài)獲取,因?yàn)橛锌赡苁莌ttp,也有可能是HTTPS String path = request.getScheme() + "://" + request.getServerName() + ":" + request.getServerPort() + "/img" + format + newName; System.out.println(path); } catch (IOException e) { e.printStackTrace(); } } //因?yàn)槲募赡軙?huì)重復(fù),所以要對(duì)文件名進(jìn)行修改 return "success"; }
前端處理:
文件上傳
看完上述內(nèi)容,是不是對(duì)Spring Boot如何整合web層有進(jìn)一步的了解,如果還想學(xué)習(xí)更多內(nèi)容,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。