公司需要把以前的Struts2自带的图片上传替换掉,因为不能一个file选择多个文件,本人直接百度搜索图片插件,  貌似就它(uploadify3.2.1)在最前面,也找过很多案例, 其中有不少问题,好了直接代码

1、导入插件(我这里用的是uploadify3.2.1)

把uploadify3.2.1放在webroot下面,如图:(在页面引入插件的js和css我就不贴图了)

2、初始化插件

html:

<div class="picOP">
<form action="<%=basePath %>mng/saveProductPicture.do" id="uploadForm" method="post" enctype="multipart/form-data">
<input id="inputPicFile" name="inputPicFile" type="file"/>
<span id="fileSize">已选择0个文件</span>
<input type="button" class="btn btn-default" value="上传">
<div style="display: none" id="fileOkMSgDiv" class="form-group">
<span id="fileOk"></span>
</div>
</form>
</div>

js:这里是初始化插件

$(function(){
$("#inputPicFile").uploadify({
'debug' : false, //开启调试
'auto' : false, //是否自动上传
'swf' : '<%=basePath %>uploadify3.2.1/uploadify.swf', //引入uploadify.swf
'uploader' : 'saveProductPicture.do',//请求路径
'formData' : {'uid':$("#pid").val()},
'queueID' : 'fileQueue',//队列id,用来展示上传进度的
'width' : '130', //按钮宽度
'height' : '30', //按钮高度
'queueSizeLimit' : 99, //同时上传文件的个数
'simUploadLimit': 99,
'uploadLimit' : 99,
'fileTypeDesc' : '图片文件(*.jpg;*.gif;*.png)', //可选择文件类型说明
'fileTypeExts' : '*.jpg;*.gif;*.png', //控制可上传文件的扩展名
'multi' : true, //允许多文件上传
'buttonText' : '请选择图片',//按钮上的文字
'fileSizeLimit' : '250KB', //设置单个文件大小限制
'fileObjName' : 'inputPicFile', //<input type="file"/>的name
'method' : 'post',
'removeCompleted' : true,//上传完成后自动删除队列
'onFallback':function(){
alert("您未安装FLASH控件,无法上传图片!请安装FLASH控件后再试。");
},
'onUploadSuccess' : function(file, data, response){//单个文件上传成功触发
//data就是action中返回来的数据
},'onQueueComplete' : function(){//所有文件上传完成
$("#fileOkMSgDiv").css("display", "");
$("#fileOk").text("文件上传......OK");
this.queueData.files = [];
fileSizeNum = 0;
isSelectFile = false;
$('#inputPicFile').uploadify('settings', 'buttonText','请选择图片');
$("#fileSize").text("已选择"+fileSizeNum+"个文件");
loadMorePhoto($("#pid").val(), '', '');
},'overrideEvents': ['onSelectError', 'onDialogClose', 'onDialogOpen'] ,//声明被从写的事件
'onDialogOpen':function(){//打开选择文件窗口
fileSizeNum = 0;
isSelectFile = false;
this.queueData.files = [];
$('#inputPicFile').uploadify('settings', 'buttonText','请选择图片');
$("#fileOkMSgDiv").css({display:"none"});
$("#fileSize").text("已选择"+fileSizeNum+"个文件");
$("#fileOk").text("");
},
'onSelectError': function(file, error,errorMsg){//选择错误事件
// debugger;
switch(error){
case -110:
alert("文件["+file.name+"]大小超出系统限制的"+$("#inputPicFile").uploadify('settings', 'fileSizeLimit')+"大小");
break;
case -130:
alert("文件["+file.name+"]类型不对");
break;
};
return false;
},
'onSelect': function(file){//选择图片是触发
// debugger;
if(file){
isSelectFile = true;
fileSizeNum = fileSizeNum+1;
$("#fileSize").css("display", "");
$('#inputPicFile').uploadify('settings', 'buttonText','请点击上传图片');
}
$("#fileSize").text("已选择"+fileSizeNum+"个文件");
},
'onUploadStart': function(file){//上传文件时触发
$('#inputPicFile').uploadify('settings', 'buttonText','玩命上传中,请稍候...');
} });
});

然后想说明一下的是,在初始化的时候插件时只能传递固定的参数,不能等页面加载后用jQuery去获取,传递过去的也是一个null,

传递动态的参数:

//上传图片——这里的代码是在js文件中,上面的初始化是在jsp页面中
var isSelectFile = false;//这个变量使用来判断是否选择图片的
var fileSizeNum = 0;//这个是用来显示选择图片的数量的

$(".picOP input.btn-default").on("click", function(){
if(!isSelectFile){
alert('请选择图片后在上传!');
return;
}
$('#inputPicFile').uploadify('settings','formData',{'uid':$("#pid").val()});//这里是动态传递参数
$('#inputPicFile').uploadify('upload', '*');//上传所有文件
return;
});

Java后台代码:

     public String saveProductPicture(){
System.out.println("进入方法");
String uid = request.getParameter("uid");
try {
if (StringUtils.isNotBlank(uid)) {
String xdPath = sc.getInitParameter("UPLOAD_IMAGE_PRODUCT");
File file = new File(xdPath+"/"+uid);
if (!file.exists() && !file.isDirectory()) {
file.mkdirs();
}
Long l = System.currentTimeMillis();
file = new File(file, l+"");
inputPicFile.renameTo(file); uploadPhotoService.saveUploadPhoto(l, uid, inputPicFileFileName, "1", "product");
response.getWriter().print("success");
}
} catch (Exception e) {
e.printStackTrace();
}
return null;
}//

目前公司是直接拷贝到服务器上面,没有上传到第三方服务器。

如果你发现传输数据的过程中被Struts2拦截器给拦截了,我当时说的时候我的类型不对,后来我在Struts2的配置文件中发现:

<interceptor-ref name="defaultStack">
<param name="modelDriven.refreshModelBeforeResult">true</param>
<!-- 文件大小 -->
<param name="fileUpload.maximumSize">256000</param>
<!-- 文件扩展名 -->
<param name="fileUpload.allowedExtensions">.jpg,.jpeg,.png,.bmp,.gif</param>
<!-- 文件内容类型 -->
<!-- <param name="fileUpload.allowedTypes">image/jpg,image/jpeg,image/png,image/x-png,image/bmp,image/gif</param> -->
</interceptor-ref>

注释掉文件扩展名或者文件内容类型中的一个即可,该地方还需要优化。

最后,关于uploadify的事件,最好是看看插件的源码, 就明白了。

本人热爱Java相关技术,如有好的文章希望多多推荐推荐,谢谢了~~~

Struts2文件上传--多文件上传(插件uploadify)的更多相关文章

  1. struts2实现文件上传(多文件上传)及下载

    一.要实现文件上传,需在项目中添加两个jar文件 二.上传准备的页面 注:必须植入enctype="multipart/form-data"属性,以及提交方式要设置成post &l ...

  2. struts2学习笔记之十:文件上传

    Struts2的上传 1.Struts2默认采用了apache commons-fileupload 2.Struts2支持三种类型的上传组件 3.需要引入commons-fileupload相关依赖 ...

  3. Struts2 单个文件上传/多文件上传

    1导入struts2-blank.war所有jar包:\struts-2.3.4\apps\struts2-blank.war 单个文件上传 upload.jsp <s:form action= ...

  4. struts2文件上传,文件类型 allowedTypes

    struts2文件上传,文件类型 allowedTypes 1 '.a' : 'application/octet-stream', 2 '.ai' : 'application/postscript ...

  5. 文件上传插件Uploadify在Struts2中的应用,完整详细实例

    —>最近由于项目需要使用到一个上传插件,在网上发现uploadify挺不错,所以决定使用它,但是官网文档和例子是php的,而项目是SSI框架的,所以自己对uploadify在struts2中的使 ...

  6. Struts2第六篇【文件上传和下载】

    前言 在讲解开山篇的时候就已经说了,Struts2框架封装了文件上传的功能--..本博文主要讲解怎么使用Struts框架来完成文件上传和下载 回顾以前的文件上传 首先,我们先来回顾一下以前,我们在we ...

  7. struts2一个和多个文件上传及下载

    struts2的文件上传相比我们自己利用第三方jar包(commons-fileupload-1.2.1.jar   commons-io-1.3.2.jar )要简单的多,当然struts2里面也是 ...

  8. Struts2学习(六)———— 文件上传和下载

    一.单文件上传 在没学struts2之前,我们要写文件上传,非常麻烦,需要手动一步步去获取表单中的各种属性,然后在进行相应的处理,而在struts2中就不需要了,因为有一个fileUpload拦截器帮 ...

  9. java struts2入门学习实例--使用struts2快速实现多个文件上传

    一.错误提示信息配置 昨天说到更改默认错误配置信息,我测试很多遍,一直都不对.下面贴出来,待以后有好方法了再补充吧. 首先新建一个properties文件,这里命名为testupload.proper ...

随机推荐

  1. 02_JNI中Java代码调用C代码,Android中使用log库打印日志,javah命令的使用,Android.mk文件的编写,交叉编译

     1  编写以下案例(下面的三个按钮都调用了底层的C语言): 项目案例的代码结构如下: 2 编写DataProvider的代码: package com.example.ndkpassdata; ...

  2. 【公开课】【阿里在线技术峰会】魏鹏:基于Java容器的多应用部署技术实践

    对于公开课,可能目前用不上这些,但是往往能在以后想解决方案的时候帮助到我.以下是阿里对公开课的整理 摘要: 在首届阿里巴巴在线峰会上,阿里巴巴中间件技术部专家魏鹏为大家带来了题为<基于Java容 ...

  3. eclipse搭建ssh后台

    SSH框架是最常用的框架之一,在搭建SSH框架的时候总有人遇到这样,那样的问题.下面我介绍一下SSH框架搭建的全过程.  第一步:准备工作.    下载好eclipse,Struts2,Spring, ...

  4. 对FMDB的封装JRDB

    在自己开发中,每次用到数据库都会纠结是使用CoreData还是FMDB.CoreData虽然Api简单,但是调用栈非常复杂,要初始化一个Context需要至少20行代码.显然,对于这种这么恶心的情况, ...

  5. 仿百度壁纸客户端(六)——完结篇之Gallery画廊实现壁纸预览已经项目细节优化

    仿百度壁纸客户端(六)--完结篇之Gallery画廊实现壁纸预览已经项目细节优化 百度壁纸系列 仿百度壁纸客户端(一)--主框架搭建,自定义Tab + ViewPager + Fragment 仿百度 ...

  6. Linux - mail

    使用者邮件信箱: mail 使用 wall, write 毕竟要等到使用者在在线才能够进行,有没有其他方式来联络啊? 不是说每个 Linux 主机上面的用户都具有一个 mailbox 吗? 我们可否寄 ...

  7. iOS9 系统分享调用(UIActivityViewController)

    猴子原创,欢迎转载.转载请注明: 转载自Cocos2Der-CSDN,谢谢! 原文地址: http://blog.csdn.net/cocos2der/article/details/49615109 ...

  8. HBase flush

    flush触发方式 1. Server端执行更新操作(put.delete.multi(MultiAction<R>multi).(private)checkAndMutate.mutat ...

  9. Xcode使用心得03:打开僵尸(Zombie)模式

    如果打开了ARC或垃圾回收模式,在程序中发消息给以及重新分配的对象,将会引起程序崩溃.这时定位崩溃原因将非常困难,因为出问题的对象已经重新分配了.一个解决的方法就是要求Xcode将对象设置为" ...

  10. unity 代码C#封装为dll

    1  Visual studio软件打开后创建一个项目 2并选择类库类型 3编写简单的代码看看效果(发现会报错),主要是没有添加类库,以及using UnityEngine;引用空间 4添加类库,引用 ...