java实现批量上传(swfupload)
下载 swfupload 文件夹 里面包含handlers.js,swfupload.js,swfupload.swf 三个文件。
我的是和ssh项目整合在一起的。因为struts2的拦截器会拦截所有请求,在跳转到上传文件的servlet中时request请求会被转换为struts的请求。所以要去掉struts的请求。
假如web.xml配置的拦截所有请求,可以修改这里,不拦截所有
<filter>
<filter-name>struts2</filter-name>
<filter-class>
org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter
</filter-class>
<init-param>
<param-name>config</param-name>
<param-value>
struts-default.xml,struts-plugin.xml,resources/struts/struts.xml
</param-value>
</init-param>
<init-param>
<param-name>actionPackages</param-name>
<param-value>com.yuncai.modules</param-value>
</init-param>
</filter>
<filter-mapping>
<filter-name>struts2</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
或者在struts.xml中加上 <constant name="struts.action.excludePattern" value="/servlet/.*" /> struts不会拦截这个路径下的所有
上传文件的servlet的路径
<struts>
<!-- 开启使用开发模式,详细错误提示 -->
<constant name="struts.devMode" value="true" />
<!-- 默认后缀名 -->
<constant name="struts.action.extension" value="jsp" />
<constant name="struts.action.excludePattern" value="/servlet/.*" />
<!-- 指定每次请求到达,重新加载资源文件 -->
<constant name="struts.i18n.reload" value="true" />
<!-- 视图标签默认的视图主题-->
<constant name="struts.ui.theme" value="simple" />
<!-- 国际化资源文件 -->
<constant name="struts.custom.i18n.resources" value="globalMessages" />
<!-- locale -->
<constant name="struts.locale" value="zh_CN" />
<!-- 指定资源编码类型 -->
<constant name="struts.i18n.encoding" value="UTF-8" />
<!-- 生成URL时是否包含请求参数 -->
<constant name="struts.url.includeParams" value="none" />
<!-- 文件上传中整个请求内容允许的最大字节数 -->
<constant name="struts.multipart.maxSize" value="1048576000" /> <constant name="struts.objectFactory" value="spring"/> </struts>
<%@ page language="java" pageEncoding="utf-8"%>
<%@ taglib prefix="fmt" uri="http://java.sun.com/jsp/jstl/fmt"%>
<%
String path = request.getContextPath();
String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
%>
<head>
<link rel="stylesheet" type="text/css" href="../css/zlstyle.css">
<script type="text/javascript" src="/swfupload/swfupload.js"></script>
<script type="text/javascript" src="/swfupload/handlers.js"></script>
<script type="text/javascript" src="../js/jquery-1.10.2.min.js"></script>
</head>
<body leftmargin="10" topmargin="10" marginwidth="10" marginheight="10">
<table width="100%" border="1" bordercolor="#464646" align="center"
cellpadding="0" cellspacing="0">
<tr>
<td align="right">
是否显示:
</td>
<td>
<input type="checkbox" id="isValid" value="0" onclick="check1();"/>
</td>
</tr>
<tr>
<td align="right">
说明:
</td>
<td>
<textarea rows="" cols="" id="info"></textarea>
</td>
</tr>
</table>
<input type="button" onclick="swfupload();" value="添加控件"/>
<span id="spanButtonPlaceholder"></span>
<div id="divFileProgressContainer" style="width:200;display:none;"></div>
<div id="thumbnails">
<table id="infoTable" border="0" style="background-color: #C5D9FF;"></table>
</div>
<!--为了把表单数据传到servlet,所以多加了一个点击按钮-->
<script type="text/javascript">
var swfu;
function swfupload() {
swfu = new SWFUpload({
upload_url: "/servlet/FileUploadServlet",
// File Upload Settings
file_size_limit : "50 MB", // 1000MB
file_types : "*.apk",//设置可上传的类型
file_types_description : "所有文件",
file_upload_limit : "100",
// 向服务端传递的参数
use_query_string : true,
post_params: {
"isValid" : document.getElementById("isValid").value,"info" : document.getElementById("info").value
}, file_queue_error_handler : fileQueueError,//选择文件后出错
file_dialog_complete_handler : fileDialogComplete,//选择好文件后提交
file_queued_handler : fileQueued,
upload_progress_handler : uploadProgress,
upload_error_handler : uploadError,
upload_success_handler : uploadSuccess,
upload_complete_handler : uploadComplete, // Button Settings
button_image_url : "images/SmallSpyGlassWithTransperancy_17x18.png",
button_placeholder_id : "spanButtonPlaceholder",
button_width: 100,
button_height: 18,
button_text : '<span class="button">选择APK</span>',
button_text_style : '.button { font-family: Helvetica, Arial, sans-serif; font-size: 12pt; } .buttonSmall { font-size: 10pt; }',
button_text_top_padding: 0,
button_text_left_padding: 18,
button_window_mode: SWFUpload.WINDOW_MODE.TRANSPARENT,
button_cursor: SWFUpload.CURSOR.HAND, // Flash Settings
flash_url : "swfupload/swfupload.swf", custom_settings : {
upload_target : "divFileProgressContainer"
},
// Debug Settings
debug: false //是否显示调试窗口
});
};
function startUploadFile(){
swfu.startUpload();
} function check1(){
var isValid = document.getElementById("isValid").value;
if(isValid==0)
document.getElementById("isValid").value="1";
else
document.getElementById("isValid").value="0";
}</script>
</body>
package com.yuncai.modules.servlet; import java.io.File;
import java.io.IOException;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.Enumeration; import javax.servlet.ServletConfig;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession; import org.apkinfo.api.GetApkInfo;
import org.apkinfo.api.domain.ApkInfo; import com.oreilly.servlet.MultipartRequest;
import com.yuncai.core.tools.DBConn;
import com.yuncai.core.tools.HttpOut;
import com.yuncai.core.tools.LogUtil;
import com.yuncai.core.util.DBHelper;
import com.yuncai.core.util.DBUpload; /**
* @author gx
* @version 2014-4-3
*/
public class FileUploadServlet extends HttpServlet { private static final long serialVersionUID = -3096800116651263134L; private String fileSizeLimit; public void init(ServletConfig config) throws ServletException {
this.fileSizeLimit = config.getInitParameter("fileSizeLimit");
} public void destroy() {
super.destroy();
} public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
HttpSession session = request.getSession();
String uploadDir = "upload" + File.separatorChar + "apk" + File.separatorChar;
String ctxDir = session.getServletContext().getRealPath(String.valueOf(File.separatorChar));
if (!ctxDir.endsWith(String.valueOf(File.separatorChar))) {
ctxDir = ctxDir + File.separatorChar;
}
File savePath = new File(ctxDir + uploadDir);
if (!savePath.exists()) {
savePath.mkdirs();
}
String saveDirectory = ctxDir + uploadDir;
int maxPostSize = 80 * 1024 * 1024;
String encoding = "UTF-8";
MultipartRequest multi = null;
try {
multi = new MultipartRequest(request, saveDirectory, maxPostSize, encoding);
} catch (IOException e) {
e.printStackTrace();
return;
} Enumeration<?> files = multi.getFileNames();
while (files.hasMoreElements()) {
String name = (String) files.nextElement();
File f = multi.getFile(name);
if (f != null) { Connection conn = DBConn.getConn("sqlServer");
String sql ="";
PreparedStatement ps=null;
sql = "select ID from T_Channel where NAME=?";
ResultSet rs =null;
try {
conn = DBConn.getConn("sqlServer");
sql ="insert into table(isValid,info) values(?,?)";
ps=conn.prepareStatement(sql); ps.setString(2, request.getParameter("info"));
ps.setString(1, request.getParameter("isValid"));
ps.executeUpdate();
} catch (SQLException e) {
e.printStackTrace();
}finally{
try {
if(DBHelper.isNoNull(ps))
ps.close();
if(DBHelper.isNoNull(conn))
conn.close();
} catch (SQLException e) {
}
}
}
} } public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
this.doPost(request, response);
} public String getFileSizeLimit() {
return fileSizeLimit;
} public void setFileSizeLimit(String fileSizeLimit) {
this.fileSizeLimit = fileSizeLimit;
} }
java实现批量上传(swfupload)的更多相关文章
- [Pulgin] 利用swfupload实现java文件批量上传
		
URL:http://blog.csdn.net/xuweilinjijis/article/details/8876305 之前在网上找过很多相关资料,很多所谓的批量上传都是忽悠人的,真正的批量上传 ...
 - WEB版一次选择多个文件进行批量上传(swfupload)的解决方案
		
说明:功能完全支持ie和firefox浏览器! 一般的WEB方式文件上传只能使用FileUpload控件进行一个文件一个文件的进行上传,就算是批量上传,也要把文件一个一个的添加到页面,无法如windo ...
 - [Plugin] WEB版一次选择多个文件进行批量上传(swfupload)的解决方案
		
URL:http://www.cnblogs.com/chillsrc/archive/2010/02/21/1670594.html 说明:功能完全支持ie和firefox浏览器! 一般的WEB方式 ...
 - JAVA图片批量上传JS-带预览功能
		
这篇文章就简单的介绍一个很好用的文件上传工具,批量带预览功能.直接贴代码吧,都有注释,很好理解. HTML页面 <!DOCTYPE html> <%@ taglib prefix=& ...
 - java”伪“批量上传
		
jsp页面代码 <form method="post" action="" enctype="multipart/form-data" ...
 - WEB版一次选择多个文件进行批量上传(Plupload)的解决方案
		
WEB版一次选择多个文件进行批量上传(Plupload)的解决方案 转载自http://www.cnblogs.com/chillsrc/archive/2013/01/30/2883648.htm ...
 - WEB版一次选择多个文件进行批量上传(WebUploader)的解决方案
		
本人在2010年时使用swfupload为核心进行文件的批量上传的解决方案.见文章:WEB版一次选择多个文件进行批量上传(swfupload)的解决方案. 本人在2013年时使用plupload为核心 ...
 - asp.net+swfupload 多图片批量上传(附源码下载)
		
asp.net的文件上传都是单个文件上传方式,无法执行一次性多张图片批量上传操作,要实现多图片批量上传需要借助于flash,通过flash选取多个图片(文件),然后再通过后端服务进行上传操作. 本次教 ...
 - Java Miniui实现批量上传文件demo 201906221520
		
可能需要的jar包: 需要miniui(类似easyui). Test2019062201.jsp <%@ page language="java" contentType= ...
 
随机推荐
- web性能调优
			
http://blog.csdn.net/chengzhezhijian/article/details/50680250 Java Web应用调优线程池:没你想的那么复杂 标签: java 线程池 ...
 - ajax基础了解
			
使用Ajax的最大优点,就是能在不更新整个页面的前提下维护数据.这使得Web应用程序更为迅捷地回应用户动作,并避免了在网络上发送那些没有改变过的信息.AJAX即“Asynchronous JavaSc ...
 - JVM性能调优监控工具jps、jstack、jmap、jhat、jstat使用详解(转VIII)
			
JVM本身就是一个java进程,一个java程序运行在一个jvm进程中.多个java程序同时运行就会有多个jvm进程.一个jvm进程有多个线程至少有一个gc线程和一个用户线程. JDK本身提供了很多方 ...
 - xcode7 NSAppTransportSecurity
			
在Info.plist中添加 NSAppTransportSecurity 类型 Dictionary Dictionary 下添加 NSAllowsArbitraryLoads 类型 Bool ...
 - Apache开发模块
			
输入perl Configure.pl 安装目录...\apache2.2 “httpd.exe” 生成apxs命令, apache2.2下build目录中的config_vars.mk文件 将CC ...
 - linux查找某一进程并杀死
			
1. 查找redis进程 ps -ef|grep redis-server 2.打印第二个参数,因为上面第二列是进程号 3.这两个进程号有一个是grep进程号,所以要去掉,反选 grep ps ...
 - Linux上安装五笔
			
1.安装# yum install ibus-table-chinese-wubi-jidian 2.设置ibus平台,添加五笔输入法# ibus-setup 3.#gsettings set org ...
 - Mongodb——GridFS
			
GridFS用于存储和恢复那些超过16M(BSON文件限制)的文件. GridFS将文件分成大块,将每个大块存储为单独的文件.GridFS中限制chunk最大为256k.GridFS使用两个colle ...
 - git  教程(12)--分支管理
			
分支就是科幻电影里面的平行宇宙,当你正在电脑前努力学习Git的时候,另一个你正在另一个平行宇宙里努力学习SVN. 如果两个平行宇宙互不干扰,那对现在的你也没啥影响.不过,在某个时间点,两个平行宇宙合并 ...
 - Bloom Filter 概念和原理
			
Bloom filter 是由 Howard Bloom 在 1970 年提出的二进制向量数据结构,它具有很好的空间和时间效率,被用来检测一个元素是不是集合中的一个成员.如果检测结果为是,该元素不一定 ...