• ICSharpCode.SharpZipLib 中文乱码问题


    今天在调用ICSharpCode.SharpZipLib解压zip文件时出现了中文文件乱码的问题。
    解决过程如下:
    1.判断是否压缩包本身问题。经查zip文件夹在本地直接解压打开时正确的中文名称,所以不是压缩包本身的问题。
    2.判断是否是web页面的编码问题,经查web页面的编码为UTF-8,也不是页面问题。
    3.问题的焦点集中到第三方库,ICSharpCode.SharpZipLib.dll
    4.通过在网上搜索,出现了多种解决方案:
        a.修改源码中类ZipConstants.cs的ConvertToString方法
          public static string ConvertToString(byte[] data)
    {
           return Encoding.GetEncoding("gb2312").GetString(data, 0, data.Length);
           //return Encoding.ASCII.GetString(data,0, data.Length);
    }
      
    public static byte[] ConvertToArray(string str)
    {
           return Encoding.GetEncoding("gb2312").GetBytes(str);
           //return Encoding.ASCII.GetBytes(str);
    }
    这种方法我感觉不够直观破坏性大。
    b.修改源码ZipEntryFactory.cs文件中MakeFileEntry函数。
    将result.IsUnicodeText =isUnicodeText_改为 result.IsUnicodeText =true
    我尝试了这种方法,但是没有解决我的问题。
    c.使用DefaultCodePage 方法从外部修改。
    在调用ICSharpCode.SharpZipLib的ZipInputStream之前:
    1. // 出现乱码就是因为CodePage不对  
    2.   
    3. Encoding gbk = Encoding.GetEncoding("gbk");  
    4.   
    5. ICSharpCode.SharpZipLib.Zip.ZipConstants.DefaultCodePage = gbk.CodePage; 
       这种方法,有很多优点:
       1.无需修改第三方控件源码。
       2.方便快捷
       3.灵活性更强
  • 相关阅读:
    SQL 左外连接,右外连接,全连接,内连接
    CentOS 7.0默认使用的是firewall作为防火墙
    Python-WEB自动化-三种等待方式
    Python + Selenium的web自动化框架
    BS架构和CS架构的区别
    ERROR 1062 (23000): Duplicate entry '%-root' for key 'PRIMARY'
    CentOS 7镜像下载
    CentOS7各个版本镜像下载地址
    CentOS7的Minimal版本安装
    Python 文字转语音
  • 原文地址:https://www.cnblogs.com/wenpeng/p/9397026.html
Copyright © 2020-2023  润新知