码迷,mamicode.com
首页 > 编程语言 > 详细

JavaWeb之上传与下载

时间:2018-10-24 01:12:33      阅读:210      评论:0      收藏:0      [点我收藏+]

标签:use   概述   value   pac   javaweb   method   的区别   type   之间   

文件上传概述:

1,文件上传对页面的要求:

必须使用表单,而不能是超链接

表单的method必须是post

表单的enctype必须是multipart/form-data

在表单中添加file表单字段,即<input type=”file”…/>比如:

 <form action="${pageContext.request.contextPath }/XXXServlet" method="post" enctype="multipart/form-data">
        用户名:<input type="text" name="username"/><br/>
        文件1:<input type="file" name="file1"/><br/>
        文件2:<input type="file" name="file2"/><br/>
        <input type="submit" value="提交"/>
    </form>

 2,对比文件上传表单与普通表单的区别

通过httpWatch查看“文件上传表单”和“普通文本表单”的区别。

文件上传表单的enctype=”multipart/form-data”,表示多部件表单数据;

普通文本表单可以不设置enctype属性:

method=”post”时,enctype的默认值为application/x-www-form-urlencoded,表示使用url编码正文;

method=”get”时,enctype的默认值为null,没有正文,所以就不需要enctype了

通过httpWatch测试,查看表单的请求数据正文,我们发现请求中只有文件名称,而没有文件内容。也就是说,当表单的enctype不是multipart/form-data时,请求中不包含文件内容,而只有文件的名称,这说明普通文本表单中input:file与input:text没什么区别了。

通过httpWatch测试,查看表单的请求数据正文部分,发现正文部分是由多个部件组成,每个部件对应一个表单字段,每个部件都有自己的头信息。头信息下面是空行,空行下面是字段的正文部分。多个部件之间使用随机生成的分隔线隔开。

文本字段的头信息中只包含一条头信息,即Content-Disposition,这个头信息的值有两个部分,第一部分是固定的,即form-data,第二部分为字段的名称。在空行后面就是正文部分了,正文部分就是在文本框中填写的内容。

文件字段的头信息中包含两条头信息,Content-Disposition和Content-Type。Content-Disposition中多出一个filename,它指定的是上传的文件名称。而Content-Type指定的是上传文件的类型。文件字段的正文部分就是文件的内容。

 

请注意,因为我们上传的文件都是普通文本文件,即txt文件,所以在httpWatch中是可以正常显示的,如果上传的是exe、mp3等文件,那么在httpWatch看到的就是乱码了

 

3,文件上传对Servlet的要求

当提交的表单是文件上传表单时,那么对Servlet也是有要求的。

首先我们要肯定一点,文件上传表单的数据也是被封装到request对象中的。

request.getParameter(String)方法获取指定的表单字段字符内容,但文件上传表单已经不在是字符内容,而是字节内容,所以失效。

这时可以使用request的getInputStream()方法获取ServletInputStream对象,它是InputStream的子类,这个ServletInputStream对象对应整个表单的正文部分(从第一个分隔线开始,到最后),这说明我们需要的解析流中的数据。当然解析它是很麻烦的一件事情,而Apache已经帮我们提供了解析它的工具:commons-fileupload

需要使用的jar包

commons-fileupload.jar,核心包;最主要的工作就是帮我们解析request.getInputStream()

commons-io.jar,依赖包

 

JavaWeb之上传与下载

标签:use   概述   value   pac   javaweb   method   的区别   type   之间   

原文地址:https://www.cnblogs.com/QianYue111/p/9840421.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!