使用ajax、servlet实现多文件的上传

搭建环境

这里使用maven导入jar包:

<dependencies>
  <!--文件上传-->
  <dependency>
      <groupId>commons-fileupload</groupId>
      <artifactId>commons-fileupload</artifactId>
      <version>1.3.2</version>
  </dependency>
  <dependency>
      <groupId>org.apache.commons</groupId>
      <artifactId>commons-io</artifactId>
      <version>1.3.2</version>
  </dependency>
  <!--json-->
  <dependency>
      <groupId>org.json</groupId>
      <artifactId>json</artifactId>
      <version>20160810</version>
  </dependency>

</dependencies>

这里写图片描述
这里写图片描述
三个主要的jar包,这里还将使用jquery以及异步提交表单,所以需要jquery和jquery.form文件
这里写图片描述

jsp页面

<%--
  Created by IntelliJ IDEA.
  User: wqh
  Date: 2017/5/26
  Time: 9:46
  To change this template use File | Settings | File Templates.
--%>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<meta http-equiv="Content-Type" content="text/html;charset=UTF-8">
<script type="text/javascript" src="${pageContext.request.contextPath}/js/jquery-3.1.1.min.js"></script>
<script type="text/javascript" src="${pageContext.request.contextPath}/js/jquery.form.js"></script>

<script type="text/javascript">
    $(function () {
      $("#sub").bind("click",function () {
          var option = {
              type:"post",
              url:"${pageContext.request.contextPath}/TestServlet",
              async: true,
              enctype:"multipart/form-data",
              dataType:"json",
              error:function(data){
                  alert(data);
              },
              success:function(msg){
                  //将结果格式化为json
                  var json = eval(msg);
                  var data = "";
                  $.each(json,function (index,item) {
                       var key = json[index].file;
                       data = data +"==="+ key
                  });
                    alert(data);
              }
          };
         $("#fileForm").ajaxSubmit(option);
      })
    });

</script>
<head>
    <title>Title</title>
</head>
<body>
    <form action="#" id="fileForm" enctype="multipart/form-data" method="post" >
        <input type="file" name="file"/><br>
        <input type="file" name="file"/><br>
        <input type="file" name="file"/><br>
        <button type="submit"  name="sub" id="sub">提交</button>
    </form>
</body>
</html>

这里写图片描述

servlet代码

文件上传测试,上传文件就不保存到本地l。直接向页面返回文件名,返回json格式。

 req.setCharacterEncoding("utf-8");
        resp.setCharacterEncoding("utf-8");

        List<String> fileName = new ArrayList<>();
        boolean ismultipartContent = ServletFileUpload.isMultipartContent(req);
        //判断是否是文件上传
        if (ismultipartContent) {
            DiskFileItemFactory factory = new DiskFileItemFactory();
            ServletFileUpload fileUpload = new ServletFileUpload(factory);
            try {
                List<FileItem> fileItems = fileUpload.parseRequest(req);
                for (FileItem fileItem : fileItems) {
                    //判断字段的类型
                    if (fileItem.isFormField()) {
                        //处理普通字段
                    } else{
                        //文件字段,处理上传字段,这里就不把文件保存到本地了
                        fileName.add(fileItem.getName());
                    }
                }
            } catch (FileUploadException e) {
                e.printStackTrace();
            }
            //将list转化为json
            int index = 1;
            JSONArray jsonArray = new JSONArray();
            for (String s : fileName){
                JSONObject jsonObject = new JSONObject();
                jsonObject.put("file",s);
                jsonArray.put(jsonObject);
            }
            resp.getWriter().print(jsonArray);
        }

测试

选择上传的文件
这里写图片描述

这里写图片描述
文件上传测试和返回json格式的文件名成功!!

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值