文件上传与下载

合集下载
相关主题
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

文件上传与下载

上传

文件上传概述

●实现web开发中的文件上传功能,需完成如下二步操作:

•在web页面中添加上传输入项

•在servlet中读取上传文件的数据,并保存到服务器硬盘中。

●如何在web页面中添加上传输入项?

标签用于在web页面中添加文件上传输入项,设置文件上传输入项时须注意:

•1、必须要设置input输入项的name属性,否则浏览器将不会发送上传文件的数据。

•2、必须把form的enctype属值设为multipart/form-data.设置该值后,浏览器在上传文件时,将把文件数据附带在http请求消息体中,并使用MIM

E协议对上传的文件进行描述,以方便接收方对上传数据进行解析和处理。

•3、表单的提交方式要是post

●如何在Servlet中读取文件上传数据,并保存到本地硬盘中?

•Request对象提供了一个getInputStream方法,通过这个方法可以读取到客户端提交过来的数据。但由于用户可能会同时上传多个文件,在servlet端编程

直接读取上传数据,并分别解析出相应的文件数据是一项非常麻烦的工作,

示例。

•为方便用户处理文件上传数据,Apache 开源组织提供了一个用来处理表单文件上传的一个开源组件(Commons-fileupload ),该组件性能优异,并且

其API使用极其简单,可以让开发人员轻松实现web文件上传功能,因此

在web开发中实现文件上传功能,通常使用Commons-fileupload组件实现。

●使用Commons-fileupload组件实现文件上传,需要导入该组件相应的支撑jar包:

Commons-fileupload和commons-io。commons-io 不属于文件上传组件的开发jar文件,但Commons-fileupload 组件从1.1 版本开始,它工作时需要commons-io包的支持。

文件上传步骤

●实现步骤

1、创建DiskFileItemFactory对象,设置缓冲区大小和临时文件目录

2、使用DiskFileItemFactory 对象创建ServletFileUpload对象,并设置上传文件的大小限制。3、调用ServletFileUpload.parseRequest方法解析request对象,得到一个保存了所有上传内容的List对象。

4、对list进行迭代,每迭代一个FileItem对象,调用其isFormField方法判断是否是上传文件

•True 为普通表单字段,则调用getFieldName、getString方法得到字

段名和字段值

•False 为上传文件,则调用getInputStream方法得到数据输入流,从

而读取上传数据。

FileUpload上传操作核心API

1、DiskFileItemFactory 磁盘文件项工厂类

public DiskFileItemFactory(int sizeThreshold, java.io.File repository) 构造工厂时,指定内存缓冲区大小和临时文件存放位置

public void setSizeThreshold(int sizeThreshold) 设置内存缓冲区大小,默认10K

public void setRepository(java.io.File repository)设置临时文件存放位置,默认System.getProperty("java.io.tmpdir").

内存缓冲区:上传文件时,上传文件的内容优先保存在内存缓冲区中,当上传文件大小超过缓冲区大小,就会在服务器端产生临时文件

临时文件存放位置:保存超过了内存缓冲区大小上传文件而产生临时文件

* 产生临时文件可以通过FileItem的delete方法删除

2、ServletFileUpload 文件上传核心类

static boolean isMultipartContent(javax.servlet.http.HttpServletRequest request) 判断request 的编码方式是否为multipart/form-data

java.util.List parseRequest(javax.servlet.http.HttpServletRequest request) 解析request,将请求体每个部分封装FileItem对象,返回List

void setFileSizeMax(long fileSizeMax) 设置单个文件上传大小

void setSizeMax(long sizeMax) 设置总文件上传大小

void setHeaderEncoding(ng.String encoding) 设置编码集解决上传文件名乱码*****

3、FileItem 表示文件上传表单中每个数据部分

boolean isFormField() 判断该数据项是否为文件上传项,true 不是文件上传false 是文件上传

if(fileItem.isFormField()){

// 不是上传项

ng.String getFieldName() 获得普通表单项name属性

ng.String getString() / ng.String getString(ng.String encoding) 获得普通表单项value属性传入编码集用来解决输入value乱码

}else{

// 是上传项

ng.String getName() 获得上传文件名(注意IE6存在路径)

java.io.InputStream getInputStream() 获得上传文件内容输入流

// 上传文件

void delete() 删除临时文件(删除时,必须要管理输入输出流)

}

注意事项:因为文件上传表单采用编码方式multipart/form-data 与传统url编码不同,所有getParameter 方法不能使用setCharacterEncoding 无法解决输入项乱码问题

JavaScript的多文件上传表单

●技巧:

•每次动态增加一个文件上传输入框,都把它和删除按纽放置在一个单独的div中,并对删除按纽的onclick事件进行响应,使之删除删除按纽所在的

div。

•如:

this.parentNode.parentNode.removeChild(this.parentNode);

上传文件存在的问题

➢上传文件后,在服务器端保存位置

第一类存放位置:直接存放WebRoot目录下和除WEB-INF META-INF的其它子目录下例如: WebRoot/upload

* 客户端可以直接在浏览器上通过url访问位置(资料无需通过权限控制,而可以直接访问)---- 对上传资源安全性要求不高、或者资源需要用户直接可见

* 例如:购物商城商品图片

第二类存放位置:放入WEB-INF及其子目录或者不受tomcat服务器管理目录例如:WebRoot/WEB-INF/upload 、c:\ 、d:\abc

* 客户端无法通过URL直接访问,必须由服务器内部程序才能读取(安全性较高,可以很容易添加权限控制)

* 例如:会员制在线视频

➢上传文件在同一个目录重名问题

如果文件重名,后上传文件就会覆盖先上传文件

文件名UUID

filename = UUID.randomUUID().toString() + "_" + filename;

相关文档
最新文档