SpringBoot實現單文件上傳

SpringBoot實現單文件上傳功能

架構爲springboot+thymeleaf,採用ajax方式提交

1. 頁面testFile.html

<!DOCTYPE html>
<html>
<head>
	<meta charset="UTF-8">
	<title>測試文件上傳</title>
	
	<script src="../static/jquery/jquery-2.1.1.min.js" th:src="@{/jquery/jquery-2.1.1.min.js}"></script>
    
    <script type="text/javascript">
    $(function () {
        $("#upload1").click(function () {
            var formData = new FormData();
            formData.append("file", document.getElementById("file").files[0]);   
            $.ajax({
                url: "/file/upload1",
                type: "POST",
                data: formData,
                
                //必須false纔會自動加上正確的Content-Type
                contentType: false,
                
                //必須false纔會避開jquery對 formdata 的默認處理
                //XMLHttpRequest會對 formdata 進行正確的處理
                processData: false,
                
                success: function (data) {
                    if (data.status == "true") {
                        alert("上傳成功!");
                    }
                    if (data.status == "error") {
                        alert(data.msg);
                    }
                },
                error: function () {
                    alert("上傳失敗!");
                }
            });
        });
    });
    </script>
</head>
<body>
	
    <form method="POST" enctype="multipart/form-data" action="/file/upload1">
    	<fieldset>
        	<legend>單一文件上傳實例:</legend>
           	 文件1<input type="file" name="file" id="file"/><br/>
            
            <input type="button" id="upload1" value="上傳"/><br/>
        </fieldset>
    </form>

</body>
</html>

2. FileController.java

package com.stormkai.controller;

import java.io.File;
import java.io.IOException;
import java.util.HashMap;
import java.util.Map;

import javax.servlet.http.HttpServletRequest;

import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.GetMapping;
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.ResponseBody;
import org.springframework.web.multipart.MultipartFile;

import lombok.extern.slf4j.Slf4j;

@Controller
@RequestMapping("/file")
@Slf4j
public class FileController {
	
	@GetMapping("/index")
	public String index() {
		return "testFile";
	}
	
	@PostMapping("/upload1")
    @ResponseBody
    public Map<String, Object> upload1(@RequestParam("file") MultipartFile file, HttpServletRequest request) throws IOException {
        
        log.info("系統路徑={}",request.getSession().getServletContext().getRealPath(""));
        String path = "F:\\uploadfile\\";
        if(!new File(path).exists()){
        	new File(path).mkdirs();
		}
        file.transferTo(new File(path + file.getOriginalFilename()));
        Map<String, Object> result = new HashMap<>();
        result.put("status", "true");
        result.put("data", null);
        return result;
    }

}


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章