java文件上传

控制器(Controller)

普通上传
// 普通上传
@ResponseBody
@RequestMapping("fileUp")
public void fileUp(MultipartFile file){
	String root_path = ApplicationConstant.fileDisk;
	
	long length = (1024 * 1024 * 5);
	String filepath ="";
	
	if( Long.parseLong(size) < length){
		// 正常上传
		String file_path = root_path + File.separator + proname + File.separator + t1;
		
		//创建项目文件夹
		File newFile = new File(file_path);
		if (!newFile.exists()) {
			newFile.mkdirs();
		}
		
		filepath = UploadUtil.upload(file, file_path);
}
分块上传
// 分块上传
@ResponseBody
@RequestMapping("fileUp")
public void fileupload(MultipartFile file){

filepath = UploadUtil.upload(file, file_path + File.separator + name ,count,filename); 
				
				if( (Long.parseLong(size)/length) == Integer.parseInt(count) ){
					// 如果 是最后一次分块上传 进行合并
 					File filelist = new File(file_path + File.separator + name);
					File[] list = filelist.listFiles();
					
					// 如果是最后一次  把所有文件合在一起 并删掉
					try {
						String saveFile = newFile + File.separator + t1;
						// 创建 所有小文件合成后的  大文件的文件夹
						File newFile2 = new File(saveFile);
						if (!newFile2.exists()) {
							newFile2.mkdirs();
						}
						
						RandomAccessFile  raf = new RandomAccessFile(saveFile + File.separator + newfilename, "rw");
						// 定义一个新的文件
						for(int i = 0; i < list.length; i++){
							// 循环所有分块
							InputStream reader = new FileInputStream(file_path + File.separator + name+File.separator+ name+"_"+(i)+"."+FilenameUtils.getExtension(filename));
							// 获得当前 的 分块
							byte[] b = new byte[1024]; 
							int n = 0; 
							while((n = reader.read(b)) != -1){ 
								raf.write(b, 0, n); 
								// 写入
							}
							reader.close();
						}
						raf.close();
						
						// 完成后删除所有分块
						fileDao.getSession().createSQLQuery("update t_assets_filepath set fileid = '"+t1+"_"+newfilename+"', note = 'new' where note = 'file' and inuse = '1'" ).executeUpdate();
						
						File f =new File(file_path + File.separator+ name);
						File[] fs = f.listFiles();
						for(int j=0;j<fs.length;j++){
							fs[j].delete();
						}
						f.delete();
						
					} catch (IOException e) {
						// TODO Auto-generated catch block
						e.printStackTrace();
					} 
				}
	}
	

js


	// 开始
		function Start() {
        	S_index = 0;
            Upload();
        }

        function Upload() {
        	var i = loading[0];
        	
            var files = document.getElementById("hi_file-"+i).files;
            
            var file = files[0];
            var totalSize = file.size;//文件大小
            var blockSize = 1024 * 1024 * 5;//块大小
            var blockCount = Math.ceil(totalSize / blockSize)-1;//总块数
            //创建FormData对象
            var formData = new FormData();
            formData.append('filename', file.name);//文件名
            formData.append('size', totalSize);
            
            UploadPost(file, formData, totalSize, blockCount, blockSize);
        }
        
        function UploadPost(file, formData, totalSize, blockCount, blockSize) {
           	
        	var foldername =  $('#dg_project').treegrid('getSelected').foldername;// 文件夹名称
			var proid = $('#dg_project').treegrid('getSelected').id;
			
			for(var i=1;i>0;i++){
	         	var father = $('#dg_project').treegrid("getParent",proid);
	         	if(father != null){
	         		foldername = father.foldername +"\\"+ foldername;
	         		proid = father.id;
	         	}else{
	         		break;
	         	}
	         } 
        	
        	var id = loading[0];
        	if (pause) {
            	$('#dg_prog-'+id).html('已暂停')
                return; //暂停
            }
            try {
            	var start = S_index * blockSize;
            	var end = start + blockSize ;
            	end = Math.min(totalSize,end);
            	
                var block = file.slice(start, end);
                if(blockSize >= totalSize){
                	block = file;
                }
                
                formData.set('file', block);
                formData.set('count', S_index);
                formData.set('proname',foldername);
                
                opering =true; // 正在上传
                
                $('#sc_state-'+id).html("上传中。。")
                $.ajax({
                    url: '${baseurl}/intangibleassets/list/uploading',
                    type: 'post',
                    data: formData,
                    processData: false,
                    contentType: false,
                    success: function(res) {
                        block = null;
                        if (1 == 1) {
							
                            var id = loading[0];
                            
                            var progressBar = document.getElementById("progressBar-"+id);
                            progressBar.max = totalSize;
                            progressBar.value = end;
                            
                            var files = document.getElementById("hi_file-"+id).files;
                            var file = files[0]; 
                            
                            if(totalSize <= blockSize){
                            	$('#percentage-'+id).text(100 + '%');
                            }else{
                            	
                            	$('#percentage-'+id).text((S_index / blockCount * 100).toFixed(2) + '%');
                            	
                            	if($('#dg_prog-'+id).length>0){
                                	
                                	$('#dg_prog-'+id).html((S_index / blockCount * 100).toFixed(2) + '%')
                                	
                                	if(( S_index / blockCount * 100).toFixed(2)>90 ){
                                		closeMinWind = true;
                                	}else{
                                		closeMinWind = false;
                                	}
                                }
                            }
                            
                            if (S_index < blockCount) {
                            	S_index++;
                            	
                                UploadPost(file, formData, totalSize, blockCount, blockSize);
                            }else{
                            	opering = false;// 上传结束
                                
                      			$('#sc_state-'+id).html("上传成功");
                      			
                      			$('#dg_prog-'+id).html('待保存')
                            	
                      			fileidList.push({
								    id : id,
								    fileid : res
								})
                      			
                    			loading.splice(0, 1);// 取第一个上传 并删除掉
                    			
                    			if(loading.length>0){
                    				
                    				var id2 = loading[0];
                    				var file = document.getElementById("hi_file-"+id2).files[0];
                    				sc(file.size,file.name);//如果列表还有 再进行上传
                    			}else{
                    				// 判断 如果已经最小化 自动保存
                    				if(open_coll){
                    					// 自动保存
                    					submit();
                    				}
                    			}
                            }
                        }
                    }
                });
            } catch (e) {
                alert(e);
            }
        }
        ///暂停
        function Pause() {
            pause = true;
        }
        //继续
        function Continue() {
            pause = false;
            Start();
        }
    	
       	function stopORstart(){
       		
       		var id = loading[0];
       		
       		if(id == undefined){
       			return ;
       		}
       		
			var file = document.getElementById("hi_file-"+id).files[0];
       		
			var foldername =  $('#dg_project').treegrid('getSelected').foldername;// 文件夹名称
			var proid = $('#dg_project').treegrid('getSelected').id;
			
			for(var i=1;i>0;i++){
	         	var father = $('#dg_project').treegrid("getParent",proid);
	         	if(father != null){
	         		foldername = father.foldername +"\\"+ foldername;
	         		proid = father.id;
	         	}else{
	         		break;
	         	}
	         } 
			
       		if(pause){
       			// 暂停中
       			$.ajax({
       				url: '${baseurl}/intangibleassets/list/fileCount',
       				data:{'filename': file.name,'proname': foldername},
       				success: function(count){
       					pause = false;
       					$('#sc_state-'+id).html("上传中。。")
       					S_index = count;
       					Upload();
       					
       				}
       			})
       		}else{
       			// 运行中
       			pause = true;
       			$('#sc_state-'+id).html("已暂停")
       		}
        }

web


    <style type="text/css">
  
	.sc_div {
		border: 1px solid  #c0ccda;
		border-radius:5px 5px 5px 5px;
		width: 100%;
		height: 70px ;
	}
	
    </style>

<div id="p" class="easyui-panel" title="文件上传" style="width: 96%;height: 350px">
 			<div style="padding: 5px; text-align:left;">
	 			<a href="javascript:void(0)" class="easyui-linkbutton " style="width: 80px; text-align: center;" onclick="addfile()">选择文件</a> 
	 			<a id="on-off" href="javascript:void(0)" class="easyui-linkbutton " style="width: 80px; text-align: center;" onclick="stopORstart()">暂停/继续</a>
			</div>
			
			<div style="display: none;" id="hi_addfile"></div>
			
			<div id="SC-one" style="width: 100%;height: 270px;overflow: auto;" align="center">
				<ul	id="ul_file_list" >
				</ul>
			</div>
	 	</div>

文件上传工具

CSDN-上传工具

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值