文件上传原理:html
浏览器端:
1.表单的method必须是post.
2.要上传信息须要使用<input type="file" name="f">这个组件,必须有名称.
3.必须指定表单的encType的值为 multipart/form-data
服务器端:
能够经过request.getInputStream()获取输入流读取信息web
具体流程:api
1.导入jar包
2.使用commons-fileupload完成文件上传操做
1.DiskFileItemFactory ----它是用于设置文件上传相关属性
DiskFileItemFactory factory=new DiskFileItemFactory();
2.ServletFileUpload -----真正完成文件上传操做
ServletFileUpload upload=new ServletFileUpload(factory);
3.FileItem ----它是用于处理上传项的。
List<FileItem> fileItems=upload.parseRequest(request);
api详解
1.DiskFileItemFactory
构造方法
DiskFileItemFactory() 默认缓冲区大小10k
DiskFileItemFactory(int sizeThreshold, File repository) 参数sizeThreshold表明缓冲区大小 repository临时文件存储位置
若是在建立时,使用的是无参数构造,那么也能够经过其提供的setXxx方法来设置缓冲区大小与临时文件存储位置
setSizeThreshold(int sizeThreashold) 用于设置缓冲区大小
setRepository(File f) 用于设置临时文件存储位置
2.FileServletUpload
1.isMultipartContent
这个方法返回的是boolean类型值,它用于判断当前是不是上传操做.
若是是上传操做,咱们在获取全部上传信息时,使用的是commons-fileuplad的api,而不能在使用web经常使用对象 request
2.parseRequest 获得一个List<FileItem> 能够理解成获得全部的上传项.
3.设置上传文件大小
void setFileSizeMax(long fileSizeMax) 设置单个文件上传大小
void setSizeMax(long sizeMax) 设置总文件上传大小
4.解决上传文件的名称乱码
setHeaderEncoding(String c) 它用于解决上传文件的名称乱码问题
3.FileItem
isFormField() 返回true,false,表明的是普通组件,上传组件.
getName() 普通组件获取的为null,上传组件获取的上传文件的路径.
getFieldName() 获取组件的名称
getString() 普通组件获取的是value,上传组件获取的是文件的内容
getInputStream(); 它用于对上传组件进行操做,能够获得一个指向上传文件的输入流。
对于getString()它有一重载的方法 getString(String c),它用于解决乱码问题.
delete()方法,用于删除临时文件。
------------------------------------------------------
对于上传操做它的乱码问题:
不能使用request.setCharacterEncoding("utf-8");解决.
使用commons-fileupload这个插件:
若是是普通组件:item.getString(String encoding);
若是是上传组件:主要是上传文件的名称乱码: ServletFileUpload.setHeaderEncoding(String encoding);来解决
浏览器
文件下载服务器
这种下载,只须要让超链接标签它的href指向要下载的文件就能够。
缺点:
1.若是要下载的文件是能够直接被浏览器解析的,在点击时会在浏览器中打开。咱们必须右键另存为。
2.要求被下载的文件必须是能够直接被浏览器访问的。jsp
服务器端经过流下载:post
如今要下载的文件是 d:/upload目录下的内容
若是只是将要下载的文件内容经过response获取输出流写回到浏览器端,那么对于浏览器
来讲,它须要作的事情就是将信息在浏览器中显示出来。
MIMEType:它表明的是服务器通知浏览器响应的数据的类型。
//response.setContextType("text/html;charset=utf-8");
这种方式文件下载操做必须设置两个信息:
1.respose.setContentType(); 必须设置响应的数据的mimetype类型.
设置它之后,若是当前的mimeType类型浏览器能够直接解析,就将其显示在浏览器中了,
若是不能解析,会让你下载 ,可是下载文件的名称不对。
2.response.setHeader("Content-Disposition","attachment;filename=??");
这项设置后,点击时就是下载操做了,而filename的值就是下载文件的名称.google
下载乱码问题:编码
在download2.jsp页面上修改
<a href="${pageContext.request.contextPath}/download1?filename=第一.txt">下载第一.txt</a><br>
<a href="${pageContext.request.contextPath}/download1?filename=汽车.jpg">下载汽车.jpg</a><br>
<a href="${pageContext.request.contextPath}/download1?filename=HTML笔记.doc">下载HTML笔记.doc</a><br>
问题1:这时超链接它是get请求,到服务器端获得的数据乱码,查找不到。
解决:get请求的乱码问题
filename = new String(filename.getBytes("iso8859-1"), "utf-8"); //解决get请求的乱码问题
---------------------------------------------------------------------------------------------
问题2:下载文件的名称乱码
在文件下载时,文件的名称,它对于不一样的浏览器使用的是不一样的编码。
ie使用的是utf-8码
firefox使用base64编码.
response.setHeader("content-disposition","attachement;filename=??");
若是filename的值中包含了中文,那么对于不现的浏览器在解析时使用的编码不同。
if (agent.contains("MSIE")) {
// IE浏览器
filename = URLEncoder.encode(filename, "utf-8");
filename = filename.replace("+", " ");
} else if (agent.contains("Firefox")) {
// 火狐浏览器
BASE64Encoder base64Encoder = new BASE64Encoder();
filename = "=?utf-8?B?"
+ base64Encoder.encode(filename.getBytes("utf-8"))
+ "?=";
} else if (agent.contains("Chrome")) {
// google浏览器
filename = URLEncoder.encode(filename, "utf-8");
} else {
// 其它浏览器
filename = URLEncoder.encode(filename, "utf-8");
}spa