springmvc的文件上传

1.文件上传的原理

在这里插入图片描述

2.文件上传到本地服务器。

(1)引入文件上传的依赖。

<!--文件上传的依赖-->
    <dependency>
      <groupId>commons-fileupload</groupId>
      <artifactId>commons-fileupload</artifactId>
      <version>1.4</version>
    </dependency>

(2) 创建一个页面

<%--
  Created by IntelliJ IDEA.
  User: 17162
  Date: 2022/6/10
  Time: 10:30
  To change this template use File | Settings | File Templates.
--%>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
    <title>Title</title>
</head>
<body>
    <%--
         method: 提交方式 文件上传必须为post提交。
         enctype:默认application/x-www-form-urlencoded 表示提交表单数据
                 multipart/form-data:可以包含文件数据
         input的类型必须为file类型,而且必须有name属性
      --%>
    <form method="post" action="upload03" enctype="multipart/form-data">
        <input type="file" name="myfile">
        <input type="submit" value="提交">
    </form>
</body>
</html>

(3)在springmvc中配置文件上传解析器

   <!--
     id的名称必须叫multipartResolver
     -->
     <bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver">
          <!--这里的单位为字节10M*1024K*1024-->
          <property name="maxUploadSize" value="10485760"/>
     </bean>

(4)创建upload01接口方法

 @RequestMapping("upload03")
    //注意:MultipartFile 参数名必须和<input type="file" name="myfile"/>中name属性相同
    public String upload03(MultipartFile myfile,HttpServletRequest request) throws IOException {
   
       // 1 得到本地服务目录的地址
        String path = request.getSession().getServletContext().getRealPath("upload");
        File file = new File(path);
        System.out.println(file);
       // 2 判断该目录是否存在
        if(!file.exists()){
   
            System.out.println(file);
            file.mkdirs();
        }
        // 3 把myfile保存到本地服务中某个文件夹下
        String filename =UUID.randomUUID().toString().replace("-","")+myfile.getOriginalFilename();
        File target = new File(path+"/"+filename);
        System.out.println(target);
         // 4 把myfile转移到目标目录下
        myfile.transferTo(target);
        return "";

    }

3.elementui+vue+axios完成文件上传

(1)页面的布局

<%--
  Created by IntelliJ IDEA.
  User: 17162
  Date: 2022/6/10
  Time: 9:28
  To change this template use File | Settings | File Templates.
--%>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
    <title>Title</title>
    <link type="text/css" rel="stylesheet" href="css/index.css"/>
    <!--引入vue得js文件 这个必须在element之前引入-->
    <script type="text/javascript" src="js/vue.js"></script>
    <script type="text/javascript" src="js/qs.min.js"></script>
    <script type="text/javascript" src="js/axios.min.js"></script>
    <!--element得js文件-->
    <script type="text/javascript" src="js/index.js"></script>
</head>
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值