windows下文件名正常,但linux下用ZipOutputStream压缩后中文文件名乱码
2010-08-22 11:50
309 查看
在windows下文件名正常,但部署linux下文件名却出现乱码
搞了一个晚上,知道是编码的问题,网上查到的大致有两种解决方面(好像都不行):
1、修改java.util.zip下对应的类。这个方法改了太麻烦了,而且ant包中的已经有现成的了,而且也没有用(可能是我没改好吧)
2、用ant提供的来代替,把import 里的java.util.zip改成org.apache.tools.zip。这种方法在window下支持中文了,但在linux下还是会乱码。
今天再回头看,只要在第二种方法的情况下为ZipOutputStream对象加一句setEncoding("gbk")就可以了。把自己的理解记下来以便大家遇到相似的问题可以查看,说的有有问题还请指出来哦
解决办法:
原因:org.apache.tools.zip.ZipOutputStream使用的默认编码是系统编码(window是gbk而linux是utf-8),在window下解压时用的是gbk,因些如果是在linux下压缩的文件,到window下解压就会出现乱码,因些在压缩时就为其指定编码为gbk
代码如下:
import org.apache.tools.zip.ZipEntry;
import org.apache.tools.zip.ZipOutputStream;
/**
* 多个指定文件压缩Zip文件/目录的方法。
*
* @param inputFileNames
* 需要添加到压缩文件的文件名/目录
* @param outputFileName
* 压缩文件的文件名
*/
public static boolean zipFiles(List inputFileNames, String outputFileName) {
boolean result = true;
try {
ZipOutputStream out = null;
try {
File parent = new File(new File(outputFileName).getParent()); // 得到父文件夹
if (!parent.exists()) {
parent.mkdirs();
}
out = new ZipOutputStream(new FileOutputStream(outputFileName));
out.setEncoding("gbk");//指定编码为gbk,否则部署到linux下会出现乱码
File inputFile = null;
for (Object obj:inputFileNames) {
Object[] input = (Object[])obj;
if(input.length != 2)
continue;
inputFile = new File((String) input[0]);
String fileN = (String)input[1];
zip(out, inputFile, fileN);
}
System.out.println("zip done ");
} catch (Exception e) {
result = false;
} finally {
if (out != null)
out.close();
}
} catch (Exception e) {
result = false;
e.printStackTrace();
}
return result;
}
private static boolean zip(ZipOutputStream out, File file, String base) {
boolean result = true;
try {
if (file.isDirectory()) {
File[] subfiles = file.listFiles();
if (base.length() != 0) {
out.putNextEntry(new ZipEntry(base + File.separator));
base += File.separator;
}
for (int i = 0; i < subfiles.length; i++) {
zip(out, subfiles[i], base + subfiles[i].getName());
}
} else {
String filename = base;//java.net.URLEncoder.encode(base,"UTF-8");
out.putNextEntry(new ZipEntry(filename));
FileInputStream in = new FileInputStream(file);
int b;
System.out.println(filename);
try {
while ((b = in.read()) != -1) {
out.write(b);
}
} catch (Exception e) {
result = false;
} finally {
in.close();
}
}
} catch (Exception e) {
result = false;
}
return result;
}
搞了一个晚上,知道是编码的问题,网上查到的大致有两种解决方面(好像都不行):
1、修改java.util.zip下对应的类。这个方法改了太麻烦了,而且ant包中的已经有现成的了,而且也没有用(可能是我没改好吧)
2、用ant提供的来代替,把import 里的java.util.zip改成org.apache.tools.zip。这种方法在window下支持中文了,但在linux下还是会乱码。
今天再回头看,只要在第二种方法的情况下为ZipOutputStream对象加一句setEncoding("gbk")就可以了。把自己的理解记下来以便大家遇到相似的问题可以查看,说的有有问题还请指出来哦
解决办法:
原因:org.apache.tools.zip.ZipOutputStream使用的默认编码是系统编码(window是gbk而linux是utf-8),在window下解压时用的是gbk,因些如果是在linux下压缩的文件,到window下解压就会出现乱码,因些在压缩时就为其指定编码为gbk
代码如下:
import org.apache.tools.zip.ZipEntry;
import org.apache.tools.zip.ZipOutputStream;
/**
* 多个指定文件压缩Zip文件/目录的方法。
*
* @param inputFileNames
* 需要添加到压缩文件的文件名/目录
* @param outputFileName
* 压缩文件的文件名
*/
public static boolean zipFiles(List inputFileNames, String outputFileName) {
boolean result = true;
try {
ZipOutputStream out = null;
try {
File parent = new File(new File(outputFileName).getParent()); // 得到父文件夹
if (!parent.exists()) {
parent.mkdirs();
}
out = new ZipOutputStream(new FileOutputStream(outputFileName));
out.setEncoding("gbk");//指定编码为gbk,否则部署到linux下会出现乱码
File inputFile = null;
for (Object obj:inputFileNames) {
Object[] input = (Object[])obj;
if(input.length != 2)
continue;
inputFile = new File((String) input[0]);
String fileN = (String)input[1];
zip(out, inputFile, fileN);
}
System.out.println("zip done ");
} catch (Exception e) {
result = false;
} finally {
if (out != null)
out.close();
}
} catch (Exception e) {
result = false;
e.printStackTrace();
}
return result;
}
private static boolean zip(ZipOutputStream out, File file, String base) {
boolean result = true;
try {
if (file.isDirectory()) {
File[] subfiles = file.listFiles();
if (base.length() != 0) {
out.putNextEntry(new ZipEntry(base + File.separator));
base += File.separator;
}
for (int i = 0; i < subfiles.length; i++) {
zip(out, subfiles[i], base + subfiles[i].getName());
}
} else {
String filename = base;//java.net.URLEncoder.encode(base,"UTF-8");
out.putNextEntry(new ZipEntry(filename));
FileInputStream in = new FileInputStream(file);
int b;
System.out.println(filename);
try {
while ((b = in.read()) != -1) {
out.write(b);
}
} catch (Exception e) {
result = false;
} finally {
in.close();
}
}
} catch (Exception e) {
result = false;
}
return result;
}
相关文章推荐
- windows下文件名正常,但linux下用ZipOutputStream压缩后中文文件名乱码
- Java压缩解压zip文件的中文文件名在Windows和Linux环境下乱码问题的解决方案
- 解决Linux与Windows压缩解压中文文件名乱码(转载)
- windows下eclipse java开发能正常运行,移植到linux下,从Mysql中读取数据,出现中文乱码
- windows下压缩的文件在linux下解压后中文乱码问题
- linux下tar打包到windows下解压缩后中文文件名乱码
- Linux->Windows主机目录和文件名中文乱码恢复
- linux下将中文文件名文件cp到windows目录下后文件名乱码问题的解决
- Linux下unzip解压windows压缩的zip件,中文名乱码问题
- URL传递中文参数,Windows正常在后台获取参数,但Linux获取的参数是乱码 的解决方法。
- Linux下压缩Windows下解压文件名乱码问题
- linux下解压windows压缩的zip文件,文件名乱码
- linux下tar打包到windows下解压缩后中文文件名乱码
- Linux下如何解压rar、zip格式文件?Linux VPS安装7zip/使用方法/压缩解压中文文件名乱码解决方案
- java调用pdfbox转pdf文件为图片文件,有中文时在windows上正常,部署到linux下乱码
- linux下tar打包到windows下解压缩后中文文件名乱码 用zip 或者 rar
- 解决windows传送到linux下中文文件名及文件内容乱码问题
- jfreechart图,windows下中文显示正常,linux下乱码
- windows下的中文文件名共享在linux下显示乱码的问题
- linux下将中文文件名文件cp到windows目录下后文件名乱码问题的解决