SpringMVC+uploadify3.2.1版实现附件上传功能(直接可以使用)
<link rel="stylesheet" type="text/css" href='<c:url value="/uploadify/uploadify.css"/>' />
<script src="<c:url value="/uploadify/jquery.uploadify.min.js"/>"type="text/javascript"></script>
<a class="task_btn_upload" href="javascript:$('#file_upload1').uploadify('upload','*')">开始上传</a>
<input type="file" name="file_upload" id="file_upload"/> $(function() {
$("#file_upload").uploadify({
'auto':false, //是否允许自动上传
'swf' : '../uploadify/uploadify.swf?var='
+(new Date()).getTime(), //引入flash
'buttonText':'', //设置button文字
'removeCompleted': true,//是否移除掉队列中已经完成上传的文件。false为不移除
'removeTimeout': 3,//设置上传完成后删除掉文件的延迟时间,默认为3秒。
'width ':'120', //按钮宽度
'method':'PSOT', //提交方式
'multi':'true', //是否多文件上传
'fileObjName' : 'myFile', //文件对象名称,用于后台获取文件对象时使用
'preventCaching':'true', //防止浏览器缓存
'formData':{'emergencyId':1111}, //动态传参
'queueID': 'custom-queue', //显示在某个div的位置 custom-queue div的id
'uploader' : 'emergencyQueryRevision.do?
method=addAnnex' , //提交后台方法路径
//onUploadStart 动态传参的关键
'onUploadStart':function(){
$("#file_upload").uploadify("settings","formData",
{'emergencyId': $("#id").val()});
},
'onFallback' : function() {//检测FLASH失败调用
alert("您未安装FLASH控件,无法上传图片!请安装FLASH控件后再试。");
},
'onUploadSuccess':function(file, data, response){
var Data = eval('('+data+')');
// alert(file.name+"上传"+Data.result);
},
onError: function(event, queueID, file)
{
alert(file.name + " 上传失败");
},
'onQueueComplete':function(stats) {
//版本不一样方法也存在差异
alert("成功上传的文件数:" + stats.uploadsSuccessful + " =上传出错的文件数:" +stats.uploadsErrored + " -上传的文件总大小:" + stats.uploadSize);
cancel();
},
});
});
//上传附件
MultipartHttpServletRequest multipartRequest =
(MultipartHttpServletRequest) request;
MultipartFile file =multipartRequest.getFile("myFile");
//获取服务器地址
ServletContext sc = request.getSession().getServletContext();
//附件存放服务器路径
String dir = sc.getRealPath("/upload/yingjiwuzhi/");
//如果文件夹不存在,则创建文件夹
if (!new File(dir).exists()){
new File(dir).mkdirs();
}
String fileName = file.getOriginalFilename();
String realName = fileName.substring(0, fileName.indexOf("."));
//防止文件被覆盖,以纳秒生成文件名称
Long _l = System.nanoTime();
String _extName = fileName.substring(fileName.indexOf("."));
fileName = _l + _extName;
String uploadPath = request.getContextPath() +
"/upload/yingjiwuzhi/" + fileName;
//存储格式为:/项目名/upload/yingjiwuzhi/43038800303864.log
//存储到数据库的相对路径
String responseStr="";
try {
FileUtils.writeByteArrayToFile(new File(dir, fileName),
file.getBytes());//服务器中生成文件
responseStr="上传成功";
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
responseStr="上传失败";
}
//删除服务器上的附件
//获取服务器地址
ServletContext sc = request.getSession().getServletContext();
//项目名称
String projectName = request.getContextPath();
String annexId = request.getParameter("annexId");
String emergencyId = request.getParameter("emergencyId");
//附件路径 存储格式为:/项目名/upload/yingjiwuzhi/43038800303864.log
String annexPath=request.getParameter("path");
if(!"".equals(annexPath)&&annexPath!=null){
String path = annexPath.replace(projectName, "");
String filePath = sc.getRealPath(path.trim());
File file = new File(filePath);
// 如果文件路径所对应的文件存在,并且是一个文件,则直接删除
if (file.exists() && file.isFile()) {
if (file.delete()) {
map.put("result", "true");
} else {
map.put("result", "false");
}
} else {
file.delete();
map.put("result", "true");
}
}
SpringMVC+uploadify3.2.1版实现附件上传功能(直接可以使用)的更多相关文章
- Springmvc file多附件上传 显示 删除操作
之前项目需求要做一个多附件上传 并显示上传文件 带删除操作 一筹莫展之际搜到某个兄弟发的博客感觉非常好用被我copy下来了此贴算是改良版 再次感谢(忘记叫什么了时间也有点久没有历史记录了)先上图 基于 ...
- 跟版网 > 织梦教程 > 织梦安装使用 > 织梦DedeCMS附件上传大
织梦DedeCMS附件上传大小受限制,超过2M就不能上传了,针对此问题按如下方法修改: 1.进入后台→系统设置→系统基本参数→会员设置→会员上传文件大小(K),改成你需要限制的大小: 2.在dede ...
- java附件上传下载磁盘版
ACTION public class UploadAction extends BaseAction { private static final long serialVersionUID = 1 ...
- asp.net结合uploadify实现多附件上传
1.说明 uploadify是一款优秀jQuery插件,主要功能是批量上传文件.大多数同学对多附件上传感到棘手,现将asp.net结合uploadfiy如何实现批量上传附件给大家讲解一下,有什么不对的 ...
- 基于MVC4+EasyUI的Web开发框架形成之旅--附件上传组件uploadify的使用
大概一年前,我还在用Asp.NET开发一些行业管理系统的时候,就曾经使用这个组件作为文件的上传操作,在随笔<Web开发中的文件上传组件uploadify的使用>中可以看到,Asp.NET中 ...
- 使用plupload做一个类似qq邮箱附件上传的效果
公司项目中使用的框架是springmvc+hibernate+spring,目前需要做一个类似qq邮箱附件上传的功能,暂时只是上传小类型的附件 处理过程和解决方案都需要添加附件,处理过程和解决方案都可 ...
- 基于MVC4+EasyUI的Web开发框架形成之旅(4)--附件上传组件uploadify的使用
大概一年前,我还在用Asp.NET开发一些行业管理系统的时候,就曾经使用这个组件作为文件的上传操作,在随笔<Web开发中的文件上传组件uploadify的使用>中可以看到,Asp.NET中 ...
- (转)基于MVC4+EasyUI的Web开发框架形成之旅--附件上传组件uploadify的使用
http://www.cnblogs.com/wuhuacong/p/3343967.html 大概一年前,我还在用Asp.NET开发一些行业管理系统的时候,就曾经使用这个组件作为文件的上传操作,在随 ...
- SpringMVC入手项目注解版
SpringMVC入手项目注解版 1.创建Maven项目在pom.xml文件引入相关的依赖 <dependencies> <dependency> <groupId> ...
随机推荐
- Singleton pattern的线程安全问题
original post from here方法一:同步机制关键词public class Singleton { 2 //利用静态变量来记录Singleton的唯一实例 3 private sta ...
- 【Oracle】Rman简介
1.备份和恢复功能的用途: –保护数据 -介质故障 -用户错误 -应用程序错误 –数据保存和历史数据保留 –数据传输 2.典型的备份和恢复任务 –通过配置数据库实现可恢复 –定义备份计划 –对不同类型 ...
- PostgreSQL的HA解决方案-项目概述
公司使用的数据库时postgresql,一直运行都很流畅,但是最近java新做的管理平台,由于登录用户较多,并发性比较大.另外新系统可能优化也存在问题,所以pg经常崩溃,所以我就开始研究如何事项pg的 ...
- SQLServer 事务的隔离级别
SQLServer事务的隔离级别 数据库是要被广大客户所共享访问的,那么在数据库操作过程中很可能出现以下几种不确定情况. 更新丢失(Lost update) 两个事务都同时更新一行数据,但是第二个事务 ...
- 如何上传SNAPSHOT类型的JAR文件到nexus中
在要上传的文件的目录中执行以下命令即可: mvn deploy:deploy-file -DgroupId=com.alibaba -DartifactId=dubbo -Dversion=2.5.4 ...
- 解决strip: Unable to recognise the format of the input file问题
前言 在编译xilinx的uboot的时候出现了一个问题,始终报错:“strip: Unable to recognise the format of the input file `gen_et ...
- (转)RabbitMQ学习之路由(java)
http://blog.csdn.net/zhu_tianwei/article/details/40887755 参考:http://blog.csdn.NET/lmj623565791/artic ...
- python tips:类与实例的属性问题
实例是具象化的类,它可以作为类访问所有静态绑定到类上的属性,包括类变量与方法,也可以作为实例访问动态绑定到实例上的属性. 实例1: class A: work = list("hello&q ...
- [POJ2104] K – th Number (可持久化线段树 主席树)
题目背景 这是个非常经典的主席树入门题--静态区间第K小 数据已经过加强,请使用主席树.同时请注意常数优化 题目描述 如题,给定N个正整数构成的序列,将对于指定的闭区间查询其区间内的第K小值. 输入输 ...
- String,StringBuffer,StringBuild的区别
1.三者在执行速度方面的比较:StringBuilder > StringBuffer > String 2.String <(StringBuffer,StringBuild ...