Spring Boot整合web层实现过程详解

 更新时间:2020年04月09日 09:58:24   作者:繁华乱世  
这篇文章主要介绍了Spring Boot整合web层实现过程详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下

Spring Boot中对Spring MVC的文件上传是一脉相传的,我们双击shift去搜CommonsMultipartResolver这个类,它是文件上传的一个实现类。我们先看一下源码:

我们可以看到它是MultipartResolver的实现类,我们再Ctrl+H,就可以看到右侧MultipartResolver的两个实现类。第一个实现类在servlet3.0之后,什么都不用加,就可以直接使用。第二个实现类的兼容性要好一些,早期的servlet也可以使用,但需要自己额外的加依赖。那么在Spring Boot中,我们就可以直接使用第一个实现类去完成文件上传。

只需要一个controller和一个静态html文件,就可以,先看一下代码

package com.zl.upload;

import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RestController;
import org.springframework.web.multipart.MultipartFile;

import javax.servlet.http.HttpServletRequest;
import java.io.File;
import java.io.IOException;
import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.UUID;
import java.util.logging.SimpleFormatter;

@RestController
public class UploadController {
  SimpleDateFormat ss=new SimpleDateFormat("yyyy/MM/dd/");
  @PostMapping("/upload")
  //HttpServletRequest request获取缓存地址,一般这里使用图片服务器
  public String upload(MultipartFile multipartFile , HttpServletRequest request){
  //图片保存在项目的运行路径下
    String format = ss.format(new Date());
    String realpath = request.getServletContext().getRealPath("img") + format;
    //创建保存的文件夹
    File f = new File(realpath);
    if(!f.exists()){
      f.mkdirs();
    }
    //因为文件名可能会重复,所以要对文件名进行修改
    String oldName = multipartFile.getOriginalFilename();
    System.out.println(oldName);
    String newName = UUID.randomUUID().toString() + oldName.substring(oldName.lastIndexOf("."));
    //保存图片
    try {
      multipartFile.transferTo(new File(f,newName));
      //获取路径,动态获取,因为有可能是http,也有可能是HTTPS
      String path = request.getScheme() + "://" + request.getServerName() + ":" + request.getServerPort() + "/img" + format + newName;
      return path ;
    } catch (IOException e) {
      e.printStackTrace();
    }
    return "error";
  }
}

第一步,创建文件的存放地址,和路径

第二步,修改文件名

第三步,保存文件(文件件,和文件名)

后端的处理就完了,我们看一下前台如何处理

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title>文件上传</title>
</head>
<body>
<form action="/upload" method="post" enctype="multipart/form-data">
  <input type="file" name="multipartFile">
  <input type="submit" value="提交">
</form>
</body>
</html>

前端处理很简单,就是开启文件上传通道就可以了。

但是这种做法在前后端分离开发中很少使用,接下来我们看一下用ajax如何实现。

后端的不用变,前端的改成ajax的:

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title>ajax文件上传</title>

  <script src="jquery-3.4.1.min.js"></script>
</head>
<script>
  function uploads() {
    alert("ss");
    var multipartFile=$("#file")[0].files[0];
    alert(multipartFile);
    var formData=new FormData();

    formData.append("multipartFile",multipartFile);
    $.ajax({
      type:'post',
      url:'/upload',
      processData:false,
      contentType:false,
      data:formData,
      success:function (msg) {
        $("#result").html(msg);
      }

    } )
  }
</script>
<body>
<form enctype="multipart/form-data">
<input type="file" id="file">
<input type="button" value="上传" onclick="uploads()">
</form>
<div id="result"></div>

</body>
</html>

这个是单文件上传,如果是多文件上传,改如何处理呢?

后端处理

@PostMapping("/uploads")
  //HttpServletRequest request获取缓存地址,一般这里使用图片服务器
  public String uploads(MultipartFile [] multipartFiles , HttpServletRequest request){
    //图片保存在项目的运行路径下
    String format = ss.format(new Date());
    String realpath = request.getServletContext().getRealPath("img") + format;
    //创建保存的文件夹
    File f = new File(realpath);
    if(!f.exists()){
      f.mkdirs();
    }
    //用for循环获取每个文件
    for (MultipartFile file: multipartFiles){
      String oldName = file.getOriginalFilename();
      String newName = UUID.randomUUID().toString() + oldName.substring(oldName.lastIndexOf("."));
      //保存图片
      try {
        file.transferTo(new File(f,newName));
        //获取路径,动态获取,因为有可能是http,也有可能是HTTPS
        String path = request.getScheme() + "://" + request.getServerName() + ":" + request.getServerPort() + "/img" + format + newName;
        System.out.println(path);
      } catch (IOException e) {
        e.printStackTrace();
      }
    }
    //因为文件名可能会重复,所以要对文件名进行修改

    return "success";
  }

前端处理:

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title>文件上传</title>
</head>
<body>
<form action="/uploads" method="post" enctype="multipart/form-data">
  <input type="file" name="multipartFiles" multiple>
  <input type="submit" value="提交">
</form>
</body>
</html>

就是把前端拿到的文件存在数组里,去遍历每一个,和单文件的做法一致。以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • Spring Cloud灰度部署实现过程详解

    Spring Cloud灰度部署实现过程详解

    这篇文章主要为大家介绍了Spring Cloud灰度部署实现过程详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-06-06
  • SpringBoot请求响应方式示例详解

    SpringBoot请求响应方式示例详解

    这篇文章主要介绍了SpringBoot请求响应的相关操作,本文通过示例代码给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧
    2024-06-06
  • 如何使用BufferedReader循环读文件

    如何使用BufferedReader循环读文件

    这篇文章主要介绍了如何使用BufferedReader循环读文件的操作,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-07-07
  • java微信红包实现算法

    java微信红包实现算法

    这篇文章主要为大家详细介绍了java微信红包实现算法,列出红包的核心算法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-02-02
  • 面试必时必问的JVM 类加载机制详解

    面试必时必问的JVM 类加载机制详解

    这篇文章主要介绍了一文读懂Jvm类加载机制,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2021-08-08
  • Java中HashMap和Hashtable的区别小结

    Java中HashMap和Hashtable的区别小结

    本文主要介绍了Java中HashMap和Hashtable的区别小结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-07-07
  • Java线程监听,意外退出线程后自动重启的实现方法

    Java线程监听,意外退出线程后自动重启的实现方法

    下面小编就为大家带来一篇Java线程监听,意外退出线程后自动重启的实现方法。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-03-03
  • Spring-AOP 静态正则表达式方法如何匹配切面

    Spring-AOP 静态正则表达式方法如何匹配切面

    这篇文章主要介绍了Spring-AOP 静态正则表达式方法如何匹配切面的操作,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-07-07
  • 使用java的milo框架访问OPCUA服务的过程

    使用java的milo框架访问OPCUA服务的过程

    这篇文章主要介绍了使用java的milo框架访问OPCUA服务的方法,本次采用KEPServerEX5模拟服务端,使用milo开发的程序作为客户端,具体操作使用过程跟随小编一起看看吧
    2022-01-01
  • 基于Spring AOP的Log收集汇总

    基于Spring AOP的Log收集汇总

    张三针对公司现有日志处理系统的不足,采用了SpringAOP技术和Redis存储,设计并实现了一个性能更高效的日志处理系统,该系统通过SpringAOP的切面拦截功能,捕获方法调用信息作为日志内容,并将其统一格式化后存储到Redis中
    2024-10-10

最新评论