删除文件

前端

//删除
function delbutton(id){
	var gridData = $('#jqGrid').jqGrid('getRowData',id);
 	layer.confirm('确认要删除该证件吗?',function(index){
 		$.ajax({
 			url:'${appName}/t9c_employee_resumes/upload_papers/delFile.ajax',
 			data:{id:gridData.id,address:gridData.address,seq:gridData.seq,userid:gridData.userid},
 			type:'post',
 			dataType:'json',
 			success:function(data){
 					 if("1" == data.messageFlag){
 						var popLayerWindow = getPopLayerWindow();
 					queryList();
 					successMsg(data.message);
 					 }else{
 						layer.alert(data.message);
 					 }
 			}
 		})
	});
}

后端

//删除证件
	@RequestMapping(value="/delFile.ajax",method=RequestMethod.POST)
	@ResponseBody
	public OprMessage delFile(T9c_employee_papersDTO t9c_employee_papersDTO){
		OprMessage oprMessage = new OprMessage("1", "删除成功!");
			try {
				t9c_employee_papersService.delFile(t9c_employee_papersDTO);
				String address=t9c_employee_papersDTO.getAddress();
				if(!address.equals("")) {
					String seq=t9c_employee_papersDTO.getSeq();
					String userid=t9c_employee_papersDTO.getUserid();
					String index_path=userid+"/"+seq;
					int len=index_path.length();
					//获得压缩到路径
					String del_paht=address.substring(0,address.indexOf(index_path)+len);
					File file =new File(del_paht);
					//调用方法,递归删除
					deleteFile(file);
				}
			} catch (Exception e) {

				oprMessage.setFlagMessage("0", "删除失败!数据库错误");
				e.printStackTrace();
			}
		return oprMessage;
	}

deleteFile(file)方法
如果是文件,直接删除。如果是目录,必须删除里面每一层目录里所有文件,最后才能删除最外层的目录。原因:不为空的话,删不了

public static void deleteFile(File file) {
		if(file.exists()) {//判断路径是否存在
			if(file.isFile()){//boolean isFile():测试此抽象路径名表示的文件是否是一个标准文件。 
				file.delete();
			}else{//不是文件,对于文件夹的操作
				//保存 路径D:/1/新建文件夹2  下的所有的文件和文件夹到listFiles数组中
				File[] listFiles = file.listFiles();//listFiles方法:返回file路径下所有文件和文件夹的绝对路径
				for (File file2 : listFiles) {
					/*
					 * 递归作用:由外到内先一层一层删除里面的文件 再从最内层 反过来删除文件夹
					 *    注意:此时的文件夹在上一步的操作之后,里面的文件内容已全部删除
					 *         所以每一层的文件夹都是空的  ==》最后就可以直接删除了
					 */
					deleteFile(file2);
				}
			}
			file.delete();
		}else {
			System.out.println("该file路径不存在!!");
		}
	}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
一个通用的Android端弹窗管理框架,内部维护弹窗优先级队列 具备弹窗管理扩展功能 整合Dialog,PoupoWindow,悬浮Widget,透明Webview,Toast,SnackBar,无需再为繁琐的业务弹窗逻辑所困扰如何添加依赖只需要两行代码轻松接入//add this to your repositories  maven { url 'https://www.jitpack.io' } //add this to your dependencies implementation 'com.github.MrCodeSniper:PopLayer:2.0.0'具体如何使用1.根据策略创建对应的弹窗view//Dialog形式 PopLayerView  mLayerView = new PopLayerView(this,R.layout.common_dialog_upgrade_app); //透明Webview形式 PopLayerView mLayerView = new PopLayerView(this,LayerConfig.redPocketScheme);2.开始装配弹窗配置Popi mUpgradePopi1 = new Popi.Builder()                 .setmPopId(4)//弹窗的唯一标识 当id发生改变 视为新的弹窗                 .setmPriority(2)//优先级这里不具体划分对应的范围 值越小优先级越高                 .setmCancelType(TRIGGER_CANCEL)//弹窗消失的类型分为 TRIGGER_CANCEL(触摸消失) COUNTDOWN_CANCEL (延时消失)                 .setMaxShowTimeLength(5)//最长显示时间(S)                 .setMaxShowCount(5)//最大显示次数                 .setmBeginDate(1548858028)//开始时间 2019-01-30 22:20:28                 .setmEndDate(1548944428)//结束时间 2019-01-31 22:20:28                 .setLayerView(mLayerView)//弹窗View                 .build();3.纳入弹窗管理//纳入弹窗管理 PopManager.getInstance().pushToQueue(mUpgradePopi); //开始显示弹窗 PopManager.getInstance().showNextPopi();效果预览未来的计划逐步统一 其他类型的弹窗 希望能提供给大家一个较为全面的应对业务需求的弹窗管理框架版本记录V1方案版本号LOG进度更新V1.0.0项目开源,完成弹窗管理与Dialog形式扩展Dialog策略扩展完成V1.0.1修复Dialog策略无法获取dialog实体bugDialog策略优化V1.0.2修复activity摧毁造成的弹窗异常 bugDialog策略优化V1.0.3优化了弹窗的使用更加方便快捷框架使用优化V2方案版本号LOG进度更新V2.0.0正式加入透明Webview弹窗策略扩展透明Webview策略扩展完成作者介绍Hello 我叫lalala,如果您喜欢这个项目 请给个star 能follow我那真是太好了!!
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值