<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    Java快速開發(fā)平臺

    www.fastunit.com

      BlogJava :: 首頁 :: 聯(lián)系 :: 聚合  :: 管理
      23 Posts :: 0 Stories :: 273 Comments :: 0 Trackbacks
    數(shù)據(jù)傳輸時,有時需要將數(shù)據(jù)壓縮和解壓縮,本例使用GZIPOutputStream/GZIPInputStream實現(xiàn)。

    1、使用ISO-8859-1作為中介編碼,可以保證準(zhǔn)確還原數(shù)據(jù)
    2、字符編碼確定時,可以在uncompress方法最后一句中顯式指定編碼
    import java.io.ByteArrayInputStream;
    import java.io.ByteArrayOutputStream;
    import java.io.IOException;
    import java.util.zip.GZIPInputStream;
    import java.util.zip.GZIPOutputStream;

    // 將一個字符串按照zip方式壓縮和解壓縮
    public class ZipUtil {

      
    // 壓縮
      public static String compress(String str) throws IOException {
        
    if (str == null || str.length() == 0) {
          
    return str;
        }
        ByteArrayOutputStream out 
    = new ByteArrayOutputStream();
        GZIPOutputStream gzip 
    = new GZIPOutputStream(out);
        gzip.write(str.getBytes());
        gzip.close();
        
    return out.toString("ISO-8859-1");
      }

      
    // 解壓縮
      public static String uncompress(String str) throws IOException {
        
    if (str == null || str.length() == 0) {
          
    return str;
        }
        ByteArrayOutputStream out 
    = new ByteArrayOutputStream();
        ByteArrayInputStream in 
    = new ByteArrayInputStream(str
            .getBytes(
    "ISO-8859-1"));
        GZIPInputStream gunzip 
    = new GZIPInputStream(in);
        
    byte[] buffer = new byte[256];
        
    int n;
        
    while ((n = gunzip.read(buffer)) >= 0) {
          out.write(buffer, 
    0, n);
        }
        
    // toString()使用平臺默認(rèn)編碼,也可以顯式的指定如toString("GBK")
        return out.toString();
      }

      
    // 測試方法
      public static void main(String[] args) throws IOException {
        System.out.println(ZipUtil.uncompress(ZipUtil.compress(
    "中國China")));
      }

    }
    posted on 2008-04-25 12:37 FastUnit 閱讀(23070) 評論(8)  編輯  收藏 所屬分類: Java

    Feedback

    # re: 字符串的壓縮和解壓縮[未登錄] 2008-04-25 22:01 Matthew Chen
    toString()不是采用平臺默認(rèn)編碼,而是就是unicode,而且("中國China")也是unicode,java內(nèi)部字符串編碼只是這種類型,對外實現(xiàn)讀取和寫入文本才是使用平臺默認(rèn)編碼的。  回復(fù)  更多評論
      

    # re: 字符串的壓縮和解壓縮 2008-04-25 23:51 FastUnit
    @Matthew Chen
    看一下ByteArrayOutputStream.toString()的源碼,最終使用的編碼是Converters.getDefaultEncodingName(),不同環(huán)境下編碼可能不同,我的是GBK。  回復(fù)  更多評論
      

    # re: 字符串的壓縮和解壓縮 2008-04-29 16:22 曉秋
    我的輸出結(jié)果是這樣的.
    ??China
    我的編輯器的系統(tǒng)編碼是:utf-8

    若指定編碼時報錯.GZIP is not fomat.  回復(fù)  更多評論
      

    # re: 字符串的壓縮和解壓縮 2008-05-06 14:07 FastUnit
    @曉秋
    不要修改過渡編碼“ISO-8859-1”;
    傳入字符的編碼是什么,解壓的時候就指定這個編碼,在uncompress方法的最后一句中指定,如“return out.toString("UTF-8");”  回復(fù)  更多評論
      

    # re: 字符串的壓縮和解壓縮[未登錄] 2009-09-04 13:58 菜鳥
    我想問問,為什么壓縮后的字符串怎么更長了?
    System.out.println("中國China".length());
    System.out.println(ZipUtil.compress("中國China").length());
    未壓縮前衛(wèi)7,壓縮后為29,怎么回事?  回復(fù)  更多評論
      

    # re: 字符串的壓縮和解壓縮[未登錄] 2009-10-20 18:06 菜菜鳥
    @菜鳥
    字符串超過一定長度時,壓縮才有效!  回復(fù)  更多評論
      

    # re: 字符串的壓縮和解壓縮[未登錄] 2012-04-20 14:17 yy
    gzip.write(str.getBytes());

    return out.toString();

    此兩處建議默認(rèn)加上相應(yīng)的字符集編碼,以在不同平臺的不同默認(rèn)字符集下的壓縮和解壓縮結(jié)果完全相同和正確。  回復(fù)  更多評論
      

    # re: 字符串的壓縮和解壓縮 2016-01-30 19:49 www我
    lz,InputStream為什么輸出卻是GZIPInputStream型,這也導(dǎo)致數(shù)據(jù)流錯誤,有辦法解決嗎?  回復(fù)  更多評論
      

    主站蜘蛛池模板: 国产99精品一区二区三区免费| 国产成人在线免费观看| 亚洲国产a∨无码中文777| 黄桃AV无码免费一区二区三区 | 久久亚洲精品高潮综合色a片| 免费99精品国产自在现线| 免费特级黄毛片在线成人观看 | 久久av无码专区亚洲av桃花岛| 久久九九全国免费| 亚洲日本精品一区二区| 亚洲精品在线视频观看| 美女羞羞免费视频网站| 日本高清高色视频免费| 国产精品另类激情久久久免费| 久久综合亚洲色hezyo| 亚洲AV无码专区日韩| 四虎影视久久久免费| 精品亚洲综合久久中文字幕| 日韩在线不卡免费视频一区| 亚洲一区二区三区亚瑟| 99精品全国免费观看视频..| 香蕉视频在线观看免费国产婷婷| 久久久久亚洲精品无码网址色欲 | 久久影院亚洲一区| 久草免费福利视频| 亚洲综合久久一本伊伊区| 日产乱码一卡二卡三免费| 亚洲天堂久久精品| 日韩精品成人无码专区免费| 午夜在线亚洲男人午在线| 国产日产亚洲系列| 日本片免费观看一区二区| 国产成人无码综合亚洲日韩| 亚洲网站免费观看| 美女黄频免费网站| 亚洲成色在线影院| 国内精品一级毛片免费看| 亚洲av无码电影网| 亚洲一区无码中文字幕| 免费大片av手机看片高清| 亚洲免费在线播放|