`
renjie120
  • 浏览: 234917 次
  • 性别: Icon_minigender_1
  • 来自: 上海
博客专栏
D11bba82-ec4a-3d31-a3c0-c51130c62f1c
Java应用集锦
浏览量:22453
社区版块
存档分类
最新评论

java应用集锦4:保存大对象 上传显示进度条

    博客分类:
  • java
阅读更多

转载请注明出处: http://renjie120.iteye.com/

 

使用fileupload上传文档,并保存到blob字段中,上传的过程中显示进度.

<form name="uploadform" id="uploadform" method="POST"
			action="upload.action" ENCTYPE="multipart/form-data" target="hidden">
			上传文件1:
			<input type="file" id="filename1" name="filename1"
				onchange="setflag(true);"
				onblur="getFileSize('filename1','fileinf1');" name="filename">
			<div id="fileinf1" style="display: none"></div>
			<br>
			上传文件2:
			<input type="file" id="filename2" name="filename2"
				onchange="setflag(true);"
				onblur="getFileSize('filename2','fileinf2');" name="sheet">
			<div id="fileinf2" style="display: none"></div>
			<br>
			上传文件3:
			<input type="file" id="filename3" name="filename3"
				onchange="setflag(true);"
				onblur="getFileSize('filename3','fileinf3');" name="sheet">
			<div id="fileinf3" style="display: none"></div>
			<br>
			上传文件4:
			<input type="file" accept="image/gif" name="filename4" id="filename4"
				onchange="setflag(true);"
				onblur="getFileSize('filename4','fileinf4');" name="sheet">
			<div id="fileinf4" style="display: none"></div>
			<br>
			<button onclick="upload();">
				上传
			</button>
		</form>

 action:

package upload;

import java.io.File;
import java.util.Iterator;
import java.util.List;

import javax.servlet.http.HttpServletRequest;

import org.apache.commons.fileupload.DiskFileUpload;
import org.apache.commons.fileupload.FileItem;
import org.apache.commons.fileupload.ProgressListener;
import org.apache.commons.fileupload.disk.DiskFileItemFactory;
import org.apache.commons.fileupload.servlet.ServletFileUpload;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;

import com.lsframe.mvc.ActionContext;

public class NewUpload {
	private Log log = LogFactory.getLog("logger");

	private long maxsize = 1000000000;
	UploadDao dao = new UploadDao();

	public String execute() throws Exception {
		ActionContext context = ActionContext.getContext();
		final HttpServletRequest request = context.getHttpServletRequest();

		DiskFileItemFactory factory = new DiskFileItemFactory();
		// 设置内存里面存储的文件的最大字节
		factory.setSizeThreshold(10000);
		// 设置超出文件大小限制的文件存储的位置!
		factory.setRepository(new File("c:\\temp"));
		ServletFileUpload upload = new ServletFileUpload(factory);
		upload.setSizeMax(maxsize);
		
		// 下面是监听上传的进度的代码.


		ProgressListener progressListener = new ProgressListener() {
			private long megaBytes = -1;
			public void update(long pBytesRead, long pContentLength, int pItems) {
				System.out.println("We are currently reading item " + pItems);
				long mBytes = pBytesRead / 1000000;
				System.out.println(mBytes);
				if (megaBytes == mBytes) {
					return;
				}
				System.out.println(" " + pItems);
				megaBytes = mBytes;
				System.out.println("We are currently reading item " + pItems);
				if (pContentLength == -1) {
					System.out.println("So far, " + pBytesRead
							+ " bytes have been read.");
				} else {
					System.out.println("So far, " + pBytesRead + " of "
							+ pContentLength + " bytes have been read.");
				}
			}
		};
		// 对加载对象添加进度监听.
		upload.setProgressListener(progressListener);
		FileItem fi = null;
		String fileName = "";
		int endtag = 0;
		String shortName = "";
		Iterator it =  null;
		//下面的这句话必须放在上面的进度监听后面才可以在监听里面得到信息!!


		final List fileItems = upload.parseRequest(request);
		try {
			it = fileItems.iterator();
			while (it.hasNext()) {
				fi = (FileItem) it.next();
				fileName = fi.getName();
				endtag = fileName.lastIndexOf("\\");
				if (endtag == -1) {
					continue;
				}
				shortName = fileName.substring(endtag + 1);
				//下面演示保存到数据库的大对象字段
				UploadVO file = new UploadVO(shortName,fi.get(),(int)fi.getSize());
				file = dao.preSaveBlob(file);
				dao.insertIntoBlob(file);				
			}
			request.setAttribute("aaa", "上传OK!");
		} catch (Exception e) {
			e.printStackTrace();
			request.setAttribute("aaa", "上传失败,文件最大不得超过"
					+ new Long(maxsize).toString() + "字节!");
		}
		return "success";
	}

	/**
	 * 得到上传的进度信息,返回进度条的json信息..
	 * 
	 * @return
	 */
	public String getUploadProgress() {
		return null;
	}

	/**
	 * 返回指定文件的大小
	 * 
	 * @param fileName
	 * @return
	 */
	public String getMaxFileSize() {
		String str = new Long(maxsize).toString();
		return str;
	}

}

 

保存到blob字段,首先要插入一个空的blob字段占位,然后再以io流的方式写到数据库中的这个字段:

package upload;

import java.io.IOException;
import java.io.OutputStream;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.ArrayList;
import java.util.List;

import oracle.sql.BLOB;

import com.lsframe.jdbc.DBPoolManager;
import com.lsframe.jdbc.DataBase;

public class UploadDao {
	private DataBase dao = new DataBase();

	/**
	 * 添加大对象之前先保存一个位置,添加一个空的对象进去
	 * @return
	 * @throws SQLException 
	 */
	public int insertIntoBlob(UploadVO file) throws SQLException {
		String saveSql = "SELECT BLOB_CONTENT FROM TEST_BLOB_T WHERE BLOB_ID = ? FOR UPDATE";
		Connection conn = null;
		PreparedStatement pstmt = null;
		ResultSet rest = null;
		boolean ans = false;
		conn = DBPoolManager.getInstance().getDBConn();  
		try {
			conn.setAutoCommit(false);
			pstmt = conn.prepareStatement(saveSql);
			pstmt.setString(1, file.getBlobId());
			rest = pstmt.executeQuery();

			if (rest.next()) {
				ans = saveToDatabase((BLOB) rest.getBlob("BLOB_CONTENT"),
						file.getFileContent(), file.getFsize());
			}
			conn.setAutoCommit(true);
		} catch (Exception e) {
			System.out.println("保存大对象到数据库出错!\n错误信息:" + e.getMessage());
		}  finally {
			rest.close();
			pstmt.close();
			conn.close();
        }
		return 0;
	}

	/**
	 * 将大对象以字节流的方式写入到数据库中的blob字段.
	 * @param blobContent 从数据库中返回的blob字段对象
	 * @param fileBody 要添加到字段中的文件,以字节数组的方式保存
	 * @param vSize 文件大小
	 * @return
	 * @throws IOException
	 */
	private boolean saveToDatabase(BLOB blobContent, byte[] fileBody, int vSize)
			throws IOException {
		boolean result = false;
		try {
			OutputStream outstream = blobContent.getBinaryOutputStream();
			outstream.write(fileBody, 0, vSize);
			outstream.close();
			result = true;
		} catch (SQLException e) {
			result = false;
			e.printStackTrace();
		} catch (Exception e) {
			result = false;
			e.printStackTrace();
		}
		return result;
	}

	/**
	 * 预添加大对象到数据库.
	 * @return
	 */
	public UploadVO preSaveBlob(UploadVO file) {
		String getSeq = "SELECT TESTBLOBSEQ.NEXTVAL  FROM DUAL";
		String saveSql = "INSERT INTO TEST_BLOB_T(BLOB_CONTENT,BLOB_TIME,BLOB_SIZE,BLOB_NAME,BLOB_ID) VALUES " +
				"(EMPTY_BLOB(),SYSDATE,?,?,?)";
		List argList = new ArrayList();
		argList.add(file.getFsize());
		argList.add(file.getFileName());
		int ans = 0;
		String seq = "";
		try {
			//查询数据库中的这个文件对应的流水号
			seq = dao.queryForString(getSeq);
			argList.add(seq);
			//保存文件相关信息到数据库,并在文件内容的字段上面插入空的blob对象
			ans = dao.updateRecords(saveSql,argList);
			file.setBlobId(seq);
		} catch (Exception e) {
			System.out.println("预添加大对象失败!\n错误信息:" + e.getMessage());
		}
		return file;
	}
}

 

相关的表的结构:

create table TEST_BLOB_T
(
  BLOB_ID      VARCHAR2(30) not null,
  BLOB_SIZE    NUMBER(20,4),
  BLOB_CONTENT BLOB,
  BLOB_TIME    DATE,
  BLOB_NAME    VARCHAR2(50)
)

 

分享到:
评论
1 楼 495372396 2012-09-07  


l;'l[;l'l';l';ll;'l;';l'l;'[flash=2l;';l'l;'l;'l;'
00,200][/flash]

相关推荐

    网络编程网络编程网络编程

    网络编程网络编程网络编程网络编程

    setuptools-5.4.zip

    Python库是一组预先编写的代码模块,旨在帮助开发者实现特定的编程任务,无需从零开始编写代码。这些库可以包括各种功能,如数学运算、文件操作、数据分析和网络编程等。Python社区提供了大量的第三方库,如NumPy、Pandas和Requests,极大地丰富了Python的应用领域,从数据科学到Web开发。Python库的丰富性是Python成为最受欢迎的编程语言之一的关键原因之一。这些库不仅为初学者提供了快速入门的途径,而且为经验丰富的开发者提供了强大的工具,以高效率、高质量地完成复杂任务。例如,Matplotlib和Seaborn库在数据可视化领域内非常受欢迎,它们提供了广泛的工具和技术,可以创建高度定制化的图表和图形,帮助数据科学家和分析师在数据探索和结果展示中更有效地传达信息。

    基于树莓派智能小车(H5页面操作移动+实时显示摄像头内容+各类传感器)源码+详细文档+全部资料齐全 高分项目.zip

    【资源说明】 基于树莓派智能小车(H5页面操作移动+实时显示摄像头内容+各类传感器)源码+详细文档+全部资料齐全 高分项目.zip基于树莓派智能小车(H5页面操作移动+实时显示摄像头内容+各类传感器)源码+详细文档+全部资料齐全 高分项目.zip 【备注】 1、该项目是个人高分项目源码,已获导师指导认可通过,答辩评审分达到95分 2、该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的,请放心下载使用! 3、本项目适合计算机相关专业(人工智能、通信工程、自动化、电子信息、物联网等)的在校学生、老师或者企业员工下载使用,也可作为毕业设计、课程设计、作业、项目初期立项演示等,当然也适合小白学习进阶。 4、如果基础还行,可以在此代码基础上进行修改,以实现其他功能,也可直接用于毕设、课设、作业等。 欢迎下载,沟通交流,互相学习,共同进步!

    2024-01-03-【办公自动化】Python执行Windows命令.md

    2024-01-03-【办公自动化】Python执行Windows命令

    基于FPGA的FS-FBMC调制器的设计源码+全部资料齐全.zip

    【资源说明】 基于FPGA的FS-FBMC调制器的设计源码+全部资料齐全.zip基于FPGA的FS-FBMC调制器的设计源码+全部资料齐全.zip 【备注】 1、该项目是高分课程设计项目源码,已获导师指导认可通过,答辩评审分达到95分 2、该资源内项目代码都经过mac/window10/11/linux测试运行成功,功能ok的情况下才上传的,请放心下载使用! 3、本项目适合计算机相关专业(如软件工程、计科、人工智能、通信工程、自动化、电子信息等)的在校学生、老师或者企业员工下载使用,也可作为课程设计、作业、项目初期立项演示等,当然也适合小白学习进阶。 4、如果基础还行,可以在此代码基础上进行修改,以实现其他功能,也可直接用于课设、作业等。 欢迎下载,沟通交流,互相学习,共同进步!

    MySQL进阶篇学习笔记

    黑马MySQL课程总结的学习笔记

    setuptools-41.1.0.zip

    Python库是一组预先编写的代码模块,旨在帮助开发者实现特定的编程任务,无需从零开始编写代码。这些库可以包括各种功能,如数学运算、文件操作、数据分析和网络编程等。Python社区提供了大量的第三方库,如NumPy、Pandas和Requests,极大地丰富了Python的应用领域,从数据科学到Web开发。Python库的丰富性是Python成为最受欢迎的编程语言之一的关键原因之一。这些库不仅为初学者提供了快速入门的途径,而且为经验丰富的开发者提供了强大的工具,以高效率、高质量地完成复杂任务。例如,Matplotlib和Seaborn库在数据可视化领域内非常受欢迎,它们提供了广泛的工具和技术,可以创建高度定制化的图表和图形,帮助数据科学家和分析师在数据探索和结果展示中更有效地传达信息。

    张祖豪-软件工程师-职业规划.pdf

    张祖豪-软件工程师-职业规划.pdf

    智慧工地整体解决方案qy.pptx

    智慧工地整体解决方案qy.pptx

    setuptools-49.1.1-py3-none-any.whl

    Python库是一组预先编写的代码模块,旨在帮助开发者实现特定的编程任务,无需从零开始编写代码。这些库可以包括各种功能,如数学运算、文件操作、数据分析和网络编程等。Python社区提供了大量的第三方库,如NumPy、Pandas和Requests,极大地丰富了Python的应用领域,从数据科学到Web开发。Python库的丰富性是Python成为最受欢迎的编程语言之一的关键原因之一。这些库不仅为初学者提供了快速入门的途径,而且为经验丰富的开发者提供了强大的工具,以高效率、高质量地完成复杂任务。例如,Matplotlib和Seaborn库在数据可视化领域内非常受欢迎,它们提供了广泛的工具和技术,可以创建高度定制化的图表和图形,帮助数据科学家和分析师在数据探索和结果展示中更有效地传达信息。

    setuptools-40.1.1.zip

    Python库是一组预先编写的代码模块,旨在帮助开发者实现特定的编程任务,无需从零开始编写代码。这些库可以包括各种功能,如数学运算、文件操作、数据分析和网络编程等。Python社区提供了大量的第三方库,如NumPy、Pandas和Requests,极大地丰富了Python的应用领域,从数据科学到Web开发。Python库的丰富性是Python成为最受欢迎的编程语言之一的关键原因之一。这些库不仅为初学者提供了快速入门的途径,而且为经验丰富的开发者提供了强大的工具,以高效率、高质量地完成复杂任务。例如,Matplotlib和Seaborn库在数据可视化领域内非常受欢迎,它们提供了广泛的工具和技术,可以创建高度定制化的图表和图形,帮助数据科学家和分析师在数据探索和结果展示中更有效地传达信息。

    基于FPGA设计的电梯控制电路系统源码+全部资料齐全.zip

    【资源说明】 基于FPGA设计的电梯控制电路系统源码+全部资料齐全.zip基于FPGA设计的电梯控制电路系统源码+全部资料齐全.zip 【备注】 1、该项目是高分课程设计项目源码,已获导师指导认可通过,答辩评审分达到95分 2、该资源内项目代码都经过mac/window10/11/linux测试运行成功,功能ok的情况下才上传的,请放心下载使用! 3、本项目适合计算机相关专业(如软件工程、计科、人工智能、通信工程、自动化、电子信息等)的在校学生、老师或者企业员工下载使用,也可作为课程设计、作业、项目初期立项演示等,当然也适合小白学习进阶。 4、如果基础还行,可以在此代码基础上进行修改,以实现其他功能,也可直接用于课设、作业等。 欢迎下载,沟通交流,互相学习,共同进步!

    全系统实战营销课,从小白到营销高手

    课程内容: 将成功建立在问题基层上 不做第- 就做唯一 新切割营销 品牌4s战略-构建高效强势品牌 智慧底牌-成功背后的10大思维方式 切割营销将对手通向一侧的营销策略 营销绝对竞争力 品牌突破 切割营销 企业家修炼-第九届学习型中国世纪成功论坛 如何创造七种动力进行整合营销 营销品牌教材 林伟贤董进宇姜岚昕演讲-第八届学习型中国世纪成功论坛 内部报告:处理人生10种关系智慧 高效构建强势品牌 营销纲领(首部谋定未来的营销大典)1~4

    基于SpringBoot+Vue的酒店(预约)客房管理系统的设计与实现+毕业论文(包运行成功)

    酒店客房管理系统为酒店管理者和用户、清洁人员提供一个在线管理酒店客房的系统。在网站的设计中,一共分为了两个模块设计,一个是前台模块,一个是后台模块,前台主要用于提供查看客房信息,酒店资讯,留言反馈,个人中心,在线客服等一系列的功能,后台会根据等于角色的不同分配不同的权限,如果登录的是管理员角色的话,则有管理员个人信息管理,用户管理,客房管理,清洁管理,系统管理等,如果登录的是用户角色的话,则有用户个人信息管理,预约管理,入住管理,收藏管理等,如果登录的是清洁人员角色的话,,则有清洁人员个人信息管理,退房管理,清洁管理等。 整个后台系统的大致功能如图1所示,整个后台系统分为两个部分,一部分为用户端,一部分为管理端,用户端的功能主要是用户来进行房屋预约,房屋入住,房屋收藏,浏览反馈,在线咨询。管理端也分三类角色的管理,管理员角色,用户角色,清洁人员角色,对应的角色不同,相应的对应的管理端也不同。

    IDC智能机房整体解决方案.ppt

    IDC智能机房整体解决方案.ppt

    setuptools-25.4.0.zip

    Python库是一组预先编写的代码模块,旨在帮助开发者实现特定的编程任务,无需从零开始编写代码。这些库可以包括各种功能,如数学运算、文件操作、数据分析和网络编程等。Python社区提供了大量的第三方库,如NumPy、Pandas和Requests,极大地丰富了Python的应用领域,从数据科学到Web开发。Python库的丰富性是Python成为最受欢迎的编程语言之一的关键原因之一。这些库不仅为初学者提供了快速入门的途径,而且为经验丰富的开发者提供了强大的工具,以高效率、高质量地完成复杂任务。例如,Matplotlib和Seaborn库在数据可视化领域内非常受欢迎,它们提供了广泛的工具和技术,可以创建高度定制化的图表和图形,帮助数据科学家和分析师在数据探索和结果展示中更有效地传达信息。

    setuptools-0.8.zip

    Python库是一组预先编写的代码模块,旨在帮助开发者实现特定的编程任务,无需从零开始编写代码。这些库可以包括各种功能,如数学运算、文件操作、数据分析和网络编程等。Python社区提供了大量的第三方库,如NumPy、Pandas和Requests,极大地丰富了Python的应用领域,从数据科学到Web开发。Python库的丰富性是Python成为最受欢迎的编程语言之一的关键原因之一。这些库不仅为初学者提供了快速入门的途径,而且为经验丰富的开发者提供了强大的工具,以高效率、高质量地完成复杂任务。例如,Matplotlib和Seaborn库在数据可视化领域内非常受欢迎,它们提供了广泛的工具和技术,可以创建高度定制化的图表和图形,帮助数据科学家和分析师在数据探索和结果展示中更有效地传达信息。

    电子行业周报:华为召开鸿蒙生态春季沟通会,智界S7与MateBook X Pro焕新亮相.pdf

    电子元件 电子行业 行业分析 数据分析 数据报告 行业报告

    PasteSpider的管理端静态页面V24.5.12.1(主服务端和文件同步器版本至少要24.5.12.1及以上版本)

    当前文件需要和PasteSpider配套使用, 配套的还有PasteSpiderFile(文件同步管理器), 和PasteSpider的主端(一款类似K8S的容器管理工具)。 当前版本为大版本升级,需要和配套的其他端的版本使用,否则出现访问错误等! 把当前文件解压后,放于服务器上,或者是方入PasteSpider的解压缩里面的wwwroot文件夹下。 个人建议独立存放,因为PasteSpider是需要打包到docker的镜像里面的,存放于宿主服务器上便于修改! 当前版本修改内容主要如下: 1.数据的获取修改为get模式,后续会基于http的method做一些特定的日志记录,大致的思路是get只做简单的校验,post做强校验并记录日志等。 2.定时任务添加任务串的支持,比如需要发布一个项目中的几个服务,他们有执行顺序,只需要把上一个任务的ID作为当前任务的父级ID即可, 3.静态服务(一般是web静态端不需要构建的),支持暂存模式,配合定时发布使用! 更多PasteSpider资料访问 https://blog.csdn.net/apeart/category_12291787.html

    setuptools-25.1.3.zip

    Python库是一组预先编写的代码模块,旨在帮助开发者实现特定的编程任务,无需从零开始编写代码。这些库可以包括各种功能,如数学运算、文件操作、数据分析和网络编程等。Python社区提供了大量的第三方库,如NumPy、Pandas和Requests,极大地丰富了Python的应用领域,从数据科学到Web开发。Python库的丰富性是Python成为最受欢迎的编程语言之一的关键原因之一。这些库不仅为初学者提供了快速入门的途径,而且为经验丰富的开发者提供了强大的工具,以高效率、高质量地完成复杂任务。例如,Matplotlib和Seaborn库在数据可视化领域内非常受欢迎,它们提供了广泛的工具和技术,可以创建高度定制化的图表和图形,帮助数据科学家和分析师在数据探索和结果展示中更有效地传达信息。

Global site tag (gtag.js) - Google Analytics