色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁技術(shù)文章
文章詳情頁

Spring Boot 實現(xiàn)圖片上傳并回顯功能

瀏覽:36日期:2023-07-04 11:33:18
一、常規(guī)形式

1 項目結(jié)構(gòu)

Spring Boot 實現(xiàn)圖片上傳并回顯功能

2 配置文件及環(huán)境設(shè)置

(1)配置文件

# 應(yīng)用服務(wù) WEB 訪問端口server.port=8080# spring 靜態(tài)資源掃描路徑spring.resources.static-locations=classpath:/static/# 訪問template下的html文件需要配置模板spring.thymeleaf.prefix.classpath=classpath:/templates/# 是否啟用緩存spring.thymeleaf.cache=false# 模板文件后綴spring.thymeleaf.suffix=.html# 模板文件編碼spring.thymeleaf.encoding=UTF-8#上傳的絕對路徑file.upload.path=G://images/ #最關(guān)鍵##絕對路徑下的相對路徑file.upload.path.relative=/images/** #最關(guān)鍵##設(shè)置文件最大值spring.servlet.multipart.max-file-size=5MB

在相關(guān)路徑新建文件夾

Spring Boot 實現(xiàn)圖片上傳并回顯功能

3 代碼

(1)pom.xml

<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-thymeleaf</artifactId></dependency><dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId></dependency>

(2)index.html

<!DOCTYPE html><html lang='en' xmlns:th='http://www.w3.org/1999/xhtml'><head> <meta charset='UTF-8'> <title>Title</title></head><body><form action='../upload' method='post' enctype='multipart/form-data'> <input type='file' name='file' accept='image/*'> <br> <input type='text' value=''> <input type='submit' value='上傳' class='btn btn-success'></form>[[${filename}]]<br><img th:src='http://www.lshqa.cn/bcjs/@{${filename}}' alt='圖片'></body></html>

(3)TestController.java

import org.springframework.beans.factory.annotation.Value;import org.springframework.stereotype.Controller;import org.springframework.ui.Model;import org.springframework.web.bind.annotation.RequestMapping;import org.springframework.web.bind.annotation.RequestParam;import org.springframework.web.bind.annotation.ResponseBody;import org.springframework.web.multipart.MultipartFile;import java.io.File;import java.io.IOException;@Controllerpublic class TestController { /** * 上傳地址 */ @Value('${file.upload.path}') private String filePath; // 跳轉(zhuǎn)上傳頁面 @RequestMapping('test') public String test() {return 'Page'; } // 執(zhí)行上傳 @RequestMapping('upload') public String upload(@RequestParam('file') MultipartFile file, Model model) {// 獲取上傳文件名String filename = file.getOriginalFilename();// 定義上傳文件保存路徑String path = filePath + 'rotPhoto/';// 新建文件File filepath = new File(path, filename);// 判斷路徑是否存在,如果不存在就創(chuàng)建一個if (!filepath.getParentFile().exists()) { filepath.getParentFile().mkdirs();}try { // 寫入文件 file.transferTo(new File(path + File.separator + filename));} catch (IOException e) { e.printStackTrace();}// 將src路徑發(fā)送至html頁面model.addAttribute('filename', '/images/rotPhoto/' + filename);return 'index'; }}

(4)MyWebAppConfigurer

import org.springframework.beans.factory.annotation.Value;import org.springframework.context.annotation.Configuration;import org.springframework.web.servlet.config.annotation.ResourceHandlerRegistry;import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;/** * 資源映射路徑 */@Configurationpublic class MyWebAppConfigurer implements WebMvcConfigurer { /** * 上傳地址 */ @Value('${file.upload.path}') private String filePath; /** * 顯示相對地址 */ @Value('${file.upload.path.relative}') private String fileRelativePath; @Override public void addResourceHandlers(ResourceHandlerRegistry registry) {registry.addResourceHandler(fileRelativePath).addResourceLocations('file:/' + filePath); }}

4 測試

Spring Boot 實現(xiàn)圖片上傳并回顯功能

二、增加異步操作

1 前端ajax

<div class='modal-body'> <form method='post' enctype='multipart/form-data'><input type='file' name='file' id='img'><input type='button' value='上傳' onclick='uploadFile()' style='width: 30%;'> </form></div><script>//上傳文件function uploadFile() { //formData里面存儲的數(shù)據(jù)形式,一對key/value組成一條數(shù)據(jù),key是唯一的,一個key可能對應(yīng)多個value var myform = new FormData(); // 此時可以調(diào)用append()方法來添加數(shù)據(jù) myform.append(’file’, $('#img')[0].files[0]); //驗證不為空 var file = $('#img')[0].files[0]; if (file == null) {alert('請選擇文件');return false; } else {$.ajax({ url: '/user/upLoad', type: 'POST', data: myform, async: false, contentType: false, processData: false, success: function (result) {console.log(result);alert('上傳成功!');$('#div_show_img').html('<img id=’input_img’ src=’' + result + '’>');$('#imgPath').attr('value', result);$('#div_upload').removeClass('show'); }, error: function (data) {alert('系統(tǒng)錯誤'); }}); }}</script>

2 后端Controller

@ResponseBody@RequestMapping('/upLoad')public String upLoadImage(@RequestParam('file') MultipartFile file) { // 獲取上傳文件名 String filename = file.getOriginalFilename(); String suffixName = filename.substring(filename.lastIndexOf('.')); // 定義上傳文件保存路徑 String path = filePath + 'images/'; //生成新的文件名稱 String newImgName = UUID.randomUUID().toString() + suffixName; // 新建文件 File filepath = new File(path, newImgName); // 判斷路徑是否存在,如果不存在就創(chuàng)建一個 if (!filepath.getParentFile().exists()) {filepath.getParentFile().mkdirs(); } try {// 寫入文件file.transferTo(new File(path + File.separator + newImgName)); } catch (IOException e) {e.printStackTrace(); } return '/images/images/' + newImgName;}

到此這篇關(guān)于Spring Boot 實現(xiàn)圖片上傳并回顯功能的文章就介紹到這了,更多相關(guān)Spring Boot上傳圖片回顯內(nèi)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標(biāo)簽: Spring
相關(guān)文章:
主站蜘蛛池模板: 91久久国产露脸精品免费 | 国产欧美一区二区三区在线 | 男女一级 | 一级亚洲| 久久精品国产精品青草色艺 | 伊人色综合久久成人 | 国产一区二区三区免费看 | 福利视频在线午夜老司机 | 久久九九热视频 | 亚洲视频在线观看视频 | 图片区偷拍区小说区 | 欧美老妇69交 | 成人亚洲在线观看 | 九九在线精品视频xxx | 国产91无套剧情在线播放 | 免费观看欧美精品成人毛片能看的 | 国产真人毛片一级视频 | 成人午夜性视频欧美成人 | 特级淫片欧美高清视频蜜桃 | 日本在线不卡免 | 久久91亚洲精品久久91综合 | 欧美一级毛片怡红院 | 性刺激免费视频观看在线观看 | 欧美一级高清毛片aaa | 成人免费午间影院在线观看 | 国产日韩欧美swag在线观看 | 亚洲 欧美 精品 中文第三 | 成人亚洲在线 | 亚洲国产精品久久精品成人 | 香港经典a毛片免费观看看 香港经典a毛片免费观看爽爽影院 | 67194欧美成l人在线观看免费 | 中文字幕亚洲一区 | 男人天堂欧美 | 亚洲免费一 | 欧美成人精品高清在线播放 | 久久精品视频在线 | 欧美亚洲日本一区二区三区浪人 | 亚洲高清毛片 | 国产精品爱久久久久久久 | www.av在线.com | 91精品久久|