element-ui中up-load組件實現圖片上傳回顯
方式一:直接上傳(auto-upload=“true”)
一:前端樣式以及效果:

前端樣式代碼如下:
<template>
<div>
<el-upload action="api/admin/file/uploadfoodpicture" list-type="picture-card" auto-upload="true"
:on-success="sucuploadimg">
<i class="el-icon-plus"></i>
</el-upload>
<img :src="imgUrl" alt="圖" />
</div>
</template>
<script>
export default {
data() {
return {
imgUrl: ''
};
},
methods: {
sucuploadimg(res) {
this.imgUrl = res.data;
}
}
}
</script>
二:后端Controller層
@RestController
@RequestMapping("/admin/file")
@Slf4j
@Api(value = "文件相關接口",tags = {"文件相關接口操作接口"})
public class filecontroller {
@PostMapping("/uploadfoodpicture")
@ApiOperation("上傳食物圖片")
public Result uploadFoodPicture(@RequestBody MultipartFile file) throws Exception {
//獲取圖片原文件名
log.info("啟動圖片上傳功能");
String url= FileUtil.uploadimg(file);//將傳遞的圖片交給FileUtil處理
return Result.success(200,"上傳圖片成功",url);
}
}這里的處理邏輯是將前端傳遞進來的圖片交給FileUtil處理,接下來看FileUtil的代碼:
@Component
public class FileUtil {
public static String imgsrc = "D:\\image\\";
public static String uploadimg(MultipartFile file) throws IOException {
String originalFilename = file.getOriginalFilename();
//獲取原文件的后綴名
if (originalFilename != null) {
String fileExtension = originalFilename.substring(originalFilename.lastIndexOf("."));
String uuid = UUID.randomUUID().toString();
// 使用UUID和文件擴展名來創(chuàng)建一個新的文件名
String newFilename = uuid + fileExtension;
file.transferTo(new File(FileUtil.imgsrc + newFilename));
String url ="http://localhost:8080"+"/uploadimg/" +newFilename;
return url;
}
return "上傳失敗";
}
}首先獲取傳遞進來圖片的文件名后綴 然后用UUID將其拼接得到一個新的名字
將圖片存入到本地的文件夾下面 接下來返回路徑 這里我用后端進行拼接,看看這三個參數:
"http://localhost:8080"+"/uploadimg/" +newFilename;
其中"http://localhost:8080"是服務器端口號地址 根據環(huán)境進行變化,也可以拼接在前端
"/uploadimg/"是攔截器的關鍵詞 一會進行介紹
newFilename是經過UUID拼接后的新文件名
我們接下來看看攔截器:在config文件夾下新建
@Configuration
@EnableWebMvc
public class MvcConfig implements WebMvcConfigurer {
@Override
public void addResourceHandlers(ResourceHandlerRegistry registry) {
// 配置靜態(tài)資源映射
registry.addResourceHandler("/uploadimg/**")
.addResourceLocations("file:///"+ FileUtil.imgsrc);
}
}攔截到路徑為/uploadimg/**后會替換為下面的地址 而file:///是固定的,FileUtil.imgsrc是在FileUtil里面定義的存儲圖片的地址
到此后端的準備工作也完畢了
點擊上傳圖片

到此這篇關于element-ui中up-load組件實現圖片上傳回顯的文章就介紹到這了,更多相關element up-load圖片上傳回顯內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
Vue Element前端應用開發(fā)之常規(guī)Element界面組件
在我們開發(fā)BS頁面的時候,往往需要了解常規(guī)界面組件的使用,小到最普通的單文本輸入框、多文本框、下拉列表,以及按鈕、圖片展示、彈出對話框、表單處理、條碼二維碼等等,本篇隨筆基于普通表格業(yè)務的展示錄入的場景介紹這些常規(guī)Element組件的使用2021-05-05
vue?element-plus中el-input修改邊框border的方法
element樣式還是蠻好的,只是有時候我們需要做一些調整,比如el-input的邊框,下面這篇文章主要給大家介紹了關于vue?element-plus中el-input修改邊框border的相關資料,需要的朋友可以參考下2022-09-09
解決Vue項目Network:?unavailable的問題
項目只能通過Local訪問而不能通過Network訪問,本文主要介紹了解決Vue項目Network:?unavailable的問題,具有一定的參考價值,感興趣的可以了解一下2024-06-06

