<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
通過 SpringBoot 實現了表單下的檔案上傳,前後端分離情況下的檔案上傳。本案例不連線資料庫,只做基本的檔案上傳操作。
在 SpringBoot 中不需要額外匯入其他依賴,正常引入即可。
後端 controller 的寫法
package com.dailyblue.java.controller; import org.springframework.util.ResourceUtils; import org.springframework.web.bind.annotation.PostMapping; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RequestParam; 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; @RestController @RequestMapping("/upload") public class UploadController { @PostMapping public String upload(@RequestParam("file") MultipartFile file, HttpServletRequest request) throws Exception { // file:上傳檔案 // 獲取到 images 的具體路徑 // String realPath = request.getRealPath("images"); String realPath = ResourceUtils.getURL("classpath:").getPath() + "/static/images"; System.out.println("上傳的檔案地址是:" + realPath); // 伺服器中對應的位置 // 產生唯一的檔名稱 String fileName = UUID.getUUid(); // 獲取到檔案字尾 String fileType = file.getOriginalFilename().substring(file.getOriginalFilename().lastIndexOf(".")); File src = new File(realPath, fileName + fileType); // 將file檔案傳遞到src去 file.transferTo(src); return "images/" + fileName + fileType; } }
這裡只做了簡單的檔案上傳,沒有限制檔案型別。
前端寫法
這裡分為兩種寫法,一種是常用的表單提交,另一種是當下較火的 Vue 上傳方式。
表單寫法
<form action="upload" method="post" enctype="multipart/form-data"> <input type="file" name="file"/> <button>上傳</button> </form>
Vue 寫法
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Title</title> </head> <body> <div id="app"> <img :src="'http://localhost:8081/'+img" v-show="flag"/> <input type="file" @change="changeImg"/> <button @click="upload">Vue 上傳</button> </div> </body> </html> <script src="js/vue.min.js"></script> <script src="js/axios.min.js"></script> <script> new Vue({ el: '#app', data: { file: null, img: '', flag: false }, methods: { changeImg(event) { this.file = event.target.files[0]; }, upload() { // 表單資料 let data = new FormData(); data.append('file', this.file); // 定義傳送格式 let type = { headers: { 'Content-Type': 'multipart/form-data' } } axios.post('http://localhost:8081/upload', data, type) .then((response) => { this.img = response.data; this.flag = true; }); } } }); </script>
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支援it145.com。
相關文章
<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
综合看Anker超能充系列的性价比很高,并且与不仅和iPhone12/苹果<em>Mac</em>Book很配,而且适合多设备充电需求的日常使用或差旅场景,不管是安卓还是Switch同样也能用得上它,希望这次分享能给准备购入充电器的小伙伴们有所
2021-06-01 09:31:42
除了L4WUDU与吴亦凡已经多次共事,成为了明面上的厂牌成员,吴亦凡还曾带领20XXCLUB全队参加2020年的一场音乐节,这也是20XXCLUB首次全员合照,王嗣尧Turbo、陈彦希Regi、<em>Mac</em> Ova Seas、林渝植等人全部出场。然而让
2021-06-01 09:31:34
目前应用IPFS的机构:1 谷歌<em>浏览器</em>支持IPFS分布式协议 2 万维网 (历史档案博物馆)数据库 3 火狐<em>浏览器</em>支持 IPFS分布式协议 4 EOS 等数字货币数据存储 5 美国国会图书馆,历史资料永久保存在 IPFS 6 加
2021-06-01 09:31:24
开拓者的车机是兼容苹果和<em>安卓</em>,虽然我不怎么用,但确实兼顾了我家人的很多需求:副驾的门板还配有解锁开关,有的时候老婆开车,下车的时候偶尔会忘记解锁,我在副驾驶可以自己开门:第二排设计很好,不仅配置了一个很大的
2021-06-01 09:30:48
不仅是<em>安卓</em>手机,苹果手机的降价力度也是前所未有了,iPhone12也“跳水价”了,发布价是6799元,如今已经跌至5308元,降价幅度超过1400元,最新定价确认了。iPhone12是苹果首款5G手机,同时也是全球首款5nm芯片的智能机,它
2021-06-01 09:30:45