java字符串压缩解压示例

 更新时间:2014年03月22日 14:29:11   作者:  
这篇文章主要介绍了java字符串压缩解压示例,先压缩,再加密,再压缩,数据越大,压缩比例越高,需要的朋友可以参考下


我测试的字符串是JQuery源码。

明文长度:78082
压缩后:26566
加密长度:54746
再压缩:41647
-----------------------------
密文长度:41647
解压缩:54746
解密后:26566
再解压:78082
-----------------------------
比对成功

Des需要Jar:sun.misc.BASE64Decoder.jar

Test

复制代码 代码如下:

public static void main(String[] args) throws Exception {
  String cont = "";
  String cont2=jm(yjy(cont));
  if(cont.equals(cont2)){
   System.out.println("比对成功");
  }else{
   System.out.println("比对失败");
  }
 }

 public static String yjy(String cont) throws Exception {
  System.out.println("明文长度:" + cont.length());
  // 第一次压缩
  cont = ZipUtil2.compress(cont);
  System.out.println("压缩后:" + cont.length());
  // 第一次加密
  cont = DesUtil.encrypt(cont, DesUtil.PWD_KEY);
  System.out.println("加密长度:" + cont.length());
  // 第二次压缩
  cont = ZipUtil2.compress(cont);
  System.out.println("再压缩:" + cont.length());
  return cont;
 }

 public static String jm(String cont) throws Exception {
  System.out.println("-----------------------------");
  System.out.println("密文长度:" + cont.length());

  // 第一次解压缩
  cont = ZipUtil2.uncompress(cont);
  System.out.println("解压缩:" + cont.length());

  // 第一次解密
  cont = DesUtil.decrypt(cont, DesUtil.PWD_KEY);
  System.out.println("解密后:" + cont.length());

  // 第二次解压缩
  cont = ZipUtil2.uncompress(cont);
  System.out.println("再解压:" + cont.length());

  return cont;
 }

DesUtil

复制代码 代码如下:

import java.io.IOException;
import java.security.SecureRandom;

import javax.crypto.Cipher;
import javax.crypto.SecretKey;
import javax.crypto.SecretKeyFactory;
import javax.crypto.spec.DESKeySpec;

import Decoder.BASE64Decoder;
import Decoder.BASE64Encoder;

public class DesUtil {

 private final static String DES = "DES";
 public final static String PWD_KEY = "MZTHPWDJM";
 public final static String ID_KEY = "MZTHIDJM";

 public static void main(String[] args) throws Exception {
  String data = "xkajsdasdk'al;ks'dl;kasl;d";
  System.err.println("加密:"+encrypt(data, PWD_KEY));
  System.err.println("解密:" +decrypt(encrypt(data, PWD_KEY), PWD_KEY));
 }

 /**
  * Description 根据键值进行加密
  *
  * @param data
  * @param key
  *            加密键byte数组
  * @return
  * @throws Exception
  */
 public static String encrypt(String data, String key) throws Exception {
  byte[] bt = encrypt(data.getBytes(), key.getBytes());
  String strs = new BASE64Encoder().encode(bt);
  return strs;
 }

 /**
  * Description 根据键值进行解密
  *
  * @param data
  * @param key
  *            加密键byte数组
  * @return
  * @throws IOException
  * @throws Exception
  */
 public static String decrypt(String data, String key) throws IOException,
   Exception {
  if (data == null)
   return null;
  BASE64Decoder decoder = new BASE64Decoder();
  byte[] buf = decoder.decodeBuffer(data);
  byte[] bt = decrypt(buf, key.getBytes());
  return new String(bt);
 }

 /**
  * Description 根据键值进行加密
  *
  * @param data
  * @param key
  *            加密键byte数组
  * @return
  * @throws Exception
  */
 private static byte[] encrypt(byte[] data, byte[] key) throws Exception {
  // 生成一个可信任的随机数源
  SecureRandom sr = new SecureRandom();

  // 从原始密钥数据创建DESKeySpec对象
  DESKeySpec dks = new DESKeySpec(key);

  // 创建一个密钥工厂,然后用它把DESKeySpec转换成SecretKey对象
  SecretKeyFactory keyFactory = SecretKeyFactory.getInstance(DES);
  SecretKey securekey = keyFactory.generateSecret(dks);

  // Cipher对象实际完成加密操作
  Cipher cipher = Cipher.getInstance(DES);

  // 用密钥初始化Cipher对象
  cipher.init(Cipher.ENCRYPT_MODE, securekey, sr);

  return cipher.doFinal(data);
 }

 /**
  * Description 根据键值进行解密
  *
  * @param data
  * @param key
  *            加密键byte数组
  * @return
  * @throws Exception
  */
 private static byte[] decrypt(byte[] data, byte[] key) throws Exception {
  // 生成一个可信任的随机数源
  SecureRandom sr = new SecureRandom();

  // 从原始密钥数据创建DESKeySpec对象
  DESKeySpec dks = new DESKeySpec(key);

  // 创建一个密钥工厂,然后用它把DESKeySpec转换成SecretKey对象
  SecretKeyFactory keyFactory = SecretKeyFactory.getInstance(DES);
  SecretKey securekey = keyFactory.generateSecret(dks);

  // Cipher对象实际完成解密操作
  Cipher cipher = Cipher.getInstance(DES);

  // 用密钥初始化Cipher对象
  cipher.init(Cipher.DECRYPT_MODE, securekey, sr);

  return cipher.doFinal(data);
 }
}

ZipUtil2
.

复制代码 代码如下:

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 ZipUtil2 {

 // 测试方法
 public static void main(String[] args) throws IOException {

  // 测试字符串
  String str = "";
  System.out.println("原长度:" + str.length());
  System.out.println("压缩后:" + ZipUtil2.compress(str).length());
  System.out
    .println("解压缩:" + ZipUtil2.uncompress(ZipUtil2.compress(str)));
 }

 // 压缩
 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()使用平台默认编码,也可以显式的指定如toString("GBK")
  return out.toString();
 }

}

相关文章

  • Java实现图片切割功能

    Java实现图片切割功能

    这篇文章主要为大家详细介绍了Java实现图片切割功能,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-01-01
  • JAVA接入DeepSeek满血版的详细指南(问答接入、流式接入双模式)

    JAVA接入DeepSeek满血版的详细指南(问答接入、流式接入双模式)

    硅基流动推出了功能完备的DeepSeek满血版,然而众多用户在尝试接入大型模型时仍面临诸多挑战,特别是在流式接入方面,今天,我将引领大家通过Java实现双模式接入DeepSeek满血版,需要的朋友可以参考下
    2025-03-03
  • Java中Lambda表达式的使用详解

    Java中Lambda表达式的使用详解

    Lambda 表达式,也可称为闭包,它是推动 Java 8 发布的最重要新特性。Lambda 允许把函数作为一个方法的参数(函数作为参数传递进方法中)。使用 Lambda 表达式可以使代码变的更加简洁紧凑
    2021-09-09
  • Java Volatile关键字实现原理过程解析

    Java Volatile关键字实现原理过程解析

    这篇文章主要介绍了Java Volatile关键字实现原理过程解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-03-03
  • Springboot实现VNC的反向代理功能

    Springboot实现VNC的反向代理功能

    这篇文章主要介绍了Springboot实现VNC的反向代理,搭建过程也很简单,通过注册bean拦截指定URL路径进行自定义操作,具体实例代码跟随小编一起看看需要的朋友可以参考下
    2021-09-09
  • MyBatis使用annonation定义类型映射的简易用法示例

    MyBatis使用annonation定义类型映射的简易用法示例

    这篇文章主要介绍了MyBatis使用annonation定义类型映射的简易用法示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-09-09
  • Java中MapStruct使用方法解析

    Java中MapStruct使用方法解析

    这篇文章主要介绍了Java中MapStruct使用方法解析,接受请求参数都会使用一个vo类,这个vo类里封装了所有需要接受的参数,然后对参数进行业务逻辑处理,处理完后会持久化处理, 使用MapStruct可以快速帮你解决转换工作,需要的朋友可以参考下
    2023-10-10
  • mapstruct的用法之qualifiedByName示例详解

    mapstruct的用法之qualifiedByName示例详解

    qualifiedByName的意思就是使用这个Mapper接口中的指定的默认方法去处理这个属性的转换,而不是简单的get set,今天通过本文给大家介绍下mapstruct的用法之qualifiedByName示例详解,感兴趣的朋友一起看看吧
    2022-04-04
  • SpringCloud配置服务端的ConfigServer设置安全认证

    SpringCloud配置服务端的ConfigServer设置安全认证

    这篇文章主要为大家介绍了SpringCloud配置服务端的ConfigServer设置安全认证,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-08-08
  • 在Java的Hibernate框架中使用SQL语句的简单介绍

    在Java的Hibernate框架中使用SQL语句的简单介绍

    这篇文章主要介绍了在Java的Hibernate框架中使用SQL语句的方法,Hibernate是Java的SSH三大web开发框架之一,需要的朋友可以参考下
    2016-01-01

最新评论