一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - Java教程 - Spring Boot 實現圖片上傳并回顯功能

Spring Boot 實現圖片上傳并回顯功能

2021-09-27 10:01Mr_YMX Java教程

本篇文章給大家分享Spring Boot 實現圖片上傳并回顯功能,文中通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友參考下吧

一、常規形式

1 項目結構

Spring Boot 實現圖片上傳并回顯功能

2 配置文件及環境設置

(1)配置文件

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
# 應用服務 WEB 訪問端口
server.port=8080
# spring 靜態資源掃描路徑
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/     #最關鍵#
#絕對路徑下的相對路徑
file.upload.path.relative=/images/**      #最關鍵#
#設置文件最大值
spring.servlet.multipart.max-file-size=5MB

在相關路徑新建文件夾

Spring Boot 實現圖片上傳并回顯功能

3 代碼

(1)pom.xml

?
1
2
3
4
5
6
7
8
<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

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
<!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="@{${filename}}" alt="圖片">
</body>
</html>

(3)TestController.java

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
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;
 
@Controller
public class TestController {
 
    /**
     * 上傳地址
     */
    @Value("${file.upload.path}")
    private String filePath;
 
    // 跳轉上傳頁面
    @RequestMapping("test")
    public String test() {
        return "Page";
    }
 
    // 執行上傳
    @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);
        // 判斷路徑是否存在,如果不存在就創建一個
        if (!filepath.getParentFile().exists()) {
            filepath.getParentFile().mkdirs();
        }
        try {
            // 寫入文件
            file.transferTo(new File(path + File.separator + filename));
        } catch (IOException e) {
            e.printStackTrace();
        }
        // 將src路徑發送至html頁面
        model.addAttribute("filename", "/images/rotPhoto/" + filename);
        return "index";
    }
}

(4)MyWebAppConfigurer

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
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;
 
/**
 * 資源映射路徑
 */
@Configuration
public 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 實現圖片上傳并回顯功能

二、增加異步操作

1 前端ajax

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
<div class="modal-body">
     <form method="post" enctype="multipart/form-data">
        <input type="file" name="file" id="img">
        <input type="button" value="上傳" class="btn btn-outline-primary" onclick="uploadFile()"
                               style="width: 30%;">
     </form>
</div>
<script>
//上傳文件
function uploadFile() {
    //formData里面存儲的數據形式,一對key/value組成一條數據,key是唯一的,一個key可能對應多個value
    var myform = new FormData();
    // 此時可以調用append()方法來添加數據
    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("系統錯誤");
            }
        });
    }
}
</script>

2 后端Controller

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
@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);
    // 判斷路徑是否存在,如果不存在就創建一個
    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;
}

到此這篇關于Spring Boot 實現圖片上傳并回顯功能的文章就介紹到這了,更多相關Spring Boot上傳圖片回顯內容請搜索服務器之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持服務器之家!

原文鏈接:https://blog.csdn.net/Mr_YanMingXin/article/details/118484438

延伸 · 閱讀

精彩推薦
  • Java教程xml與Java對象的轉換詳解

    xml與Java對象的轉換詳解

    這篇文章主要介紹了xml與Java對象的轉換詳解的相關資料,需要的朋友可以參考下...

    Java教程網2942020-09-17
  • Java教程Java BufferWriter寫文件寫不進去或缺失數據的解決

    Java BufferWriter寫文件寫不進去或缺失數據的解決

    這篇文章主要介紹了Java BufferWriter寫文件寫不進去或缺失數據的解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望...

    spcoder14552021-10-18
  • Java教程小米推送Java代碼

    小米推送Java代碼

    今天小編就為大家分享一篇關于小米推送Java代碼,小編覺得內容挺不錯的,現在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧...

    富貴穩中求8032021-07-12
  • Java教程Java實現搶紅包功能

    Java實現搶紅包功能

    這篇文章主要為大家詳細介紹了Java實現搶紅包功能,采用多線程模擬多人同時搶紅包,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙...

    littleschemer13532021-05-16
  • Java教程Java8中Stream使用的一個注意事項

    Java8中Stream使用的一個注意事項

    最近在工作中發現了對于集合操作轉換的神器,java8新特性 stream,但在使用中遇到了一個非常重要的注意點,所以這篇文章主要給大家介紹了關于Java8中S...

    阿杜7472021-02-04
  • Java教程Java使用SAX解析xml的示例

    Java使用SAX解析xml的示例

    這篇文章主要介紹了Java使用SAX解析xml的示例,幫助大家更好的理解和學習使用Java,感興趣的朋友可以了解下...

    大行者10067412021-08-30
  • Java教程升級IDEA后Lombok不能使用的解決方法

    升級IDEA后Lombok不能使用的解決方法

    最近看到提示IDEA提示升級,尋思已經有好久沒有升過級了。升級完畢重啟之后,突然發現好多錯誤,本文就來介紹一下如何解決,感興趣的可以了解一下...

    程序猿DD9332021-10-08
  • Java教程20個非常實用的Java程序代碼片段

    20個非常實用的Java程序代碼片段

    這篇文章主要為大家分享了20個非常實用的Java程序片段,對java開發項目有所幫助,感興趣的小伙伴們可以參考一下 ...

    lijiao5352020-04-06
主站蜘蛛池模板: 国产日韩成人 | 亚洲成年网站在线777 | 四虎影视紧急入口地址大全 | 日本伦理动漫在线观看 | 国产va免费精品高清在线观看 | 国内精品91东航翘臀女神在线 | 手机国产乱子伦精品视频 | 美女gif趴跪式抽搐动态图 | 五月天色网站 | 精品香蕉99久久久久网站 | 午夜AV内射一区二区三区红桃视 | xx18美女美国 | 精品视频在线免费观看 | 91天堂在线视频 | 波多野结衣 在线 | 亚洲码和乱人伦中文一区 | 久草在线草a免费线看 | 精品久久久久久影院免费 | 91精品啪在线观看国产日本 | 贵妇的私人性俱乐部 | 色婷婷综合久久久 | 免费在线观看网址大全 | 白丝超短裙被输出娇喘不停小说 | 国产日韩欧美视频 | 四虎在线精品免费高清在线 | 亚洲精品一区二区久久久久 | 色四虎| 色花堂国产精品首页第一页 | 久久免费看少妇级毛片蜜臀 | 青青青在线视频播放 | 欧美日韩国产一区二区三区欧 | 亚洲va精品中文字幕 | 婷婷色在线观看 | 国产亚洲一欧美一区二区三区 | 日本不卡高清免费v日本 | 国产成人精品777 | 韩国甜性涩爱免费观看 | 麻豆在线传煤 | 天天做天天爽天天谢 | 精品一区在线 | 国产精品视频免费观看 |