package com.app.xizhenyin.webapp.action;
import java.io.BufferedInputStream;
import java.io.BufferedOutputStream;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.InputStream;
import java.io.OutputStream;
import java.util.Date;
import org.apache.struts2.ServletActionContext;
import com.opensymphony.xwork2.ActionSupport;
public class UploadAction extends ActionSupport {
/**
*
*/
private static final long serialVersionUID = 2854105381965508552L;
private static final int BUFFER_SIZE = 20 * 1024; // 20K
private File myFile;
private String fileName; //
private String contentType;
public File getMyFile() {
return myFile;
}
public void setMyFile(File myFile) {
this.myFile = myFile;
}
public String getFileName() {
return fileName;
}
public void setMyFileFileName(String fileName) {
this.fileName = fileName;
}
public String getContentType() {
return contentType;
}
public void setMyFileContentType(String contentType) {
this.contentType = contentType;
}
public String execute()
{
LOG.debug("fileName"+fileName);
String newFileName = fileName;//new Date().getTime() + getExtention(fileName);
File imageFile = new File(ServletActionContext.getServletContext()
.getRealPath("/upload")
+ "/" + newFileName);
upload(myFile, imageFile);
return SUCCESS;
}
private static void upload(File src, File dst) {
try {
InputStream in = null;
OutputStream out = null;
try {
in = new BufferedInputStream(new FileInputStream(src),
BUFFER_SIZE);
out = new BufferedOutputStream(new FileOutputStream(dst),
BUFFER_SIZE);
byte[] buffer = new byte[BUFFER_SIZE];
while (in.read(buffer) > 0)
{
out.write(buffer);
}
}
finally
{
if (null != in)
{
in.close();
}
if (null != out)
{
out.close();
}
}
}
catch (Exception e)
{
e.printStackTrace();
}
}
}
以上为struts2 action。
下面为struts2配置文件。。
<action name="upload" class="com.app.xizhenyin.webapp.action.UploadAction">
<result name="success" >/WEB-INF/pages/upload.jsp</result>
</action>
<!-- Add additional actions here -->
</package>
页面:
<%@ page language="java" pageEncoding="utf-8"%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<link href="jquery.uploadify/default.css" rel="stylesheet" type="text/css"/>
<link href="jquery.uploadify/uploadify.css" rel="stylesheet" type="text/css"/>
<script type="text/javascript" src="jquery.uploadify/jquery-1.3.2.min.js" ></script>
<script type="text/javascript" src="jquery.uploadify/swfobject.js" ></script>
<script type="text/javascript" src="jquery.uploadify/jquery.uploadify.v2.0.3.min.js" ></script>
<script type="text/javascript"><!--
$(document).ready(function(){
$("#uploadTest").uploadify({
'uploader' : 'jquery.uploadify/uploadify.swf',
'script' : 'upload.action',
'cancelImg' : 'jquery.uploadify/cancel.png',
'fileDataName' : 'myFile',
'queueID' : 'fileQueue',
'auto' : false,
'multi' : true,
'button Text' : " 浏 览 ",
'simUploadLimit' : 20,
'sizeLimit' : 999999999999,
'queueSizeLimit' : 20,
'fileDesc' : '支持格式:jpg,gif,png,bmp',
'fileExt' : '*.jpg;*.gif,*.jpeg,*.png,*.bmp'
});
});
// --></script>
</head>
<body>
<div id="fileQueue"></div>
<input type="file" name="myFile" id="uploadTest" >
<a href="javascript:$('#uploadTest').uploadifyUpload()" >上传</a>
</body>
</html>
页面显示:
选个jpg图片后如下
上传后 却错误,有待研究。。。。
- 大小: 5.2 KB
- 大小: 4.2 KB
- 大小: 4.9 KB
分享到:
相关推荐
struts2+jquery.uploadify实现上传下载
struts2+jquery实现文件的上传
采用jquery.uploadify插件作为前台上传,服务台用c#异步处理
Asp.net 上传 Jquery.Uploadify HTML控件+Jquery.Uploadify 支持一次上传多个文件
给予jQuery的文件上传插件:jquery.uploadify.js修复了IE9 IE10浏览按钮点击无效的bug;直接替换官网下载的jquery.uploadify.js文件即可使用。
uploadfiy这个插件是基于js里面的jquery库写的。结合了ajax和flash,实现了这个多线程上传的功能。
ASP.NET jquery.uploadify文件上传控件测试项目(已解决中文乱码)
jquery.uploadify-3.1.min.js 修改了SWFUpload.prototype.getFlashHTML ()方法,解决了在ie9在点击上传按钮后,不能弹出浏览文件的对话框问题。
该uploadify为目前官网最新版本,由鄙人修改后,可以支持buttonText属性为中文
解决 jquery.uploadify.js 在ie9 下 二次打开失效问题等问题
HTML5 PHP jquery uploadify上传文件,带进度条,author:吕大豹。仿照uploadify写的,www.codesc.net已做过修正,本例的配置参数均与uploadify官网一致,参照官网的api就可以了,直接把文件夹上传到支持php的服务器...
jquery.uploadify.v2.1.0.js 上传
主要介绍了php+jQuery.uploadify实现文件上传教程,需要的朋友可以参考下
一个简单的jquery.uploadify的demo
jquery之Uploadify实现的带进度条的文件上传
struts2 +jquey uploadify3 2 实现多文件上传 可以运行的myeclipse工程 绝对好用 访问方式http: 127 0 0 1:8080 Struts2Uploadify upload jsp uploadify 使用说明: <a href "javascript:$ "#file ...
jquery文件上传插件 jquery.uploadify.js 不支持IE10现在经过修改,已经支持IE6、IE7、IE8、IE9、IE10、IE11.zip
件上传是很多项目都会使用到的功能,SpringMVC当然也提供了这个功能。不过小编不建议在项目中通过form...下面这篇文章主要介绍了利用SpringMVC + jquery.uploadify实现上传文件功能的相关资料,需要的朋友可以参考下。
jquery.uploadify同时上传多个文件
使用Jquery.uploadify上传文件。 jquery有很多插件,其中也有不少上传文件的插件,像ajaxfileupload.js、uploadify.js,不过网上的例子几乎全是php的,很郁闷,研究了半天,终于把uploadify用jsp版本弄出来了