热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

javauploadify3.2_jQuery上传插件Uploadify3.2上传文件

项目结构:代码:index.jsp:Stringpathrequest.getContextPath();StringbasePathrequest.g

项目结构:

9148133_201411031210090504.png

代码:

index.jsp:

String path = request.getContextPath();

String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";

%>

My JSP 'index.jsp' starting page

$(function(){

$("#uploadify").uploadify({

'debug'     : false, //开启调试

'auto'           : false, //是否自动上传

'swf'            : 'uploadify/uploadify.swf',  //引入uploadify.swf

'uploader'       : 'upload;jsessionid=${pageContext.session.id}',//请求路径

'queueID'        : 'fileQueue',//队列id,用来展示上传进度的

'width'     : '75',  //按钮宽度

'height'    : '24',  //按钮高度

'queueSizeLimit' : 3,  //同时上传文件的个数

'fileTypeDesc'   : '视频文件',    //可选择文件类型说明

'fileTypeExts'   : '*.jpg;*.gif', //控制可上传文件的扩展名

'multi'          : true,  //允许多文件上传

'buttonText'     : '图片上传',//按钮上的文字

'fileSizeLimit' : '2MB', //设置单个文件大小限制

'fileObjName' : 'uploadify',  //的name

'method' : 'post',

'removeCompleted' : true,//上传完成后自动删除队列

'onFallback':function(){

alert("您未安装FLASH控件,无法上传图片!请安装FLASH控件后再试。");

},

'onUploadSuccess' : function(file, data, response){//单个文件上传成功触发

//data就是action中返回来的数据

},'onQueueComplete' : function(){//所有文件上传完成

alert("文件上传成功!");

}

});

});

开始上传

取消所有上传

struts.xml:

UploadAction.java:

package com.action;

import java.io.File;

import java.io.FileInputStream;

import java.io.FileOutputStream;

import java.io.IOException;

import java.io.InputStream;

import java.text.SimpleDateFormat;

import java.util.Date;

import java.util.Properties;

import org.apache.commons.io.IOUtils;

import com.entity.Nfcuser;

import com.util.DeleteFile;

/**

* 上传文件到resource中

* @author Administrator

*

*/

public class UploadAction extends BaseAction {

private static final long serialVersionUID = 1L;

private File uploadify;//上传文件file对象

private String uploadifyFileName;//上传文件名

private String uploadifyContentType;//上传文件类型

private String description;//上传文件的描述

public String execute() throws IOException{

System.out.println("000000000");

Properties pro = new Properties();

InputStream in = DeleteFile.class.getClassLoader().getResourceAsStream("qiniu.properties");

pro.load(in);

String headpath = pro.getProperty("headpath");//读取配置文件,获取保存文件的根路径

String num = "";

for(int i&#61;0;i<5;i&#43;&#43;){

num &#43;&#61; String.valueOf((int)(Math.random()*10));//得到5位随机数

}

SimpleDateFormat dt &#61; new SimpleDateFormat("yyyyMMddhhmmss");

String date &#61; dt.format(new Date());//获取当前时间字符串

Nfcuser user &#61; (Nfcuser)session.get("loginuser");//从内存中得到用户对象

System.out.println(user.getUseraccount());

if(user&#61;&#61;null){

System.out.println("1");

return LOGIN;//用户未登录

}else{

System.out.println("2");

int userid &#61; user.getId();//用户编号

String filenum &#61; "";//生成保存上传文件的文件夹名称&#xff0c;这个名称也作为压缩文件的名称&#xff0c;

if(session.get("filenum")&#61;&#61;null){

System.out.println(3);

filenum &#61; userid &#43; date &#43; num;

session.put("filenum", filenum);

}else{

System.out.println(4);

System.out.println(session.get("filenum"));

filenum &#61; (String)session.get("filenum");

}

String path &#61; headpath &#43; userid &#43; "/" &#43; filenum &#43; "/resource/";//保存文件的路径

System.out.println(path);

File folder &#61; new File(path);

if(!folder.exists()){

folder.mkdirs();//如果路径不存在则创建

}

//下面才是保存文件&#xff0c;这上面都是对路劲的处理

System.out.println(uploadify);

String savePath &#61; path &#43; this.uploadifyFileName;

FileInputStream fis &#61; new FileInputStream(uploadify);

FileOutputStream fos &#61; new FileOutputStream(savePath);

IOUtils.copy(fis, fos);

fos.flush();

fos.close();

fis.close();

}

return null;

}

public File getUploadify() {

return uploadify;

}

public void setUploadify(File uploadify) {

this.uploadify &#61; uploadify;

}

public String getUploadifyFileName() {

return uploadifyFileName;

}

public void setUploadifyFileName(String uploadifyFileName) {

this.uploadifyFileName &#61; uploadifyFileName;

}

public String getUploadifyContentType() {

return uploadifyContentType;

}

public void setUploadifyContentType(String uploadifyContentType) {

this.uploadifyContentType &#61; uploadifyContentType;

}

public String getDescription() {

return description;

}

public void setDescription(String description) {

this.description &#61; description;

}

}

注意&#xff1a;如果提交报错&#xff0c;数据根本就没有传递到后台&#xff0c;那么可以试着把提交路径改为

&#39;uploader&#39;       : &#39;upload.action;jsessionid&#61;${pageContext.session.id}&#39;,//请求路径

如果web.xml中的配置为&#xff1a;

struts2

/*

那么路径可以为&#xff1a;

&#39;uploader&#39;       : &#39;upload;jsessionid&#61;${pageContext.session.id}&#39;,//请求路径

如果web.xml配置为&#xff1a;

struts2

*.action

那么提交路径必须为&#xff1a;

&#39;uploader&#39;       : &#39;upload.action;jsessionid&#61;${pageContext.session.id}&#39;,//请求路径

如果需要在UploadAction中使用session&#xff0c;那么在路径后把jsessionid&#61;${pageContext.session.id}&#39;加上&#xff0c;如果不需要使用session可以不用加。



推荐阅读
  • t-io 2.0.0发布-法网天眼第一版的回顾和更新说明
    本文回顾了t-io 1.x版本的工程结构和性能数据,并介绍了t-io在码云上的成绩和用户反馈。同时,还提到了@openSeLi同学发布的t-io 30W长连接并发压力测试报告。最后,详细介绍了t-io 2.0.0版本的更新内容,包括更简洁的使用方式和内置的httpsession功能。 ... [详细]
  • 本文讨论了在手机移动端如何使用HTML5和JavaScript实现视频上传并压缩视频质量,或者降低手机摄像头拍摄质量的问题。作者指出HTML5和JavaScript无法直接压缩视频,只能通过将视频传送到服务器端由后端进行压缩。对于控制相机拍摄质量,只有使用JAVA编写Android客户端才能实现压缩。此外,作者还解释了在交作业时使用zip格式压缩包导致CSS文件和图片音乐丢失的原因,并提供了解决方法。最后,作者还介绍了一个用于处理图片的类,可以实现图片剪裁处理和生成缩略图的功能。 ... [详细]
  • SpringMVC接收请求参数的方式总结
    本文总结了在SpringMVC开发中处理控制器参数的各种方式,包括处理使用@RequestParam注解的参数、MultipartFile类型参数和Simple类型参数的RequestParamMethodArgumentResolver,处理@RequestBody注解的参数的RequestResponseBodyMethodProcessor,以及PathVariableMapMethodArgumentResol等子类。 ... [详细]
  • Nginx使用(server参数配置)
    本文介绍了Nginx的使用,重点讲解了server参数配置,包括端口号、主机名、根目录等内容。同时,还介绍了Nginx的反向代理功能。 ... [详细]
  • Java序列化对象传给PHP的方法及原理解析
    本文介绍了Java序列化对象传给PHP的方法及原理,包括Java对象传递的方式、序列化的方式、PHP中的序列化用法介绍、Java是否能反序列化PHP的数据、Java序列化的原理以及解决Java序列化中的问题。同时还解释了序列化的概念和作用,以及代码执行序列化所需要的权限。最后指出,序列化会将对象实例的所有字段都进行序列化,使得数据能够被表示为实例的序列化数据,但只有能够解释该格式的代码才能够确定数据的内容。 ... [详细]
  • 如何使用Java获取服务器硬件信息和磁盘负载率
    本文介绍了使用Java编程语言获取服务器硬件信息和磁盘负载率的方法。首先在远程服务器上搭建一个支持服务端语言的HTTP服务,并获取服务器的磁盘信息,并将结果输出。然后在本地使用JS编写一个AJAX脚本,远程请求服务端的程序,得到结果并展示给用户。其中还介绍了如何提取硬盘序列号的方法。 ... [详细]
  • Voicewo在线语音识别转换jQuery插件的特点和示例
    本文介绍了一款名为Voicewo的在线语音识别转换jQuery插件,该插件具有快速、架构、风格、扩展和兼容等特点,适合在互联网应用中使用。同时还提供了一个快速示例供开发人员参考。 ... [详细]
  • 本文介绍了Web学习历程记录中关于Tomcat的基本概念和配置。首先解释了Web静态Web资源和动态Web资源的概念,以及C/S架构和B/S架构的区别。然后介绍了常见的Web服务器,包括Weblogic、WebSphere和Tomcat。接着详细讲解了Tomcat的虚拟主机、web应用和虚拟路径映射的概念和配置过程。最后简要介绍了http协议的作用。本文内容详实,适合初学者了解Tomcat的基础知识。 ... [详细]
  • 本文介绍了如何使用C#制作Java+Mysql+Tomcat环境安装程序,实现一键式安装。通过将JDK、Mysql、Tomcat三者制作成一个安装包,解决了客户在安装软件时的复杂配置和繁琐问题,便于管理软件版本和系统集成。具体步骤包括配置JDK环境变量和安装Mysql服务,其中使用了MySQL Server 5.5社区版和my.ini文件。安装方法为通过命令行将目录转到mysql的bin目录下,执行mysqld --install MySQL5命令。 ... [详细]
  • 本文讨论了如何在codeigniter中识别来自angularjs的请求,并提供了两种方法的代码示例。作者尝试了$this->input->is_ajax_request()和自定义函数is_ajax(),但都没有成功。最后,作者展示了一个ajax请求的示例代码。 ... [详细]
  • python限制递归次数(python最大公约数递归)
    本文目录一览:1、python为什么要进行递归限制 ... [详细]
  • HTML5网页模板怎么加百度统计?
    本文介绍了如何在HTML5网页模板中加入百度统计,并对模板文件、css样式表、js插件库等内容进行了说明。同时还解答了关于HTML5网页模板的使用方法、表单提交、域名和空间的问题,并介绍了如何使用Visual Studio 2010创建HTML5模板。此外,还提到了使用Jquery编写美好的HTML5前端框架模板的方法,以及制作企业HTML5网站模板和支持HTML5的CMS。 ... [详细]
  • 本文介绍了一个免费的asp.net控件,该控件具备数据显示、录入、更新、删除等功能。它比datagrid更易用、更实用,同时具备多种功能,例如属性设置、数据排序、字段类型格式化显示、密码字段支持、图像字段上传和生成缩略图等。此外,它还提供了数据验证、日期选择器、数字选择器等功能,以及防止注入攻击、非本页提交和自动分页技术等安全性和性能优化功能。最后,该控件还支持字段值合计和数据导出功能。总之,该控件功能强大且免费,适用于asp.net开发。 ... [详细]
  • 从零基础到精通的前台学习路线
    随着互联网的发展,前台开发工程师成为市场上非常抢手的人才。本文介绍了从零基础到精通前台开发的学习路线,包括学习HTML、CSS、JavaScript等基础知识和常用工具的使用。通过循序渐进的学习,可以掌握前台开发的基本技能,并有能力找到一份月薪8000以上的工作。 ... [详细]
  • Node.js学习笔记(一)package.json及cnpm
    本文介绍了Node.js中包的概念,以及如何使用包来统一管理具有相互依赖关系的模块。同时还介绍了NPM(Node Package Manager)的基本介绍和使用方法,以及如何通过NPM下载第三方模块。 ... [详细]
author-avatar
小果康康维五_469
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有