springmvc学习笔记(17)——文件上传

springmvc 专栏收录该内容
34 篇文章 2 订阅

环境准备

文件上传有很多种方法,这里我们使用最简单的apache的包
1. 将以下jar包导入项目中
这里写图片描述
2. 在springmvc配置文件中配置multipartResolver

<!-- 配置 MultipartResolver -->
    <bean id="multipartResolver" 
        class="org.springframework.web.multipart.commons.CommonsMultipartResolver">
        <property name="defaultEncoding" value="UTF-8"/>
        <property name="maxUploadSize" value="1024000"/>
    </bean>

-这里配置了两个属性,编码 以及 上传文件大小的最大值,还有一些其他属性这里不再说明

如何实现

首先,在jsp中写一个form

<form action="testFIleUpload" method="post" enctype="multipart/form-data">
    <input type="file" name="file"/>
    <input type="submit" value="upload" />
</form>

这里有一个enctype属性,一定要写上,说明是多段提交
控制层

@RequestMapping("/testFIleUpload")
    public String testFileUpload(@RequestParam("file")MultipartFile file,
            HttpServletRequest request) throws IOException{
        //上传的文件名
        String filename = file.getOriginalFilename();
        System.out.println("file:"+filename);
        //文件的输入流
        InputStream in = file.getInputStream();
        //文件保存到该文件夹下
        File tempFile = new File(request.getServletContext().getRealPath("")+"/fileupload");
        if(!tempFile.exists()){ //文件如果不存在,就创建
            tempFile.mkdirs();
        }
        System.out.println(tempFile.getAbsolutePath());

        OutputStream out = new FileOutputStream(tempFile+"/"+filename);
        //注意:我使用的linux系统,在window下文件路径写法与linux不同
        //OutputStream out = new FileOutputStream(new File("/home/zhoujun/"+filename));

        byte[] b = new byte[1024];//字节数组,用于保存源文件读出来的字节

        int i = 0;//每一次循环所读出来的字节数
        while((i=in.read(b)) != -1){
            out.write(b, 0, i);//将字节数组b从下标为0到下标为i的内容写到输出流中
        }
        out.flush();
        out.close();
        in.close();
        return "hello";
    }

代码解析
1. 用MultipartFile类接收前端传来的文件,有了实例,就能得到文件的文件名,文件的输入流。有了输入流之后,对这个文件就想怎么操作就怎么操作啦。
2. 在本次例子中,我将文件保存到项目的fileupload目录下,在实际开发中,大家也可以将文件保存到数据库。
3. request.getServletContext().getRealPath("")是项目所在的绝对路径
4. 关于输入输出流,是java的基础,这里不做很详细的解释,上面给出的代码已经有详细的注释了。

至此,springmvc的文件上传已经全部搞定

  • 0
    点赞
  • 0
    评论
  • 1
    收藏
  • 一键三连
    一键三连
  • 扫一扫,分享海报

相关推荐
<p> <span style="font-size:14px;color:#337FE5;">【为什么学爬虫?】</span> </p> <p> <span style="font-size:14px;">       1、爬虫入手容易,但是深入较难,如何写出高效率的爬虫,如何写出灵活性高可扩展的爬虫都是一项技术活。另外在爬虫过程中,经常容易遇到被反爬虫,比如字体反爬、IP识别、验证码等,如何层层攻克难点拿到想要的数据,这门课程,你都能学到!</span> </p> <p> <span style="font-size:14px;">       2、如果是作为一个其他行业的开发者,比如app开发,web开发,学习爬虫能让你加强对技术的认知,能够开发出更加安全的软件和网站</span> </p> <p> <br /> </p> <span style="font-size:14px;color:#337FE5;">【课程设计】</span> <p class="ql-long-10663260"> <span> </span> </p> <p class="ql-long-26664262" style="font-size:11pt;color:#494949;"> 一个完整的爬虫程序,无论大小,总体来说可以分成三个步骤,分别是: </p> <ol> <li class="" style="font-size:11pt;color:#494949;"> 网络请求:模拟浏览器的行为从网上抓取数据。 </li> <li class="" style="font-size:11pt;color:#494949;"> 数据解析:将请求下来的数据进行过滤,提取我们想要的数据。 </li> <li class="" style="font-size:11pt;color:#494949;"> 数据存储:将提取到的数据存储到硬盘或者内存中。比如用mysql数据库或者redis等。 </li> </ol> <p class="ql-long-26664262" style="font-size:11pt;color:#494949;"> 那么本课程也是按照这几个步骤循序渐进的进行讲解,带领学生完整的掌握每个步骤的技术。另外,因为爬虫的多样性,在爬取的过程中可能会发生被反爬、效率低下等。因此我们又增加了两个章节用来提高爬虫程序的灵活性,分别是: </p> <ol> <li class="" style="font-size:11pt;color:#494949;"> 爬虫进阶:包括IP代理,多线程爬虫,图形验证码识别、JS加密解密、动态网页爬虫、字体反爬识别等。 </li> <li class="" style="font-size:11pt;color:#494949;"> Scrapy和分布式爬虫:Scrapy框架、Scrapy-redis组件、分布式爬虫等。 </li> </ol> <p class="ql-long-26664262" style="font-size:11pt;color:#494949;"> 通过爬虫进阶的知识点我们能应付大量的反爬网站,而Scrapy框架作为一个专业的爬虫框架,使用他可以快速提高我们编写爬虫程序的效率和速度。另外如果一台机器不能满足你的需求,我们可以用分布式爬虫让多台机器帮助你快速爬取数据。 </p> <p style="font-size:11pt;color:#494949;">   </p> <p class="ql-long-26664262" style="font-size:11pt;color:#494949;"> 从基础爬虫到商业化应用爬虫,本套课程满足您的所有需求! </p> <p class="ql-long-26664262" style="font-size:11pt;color:#494949;"> <br /> </p> <p> <br /> </p> <p> <span style="font-size:14px;background-color:#FFFFFF;color:#337FE5;">【课程服务】</span> </p> <p> <span style="font-size:14px;">专属付费社群+定期答疑</span> </p> <p> <br /> </p> <p class="ql-long-24357476"> <span style="font-size:16px;"><br /> </span> </p> <p> <br /> </p> <p class="ql-long-24357476"> <span style="font-size:16px;"></span> </p>
©️2020 CSDN 皮肤主题: 大白 设计师:CSDN官方博客 返回首页
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值