当前位置 : 主页 > 编程语言 > java >

SpringBoot实现单文件上传

来源:互联网 收集:自由互联 发布时间:2021-05-10
SpringBoot实现单文件上传功能,供大家参考,具体内容如下 架构为springboot+thymeleaf,采用ajax方式提交 1. 页面testFile.html !DOCTYPE htmlhtmlhead meta charset="UTF-8" title测试文件上传/title script src="..

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;
  }

}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持易盾网络。

网友评论