深入理解MultipartFile,以更优雅的方式处理文件

   Hello,大家好,我是Steafan_,这几天有时间我就来更新博客了,话不多说直入正题。

  在Java中处理文件向来是一种不是很方便的操作,然后随着Spring框架的崛起,使用Spring框架中的MultipartFile来处理文件也是件很方便的事了,今天就为大家带来剖析MultipartFile的神秘面纱。MultipartFile本身并没有很复杂的结构,也正是他强力封装了很多便捷的api才引来很多人的使用。

一、概述

    MultipartFile为org.springframework.web.mutipart包下的一个类,也就是说如果想使用MultipartFile这个类就必须引入spring框架,换句话说,如果想在项目中使用MultipartFile这个类,那么项目必须要使用spring框架才可以,否则无法引入这个类。MultipartFile翻译成中文来讲就是“多组件的文档”,不用太在乎他的中文含义,一般来讲使用MultipartFile这个类主要是来实现以表单的形式进行文件上传功能。

二、理解什么是MultipartFile

    要想真正理解什么是MultipartFile,我们就需要从源码角度进行分析和理解。接下来我将一步一步对MultipartFile进行源码解读,这可以使得我们更系统的理解MultipartFile。

1、MultipartFile类的注释说明

      MultipartFile类的注释说明截图如下图1.1所示:

      

 

                                                                                     图1.1 MultipartFile注释说明

      第一句:一种可以接收使用多种请求方式来进行上传文件的代表形式。也就是说,如果你想用spring框架来实现项目中的文件上传功能,则MultipartFile可能是最合适的选择,而这里提到的多种请求方式则可以通俗理解为以表单的形式提交。

      第二句:这个文件内容可以存储到内存中或者存储在磁盘的临时位置上。

      第三句:无论发生哪种情况,用户都可以自由地拷贝文件内容到session存储中,或者以一种永久存储的形式进行存储,如果有需要的话。

      第四句:这种临时性的存储在请求结束之后将会被清除掉。

2、MultipartFile常用方法解析

      首先MultipartFile是一个接口,并继承自InputStreamSource,且在InputStreamSource接口中封装了getInputStream方法,该方法的返回类型为InputStream类型,这也就是为什么MultipartFile文件可以转换为输入流。通过以下代码即可将MultipartFile格式的文件转换为输入流。

multipartFile.getInputStream();

  (1)、getName方法

          getName方法获取的是前后端约定的传入文件的参数的名称,在SpringBoot后台中则是通过@Param("uploadFile") 注解定义的内容。值得一提的是,我们来看一下该方法的注释,如下图2.1所示:

                            

                                                                              图2.1 getName方法源码截图

        从上图的return中可以看出,返回的name值从来不是null或者空,也就是说如果使用MultipartFile来接收文件,那么@Param("uploadFile")定义的接收文件的名称则必不可少,这样才能接收到文件,如果没有定义@Param("uploadFile"),则接收不到文件。

 (2)、getOriginalFileName方法 

         getOriginalFileName方法获取的是文件的完整名称,包括文件名称+文件拓展名。

 (3)、getContentType方法 

         getContentType方法获取的是文件的类型,注意是文件的类型,不是文件的拓展名。

 (4)、isEmpty方法 

         isEmpty方法用来判断传入的文件是否为空,如果为空则表示没有传入任何文件。

 (5)、getSize方法 

         getSize方法用来获取文件的大小,单位是字节。

 (6)、getBytes方法 

         getBytes方法用来将文件转换成一种字节数组的方式进行传输,会抛出IOException异常。

 (7)、getInputStream方法 

         getInputStream方法用来将文件转换成输入流的形式来传输文件,会抛出IOException异常。

 (8)、transferTo方法 

         transferTo方法用来将接收文件传输到给定目标路径,会抛出IOException、IllegalStateException异常。该方法在实际项目开发中使用较少。

         我们以上传一张图片文件为例,分别来看一下调用不同方法所获取到的数据,如下图2.2所示:

                                                                 

                                                             图2.2 MultipartFile常用方法获取数据打印结果

三、MultipartFile的一些使用技巧

    (1)我们在使用MultipartFile作为参数传递的时候,可以将MultipartFile声明为一个数组,这样就能支持多文件传输,如果只需要传输一个文件,则去掉数组就好了。

    (2)可以根据MultipartFile的getSize方法来获取到传输文件的大小,这样就能限定传输过来的文件的大小了。

可以在我的github中看到MultipartFile的实战代码:https://github.com/SteafanMrZhou/springBootPractice  

以上就是本篇博文的全部内容,有不懂的地方欢迎留言评论,感谢各位朋友关注!!!

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

Steafan_

你的鼓励将是我创作的最大动力

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

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

打赏作者

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

抵扣说明:

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

余额充值