<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版实现附件上传功能(直接可以使用)的更多相关文章

  1. Springmvc file多附件上传 显示 删除操作

    之前项目需求要做一个多附件上传 并显示上传文件 带删除操作 一筹莫展之际搜到某个兄弟发的博客感觉非常好用被我copy下来了此贴算是改良版 再次感谢(忘记叫什么了时间也有点久没有历史记录了)先上图 基于 ...

  2. 跟版网 > 织梦教程 > 织梦安装使用 > 织梦DedeCMS附件上传大

    织梦DedeCMS附件上传大小受限制,超过2M就不能上传了,针对此问题按如下方法修改: 1.进入后台→系统设置→系统基本参数→会员设置→会员上传文件大小(K),改成你需要限制的大小: 2.在dede ...

  3. java附件上传下载磁盘版

    ACTION public class UploadAction extends BaseAction { private static final long serialVersionUID = 1 ...

  4. asp.net结合uploadify实现多附件上传

    1.说明 uploadify是一款优秀jQuery插件,主要功能是批量上传文件.大多数同学对多附件上传感到棘手,现将asp.net结合uploadfiy如何实现批量上传附件给大家讲解一下,有什么不对的 ...

  5. 基于MVC4+EasyUI的Web开发框架形成之旅--附件上传组件uploadify的使用

    大概一年前,我还在用Asp.NET开发一些行业管理系统的时候,就曾经使用这个组件作为文件的上传操作,在随笔<Web开发中的文件上传组件uploadify的使用>中可以看到,Asp.NET中 ...

  6. 使用plupload做一个类似qq邮箱附件上传的效果

    公司项目中使用的框架是springmvc+hibernate+spring,目前需要做一个类似qq邮箱附件上传的功能,暂时只是上传小类型的附件 处理过程和解决方案都需要添加附件,处理过程和解决方案都可 ...

  7. 基于MVC4+EasyUI的Web开发框架形成之旅(4)--附件上传组件uploadify的使用

    大概一年前,我还在用Asp.NET开发一些行业管理系统的时候,就曾经使用这个组件作为文件的上传操作,在随笔<Web开发中的文件上传组件uploadify的使用>中可以看到,Asp.NET中 ...

  8. (转)基于MVC4+EasyUI的Web开发框架形成之旅--附件上传组件uploadify的使用

    http://www.cnblogs.com/wuhuacong/p/3343967.html 大概一年前,我还在用Asp.NET开发一些行业管理系统的时候,就曾经使用这个组件作为文件的上传操作,在随 ...

  9. SpringMVC入手项目注解版

    SpringMVC入手项目注解版 1.创建Maven项目在pom.xml文件引入相关的依赖 <dependencies> <dependency> <groupId> ...

随机推荐

  1. css relative设置top为百分比值

    前言: 最近在学习HTML.CSS的过程中,想模仿一下百度首页.发现搜索框这一部分与上下其它元素的空白距离可以随着窗口大小变化(效果如下图所示),于是自己研究了一下并记录下来. 效果实现 <!D ...

  2. Python编程Web框架 :Django 从入门到精通

    Django是一个高级别的Python Web框架,它鼓励快速开发和干净实用的设计. 现在我们开始学习它. Django学习之 第一章:Django介绍 Django学习之 第二章:Django快速上 ...

  3. RN配置

    Write by lz: 详细参考官方网址: http://reactnative.cn/docs/0.43/getting-started.html#content 若是无法安装 Chocolate ...

  4. java equals的用法

    equals方法,用于比较两个对象是否相同,它其实就是使用两个对象的内存地址在比较.Object类中的equals方法内部使用的就是==比较运算符. package Xuexi; public cla ...

  5. Python编码显示中文乱码

    爬虫时出现问题: import requests data=requests.get('http://roll.news.sina.com.cn/')print(data.text) 输出结果中文显示 ...

  6. python之组合与继承的使用场景

    1.什么时候使用类的组合?当类之间有显著的不同,并且较小的类是组成较大类所需要的组件,此时用类的组合较合理:场景:医院是由多个科室组成的,此时我们可以定义不同科室的类,这样医院的类我们可以直接使用各个 ...

  7. Btrfs 文件系统

    btrfs文件系统简介  btrfs文件系统:技术预览版(Centos7)  Btrfs(B-tree.Butter FS.Better FS),GPL授权,Orale2007提出是想用来取代Ext文 ...

  8. Zend 官方框架增加 Swoole 协程支持 !

    前言 Zend Framework 是 PHP 的官方框架,随着 Zend-Expressive-Swoole 0.2.2 的发布,率先支持了 Swoole 4 的协程功能,现在可以仅通过一个配置即可 ...

  9. gpio_request 原形代码

    http://blog.csdn.net/maopig/article/details/7428561 其原型为 int gpio_request(unsigned gpio, const char ...

  10. spring md5 加密

    一.spring 自带的 DigestUtils 工具类可以进行 md5 加密 //导入包 import org.springframework.util.DigestUtils; //对密码进行 m ...