IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> Java知识库 -> SpringBoot 使用表单或者vue实现文件上传 -> 正文阅读

[Java知识库]SpringBoot 使用表单或者vue实现文件上传

@TOC

本文的前端是HTML表单,另一种vue + axios,后端使用SpringBoot 2.x

一、创建项目

新建SpringBoot项目,同时导入依赖
项目结构
在这里插入图片描述
两个方法用的同一个控制层接口就直接先上控制层代码

二、控制层代码

package com.king.other.controller;

import io.swagger.annotations.*;
import org.springframework.web.bind.annotation.*;
import org.springframework.web.multipart.MultipartFile;

import javax.servlet.http.HttpServletRequest;
import java.io.File;
import java.io.IOException;


@RestController
@RequestMapping("/file")
@Api(value = "文件上传接口", tags = "测试接口2")
public class FileController {

    //默认上传到的路径
    private final String filePath = "F:\\A\\";

    @PostMapping("/upload")
    @ApiOperation(value = "上传单个文件", tags = "测试接口2")
    public String upload(@RequestParam("file") MultipartFile uploadFile, HttpServletRequest req) {
        if (!uploadFile.isEmpty()) {
            return saveFile(uploadFile);
        }
        return "上传失败!";
    }

    @PostMapping("/uploads")
    @ApiOperation(value = "上传多个文件", tags = "测试接口2")
    public String upload(@RequestParam("files") MultipartFile[] uploadFiles, HttpServletRequest req) {
        if (uploadFiles.length > 0) {
            return saveFile(uploadFiles);
        }
        return "上传失败!";
    }

    /**
     *
     * @param multipartFiles
     * @return 返回保存的路径
     */
    public String saveFile(MultipartFile... multipartFiles) {
        StringBuilder sb = new StringBuilder();
        try {
            for (MultipartFile multipartFile : multipartFiles) {
                multipartFile.transferTo(new File(filePath, multipartFile.getOriginalFilename()));

                sb.append(filePath).append(multipartFile.getOriginalFilename()).append("\n");
            }
        } catch (IOException e) {
            e.printStackTrace();
            return "上传失败!";
        }
        return sb.toString();
    }

}

三、表单实现文件上传

实现单文件上传

页面

<form role="form" action="/file/upload" target="myIframe" method="post" enctype="multipart/form-data"> 
   <div class="form-group"> 
    <label for="exampleInputFile">表单单个文件上传</label> 
    <input type="file" id="exampleInputFile" name="file" value="请选择文件" /> 
    <p class="help-block"> </p> 
   </div> 
   <button type="submit" class="btn btn-default">上传</button> 
</form>

实现多文件上传

页面

<form role="form" action="/file/uploads" target="myIframe" method="post" enctype="multipart/form-data"> 
   <div class="form-group"> 
    <label for="exampleInputFile">表单多个文件上传</label> 
    <input type="file" id="exampleInputFiles" name="files" value="请选择文件" multiple="" /> 
    <p class="help-block"> </p> 
   </div> 
   <button type="submit" class="btn btn-default">上传</button> 
</form>

效果截图

在这里插入图片描述

四、使用vue + axios 实现文件上传

引入js文件

<script src="https://cdn.staticfile.org/vue/2.2.2/vue.js"></script>
<script src="https://cdn.staticfile.org/axios/0.18.0/axios.js"></script>

对应js

<script type="text/javascript">
    var v = new Vue({
        el: '#main',
        data: {
        },
        methods: {
            //单个文件上传
            uploadFile: function (e) {
                var file = e.target.files[0];
                var formData = new FormData();
                formData.append("file", file)
                axios.post(
                    '/file/upload',
                    formData,
                    {headers: {'Content-Type': 'multipart/form-data'}}
                ).then(function (res) {
                    console.log(res.data)
                    const doc = document.getElementById("myIframe").contentDocument || document.frames["myIframe"].document;
                    doc.body.innerText = res.data;
                })
            },
            //多个文件上传
            uploadFiles: function (e) {
                var files = e.target.files;
                var formData = new FormData();
                files = Array.from(files); // files是类数组,需要先转为数组
                files.forEach((file) => {
                    formData.append("files", file);
                });
                axios.post(
                    '/file/uploads',
                    formData,
                    {headers: {'Content-Type': 'multipart/form-data'}}
                ).then(function (res) {
                    console.log(res.data)
                    const doc = document.getElementById("myIframe").contentDocument || document.frames["myIframe"].document;
                    doc.body.innerText = res.data;
                })
            }
        }
    });
</script>

实现单文件上传

页面

 <input type="file" name="upload-file" id="upload-file" @change="uploadFile">

实现多文件上传

页面

 <input type="file" name="upload-file" id="upload-files" @change="uploadFiles" multiple>

效果图

在这里插入图片描述
在这里插入图片描述

最后附带源码地址

Github
Gitee

  Java知识库 最新文章
计算距离春节还有多长时间
系统开发系列 之WebService(spring框架+ma
springBoot+Cache(自定义有效时间配置)
SpringBoot整合mybatis实现增删改查、分页查
spring教程
SpringBoot+Vue实现美食交流网站的设计与实
虚拟机内存结构以及虚拟机中销毁和新建对象
SpringMVC---原理
小李同学: Java如何按多个字段分组
打印票据--java
上一篇文章      下一篇文章      查看所有文章
加:2022-02-06 13:41:29  更:2022-02-06 13:42:12 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/24 9:34:41-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码