springMVC3学习(十二)--文件上传优化CommonsMultipartResolver

基于上一篇文件上传发现效率很慢,我们应该对它进行优化  使用springMVC对文件上传的解析器

来处理文件上传的时候需要在spring的applicationContext里面加上springMVC提供的MultipartResolver的申明

这样客户端请求的时候 springMVC会检查request里面是否包含多媒体信息 如果包含了就会使用MultipartResolver进行解析,

springMVC会使用一个支持文件 处理的MultipartHttpServletRequest来包裹当前的HttpServletRequest

然后使用MultipartHttpServletRequest就可以对文件进行处理了

此处只改动FileController类 其他配置参考上一篇

  1. @Controller 
  2. public class FileController{ 
  3.      
  4.     @RequestMapping("/fileUpload.do"
  5.     public String fileUpload(HttpServletRequest request,HttpServletResponse response){ 
  6.         long startTime=System.currentTimeMillis();   //获取开始时间 
  7.          
  8.         CommonsMultipartResolver multipartResolver = new CommonsMultipartResolver(request.getSession().getServletContext()); 
  9.         if(multipartResolver.isMultipart(request)){ //判断request是否有文件上传 
  10.             MultipartHttpServletRequest multiRequest = (MultipartHttpServletRequest)request; 
  11.             Iterator<String> ite = multiRequest.getFileNames(); 
  12.             while(ite.hasNext()){ 
  13.                 MultipartFile file = multiRequest.getFile(ite.next()); 
  14.                 if(file!=null){ 
  15.                     File localFile = new File("D:/"+file.getOriginalFilename()); 
  16.                     try
  17.                         file.transferTo(localFile); //将上传文件写到服务器上指定的文件 
  18.                     } catch (IllegalStateException e) { 
  19.                         e.printStackTrace(); 
  20.                     } catch (IOException e) { 
  21.                         e.printStackTrace(); 
  22.                     } 
  23.                 } 
  24.             } 
  25.         } 
  26.         long endTime=System.currentTimeMillis(); //获取结束时间 
  27.         System.out.println("上传文件共使用时间:"+(endTime-startTime)); 
  28.          
  29.         return "success"
  30.     } 
@Controller
public class FileController{
	
	@RequestMapping("/fileUpload.do")
	public String fileUpload(HttpServletRequest request,HttpServletResponse response){
		long startTime=System.currentTimeMillis();   //获取开始时间
		
		CommonsMultipartResolver multipartResolver = new CommonsMultipartResolver(request.getSession().getServletContext());
		if(multipartResolver.isMultipart(request)){ //判断request是否有文件上传
			MultipartHttpServletRequest multiRequest = (MultipartHttpServletRequest)request;
			Iterator<String> ite = multiRequest.getFileNames();
			while(ite.hasNext()){
				MultipartFile file = multiRequest.getFile(ite.next());
				if(file!=null){
					File localFile = new File("D:/"+file.getOriginalFilename());
					try {
						file.transferTo(localFile); //将上传文件写到服务器上指定的文件
					} catch (IllegalStateException e) {
						e.printStackTrace();
					} catch (IOException e) {
						e.printStackTrace();
					}
				}
			}
		}
		long endTime=System.currentTimeMillis(); //获取结束时间
		System.out.println("上传文件共使用时间:"+(endTime-startTime));
		
		return "success";
	}
}


同样上传一个3.54M的PDF文件 只使用了16毫秒(已自己计算机实际为准)

可见差别之悬殊。

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值