MVC单文件与多文件上传学习笔记

MVC单文件与多文件上传学习笔记(2019-11-04):

pom文件依赖:

	<dependency>
      <groupId>commons-io</groupId>
      <artifactId>commons-io</artifactId>
      <version>1.3.2</version>
    </dependency>
    <dependency>
      <groupId>commons-fileupload</groupId>
      <artifactId>commons-fileupload</artifactId>
      <version>1.2.1</version>
    </dependency>

配置文件(springmvc.xml):

<!-- 配置多媒体解析器 -->
    <bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver">
        <property name="defaultEncoding" value="UTF-8"></property>
        <!-- 设定文件上传的最大值100MB,100*1024*1024 -->
        <property name="maxUploadSize" value="104857600"></property>
    </bean>

单文件上传:

页面:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>个人文件上传test网站</title>
</head>
<script type="text/javascript" src="js/jquery-3.3.1.min.js"></script>
<body>
    <!--必须是表单包起来  有name属性 而且name属性必须和后端接收的参数名一样-->
    <form id="inputForm">
        <input type="file" name="updateUrl" onchange="updatefile()">
    </form>
    <div>
        <table>
            <tr>
                <td id="tset">
                    <!--回显上传后的连接-->
                </td>
            </tr>
        </table>
    </div>
</body>
    
    
<script type="text/javascript">
    function updatefile() {
        var formData = new FormData($("#inputForm")[0]);
        $.ajax({
            url: "/test/updatefile",
            async: false,
            type: "POST",
            data: formData,
            cache: false,
            contentType: false,
            processData: false,
            success: function (updateVersionFile) {
                 //插入个 a标签 回显示地址
                $("#tset").html("<a href=\""+updateVersionFile+"\">点击查看</a>");
            }
        });
    }
</script>
</html>

后端代码:

	/**
     * 单个文件上传
     * @param multipartFile的名称 如果不使用注解 必须得和页面的name一样
     * @return
     */
 @PostMapping("/updatefile")
    public String getlist(@RequestParam(value = "updateUrl", required = false) MultipartFile multipartFile){
        InputStream inputStream=null;
        try {
            inputStream = multipartFile.getInputStream();
        } catch (IOException e) {
            e.printStackTrace();
        }
        //自己进行上传云服务器获取地址后返回
        return url;
    }

单独使用<input type="file" name="updateUrl" onchange="updatefile()"> 上传方式不用表单

function updatefile() {
        var formData = new FormData();
        //jquery获取选择文件选项转换成js对象
        var file = $("#updateUrl")[0];
        //添加进去formData  updateUrl要和后端接收名一样
        formData.append("updateUrl",file.files[0]);
        $.ajax({
            url: "/updatefile",
            async: false,
            type: "POST",
            data: formData,
            cache: false,
            contentType: false,
            processData: false,
            success: function (updateVersionFile) {
                //插入个 a标签 回显示地址
                $("#tset").html("<a href=\""+updateVersionFile+"\">点击查看</a>");
            }
        });
    }

多文件上传:

页面:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>个人文件上传test网站2</title>
</head>
<script type="text/javascript" src="js/jquery-3.3.1.min.js"></script>
<body>
        <!--3个文件框 name属性必须相同  id不同用来取值-->
        <input type="file" name="updateUrl" id="updateUrl1">
        <input type="file" name="updateUrl" id="updateUrl2">
        <input type="file" name="updateUrl" id="updateUrl3">
        <button onclick="updatefile()">点击多文件上传</button>
</body>
<script type="text/javascript">

    function updatefile() {
        //根据不同id 取出每一个文件的值 添加进formData表单格式相同
        var formData =  new FormData();
        //但是key 必须是相同
        formData.append("updateUrl",$("#updateUrl1")[0].files[0])
        formData.append("updateUrl",$("#updateUrl2")[0].files[0])
        formData.append("updateUrl",$("#updateUrl3")[0].files[0])
        $.ajax({
            url: "/updatefile2",
            async: false,
            type: "POST",
            data: formData,
            cache: false,
            contentType: false,
            processData: false,
            success: function (result) {
                alert("上传成功!"+result);
            }
        });
    }
</script>
</html>

后端使用数组接收:

	/**
     * 多个文件上传
     * @param multipartFile[] 使用数组接收 名字和formData的key一样 即可
     * @return
     * @throws IOException
     */
    @PostMapping("/updatefile2")
    public String multiFile(@RequestParam(value = "updateUrl", required = false) MultipartFile[] multipartFile) throws IOException {
        for (MultipartFile file : multipartFile) {
            System.out.println(file.getSize());
            System.out.println(file.getOriginalFilename());
            System.out.println(file.getInputStream());
        }
        return "success";
    }
    /*输出结果:
    7685829
    Coffee_Android-v1.9-360.apk
    java.io.FileInputStream@7d9e7ef0
    17369219
    EWater-v2.0.1.0-release.apk
    java.io.FileInputStream@443fe880
    14672727
    test.apk
    java.io.FileInputStream@79707c66*/
页面也可以使用表单提交:
<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Insert title here</title>
</head>
<body>
    <!--3个文件框 name属性必须相同 表单属性必须 enctype="multipart/form-data"-->
    <form action="${pageContext.request.contextPath }/multifile"
        method="post" enctype="multipart/form-data">
        选择文件1:<input type="file" name="myfile"><br>
        文件描述1:<input type="text" name="description"><br />
        选择文件2:<input type="file" name="myfile"><br>
        文件描述2:<input type="text" name="description"><br />
        选择文件3:<input type="file" name="myfile"><br>
        文件描述3:<input type="text" name="description"><br />
        <input type="submit" value="提交">
    </form>
</body>
</html>


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

懵懵懂懂程序员

如果节省了你的时间, 请鼓励

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值