使用springMVC提供的CommonsMultipartFile类进行读取文件
需要用到上传文件的两个jar包commons-logging.jar、commons-io-xxx.jar1、在spring配置文件中配置文件上传解析器
- <!--文件上传解析器-->
- <beanid="multipartResolver"class="org.springframework.web.multipart.commons.CommonsMultipartResolver">
- <propertyname="defaultEncoding"value="utf-8"></property>
- <propertyname="maxUploadSize"value="10485760000"></property><!--最大上传文件大小-->
- <propertyname="maxInMemorySize"value="10960"></property>
- </bean>
2、文件上传页面(index.jsp)
- <!--method必须为post及enctype属性-->
- <formaction="fileUpload.do"method="post"enctype="multipart/form-data">
- <inputtype="file"name="file">
- <inputtype="submit"value="上传">
- </form>
3、FileController类
- @Controller
- publicclassFileController{
- @RequestMapping("/fileUpload.do")
- publicStringfileUpload(@RequestParam("file")CommonsMultipartFilefile,HttpServletRequestrequest,HttpServletResponseresponse){
- longstartTime=System.currentTimeMillis();//获取开始时间
- if(!file.isEmpty()){
- try{
- //定义输出流将文件保存在D盘file.getOriginalFilename()为获得文件的名字
- FileOutputStreamos=newFileOutputStream("D:/"+file.getOriginalFilename());
- InputStreamin=file.getInputStream();
- intb=0;
- while((b=in.read())!=-1){//读取文件
- os.write(b);
- }
- os.flush();//关闭流
- in.close();
- os.close();
- }catch(FileNotFoundExceptione){
- e.printStackTrace();
- }catch(IOExceptione){
- e.printStackTrace();
- }
- }
- longendTime=System.currentTimeMillis();//获取结束时间
- System.out.println("上传文件共使用时间:"+(endTime-startTime));
- return"success";
- }
- }
上传了一个3.54M的PDF文件 共使用29132毫秒(以自己计算机实际为准)
上面计算了上传文件所使用时间,目的为了和下篇另一种上传方法进行比较 看哪个效率更高
测试URL: http://localhost:8080/spring/
项目源码下载地址:http://download.youkuaiyun.com/detail/itmyhome/7447419