一种文件上传方式

导入依赖:

<!-- 文件上传 -->
    <dependency>
      <groupId>commons-fileupload</groupId>
      <artifactId>commons-fileupload</artifactId>
      <version>1.3.1</version>
    </dependency>

编写前端jsp:

<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<%
    String basePath=request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+request.getContextPath()+"/";
%>
<html>
<head>
    <base href="<%=basePath%>">
    <title>演示文件上传</title>
</head>
<body>
    <%--
        文件上传的表单:
        1)表单组件必须使用:<input type="file">
        2)请求方式只能用post:
           get:参数通过请求头提交,放在url后;只能提交文本数据;对参数的长度有限制;安全性低;效率高
           post:参数通过请求体提交;不但能提交文本数据,还能提交二进制数据;理论上对参数的长度没有限制;                 安全性相对较高;效率较低
        3)表单的编码格式只能用:multipart/form-data
           根据HTTP协议的规定,客户端每次向后台提交参数,都会对所有的参数进行统一编码,默认采用的编码格式是urlencoded,这种编码格式只能对文本数据进行编码;
           浏览器首先把所有参数都转换为文本数据,然后进行urlencoded编码,然后再发送到后台
           文件上传的表单,只能用multipart/form-data,作用是阻止浏览器的默认行为
    --%>

    <form action="workbench/activity/fileUpload.do" method="post" enctype="multipart/form-data">
        <input type="file" name="myFile"><br>
        <input type="text" name="userName"><br>
        <input type="submit" value="提交">
    </form>
</body>
</html>

后端Controller:

/*
    *  springMVC在接收到请求后,会调用文件上传解析器类,从请求体中获取文件的所有信息,都封装到MultipartFile对象中
    */
    @RequestMapping("/workbench/activity/fileUpload.do")
    @ResponseBody
    public Object fileUpload(String userName, MultipartFile myFile) throws Exception{
        //可以把userName打印到控制台看一下
        System.out.println("userName="+userName);
        String originalFilename = myFile.getOriginalFilename();
        //把myFile在服务器上指定的目录中生成一个同样的文件
        File file = new File("D:\\Java\\server_libs",originalFilename); //目录必须手动创建,如果文件不存在,会自动创建文件
        myFile.transferTo(file);

        //返回响应信息
        ReturnObject returnObject=new ReturnObject();
        returnObject.setCode(Contants.AJAX_RETURN_CODE_SUCCESS);
        returnObject.setMessage("上传成功");
        
        return returnObject;
    }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值