將多張圖片打包成zip包,一塊兒上傳

一、前端頁面前端

<div class="mod-body" id="showRW" style="text-align: center;font-size: 14px;letter-spacing: 1px;line-height: 24px;padding-bottom: 10px;height:400px;background:#FFFFFF !important;padding-top:140px;">
							<table style="width: 100%;background:#FFFFFF !important;">
								<tr>
									<td style="text-align: center;">
										<span>選擇類型:</span>
										<select name="photoType" id="photoType" style="width:200px;">
											
										</select>
									</td>
								</tr>
								<tr>
									<td style="text-align: center;">
										<span>選擇文件:</span>
										<input type="file" style="width:200px;padding: 0 0px !important;" name="importImg" id="importImg">
									</td>
								</tr>
								<tr style="text-align: center;">
									<td >
				  						<input id="submitBtn" type="button" class="button" value="提交" style="width:130px;background: #263552;color: #FFF;border: 0px;border-radius: 2px;height: 28px;"/>
			  						</td>
			  					</tr>
			  					<tr style="text-align: center;">
									<td >
										<div style="display: inline-block;width: 50%;line-height: 30px;text-align: left;padding-left: 550px;">
											<span style="color:red;">注意:</span><br>
											<span>一、僅支持圖片打包成ZIP包,不能直接將文件夾打壓縮包</span><br/>
											<span>二、上傳的每張圖片大小須在100K之內</span>
										</div>
										
			  						</td>
			  					</tr>
							</table>
                   		</div>

  二、js代碼java

//提交
		$("#submitBtn").click(function(){
			
			var photoTypeSelect = $("#photoType").val();
			if(photoTypeSelect == -1){
				alert("請選擇照片牆類型");
				return false;
			}
			
			var importFile = $("#importImg")[0].files[0];
			if($("#importImg").val() == ''){
				alert("請選擇文件!");
				return false;
			}else{
				var fileNameIndex = importFile.name.lastIndexOf("."); 
				var fileName = importFile.name.substring(fileNameIndex,importFile.name.length); 
				if((fileName.toLowerCase() != ".zip" )){
					 alert("文件必須爲.zip類型"); 
    				 window.location.href='#';
           			 return false;
				}
			}
			$("#mask").show();
			$("#shDiv1").show();
			var formData = new FormData();
			formData.append("importFile", importFile);
			formData.append("photoTypeSelect", photoTypeSelect);
            formData.append("conId",conId);
			$.ajax({
				url:"<%=basePath%>/Conferences/photoWallAction.do?method=importPhotoWall", 
				type:"post",
				dataType:"json",
				data: formData, 
				dataType:"json",
	            // 告訴jQuery不要去處理髮送的數據
	            processData: false,
	            // 告訴jQuery不要去設置Content-Type請求頭
	            contentType: false,
	            async:false,
				success:function(json){
					$("#mask").hide(); 
					$("#shDiv1").hide(); 
					if(json.state == 1){
						if(confirm('導入成功!')){
							window.location.reload();
						}
					}else{
						if(confirm('導入失敗!')){
							window.location.reload();
						}
					}
				},
				error:function(){
					if(confirm('導入失敗!')){
							window.location.reload();
						}
				}
			})
			
		})

  三、後臺數據處理ajax

@RequestMapping(params = "method=importPhotoWall",method = RequestMethod.POST)
	public void importPhotoWall(Integer conId,Integer photoTypeSelect,HttpServletRequest request,HttpServletResponse response,ModelMap model){
		try {
			JSONObject result = new JSONObject();
			MultipartHttpServletRequest mRequest = (MultipartHttpServletRequest) request;
			MultipartFile mFile = mRequest.getFile("importFile");
			String theUrl = request.getScheme()+"://"+request.getServerName()+request.getContextPath()+"/";
			String fileUrl =  request.getSession().getServletContext().getRealPath("files");
			try {
				File file11 = new File(fileUrl+"/photoWallZip");
				if(!file11.exists()){
					file11.mkdirs();
				}
				File file = new File(fileUrl+"/photoWallZip","zip"+conId+".zip");
				mFile.transferTo(file);
				
				//解壓到目的文件夾
				File file1 = new File(fileUrl+"/photoWall/"+conId+"/");
				if(!file1.exists()){
					file1.mkdirs();
				}
				
				if(file != null){// 壓縮文件夾存在
					ZipFile zf = new ZipFile(fileUrl+"/photoWallZip/zip"+conId+".zip",Charset.forName("GBK"));
					Enumeration<?> entries = zf.entries(); 
					while(entries.hasMoreElements()){ 
						byte[] bytes = new byte[2048]; 
						int count = -1; 
						ZipEntry entry = (ZipEntry)entries.nextElement(); 
						String fileName = entry.getName();
						String saveUrl = "";
						if(entry.isDirectory()){
							
						}else{
							fileName = new Date().getTime()+fileName.substring(fileName.lastIndexOf("."), fileName.length());
							saveUrl = fileUrl+"/photoWall/"+conId+"/"+fileName;
							File file2 = new File(saveUrl);
							file2.createNewFile(); //建立文件
							InputStream is = zf.getInputStream(entry);
							FileOutputStream fos =  new FileOutputStream(file2);
							BufferedOutputStream bos = new BufferedOutputStream(fos, 2048); 
							 while((count = is.read(bytes)) > -1) 
						        { 
						          bos.write(bytes, 0, count); 
						        } 
							bos.flush(); 
					        bos.close(); 
					        fos.close(); 
					        is.close(); 
						}
						 List<PhotoWall> phoList = photoWallService.getPhotpWallByConIdAndTypeasc(conId, photoTypeSelect);
						 PhotoWall photoWall = new PhotoWall();
			        	 photoWall.setConferencesId(conId);
			        	 photoWall.setCreateTime(new Date());
			        	 if(phoList != null && phoList.size() > 0){
			        		 if(phoList.get(0) != null && phoList.get(0).getLastDoTime() != null){
			        			 photoWall.setLastDoTime(new Date(phoList.get(0).getLastDoTime().getTime()+60000));
			        		 }else{
			        			 photoWall.setLastDoTime(new Date());
			        		 }
			        	 }else{
			        		 photoWall.setLastDoTime(new Date());
			        	 }
			        	 photoWall.setCreateUserId(-1);
			        	 photoWall.setCreateUserType(-1);
			        	 photoWall.setImageUrl(theUrl+"files/photoWall/"+conId+"/"+fileName);
			        	 photoWall.setLaudCount(0);
			        	 photoWall.setState(2);
			        	 photoWall.setTypeId(photoTypeSelect);
			        	 photoWallService.saveOrUpdateObject(photoWall);
				    }
					zf.close();
					if(!file.exists()){
						System.out.println("刪除文件失敗,文件不存在");
					}else{
						 if (file.isFile())
						   if(!file.delete()){//判斷是否刪除完畢
						       System.gc();//系統進行資源強制回收
						       file.delete();
						   }
						   System.out.println("刪除成功");
						 }
					}
			} catch (Exception e) {
				result.accumulate("state", 0);
				e.printStackTrace();
			}
			result.accumulate("state", 1);
			writeToJson(response, result.toString());
		} catch (Exception e) {
			e.printStackTrace();
		}
	}
	
相關文章
相關標籤/搜索