小編給大家分享一下SpringBoot+Vue.js怎么實現前后端分離的文件上傳功能,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
Vue是一款友好的、多用途且高性能的JavaScript框架,使用vue可以創建可維護性和可測試性更強的代碼庫,Vue允許可以將一個網頁分割成可復用的組件,每個組件都包含屬于自己的HTML、CSS、JavaScript,以用來渲染網頁中相應的地方,所以越來越多的前端開發者使用vue。
后端項目搭建
我使用的是SpringBoot1.5.10+JDK8+IDEA 使用IDEA新建一個SpringBoot項目,一直點next即可
項目創建成功后,maven的pom配置如下
<dependencies> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter</artifactId> </dependency> <!--加入web模塊--> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-test</artifactId> <scope>test</scope> </dependency> <dependency> <groupId>com.alibaba</groupId> <artifactId>fastjson</artifactId> <version>1.2.39</version> </dependency> </dependencies>
接下來編寫上傳的API接口
@RestController @RequestMapping("/upload") @CrossOrigin public class UploadController { @Value("${prop.upload-folder}") private String UPLOAD_FOLDER; private Logger logger = LoggerFactory.getLogger(UploadController.class); @PostMapping("/singlefile") public Object singleFileUpload(MultipartFile file) { logger.debug("傳入的文件參數:{}", JSON.toJSONString(file, true)); if (Objects.isNull(file) || file.isEmpty()) { logger.error("文件為空"); return "文件為空,請重新上傳"; } try { byte[] bytes = file.getBytes(); Path path = Paths.get(UPLOAD_FOLDER + file.getOriginalFilename()); //如果沒有files文件夾,則創建 if (!Files.isWritable(path)) { Files.createDirectories(Paths.get(UPLOAD_FOLDER)); } //文件寫入指定路徑 Files.write(path, bytes); logger.debug("文件寫入成功..."); return "文件上傳成功"; } catch (IOException e) { e.printStackTrace(); return "后端異常..."; } } }
CrossOrigin注解:解決跨域問題,因為前后端完全分離,跨域問題在所難免,加上這個注解會讓Controller支持跨域,如果去掉這個注解,前端Ajax請求不會到后端。這只是跨域的一種解決方法,還有其他解決方法這篇文章先不涉及。
MultipartFile:SpringMVC的multipartFile對象,用于接收前端請求傳入的FormData。
PostMapping是Spring4.3以后引入的新注解,是為了簡化HTTP方法的映射,相當于我們常用的@RequestMapping(value = "/xx", method = RequestMethod.POST).
后端至此已經做完了,很簡單。
前端項目搭建
我使用的是Node8+Webpack3+Vue2
本地需要安裝node環境,且安裝Vue-cli,使用Vue-cli生成一個Vue項目。
項目創建成功之后,用WebStorm打開,就可以寫一個簡單的上傳例子了,主要代碼如下:
<template> <div class="hello"> <h2>{{ msg }}</h2> <form> <input type="file" @change="getFile($event)"> <button class="button button-primary button-pill button-small" @click="submit($event)">提交</button> </form> </div> </template> <script> import axios from 'axios'; export default { name: 'HelloWorld', data() { return { msg: 'Welcome to Your Vue.js App', file: '' } }, methods: { getFile: function (event) { this.file = event.target.files[0]; console.log(this.file); }, submit: function (event) { //阻止元素發生默認的行為 event.preventDefault(); let formData = new FormData(); formData.append("file", this.file); axios.post('http://localhost:8082/upload/singlefile', formData) .then(function (response) { alert(response.data); console.log(response); window.location.reload(); }) .catch(function (error) { alert("上傳失敗"); console.log(error); window.location.reload(); }); } } } </script>
使用Axios向后端發送Ajax請求,使用H5的FormData對象封裝圖片數據
測試
啟動服務端,直接運行BootApplication類的main方法,端口8082
啟動前端,端口默認8080,cd到前端目錄下,分別執行:
npm install npm run dev
啟動成功后訪問localhost:8080
選擇一張圖片上傳,可以看到,上傳成功之后,后端指定目錄下也有了圖片文件
以上是“SpringBoot+Vue.js怎么實現前后端分離的文件上傳功能”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。