zoukankan      html  css  js  c++  java
  • spring html5 拖拽上传多文件

    注:这仅仅是一个粗略笔记。有些代码可能没用。兴许会再更新一个能够使用的版本号。不足之处,敬请见谅。

    1。spring环境搭建,这里使用的是spring3的jar,须要同一时候引入common-IO 和common-fileupload的jar包。

    1.1spring.XXX.xml文件配置bean

    <bean id="multipartResolver"
    		class="org.springframework.web.multipart.commons.CommonsMultipartResolver">
    		<property name="maxUploadSize" value="${web.maxUploadSize}" />
    	</bean>
    value="xxxx"依据实际情况改动。

    2.html表单

    <form id="uploadForm" action="data/myData4PipeiUpload" method="post" enctype="multipart/form-data">
                        <div class="upload_box">
                            <div class="upload_main">
                                <div class="upload_choose">
                                    <span id="fileDragArea" class="upload_drag_area">请将文件拖拽至此处上传</span>
                                    <input id="fileImage" size="30" name="fileselects[]" multiple="multiple"  type="file">
                                </div>
                                <div id="preview" class="upload_preview"></div>
                            </div>
                           
                            <div id="uploadInf" class="upload_inf"></div>
                        </div>
                        <div class="upload_box">
                            文件名2:
    				<input  name="fileFieName" id="fileFieName"  />
                        </div>
                        <DIV class="modal-footer">
    			        <BUTTON class="btn btn-primary" type="submit" id="submitBut3" data-dismiss="modal">上传数据文件</BUTTON>
    			        </DIV>
                    </form>

    2.1除了普通上传的一些格式要求之外。这里要注意多文件须要name=“XXX[]” multiple=“multiple"

     <input id="fileImage" size="30" name="fileselects[]" multiple="multiple"  type="file">

    2.2这里使用了upload.js和zxxFile.js。去配置相关參数

    3.后台代码编写两种方式。

    3.1

    @RequestMapping(value = "/myData4PipeiUpload", method = RequestMethod.POST)
    	public void handleRequest(HttpServletRequest request,   
                HttpServletResponse response) throws Exception {   
            // 转型为MultipartHttpRequest:   
           MultipartHttpServletRequest multipartRequest = (MultipartHttpServletRequest) request;   
          List<MultipartFile> singleFiles = multipartRequest.getFiles("fileselects[]"); 
                
            if(singleFiles!=null&&singleFiles.size()>0){
            	for(MultipartFile file: singleFiles){
    		        // 获得文件名称:   
    		        String filename = file.getOriginalFilename();
    		        // 获得输入流:   
    		        InputStream input = file.getInputStream();   
    		        // 写入文件   
    		        // 或者:   
    		        File source = new File("d:/dd/"+filename);   
    		        file.transferTo(source); 
            	}
            }
        }  
    注意參数的获取要使用fileselects[]去获取列表

    3.2,直接将请求名称写入到@requestParam

    @RequestMapping(value = "/myData4PipeiUpload", method = RequestMethod.POST)
    	public void handleRequest(@RequestParam("fileselects[]") MultipartFile[] files,HttpServletRequest request,   
    			HttpServletResponse response) throws Exception {   
    		           
    		if(files!=null&&files.length>0){
    			for(MultipartFile file: files){
    				// 获得文件名称:   
    				String filename = file.getOriginalFilename();
    				// 获得输入流:   
    				InputStream input = file.getInputStream();   
    				// 写入文件   
    				
    				// 或者:   
    				File source = new File("d:/dd/"+filename);   
    				file.transferTo(source); 
    			}
    		}
    	}  
    这样子就能够再进行兴许的操作。

  • 相关阅读:
    如何进行数据库设计
    安装mysql后ERROR 2002 (HY000): Can’t connect to local MySQL server through socket ‘/var mysql 启动不了
    Hive介绍、安装(转)
    Hadoop家族 路线图(转)
    Hive学习路线图(转)
    【CF949D】Curfew(贪心)
    【CF912E】Prime Game(meet in the middle)
    【BZOJ3872】Ant colony(二分,动态规划)
    【BZOJ2067】SZN(二分,动态规划,贪心)
    AtCoder Grand Contest 006
  • 原文地址:https://www.cnblogs.com/hrhguanli/p/4050064.html
Copyright © 2011-2022 走看看