ZipOutputStream压缩问题

问题描述

//////////////////action中/** * 下载服务器文件到本地 * @return */public String getAllFile()throws Exception{BufferedOutputStream bos = null;OutputStream fos = null;//byte[] dd = documentManager.getFileBody(3);HttpServletResponse response = ServletActionContext.getResponse();response.setCharacterEncoding("UTF-8");fos = response.getOutputStream();ZipOutputStream zos = new ZipOutputStream(fos);//以上定义输入输出流的一些变量//获得该备份节点的名称System.out.println(nodeid+"fffffffffffffffff");int nodeid1 = Integer.parseInt(nodeid);Node node = documentManager.findNodeById(nodeid1);String name = documentManager.findNodeById(nodeid1).getName();//响应客户端发出开始保存服务器文件的请求response.setHeader("Content-disposition","attachment;filename="+URLEncoder.encode(name+".zip", "utf-8")); //zos.putNextEntry(new ZipEntry("ss/ff.doc"));//zos.write(dd);//遍历树节点,组装zip压缩包documentManager.findNodesByRoot(node, zos,node.getName()+"/");zos.close();return null;}////////////////////业务类中/** * 根据根节点获得其子节点 */public void findNodesByRoot(Node node,ZipOutputStream zos,String path){//根据传入的节点得到他的孩子节点List list1 = HibernateFilter.getSession().createQuery("from Node where parentid=?").setInteger(0, node.getId()).list();List documentlist = HibernateFilter.getSession().createQuery("from Document where nodeid=?").setInteger(0,node.getId()).list();if(!documentlist.isEmpty()){for(int i=0;i<documentlist.size();i++){try {Document document = (Document)documentlist.get(i);//URLEncoder.encode(path+document.getSubject()+document.getFileType(), "utf-8")//URLEncoder.encode(node.getName(), "utf-8")+"/"+URLEncoder.encode(document.getSubject(), "utf-8")+document.getFileType()zos.putNextEntry(new ZipEntry(path+document.getSubject()+document.getFileType()));zos.write(getFileBody(document.getRecordID()));} catch (IOException e) {e.printStackTrace();}}//zos.putNextEntry(new ZipEntry("ss/ff.doc"));//zos.write(dd);}//如果节点不为空则if(!list1.isEmpty()){for(int i=0;i<list1.size();i++){Node node1 =(Node)list1.get(i);//System.out.println(node1.getId()+":"+node1.getName());String path1=path+node1.getName()+"/";List documentlist1 = HibernateFilter.getSession().createQuery("from Document where nodeid=?").setInteger(0,node1.getId()).list();if(!documentlist1.isEmpty()){for(int j=0;j<documentlist.size();j++){try {Document document1 = (Document)documentlist1.get(j);//URLEncoder.encode(path1+document1.getSubject()+document1.getFileType(), "utf-8")//URLEncoder.encode(node.getName(), "utf-8")+"/"+URLEncoder.encode(node1.getName(), "utf-8")+"/"+URLEncoder.encode(document1.getSubject(), "utf-8")+document1.getFileType()zos.putNextEntry(new ZipEntry(path1+document1.getSubject()+document1.getFileType()));zos.write(getFileBody(document1.getRecordID()));} catch (IOException e) {e.printStackTrace();}}}System.out.println(path1);findNodesByRoot(node1,zos,path1);}}}///异常java.net.SocketException: Software caused connection abort: socket write errorat java.net.SocketOutputStream.socketWrite0(Native Method)at java.net.SocketOutputStream.socketWrite(SocketOutputStream.java:92)at java.net.SocketOutputStream.write(SocketOutputStream.java:136)at weblogic.servlet.internal.ChunkOutput.writeChunkTransfer(ChunkOutput.java:525)at weblogic.servlet.internal.ChunkOutput.writeChunks(ChunkOutput.java:504)at weblogic.servlet.internal.ChunkOutput.flush(ChunkOutput.java:382)at weblogic.servlet.internal.CharsetChunkOutput.flush(CharsetChunkOutput.java:249)at weblogic.servlet.internal.ChunkOutput.checkForFlush(ChunkOutput.java:469)at weblogic.servlet.internal.CharsetChunkOutput.implWrite(CharsetChunkOutput.java:396)at weblogic.servlet.internal.CharsetChunkOutput.write(CharsetChunkOutput.java:198)at weblogic.servlet.internal.ChunkOutputWrapper.write(ChunkOutputWrapper.java:133)at weblogic.servlet.internal.ServletOutputStreamImpl.write(ServletOutputStreamImpl.java:168)at org.apache.tools.zip.ZipOutputStream.writeOut(ZipOutputStream.java:829)at org.apache.tools.zip.ZipOutputStream.deflate(ZipOutputStream.java:548)at org.apache.tools.zip.ZipOutputStream.closeEntry(ZipOutputStream.java:326)at org.apache.tools.zip.ZipOutputStream.putNextEntry(ZipOutputStream.java:382)at com.wzsoft.gl.manager.impl.DocumentManagerImpl.findNodesByRoot(DocumentManagerImpl.java:84)at com.wzsoft.gl.manager.impl.DocumentManagerImpl.findNodesByRoot(DocumentManagerImpl.java:115)at com.wzsoft.gl.actions.DocumentAction.getAll

解决方案

这应该是客户端点了“取消”等中断了下载,这个异常是正常的,可以不管它。
解决方案二:
引用documentManager.findNodesByRoot(node, zos,node.getName()+"/");你看看你的DocumentManagerImpl 中84行代码 是什么 这个报错信息指向了这里,可能有什么原因导致了你这个代码的错误而无法执行下去。你贴出来看看 然后在找一下原因。

时间: 2024-09-18 08:53:03

ZipOutputStream压缩问题的相关文章

java.util.zip.ZipOutputStream压缩无乱码(原创)

package io; import java.io.BufferedOutputStream; import java.io.BufferedReader; import java.io.FileInputStream; import java.io.FileOutputStream; import java.io.IOException; import java.io.InputStreamReader; import java.util.zip.Adler32; import java.u

在JAVA中解决Zip压缩乱码问题

Java自带的zip压缩工具,可以让我们方便的压缩与解压缩,但是就是默认编码UTF-8没法改(至少我没找到,如果谁找到了,别忘记告诉我,我也不想用第三方的Jar包),虽然使用Java写打压缩与解压缩没问题,但是中文字符在WinRAR里面全是乱码. 所以我采用了Ant包中的压缩功能. 多余的话不多说了,代码才是硬道理,直接上代码吧.顺便说一下,该程序依赖于ant包,但是如果你只用到压缩,你可以用WinRAR打开这个Ant.jar文件,删除org.apache.tools.zip包以外的所有clas

Java压缩文件ZIP实例代码_java

提示:java.util.zipoutputstream         java API压缩为zip文件 代码: 复制代码 代码如下: package com.gaoqi.test;import java.io.File;import java.io.FileInputStream;import java.io.FileOutputStream;import java.io.IOException;import java.util.zip.ZipEntry;import java.util.z

求解啊-html菜鸟,请教大加如何实现这个功能

问题描述 html菜鸟,请教大加如何实现这个功能 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta

压缩解压缩文件(zip格式)

using System; using System.Collections.Generic; using System.IO; using ICSharpCode.SharpZipLib.Zip; namespace TestConsole { internal class Program { private static void Main() { //CreateZipFile(@"d:\", @"d:\a.zip"); UnZipFile(@"E:

zip压缩解决文件名中文乱码问题

使用jdk自带的zip工具类Java.util.zip.ZipEntry,java.util.zip.ZipFile,java.util.zip.ZipInputStream,java.util.zip.ZipOutputStream 进行zip压缩时,没法解决文件名中文乱码问题 这里使用apache 旗下的commons-compress 库,官网是:http://commons.apache.org/proper/commons-compress/download_compress.cgi

struts2.0-struts2 将文件压缩后 下载却不成功

问题描述 struts2 将文件压缩后 下载却不成功 我用struts2 做了个文件下载功能. 对于未压缩过的文件 一下子就下完了.. 用ZipOutputStream做成压缩包后,只能下载一部分,然后就下不动了.. 这是什么问题..不压缩能下得动,压缩完就不行.是struts2 对下载压缩支持不好吗? inputStream = new FileInputStream(new File("E:work_myeclipse.metadata.me_tcatwebapps eport_manage

JSP上面实现目录压缩

js|压缩 zip方法 zipPath参数为保存zip的文件路径  srcPath参数为需要压缩的目录   在linux window上面测试无问题!主要是编码问题比较麻烦~要是有其他异常 请留言 或者 有什么更好的方法 欢迎给更多的意见 //zip zhe foldervoid zip(String zipPath, String srcPath,javax.servlet.jsp.JspWriter out) throws Exception {    FileOutputStream ou

用ASP.Net实现文件的在线压缩和解压缩

asp.net|压缩|在线 我们经常会遇到批量上传的问题,也会遇到将某个目录下所有文件都上传到服务器上的问题.那么,如何解决此类问题呢?以前的技术一般采用ActiveX等方式,这里笔者采用SharpZlib来实现,听说VS2005已有压缩和解压缩的解决方案,笔者还没有时间用VS2005,所以就只好使用VS2003 + SharpZlib来解决问题了. 1.首先从这里下载0.84版本的SharpZlib源码及示例码. 2.下载下来之后你发现它没有VS2003的解决方案文件,没有关系.你可以自己建立