把电子文件流转成base64字符串然后封装到xml里面,然后读取以用sax顺序读取的方式把电子文件读取出来。
因为sax是顺序读取xml的,不用整个xml加载到内存,解决xml大文件问题。
package com.base64.tool;
import java.io.File;
import java.io.FileOutputStream;
import java.io.FileWriter;
import java.io.IOException;
import java.io.RandomAccessFile;
import org.apache.log4j.Logger;
import org.dom4j.Document;
import org.dom4j.DocumentHelper;
import org.dom4j.io.OutputFormat;
import org.dom4j.io.XMLWriter;
import org.xml.sax.Attributes;
import org.xml.sax.SAXException;
import org.xml.sax.helpers.DefaultHandler;
import titans.common.Constant;
/**
* 大文件xml解板工具类
* @author 珠海·李正球
* @version 1.0 2012-07-20
*/
public class Base64readutil extends DefaultHandler{
protected Logger log = Logger.getLogger(this.getClass()); // log4j
private String qName=""; //元数据名称
private String filename="";//文件名称
private int pos=0; //文件指针位置
private FileWriter xmlFile =null;
private StringBuilder outstr=null;
private String filepath = "C:/";
private StringBuilder base64Str = null; //存放非电子文件内容
private StringBuilder base64File = null; //存放电子文件内容
private final static int blocksize=256;//base64分块大小
FileOutputStream out = null;
private String eepfile=null;
public Base64readutil(String eepfile )
{
this.eepfile=eepfile;
}
public Base64readutil(String eepfile,String path )
{
this.eepfile=eepfile;
this.filepath = path;
}
@Override
public void startDocument() throws SAXException {
log.info("文档打开...");
pos = 0;
base64File =new StringBuilder("");
try {
//xmlFile = new FileWriter(this.eepfile,false);
outstr=new StringBuilder("<?xml version=\"1.0\" encoding=\"utf-8\"?>");
base64File=new StringBuilder("");
} catch (Exception e) {
log.error(e.getMessage());
}
}
@Override
public void endDocument() throws SAXException {
log.info("文档结束....");
try {
Document document = DocumentHelper.parseText(outstr.toString().trim());
OutputFormat xmlFormat = OutputFormat.createPrettyPrint();
xmlFormat.setEncoding("UTF-8");
xmlFormat.setIndent(" ");
XMLWriter output = new XMLWriter( new FileOutputStream(new File(eepfile)),xmlFormat);
output.write( document );
output.close();
} catch (Exception e) {
log.error(e.getMessage());
}
}
@Override
public void characters(char[] ch, int start, int length) throws SAXException {
String content="";
if(this.qName.trim().equalsIgnoreCase("计算机文件名"))
{
content=new String(ch,start,length);
if(content.trim().length()>0){
if( filename.lastIndexOf(".")==-1)
if(filename.trim().equalsIgnoreCase(""))
filename=((filepath.endsWith("/")||this.filepath.endsWith("\\"))?filepath:(filepath + "/"))+ content;
else
filename=filename+content;
else
filename=((filepath.endsWith("/")||this.filepath.endsWith("\\"))?filepath:(filepath + "/"))+ content;
outstr.append(content);
}
}
else if(this.qName.trim().equalsIgnoreCase("编码数据"))
{
content=new String(ch,start,length);
if(content.trim().length()>0){
log.info("元数据值:"+content);
base64Str.append(content);
base64File.append(content);
byte[] base64byte=null;
try {
//通过4位整数获取 start
int total=base64File.length();
int i =total/blocksize;
if(total>blocksize)
{
for(int k=0;k<i;k++)
{
base64byte=Constant.decoderBase64(base64File.toString().substring(k*blocksize, (k+1)*blocksize));
downfile(base64byte,filename,pos,base64byte.length);
pos+=base64byte.length;
}
if( this.base64File.length()>0 )
base64File.delete(0, blocksize*i);
}
// 通过4位整数获取 end
base64Str = new StringBuilder();
if(!base64Str.toString().equalsIgnoreCase(""))
out.write(Constant.decoderBase64(base64Str.toString()));
} catch (Exception e) {
// TODO 自动生成 catch 块
log.error(e.getMessage());
}
}
}
else
{
content=new String(ch,start,length);
outstr.append(content);
}
}
@Override
public void startElement(String url, String LocalName, String qName, Attributes attr) throws SAXException {
if(this.qName.trim().equalsIgnoreCase("编码数据"))
{
//清除base64文件内容
if( this.base64File.length()>0 )
this.base64File.delete(0, this.base64File.length());
this.pos=0; //换文件时复位文件指针
}
log.info("开始元素:"+qName);
outstr.append("<"+qName);
this.qName=qName;
for(int i=0;i<attr.getLength();i++){
//log.info("属性"+attr.getQName(i)+"值是:"+attr.getValue(i));
outstr.append(" ").append(attr.getQName(i)).append("=\"").append(attr.getValue(i)).append("\"");
}
outstr.append(">");
base64Str = new StringBuilder();
}
@Override
public void endElement(String url, String LocalName, String qName) throws SAXException {
log.info("结束元素:"+qName);
if(this.qName.trim().equalsIgnoreCase("编码数据"))
{
//将剩下base64流写入到文件中
if(this.base64File.length()!=0)
{
byte[] base64byte;
try {
base64byte = Constant.decoderBase64(this.base64File.toString());
downfile(base64byte,filename,pos,base64byte.length);
//清除base64文件内容
if( this.base64File.length()>0 )
this.base64File.delete(0, this.base64File.length());
} catch (Exception e) {
//清除base64文件内容
if( this.base64File.length()>0 )
this.base64File.delete(0, this.base64File.length());
log.error(e.getMessage());
}
}
this.pos=0; //换文件时复位文件指针
}
outstr.append("</"+qName+">");
}
/**
* method 分段下载文件流
* @param buffer 上传文件流字节流
* @param downpath 文件path
* @param filename 文件名
* @param long pos 写入文件开始位置
* @param long writeSize 一次写入文件大小
* @return 返回无
* @throws Exception
*/
private void downfile( byte[] buffer ,String filename,int pos,int writeSize) {
RandomAccessFile myRAFile = null;
File f =null;
try
{
f =new File(filename);
myRAFile = new RandomAccessFile(f, "rw");
myRAFile.seek(pos);
//log.info( "每片指针位置:"+pos );
//log.info( "每片文件大小:"+writeSize );
int total=pos+writeSize;
log.info( "总大小:"+total );
myRAFile.write(buffer,0,writeSize);
f =null;
buffer=null;
myRAFile.close();
myRAFile=null;
}
catch (Exception e) {
log.error("下载电子文件不成功");
try {
f =null;
buffer=null;
myRAFile.close();
myRAFile=null;
} catch (IOException e1) {
f =null;
buffer=null;
myRAFile=null;
}
}
}
}
package com.base64.tool;
import java.io.IOException;
import javax.xml.parsers.ParserConfigurationException;
import javax.xml.parsers.SAXParser;
import javax.xml.parsers.SAXParserFactory;
import java.io.File;
import org.xml.sax.SAXException;
/**
* 大文件xml解板工具类
* @author 珠海·李正球
* @version 1.0 2012-07-20
*/
public class Base64read {
public static void main(String[] args) {
try {
SAXParserFactory factory=SAXParserFactory.newInstance();
factory.setNamespaceAware(true);
factory.setValidating(true);
SAXParser parser=factory.newSAXParser();
Base64readutil p1=new Base64readutil("c:\\testnew.xml");
parser.parse(new File("c:\\test.eep"), p1);
} catch (ParserConfigurationException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (SAXException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
分享到:
相关推荐
修炼成Javascript中级程序员必知必会_资源分享
内容概要:本文详细介绍了如何使用MATLAB的深度学习工具箱,在果树病虫害识别任务中从数据准备、模型设计、训练优化到最后的模型评估与应用全流程的具体实施步骤和技术要点。涵盖了MATLAB深度学习工具箱的基本概念及其提供的多种功能组件,如卷积神经网络(CNN)的应用实例。此外,文中还具体讲述了数据集的收集与预处理方法、不同类型的深度学习模型搭建、训练过程中的超参数设定及其优化手段,并提供了病虫害识别的实际案例。最后展望了深度学习技术在未来农业领域的潜在影响力和发展前景。 适合人群:对深度学习及农业应用感兴趣的科研人员、高校师生和相关从业者。 使用场景及目标:①希望掌握MATLAB环境下构建深度学习模型的方法和技术细节;②从事果树病虫害管理研究或实践,寻找高效的自动化解决方案。 阅读建议:在阅读本文之前,建议读者熟悉基本的MATLAB编程环境及初步了解机器学习的相关概念。针对文中涉及的理论和技术难点,可以通过官方文档或其他教程进行补充学习。同时,建议动手实践每一个关键点的内容,在实践中加深理解和掌握技能。
nodejs010-nodejs-block-stream-0.0.7-1.el6.centos.alt.noarch.rpm
机械模型与技术交底书的融合:创新点详解与解析,机械模型加技术交底书,有创新点 ,机械模型; 技术交底书; 创新点,创新机械模型与技术交底书详解
免费JAVA毕业设计 2024成品源码+论文+数据库+启动教程 启动教程:https://www.bilibili.com/video/BV1SzbFe7EGZ 项目讲解视频:https://www.bilibili.com/video/BV1Tb421n72S 二次开发教程:https://www.bilibili.com/video/BV18i421i7Dx
免费JAVA毕业设计 2024成品源码+论文+数据库+启动教程 启动教程:https://www.bilibili.com/video/BV1SzbFe7EGZ 项目讲解视频:https://www.bilibili.com/video/BV1Tb421n72S 二次开发教程:https://www.bilibili.com/video/BV18i421i7Dx
nodejs010-nodejs-cmd-shim-1.1.0-4.1.el6.centos.alt.noarch.rpm
西门子四轴卧加后处理系统:828D至840D兼容,四轴联动高效加工解决方案,支持图档处理及试看程序。,西门子四轴卧加后处理,支持828D~840D系统,支持四轴联动,可制制,看清楚联系,可提供图档处理试看程序 ,核心关键词:西门子四轴卧加后处理; 828D~840D系统支持; 四轴联动; 制程; 联系; 图档处理试看程序。,西门子四轴卧加后处理程序,支持多种系统与四轴联动
基于黏菌优化算法(SMA)的改进与复现——融合EO算法更新策略的ESMA项目报告,黏菌优化算法(SMA)复现(融合EO算法改进更新策略)——ESMA。 复现内容包括:改进算法实现、23个基准测试函数、多次实验运行并计算均值标准差等统计量、与SMA对比等。 程序基本上每一步都有注释,非常易懂,代码质量极高,便于新手学习和理解。 ,SMA复现;EO算法改进;算法实现;基准测试函数;实验运行;统计量;SMA对比;程序注释;代码质量;学习理解。,标题:ESMA算法复现:黏菌优化与EO算法融合改进的实证研究
基于MATLAB的Stewart平台并联机器人仿真技术研究与实现:Simscape环境下的虚拟模拟分析与应用,MATLAB并联机器人Stewart平台仿真simscape ,MATLAB; 并联机器人; Stewart平台; 仿真; Simscape; 关键技术。,MATLAB中Stewart平台并联机器人Simscape仿真
Grad-CAM可视化医学3D影像
探索comsol泰勒锥:电流体动力学的微观世界之旅,comsol泰勒锥、电流体动力学 ,comsol泰勒锥; 电流体动力学; 锥形结构; 电场影响,COMSOL泰勒锥与电流体动力学研究
免费JAVA毕业设计 2024成品源码+论文+数据库+启动教程 启动教程:https://www.bilibili.com/video/BV1SzbFe7EGZ 项目讲解视频:https://www.bilibili.com/video/BV1Tb421n72S 二次开发教程:https://www.bilibili.com/video/BV18i421i7Dx
PFC6.03D模型动态压缩模拟与SHPB霍普金森压杆系统理论及实验数据处理技术解析,PFC6.03D模型,动态压缩模拟,还包括: SHPB霍普金森压杆系统理论知识介绍,二波法和三波法处理实验数据,提出三波波形,计算动态压缩强度等 ,PFC模型; 动态压缩模拟; SHPB霍普金森压杆系统; 理论介绍; 二波法处理; 三波法处理; 三波波形; 动态压缩强度。,"PFC模型下的动态压缩模拟及SHPB理论实践研究"
ProASCI 开发板原理图,适用于A3P3000
免费JAVA毕业设计 2024成品源码+论文+录屏+启动教程 启动教程:https://www.bilibili.com/video/BV1SzbFe7EGZ 项目讲解视频:https://www.bilibili.com/video/BV1Tb421n72S 二次开发教程:https://www.bilibili.com/video/BV18i421i7Dx
1、文件内容:pykde4-devel-4.10.5-6.el7.rpm以及相关依赖 2、文件形式:tar.gz压缩包 3、安装指令: #Step1、解压 tar -zxvf /mnt/data/output/pykde4-devel-4.10.5-6.el7.tar.gz #Step2、进入解压后的目录,执行安装 sudo rpm -ivh *.rpm 4、安装指导:私信博主,全程指导安装
基于Comsol模拟的三层顶板随机裂隙浆液扩散模型:考虑重力影响的瞬态扩散规律分析,Comsol模拟,考虑三层顶板包含随机裂隙的浆液扩散模型,考虑浆液重力的影响,模型采用的DFN插件建立随机裂隙,采用达西定律模块中的储水模型为控制方程,分析不同注浆压力条件下的浆液扩散规律,建立瞬态模型 ,Comsol模拟; 随机裂隙浆液扩散模型; 浆液重力影响; DFN插件; 达西定律模块储水模型; 注浆压力条件; 浆液扩散规律; 瞬态模型,Comsol浆液扩散模型:随机裂隙下考虑重力的瞬态扩散分析
A simple fast, easy use distributed file system written by golang(similar fastdfs).go-fastdfs
手机编程-1738391552157.jpg