国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > Java > 正文

java字符串壓縮解壓示例

2019-11-26 15:35:27
字體:
來源:轉載
供稿:網友


我測試的字符串是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();
 }

}

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 杂多县| 屯昌县| 黄山市| 盐源县| 宁都县| 广西| 龙里县| 昌乐县| 潮州市| 永德县| 城口县| 新巴尔虎左旗| 天等县| 刚察县| 芦溪县| 苏州市| 宁远县| 承德县| 衡南县| 临泽县| 固安县| 正镶白旗| 清丰县| 宁乡县| 揭东县| 石泉县| 百色市| 金乡县| 嘉鱼县| 吉首市| 顺平县| 台南市| 赤壁市| 平乐县| 安顺市| 庄浪县| 厦门市| 浮山县| 咸阳市| 湖北省| 苏尼特右旗|