1.引言

最近在做项目中,平台提供一个http服务给其他系统调用,然后我接收到其他系统的json格式的报文后去解析,然后用拿到的数据去调用corba服务,我再把corba的返回值封装完成json字符串返回给外部系统。遇到一个接口去调用corba服务,然后corba返回的数据经过封装后字符串的长度达到7M左右,导致http客户端无法正常的接收完所有的数据。你可能会说这个接口设计的不合理,为什么不增加查询条件把查询条件范围缩小一点?但是,这个不是本节要讨论的内容,主要是因为corba服务已经发布用了很久且不在此次项目改造范围之内,再者这个corba服务已经上线用了N久,轻易的改变可能会导致未知的错误。签于此,我想到可以把json格式的字符串给压缩,然后客户端再解压。(一是字符串的压缩比例比较的高,二是字符串的压缩和解压实现起来也比较简单)。虽然,最后没有用到字符串的压缩和解压的方式,而是修改客户端(1.http客户端进一步精确查询条件 2.读取返回数据流采用循环读取的方式)来解决此问题,我还是把字符串的压缩和解压做一下简单的记录。

2.关于压缩与解压

压缩算法有多种,我说知道和接触有java I/O自带的zip和gzip两种方式。

本节主要来简单介绍一下在系统交互之间遇到大容量的字符串数据交互时,采用一端压缩,另一端再解压的方式来发送和接收数据。

关于此次的压缩和解压用到的主要就是GZIPOutputStream和GZIPInputStream类,此类的相关介绍在JDK中有详细的介绍,这里就不再累述了

3.代码如下:

  1. import java.io.ByteArrayInputStream;
  2. import java.io.ByteArrayOutputStream;
  3. import java.io.IOException;
  4. import java.util.zip.GZIPInputStream;
  5. import java.util.zip.GZIPOutputStream;
  6. /**
  7. *
  8. *Module:          ZipUtil.java
  9. *Description:    对字符串的压缩及解压
  10. *Company:
  11. *Author:           pantp
  12. *Date:             May 6, 2012
  13. */
  14. public class ZipStrUtil {
  15. public static void main(String[] args) throws IOException {
  16. // 字符串超过一定的长度
  17. String str = "ABCdef123中文~!@#$%^&*()_+{};/1111111111111111111111111AAAAAAAAAAAJDLFJDLFJDLFJLDFFFFJEIIIIIIIIIIFJJJJJJJJJJJJALLLLLLLLLLLLLLLLLLLLLL" +
  18. "LLppppppppppppppppppppppppppppppppppppppppp===========================------------------------------iiiiiiiiiiiiiiiiiiiiiii";
  19. System.out.println("\n原始的字符串为------->" + str);
  20. float len0=str.length();
  21. System.out.println("原始的字符串长度为------->"+len0);
  22. String ys = compress(str);
  23. System.out.println("\n压缩后的字符串为----->" + ys);
  24. float len1=ys.length();
  25. System.out.println("压缩后的字符串长度为----->" + len1);
  26. String jy = unCompress(ys);
  27. System.out.println("\n解压缩后的字符串为--->" + jy);
  28. System.out.println("解压缩后的字符串长度为--->"+jy.length());
  29. System.out.println("\n压缩比例为"+len1/len0);
  30. //判断
  31. if(str.equals(jy)){
  32. System.out.println("先压缩再解压以后字符串和原来的是一模一样的");
  33. }
  34. }
  35. /**
  36. * 字符串的压缩
  37. *
  38. * @param str
  39. *            待压缩的字符串
  40. * @return    返回压缩后的字符串
  41. * @throws IOException
  42. */
  43. public static String compress(String str) throws IOException {
  44. if (null == str || str.length() <= 0) {
  45. return str;
  46. }
  47. // 创建一个新的 byte 数组输出流
  48. ByteArrayOutputStream out = new ByteArrayOutputStream();
  49. // 使用默认缓冲区大小创建新的输出流
  50. GZIPOutputStream gzip = new GZIPOutputStream(out);
  51. // 将 b.length 个字节写入此输出流
  52. gzip.write(str.getBytes());
  53. gzip.close();
  54. // 使用指定的 charsetName,通过解码字节将缓冲区内容转换为字符串
  55. return out.toString("ISO-8859-1");
  56. }
  57. /**
  58. * 字符串的解压
  59. *
  60. * @param str
  61. *            对字符串解压
  62. * @return    返回解压缩后的字符串
  63. * @throws IOException
  64. */
  65. public static String unCompress(String str) throws IOException {
  66. if (null == str || str.length() <= 0) {
  67. return str;
  68. }
  69. // 创建一个新的 byte 数组输出流
  70. ByteArrayOutputStream out = new ByteArrayOutputStream();
  71. // 创建一个 ByteArrayInputStream,使用 buf 作为其缓冲区数组
  72. ByteArrayInputStream in = new ByteArrayInputStream(str
  73. .getBytes("ISO-8859-1"));
  74. // 使用默认缓冲区大小创建新的输入流
  75. GZIPInputStream gzip = new GZIPInputStream(in);
  76. byte[] buffer = new byte[256];
  77. int n = 0;
  78. while ((n = gzip.read(buffer)) >= 0) {// 将未压缩数据读入字节数组
  79. // 将指定 byte 数组中从偏移量 off 开始的 len 个字节写入此 byte数组输出流
  80. out.write(buffer, 0, n);
  81. }
  82. // 使用指定的 charsetName,通过解码字节将缓冲区内容转换为字符串
  83. return out.toString("GBK");
  84. }
  85. /**
    * 根据byte数组,生成文件
    *
    * @param bfile
    * byte数组
    * @param filePath
    * 存储路径
    * @param fileName
    * 文件名称
    * @return true:保存成功 false:保存失败
    */
    public static boolean getFile(byte[] bfile, String filePath, String fileName) {
    BufferedOutputStream bos = null;
    FileOutputStream fos = null;
    File file = null;
    boolean result = true;
    try {
    File dir = new File(filePath);
    if (!dir.exists() && dir.isDirectory()) {// 判断文件目录是否存在
    dir.mkdirs();
    }
    file = new File(filePath + "\\" + fileName);
    fos = new FileOutputStream(file);
    bos = new BufferedOutputStream(fos);
    bos.write(bfile);
    } catch (Exception e) {
    result = false;
    e.printStackTrace();
    } finally {
    if (bos != null) {
    try {
    bos.close();
    } catch (IOException e1) {
    e1.printStackTrace();
    }
    }
    if (fos != null) {
    try {
    fos.close();
    } catch (IOException e1) {
    e1.printStackTrace();
    }
    }
    }

    return result;
    }

  86. }

Java 压缩字符串的更多相关文章

  1. Java压缩字符串工具类

    StringCompressUtils.java package javax.utils; import java.io.ByteArrayInputStream; import java.io.By ...

  2. Java压缩字符串的方法收集

    说明: 1.一般来说要实现压缩,那么返回方式一般是用byte[]数组. 2.研究发现byte[]数组在转成可读的String时,大小会还原回原来的. 3.如果采用压缩之后不可读的String时,互相转 ...

  3. Java实现 LeetCode 443 压缩字符串

    443. 压缩字符串 给定一组字符,使用原地算法将其压缩. 压缩后的长度必须始终小于或等于原数组长度. 数组的每个元素应该是长度为1 的字符(不是 int 整数类型). 在完成原地修改输入数组后,返回 ...

  4. Java常量字符串String理解

    Java常量字符串String理解 以前关于String的理解仅限于三点:1.String 是final类,不可继承2.String 类比较字符串相等时时不能用“ == ”,只能用  "eq ...

  5. Java String字符串/==和equals区别,str。toCharAt(),getBytes,indexOf过滤存在字符,trim()/String与StringBuffer多线程安全/StringBuilder单线程—— 14.0

    课程概要 String 字符串 String字符串常用方法 StringBuffer StringBuilder String字符串: 1.实例化String对象 直接赋值  String str=& ...

  6. java截取字符串中的数字

    java从字符串中提取数字 随便给你一个含有数字的字符串,比如: String s="eert343dfg56756dtry66fggg89dfgf"; 那我们如何把其中的数字提取 ...

  7. 三张图彻底了解Java中字符串的不变性

    转载: 三张图彻底了解Java中字符串的不变性 定义一个字符串 String s = "abcd"; s中保存了string对象的引用.下面的箭头可以理解为"存储他的引用 ...

  8. java中字符串的非空判断

    问题如下:在java 中 字符串为null 如何判断String str;if(str==null) ??str.equal("null") ?? 答:我觉得应该搞清楚字符串对象和 ...

  9. java中字符串String 转 int(转)

    java中字符串String 转 int String -> int s="12345"; int i; 第一种方法:i=Integer.parseInt(s); 第二种方法 ...

随机推荐

  1. Encrypting bootloader (程序BIN文件加密及在线升级)

    了解更多关于bootloader 的C语言实现,请加我QQ: 1273623966 (验证信息请填 bootloader),欢迎咨询或定制bootloader(在线升级程序). 在上一个博客随笔,我介 ...

  2. EM算法(4):EM算法证明

    目录 EM算法(1):K-means 算法 EM算法(2):GMM训练算法 EM算法(3):EM算法运用 EM算法(4):EM算法证明 EM算法(4):EM算法证明 1. 概述 上一篇博客我们已经讲过 ...

  3. mysql命令行导入sql脚本中文变问号问题

    之前一直用工具连接mysql虽然小问题不断也都无伤大雅,最近做金融云项目,只能通过服务器的内网访问数据库,也就是说只能在linux下通过命令行访问,在导入中文的时候发现都变成问号了,经过查询资料解决, ...

  4. Nginx内置变量以及日志格式变量参数详解

    $args #请求中的参数值 $query_string #同 $args $arg_NAME #GET请求中NAME的值 $is_args #如果请求中有参数,值为"?",否则为 ...

  5. Java Annotation 注解

    java_notation.html div.oembedall-githubrepos { border: 1px solid #DDD; list-style-type: none; margin ...

  6. web初学之重定向与请求转发

    重定向与请求转发的问题 (1)RequestDispatcher是通过调用HttpServletRequest对象的getRequestDispatcher()方法得到的,是属于请求对象的方法. (2 ...

  7. js 下载图片与下载文件的方式一样;保存至本地 ASP.NET 方式

    <asp:Button ID="btnDownLoad" runat="server" style="display: none" T ...

  8. 忘记密码流程——UUID,AES

    忘记密码流程 1.进入忘记密码页面 2. 后台检验参数合法性(null,验证码,邮箱合法性) 3,生成更新密码链接,并将相关参数写入DB link=urlBase(baseurl)+updatePas ...

  9. cf730e

    一道数学题,这篇博客很好:http://blog.csdn.net/morejarphone/article/details/52926627(这样应该不算转载吧) 总结:做这类题目显然应该直接根据相 ...

  10. oracle 模糊查询中的转义字符用法

    drop view aaa; create view aaa as select '_BCDE' A FROM DUAL UNION ALL SELECT 'ABCDE' FROM DUAL UNIO ...