免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1857 | 回复: 0
打印 上一主题 下一主题

unzip解压缩含中文文件名zip包时出现乱码的解决办法 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2007-03-06 13:46 |只看该作者 |倒序浏览

                                                症状:
使用unzip解压缩在ms windows平台上用winzip压缩的zip文件,如果其中含有中文文件名,结果会出现乱码,而且用convmv转换文件名编码方式也无法解决问题。
分析:
参考这篇文章
让Unzip正确解压其中包含中文文件名的Winzip压缩包
,原因是unzip试图将zip文件中用 oem(ibm-dos) codepage 编码的文件名转换成自己的内部编码。可惜unzip只能转换极少数几种codepage,中文的 cp936 不在其列。
解决办法:
参考文章的作者廖中熙将 unzpriv.h 中 Ext_ASCII_TO_Native 宏中的判断去掉,不管是否为oem codepage,全部用        _ISO_INTERN((string))来转换到内部编码。
我观察到unzip源代码这段开始的地方有判断 #ifndef Ext_ASCII_TO_Native ,这样问题似乎更简单了,不用改源代码,只需在make时定义 Ext_ASCII_TO_Native 即可,这样 Ext_ASCII_TO_Native 实际为一个空的宏,不进行任何转换操作。比如,使用下面的方法编译
$make -DExt_ASCII_TO_Native
或者在bash执行下面两行
$export LOCAL_UNZIP=-DExt_ASCII_TO_Native
$make
结果:
unzip解压缩含中文文件名zip包是出现乱码的问题解决!
               
               
               
               
               
               

本文来自ChinaUnix博客,如果查看原文请点:http://blog.chinaunix.net/u/22153/showart_254038.html
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP