标签:har cto 缓冲 gravity files apche byte dna 状态
1.肯定要导入apche的jar包
2.要使用的类的介绍..
2.1DiskFileItemFactory
public DiskFileItemFactory(int sizeThreshold, java.io.File repository)
public DiskFileItemFactory()
public void setSizeThreshold(int sizeThreshold) --用来设定内存缓冲区的大小,默认是10k
public void setRepository(java.io.File repository) --设定暂时目录的大小
2.2ServletFileUpload
boolean isMultipartContent(HttpServletRequest request) 推断上传表单是否为multipart/form-data类型
List parseRequest(HttpServletRequest request) 解析request对象。并把表单中的每个输入项包装成一个fileItem 对象。并返回一个保存了全部FileItem的list集合。
setFileSizeMax(long fileSizeMax) 设置单个上传文件的最大值
setSizeMax(long sizeMax) 设置上传文件总量的最大值
setHeaderEncoding(java.lang.String encoding) 设置编码格式,解决上传文件名称乱码问题
setProgressListener(ProgressListener pListener) 实时监听文件上传状态
2.3FileItem
boolean isFormField() 推断FileItem是一个文件上传对象还是普通表单对象
假设是一个普通字段项能够调用:
String getFieldName() 获得普通表单对象的name属性
String getString(String encoding) 获得普通表单对象的value属性,能够用encoding进行编码设置
假设是一个文件上传项:
String getName() 获得上传文件的文件名称(有些浏览器会携带client路径)
InputStream getInputStream() 获得上传文件的输入流
delete() 在关闭FileItem输入流后,删除暂时文件
文件存放应该注意的问题:
1.upload目录和temp目录都要放在web-inf目录下保护起来,防止上传入侵和訪问其它用户上传资源的问题
2.文件名称要拼接uuid保证唯一
3.文件要分文件夹存储保证同一文件夹下不要有过多的文件,分文件夹的算法有非常多,介绍了一种依据hash值分文件夹算法
案例:
1.写一个文件上传的jsp页面:
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%> <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> <html> <head> <title></title> <meta http-equiv=" pragma" content="no-cache"> <meta http-equiv="cache-control" content="no-cache"> <meta http-equiv="expires" content="0"> </head> <body style="text-align: center"> <h1>文件上传</h1> <div align="center"> <form action="${pageContext.request.contextPath }/servlet/UploadServlet1" enctype="multipart/form-data" method="post"> 描写叙述信息1:<input type="text" name="description1"/><br> 描写叙述信息2:<input type="text" name="description2"/><br> <input type="file" name="file1"/><br> <input type="submit" value="提交"/><br> </form> </div> </body> </html>2.要实现文件上传的servlet类(须要在WEB-INF的文件夹下建立upload和temp文件夹)
package cn.itheima.upload; import java.io.File; import java.io.FileOutputStream; import java.io.IOException; import java.io.InputStream; import java.io.OutputStream; import java.util.List; import java.util.UUID; import javax.servlet.ServletException; import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import org.apache.commons.fileupload.FileItem; import org.apache.commons.fileupload.disk.DiskFileItemFactory; import org.apache.commons.fileupload.servlet.ServletFileUpload; import cn.itheima.utils.IOUtils; public class UploadServlet1 extends HttpServlet { public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { try { // 1.获取文件上传的工厂类 DiskFileItemFactory factory = new DiskFileItemFactory(); factory.setSizeThreshold(1024 * 100);// 设置内存的缓存,假设缓存满了就放到暂时目录中 factory.setRepository(new File(this.getServletContext() .getRealPath("WEB-INF/temp")));// 设置暂时目录 // 2.通过工厂类得到文件上传的核心类 ServletFileUpload fileUpload = new ServletFileUpload(factory); fileUpload.setFileSizeMax(1024 * 1024 * 100);// 设置单个上传文件的大小 fileUpload.setSizeMax(1024 * 1024 * 300);// 设置文件的总的大小 fileUpload.setHeaderEncoding("utf-8");// 解决上传文件里文名的乱码问题 // 3.检查提交的表单enctype类型 if (!fileUpload.isMultipartContent(request)) { throw new RuntimeException("请使用正确的表单类型上传文件"); } // --解析request List<FileItem> list = fileUpload.parseRequest(request); // --遍历list for (FileItem item : list) { if (item.isFormField()) {// 是普通输入类型 String fieldName = item.getFieldName(); String value = item.getString("utf-8");// 解决普通输入类型的中文乱码问题 System.out.println(fieldName + ":" + value); } else {// 文件上传类型 String filename = item.getName();// 上传文件的文件名称 String uuid = UUID.randomUUID().toString(); String uuidname = uuid + "_" + filename;// 上传文件使用uuid之后的文件名称 String str = Integer.toHexString(uuidname.hashCode());// 这里使用hashcode // 进行目录的创建 String path = this.getServletContext().getRealPath( "WEB-INF/upload"); for (char c : str.toCharArray()) { path += "/" + c; } new File(path).mkdirs();// 创建目录 InputStream in = item.getInputStream(); OutputStream out = new FileOutputStream(new File(path, uuidname)); IOUtils.In2Out(in, out); IOUtils.closeIO(in, out); item.delete();// 删除暂时目录 } } } catch (Exception e) { e.printStackTrace(); throw new RuntimeException(); } } public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { doGet(request, response); } }
3.工具类
package cn.itheima.utils; import java.io.IOException; import java.io.InputStream; import java.io.OutputStream; public class IOUtils { private IOUtils(){ } /** * 读取流中的数据写到输出流中 * @param in * @param out * @throws IOException */ public static void In2Out(InputStream in,OutputStream out) throws IOException{ int len=0; byte b[]=new byte[1024]; while((len=in.read(b))!=-1){ out.write(b, 0, len); } } /** * 关闭资源 * @param in * @param out */ public static void closeIO(InputStream in,OutputStream out){ if(in!=null){ try { in.close(); } catch (IOException e) { e.printStackTrace(); }finally{ in=null; } } if(out!=null){ try { out.close(); } catch (IOException e) { e.printStackTrace(); }finally{ out=null; } } } }
执行界面:
当执行完成后能够在tomcat的WEB-INF的upload文件夹下...看到
标签:har cto 缓冲 gravity files apche byte dna 状态
原文地址:http://www.cnblogs.com/blfbuaa/p/7063000.html