Struts2 + uploadify 多文件上传完整实例!

首先我这里使用的是  Jquery  Uploadify3.2的版本

 导入相关的CSS  JS   

<link rel="stylesheet" type="text/css" href="<%=basePath%>css/uploadify/uploadify.css">

<script src="<%=basePath%>js/jquery.min.js"></script>

<script src="<%=basePath%>js/uploadify/jquery.uploadify.min.js"></script>

接下来是  上传的 JSP 页面代码

<form action="" method="post" >
    	<input type="file" name="img_file" id="img_file">
    		<div id="uploadfileQueue" ></div>
    		<div id="imgs" ></div>
    		<div id="dialog-message" ></div>
    </form>

     <p>
        <a href="javascript:void(0);" onclick="myUpload()">上传</a>
        <a href="javascript:$('#img_file').uploadify('cancel')">取消上传</a>
    </p>  

这里是最关键的 JS  代码  有注释

$(function(){
    		$("#img_file").uploadify({
    			  auto:false,//是否自动上传
				  height: 30,
             	  buttonText:'选择图片',
			      cancelImage:'<%=basePath%>img/uploadify/uploadify-cancel.png',
 				  swf : '<%=basePath %>js/uploadify/uploadify.swf',
 			 	// expressInstall:'js/uploadify/expressInstall.swf',
  				 uploader : '<%=basePath%>json/fileUploadAction.action', //后台处理上传文件的action
 				 width  : 120 ,
    	         'multi': true, //设置为true将允许多文件上传
    	         'filesSelected': '4',
    	         queueID:'uploadfileQueue',
				 fileObjName:'img_file', //与后台Action中file属性一样
                  /*
                  formData:{ //附带值
								'userid':'111',
								'username':'tom',
							   'rnd':'111'
							},
                                */
                fileTypeDesc:'上传文件支持的文件格式:jpg,jpge,gif,png',
				fileTypeExts:'*.jpg;*.jpge;*.gif;*.png',//*.jpg;*.jpge;*.gif;*.png
				queueSizeLimit : 4,//只能一次上传4张图片
				// simUploadLimit:1,//一次可以上传1个文件
				fileSizeLimit:'2097152',//上传文件最大值   单位为字节   2M
                     //返回一个错误,选择文件的时候触发
				onSelectError:function(file, errorCode, errorMsg){

						 switch(errorCode) {
								case -100:
                                  alert("上传的文件数量已经超出系统限制的4个文件!");
                                  break;
                              case -110:
                                  alert("文件 ["+file.name+"] 大小超出系统限制的2M大小!");
                                  break;
                              case -120:
                                  alert("文件 ["+file.name+"] 大小异常!");
                                  break;
                              case -130:
                                  alert("文件 ["+file.name+"] 类型不正确!");
                                  break;
                          }
                      },  //
                        //上传到服务器,服务器返回相应信息到data里
                     onUploadSuccess:function(file, data, response){
                    	var objs = eval('('+data+')');
						var phtml = "<span><img style='width:150;height:150' src='/uploads/"+objs.filename+"'></span>";
						 if($("#imgs span").length==0){
                           $("#imgs").html(phtml);
                      }else{
                           $("#imgs span:last").after(phtml);
                      }
						},
                     onSelect : function(file) {
                      //alert(file.name);
                      },
                     //removeCompleted:true,//上传的文件进度条是否消失
                      requeueErrors:false,
                     // removeTimeout:2,//进度条消失的时间,默认为3
                      progressData:"percentage",//显示上传的百分比
                      onUploadError : function(file,errorCode,errorMsg,errorString,swfuploadifyQueue) { //这里是取消的时候发生
                        // $("#dialog-message").html(errorString);
                        }
    		});

    	});

   		//上传文件
    	function myUpload(){
    	 		$("#img_file").uploadify('upload','*');
    	 	}
    

java  上传的 Action 代码

/**
 * 上传文件的Action
 * @author wzh
 *
 */
@Controller
@Scope("prototype")
public class FileUploadAction extends BaseAction {
	private File  img_file;
	 private String img_fileContentType;//格式同上"fileName"+ContentType
	 private String img_fileFileName;//格式同上"fileName"+FileName
	 private String savePath;//文件上传后保存的路径
	 private Map<String, Object> dataMap = new HashMap<String, Object>();

	@Override
	/***
	 *  上传文件
	 */
	public String execute() throws Exception{

		System.out.println("savePath"+getSavePath());

		 File dir=new File(getSavePath());
		 System.out.println(dir.getAbsolutePath());

		 //判断是否存在路径
	        if(!dir.exists()){
	            dir.mkdirs();
	        }  

	        //当前上传的文件
	        	File file=getImg_file();
	        	//获得后缀
	        	String  ext =FileUtil.getExtensionName(getImg_fileFileName());
	        	String  newFileName = UUID.randomUUID()+ext;
	            FileOutputStream fos=new FileOutputStream(getSavePath()+"//"+newFileName);
	            FileInputStream fis=new FileInputStream(getImg_file());
	            byte []buffers=new byte[1024];
	            int len=0;
	            while((len=fis.read(buffers))!=-1){
	                fos.write(buffers,0,len);
	            }   

	            fos.close();
	            fis.close();

	          //  String uploadFileName = getImg_fileFileName();
	            dataMap.put("filename",newFileName);

		return SUCCESS;
	}
<!-- 文件上传相关的 -->
		 <action name="fileUploadAction" class="fileUploadAction">
       		 <param name="savePath">E:/Tomcat6.0/webapps/uploads</param>
       		<result type="json">
				<param name="root">dataMap</param>
			</result>
       </action>

配置完以上的 基本就OK了   有什么不懂的可以评论问问,我会回复

Struts2 + uploadify 多文件上传完整实例!

时间: 2024-10-10 18:25:36

Struts2 + uploadify 多文件上传完整实例!的相关文章

Struts2 + uploadify 多文件上传完整的例子!

首先,我这里使用的是  Jquery  Uploadify3.2版本号  导入相关的CSS  JS    <link rel="stylesheet" type="text/css" href="<%=basePath%>css/uploadify/uploadify.css"> <script src="<%=basePath%>js/jquery.min.js"></s

PHP实现视频文件上传完整实例

PHP实现视频文件上传完整实例 转载 这篇文章主要介绍了PHP实现视频文件上传的技巧,包含了PHP配置信息的设计及大文件的处理,需要的朋友可以参考下 本文以一个完整实例的形式实现了视频文件上传的功能.虽然是比较基础的应用,仍有一定的参考价值.分享给大家供大家参考之用.具体方法如下: 首先,对PHP来说视频也属于文件,我们利用这个道理,可以通过与上传普通文件类似的方式实现上传PHP视频文件.不同的是视频文件一般较大,上传时间长,而php配置文件也对上传文件的大小有限制.如果需要更好地用PHP实现文

jQuery.uploadify文件上传组件实例讲解

1.jquery.uploadify简介 在ASP.NET中上传的控件有很多,比如.NET自带的FileUpload,以及SWFUpload,Uploadify等等,尤其后面两个控件的用户体验比较好,无刷新,带上传进度等等.在最近的短信平台开发中,使用Uploadify进行文件上传. Uploadify官网地址是:http://www.uploadify.com/ 可满足项目开发需求. 下载地址:http://www.uploadify.com/wp-content/uploads/files/

【SSH2(实践篇)】--Struts2文件上传下载实例

上篇文章又一次回顾了Struts2的运行机制,对它的运行步骤做了一步步的解析,这个解析不但再一次理清了Struts2的使用方法,而且对它的映射机制进行了深入的解析,并在最后通过一个实例来介绍了Struts2的一种使用方法,这里将做一个有关文件上传下载的实例. 一.文件上传 Struts2并没有提供文件上传的组件,所以想要实现上传的功能就必须通过第三方组件来实现,在Struts2引用的jar中包含了文件上传的组件,它是通过commons-fileupload.jar和commons-io.jar来

struts2+extjs文件上传完整实现(解决了上传中的各种问题)

首先需要引入上传控件 <script type="text/javascript" src="<%=basePath%>/js/ext/examples/ux/fileuploadfield/FileUploadField.js" charset="utf-8"></script> 弹出上传框对应extjs代码 var uploadForm=new Ext.FormPanel({ id:'uploadForm'

[转]Struts2多个文件上传

转载至:http://blog.csdn.net/hanxiaoshuang123/article/details/7342091 Struts2多个文件上传多个文件上传分为List集合和数组,下面我们着重介绍一下list集合的上传.都大同小异.一 介绍1. 在struts2文件上传的时候要先导入struts2的几个包,在struts2.3.1.2中,导入的包如图所视: 从图上可以看出其中文件上传所需要的是包为commons-fileupload-1.2.2.jar和commons-io-2.0

struts2中的文件上传和下载

天下大事,必做于细.天下难事,必作于易. 曾经见过某些人,基础的知识还不扎实就去学习更难的事,这样必然在学习新的知识会很迷惑结果 再回来重新学习一下没有搞懂的知识,这必然会导致学习效率的下降!我写的这篇上传和下载都很基础. 十分适合初学者! jsp:页面 <!--在进行文件上传时,表单提交方式一定要是post的方式,因为文件上传时二进制文件可能会很大,还有就是enctype属性,这个属性一定要写成multipart/form-data, 不然就会以二进制文本上传到服务器端--> <for

笨鸟先飞之Java(一)--使用struts2框架实现文件上传和下载

不管是.net还是Java,我们最常接触到的就是文件的上传和下载功能,在Java里要实现这两个常用功能会有很多种解决方式,但是struts2的框架却能给我们一个比较简单的方式,下面就一起来看吧: 文件上传: 首先来看实现上传功能的表单,Index.jsp: <span style="font-family:FangSong_GB2312;font-size:18px;"><%@ page language="java" contentType=&q

uploadify多文件上传插件

这个插件是兼容IE8及以上版本的,实现了基本功能,底部有下载连接 代码如下: <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"><html><head> <title>uploadify多文件上传插件使用</title> <meta http-equ