- 浏览: 21792 次
- 性别:
- 来自: 长沙
文章分类
最新评论
-
terry21:
找了半天发现加密时byte[] byteContent = c ...
java对象序列化、gzip压缩解压缩、加密解密 -
terry21:
@SuppressWarnings("uncheck ...
java对象序列化、gzip压缩解压缩、加密解密
有时在应用中需要将java对象序列化存储起来,有的需要压缩,有的需要加密
EncryptUtil.java
package org.test.demo; import java.io.UnsupportedEncodingException; import java.security.InvalidKeyException; import java.security.NoSuchAlgorithmException; import java.security.SecureRandom; import javax.crypto.BadPaddingException; import javax.crypto.Cipher; import javax.crypto.IllegalBlockSizeException; import javax.crypto.KeyGenerator; import javax.crypto.NoSuchPaddingException; import javax.crypto.SecretKey; import javax.crypto.spec.SecretKeySpec; public class EncryptUtil { private final static String ENCRYPTKEY="0123456789"; /** * * @Title: getEncryptKey * @Description: 检验加密key * @param encryptKey * @return * String * */ private static String getEncryptKey(String encryptKey){ if(null==encryptKey || "".equals(encryptKey)) return ENCRYPTKEY; return encryptKey; } /** * * @Title: encrypt * @Description: 加密:普通java字串加密成16进制字串(String -> Byte -> HexStr) * @param content 要加密处理的字串 * @param encryptKey 加密密钥 * @return * String * */ public static String encrypt(String content, String encryptKey){ byte[] encryptResult = encryptStrToByte(content, getEncryptKey(encryptKey)); return parseByte2HexStr(encryptResult); } /** * * @Title: decrypt * @Description: 加密:16进制字串解密成普通java字串(HexStr -> Byte ->String) * @param content 要解密处理的16进制字串 * @param encryptKey 解密密钥 * @return * String * */ public static String decrypt(String content, String encryptKey){ byte[] decryptFrom = parseHexStr2Byte(content); byte[] decryptResult = decrypt(decryptFrom,getEncryptKey(encryptKey)); return new String(decryptResult); } /** * 加密:字串 --> 二进制 * @param content 需要加密的内容 * @param password 加密密码 * @return */ private static byte[] encryptStrToByte(String content, String password) { try { KeyGenerator kgen = KeyGenerator.getInstance("AES"); kgen.init(128, new SecureRandom(password.getBytes())); SecretKey secretKey = kgen.generateKey(); byte[] enCodeFormat = secretKey.getEncoded(); SecretKeySpec key = new SecretKeySpec(enCodeFormat, "AES"); Cipher cipher = Cipher.getInstance("AES");// 创建密码器 byte[] byteContent = content.getBytes("utf-8"); cipher.init(Cipher.ENCRYPT_MODE, key);// 初始化 byte[] result = cipher.doFinal(byteContent); return result; // 加密 } catch (NoSuchAlgorithmException e) { e.printStackTrace(); } catch (NoSuchPaddingException e) { e.printStackTrace(); } catch (InvalidKeyException e) { e.printStackTrace(); } catch (UnsupportedEncodingException e) { e.printStackTrace(); } catch (IllegalBlockSizeException e) { e.printStackTrace(); } catch (BadPaddingException e) { e.printStackTrace(); } return null; } /**解密 * @param content 待解密内容 * @param password 解密密钥 * @return */ private static byte[] decrypt(byte[] content, String password) { try { KeyGenerator kgen = KeyGenerator.getInstance("AES"); kgen.init(128, new SecureRandom(password.getBytes())); SecretKey secretKey = kgen.generateKey(); byte[] enCodeFormat = secretKey.getEncoded(); SecretKeySpec key = new SecretKeySpec(enCodeFormat, "AES"); Cipher cipher = Cipher.getInstance("AES");// 创建密码器 cipher.init(Cipher.DECRYPT_MODE, key);// 初始化 byte[] result = cipher.doFinal(content); return result; // 加密 } catch (NoSuchAlgorithmException e) { e.printStackTrace(); } catch (NoSuchPaddingException e) { e.printStackTrace(); } catch (InvalidKeyException e) { e.printStackTrace(); } catch (IllegalBlockSizeException e) { e.printStackTrace(); } catch (BadPaddingException e) { e.printStackTrace(); } return null; } /**将二进制转换成16进制 * @param buf * @return */ private static String parseByte2HexStr(byte buf[]) { StringBuffer sb = new StringBuffer(); for (int i = 0; i < buf.length; i++) { String hex = Integer.toHexString(buf[i] & 0xFF); if (hex.length() == 1) { hex = '0' + hex; } sb.append(hex.toUpperCase()); } return sb.toString(); } /** * 将16进制转换为二进制 * * @param hexStr * @return */ private static byte[] parseHexStr2Byte(String hexStr) { if (hexStr.length() < 1) return null; byte[] result = new byte[hexStr.length() / 2]; for (int i = 0; i < hexStr.length() / 2; i++) { int high = Integer.parseInt(hexStr.substring(i * 2, i * 2 + 1), 16); int low = Integer.parseInt(hexStr.substring(i * 2 + 1, i * 2 + 2), 16); result[i] = (byte) (high * 16 + low); } return result; } }
GZipUtils.java
package org.test.demo; import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputStream; import java.io.File; import java.io.FileInputStream; import java.io.FileOutputStream; import java.io.IOException; import java.io.InputStream; import java.io.OutputStream; import java.util.zip.GZIPInputStream; import java.util.zip.GZIPOutputStream; /** * GZIP工具 * */ public abstract class GZipUtils { public static final int BUFFER = 1024; public static final String EXT = ".gz"; /** * 数据压缩 * * @param data * @return * @throws IOException * @throws Exception */ public static byte[] compress(byte[] data) throws IOException { ByteArrayInputStream bais = new ByteArrayInputStream(data); ByteArrayOutputStream baos = new ByteArrayOutputStream(); // 压缩 compress(bais, baos); byte[] output = baos.toByteArray(); baos.flush(); baos.close(); bais.close(); return output; } /** * 文件压缩 * * @param file * @throws Exception */ public static void compress(File file) throws Exception { compress(file, true); } /** * 文件压缩 * * @param file * @param delete * 是否删除原始文件 * @throws Exception */ public static void compress(File file, boolean delete) throws Exception { FileInputStream fis = new FileInputStream(file); FileOutputStream fos = new FileOutputStream(file.getPath() + EXT); compress(fis, fos); fis.close(); fos.flush(); fos.close(); if (delete) { file.delete(); } } /** * 数据压缩 * * @param is * @param os * @throws IOException * @throws Exception */ public static void compress(InputStream is, OutputStream os) throws IOException { GZIPOutputStream gos = new GZIPOutputStream(os); int count; byte data[] = new byte[BUFFER]; while ((count = is.read(data, 0, BUFFER)) != -1) { gos.write(data, 0, count); } gos.finish(); gos.flush(); gos.close(); } /** * 文件压缩 * * @param path * @throws Exception */ public static void compress(String path) throws Exception { compress(path, true); } /** * 文件压缩 * * @param path * @param delete * 是否删除原始文件 * @throws Exception */ public static void compress(String path, boolean delete) throws Exception { File file = new File(path); compress(file, delete); } /** * 数据解压缩 * * @param data * @return * @throws IOException * @throws Exception */ public static byte[] decompress(byte[] data) throws IOException { ByteArrayInputStream bais = new ByteArrayInputStream(data); ByteArrayOutputStream baos = new ByteArrayOutputStream(); // 解压缩 decompress(bais, baos); data = baos.toByteArray(); baos.flush(); baos.close(); bais.close(); return data; } /** * 文件解压缩 * * @param file * @throws Exception */ public static void decompress(File file) throws Exception { decompress(file, true); } /** * 文件解压缩 * * @param file * @param delete * 是否删除原始文件 * @throws Exception */ public static void decompress(File file, boolean delete) throws Exception { FileInputStream fis = new FileInputStream(file); FileOutputStream fos = new FileOutputStream(file.getPath().replace(EXT, "")); decompress(fis, fos); fis.close(); fos.flush(); fos.close(); if (delete) { file.delete(); } } /** * 数据解压缩 * * @param is * @param os * @throws IOException * @throws Exception */ public static void decompress(InputStream is, OutputStream os) throws IOException { GZIPInputStream gis = new GZIPInputStream(is); int count; byte data[] = new byte[BUFFER]; while ((count = gis.read(data, 0, BUFFER)) != -1) { os.write(data, 0, count); } gis.close(); } /** * 文件解压缩 * * @param path * @throws Exception */ public static void decompress(String path) throws Exception { decompress(path, true); } /** * 文件解压缩 * * @param path * @param delete * 是否删除原始文件 * @throws Exception */ public static void decompress(String path, boolean delete) throws Exception { File file = new File(path); decompress(file, delete); } }
SerializeUtil.java
package org.test.demo; import java.io.BufferedInputStream; import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputStream; import java.io.IOException; import java.io.ObjectInputStream; import java.io.ObjectOutputStream; import java.io.UnsupportedEncodingException; import java.util.Map; /** * 于对java数据进行序列化和反序列化处理 * @author: * @update: 2012-4-12 上午8:34:47 */ public class SerializeUtil { public final static String CHARSET_ISO88591="iso-8859-1"; /** * @Title: serialize * @Description: java对象序列化 <br> * eg:<br> * Map<String,String> map = new HashMap<String,String>();<br> * map.put("test","序列化");<br> * String serializedMapStr=SerializeUtil.serialize(map); * @param original 要进行序列化的java对象 * @return String 序列化的后的值 * @throws IOException * * */ public static String serialize(Object original) throws IOException { if(null==original) return null; ByteArrayOutputStream baos = new ByteArrayOutputStream(); ObjectOutputStream oos = new ObjectOutputStream(baos); oos.writeObject(original); byte[] str = baos.toByteArray(); oos.close(); baos.close(); return new String(str,CHARSET_ISO88591); } /** * @Title: deserialize * @Description: 序列化的String对象的反序列化<br> * 需要自己进行强制转换得到最终类型<br> * eg:<br> * Map newmap = (Map)SerializeUtil.deserialize(serializedMapStr); * @param serializedstr 经序列化处理过的信息 * @return Object 反序列化后生成的Object。<br> * @throws IOException * @throws UnsupportedEncodingException * @throws ClassNotFoundException * * */ public static Object deserialize(String serializedstr) throws UnsupportedEncodingException, IOException, ClassNotFoundException{ if(null==serializedstr)return null; BufferedInputStream bis=new BufferedInputStream(new ByteArrayInputStream(serializedstr.getBytes(CHARSET_ISO88591))); ObjectInputStream ois = new ObjectInputStream(bis); Object obj = ois.readObject(); ois.close(); bis.close(); return obj; } public static byte[] objectToByteArray(Object original) throws IOException { if (null == original) return null; ByteArrayOutputStream bout = new ByteArrayOutputStream(); try (ObjectOutputStream oout = new ObjectOutputStream(bout);) { oout.writeObject(original); } return bout.toByteArray(); } @SuppressWarnings("unchecked") public static Map<String, Object> byteArrayToObject(byte[] bytearry) throws IOException, ClassNotFoundException { if (bytearry.length==0) return null; return (Map<String, Object>)new ObjectInputStream(new ByteArrayInputStream(bytearry)).readObject(); } }
当然你序列化的类型不一定就是map,也可能是其他类型,这个要根据你的实际需要来改写SerializeUtil.java,直接返回Object类型
测试类:
package org.util.test; import java.util.Map; import java.util.HashMap; import javax.servlet.http.Cookie; import junit.framework.TestCase; import java.util.String; import org.test.demo.EncryptUtil; import org.test.demo.GZipUtils; import org.test.demo.SerializeUtil; public class MainTest extends TestCase{ public void testToCookie() throws Exception{ Map<String,Human> map = new HashMap<String,Human>(); map.put("test", "test"); map.put("test2", 123); map.put("test3", new Cookie("cookie","cookievalue")); String datatemp = new String(GZipUtils.compress(SerializeUtil.objectToByteArray(map)),SerializeUtil.CHARSET_ISO88591); String str = EncryptUtil.encrypt(datatemp, "123"); System.out.println("加密后:"+str); String str2 = EncryptUtil.decrypt(str, "123"); System.out.println("解密后"+SerializeUtil.byteArrayToObject(GZipUtils.decompress(str2.getBytes(SerializeUtil.CHARSET_ISO88591)))); } }
评论
2 楼
terry21
2012-10-19
找了半天
发现加密时byte[] byteContent = content.getBytes("utf-8");
解密的时候需要new String(decryptResult,"utf-8");
不然反序列化读取对象时会报错。
发现加密时byte[] byteContent = content.getBytes("utf-8");
解密的时候需要new String(decryptResult,"utf-8");
不然反序列化读取对象时会报错。
1 楼
terry21
2012-10-19
@SuppressWarnings("unchecked")
public static Map<String, Object> byteArrayToObject(byte[] bytearry)
throws IOException, ClassNotFoundException {
if (bytearry.length == 0)
return null;
return (Map<String, Object>) new ObjectInputStream(
new ByteArrayInputStream(bytearry)).readObject();
}
在return语句报错了。。
public static Map<String, Object> byteArrayToObject(byte[] bytearry)
throws IOException, ClassNotFoundException {
if (bytearry.length == 0)
return null;
return (Map<String, Object>) new ObjectInputStream(
new ByteArrayInputStream(bytearry)).readObject();
}
在return语句报错了。。
发表评论
-
POI 内存溢出解决方案
2012-09-26 16:41 2222POI之前的版本不支持大数据量处理,如果数据过多则经常报OOM ... -
java任务调度(Quartz篇)
2012-04-26 16:31 778java任务调度(Quartz篇) 1、Timer介绍 ... -
Scheduled Jobs in Spring 3
2012-04-26 16:03 1104... -
几种任务调度的 Java 实现方法与比较
2012-04-26 15:57 746张 静 , 软件工程 ... -
JfreeChart学习总结(2)
2011-12-26 10:26 5243)jsp+servlet+javabean方式 ... -
JFreeChart 图表 实例
2011-12-26 10:13 1711/** * @Title JFreeChartGo.j ... -
java集合中对象某属性比较排序Comparable与Comparator
2011-12-26 10:10 751要对集合中的对象的某属性进行排序有两种方式。 a. 一种是要 ...
相关推荐
这些文件表明这个压缩包可能包含了一个Java项目的API文档或教程,涵盖了文件压缩、加密和解密的相关知识。 总的来说,Java提供了丰富的库和工具来处理文件的压缩。无论是通过源码自定义压缩流程,还是利用已有的...
Java生成密钥、保存密钥的实例源码,通过本源码可以了解到Java如何产生单钥加密的密钥(myKey)、产生双钥的密钥对(keyPair)、如何保存公钥的字节数组、保存私钥到文件privateKey.dat、如何用Java对象序列化保存私钥...
Java生成密钥、保存密钥的实例源码,通过本源码可以了解到Java如何产生单钥加密的密钥(myKey)、产生双钥的密钥对(keyPair)、如何保存公钥的字节数组、保存私钥到文件privateKey.dat、如何用Java对象序列化保存私钥...
Java生成密钥、保存密钥的实例源码,通过本源码可以了解到Java如何产生单钥加密的密钥(myKey)、产生双钥的密钥对(keyPair)、如何保存公钥的字节数组、保存私钥到文件privateKey.dat、如何用Java对象序列化保存私钥...
密钥 Java生成密钥、保存密钥的实例源码,通过本源码可以了解到Java如何产生单钥加密的密钥(myKey)、产生双钥的密钥对(keyPair)、如何保存公钥的字节数组、保存私钥到文件privateKey.dat、如何用Java对象序列化保存...
Java生成密钥、保存密钥的实例源码,通过本源码可以了解到Java如何产生单钥加密的密钥(myKey)、产生双钥的密钥对(keyPair)、如何保存公钥的字节数组、保存私钥到文件privateKey.dat、如何用Java对象序列化保存私钥...
密钥 Java生成密钥、保存密钥的实例源码,通过本源码可以了解到Java如何产生单钥加密的密钥(myKey)、产生双钥的密钥对(keyPair)、如何保存公钥的字节数组、保存私钥到文件privateKey.dat、如何用Java对象序列化保存...
2. 序列化过程:在游戏环境中,XML数据序列化是指将游戏运行时的对象转换为XML字符串,以便于存储或传输。这通常涉及将游戏对象的属性映射到XML元素和属性,然后将整个数据结构转换为文本格式。反序列化则是相反的...
此外,还有对象流如ObjectInputStream和ObjectOutputStream,用于序列化和反序列化Java对象。 Java IO还引入了缓冲区的概念,提高了读写效率。BufferedInputStream、BufferedOutputStream、BufferedReader和...
5. Newtonsoft.Json.dll是Json.NET库,用于JSON序列化和反序列化,常用于数据交换和配置文件的读写。 综上所述,SQLite查询分析器是一个功能齐全的SQLite数据库管理工具,集成了数据压缩、加密以及丰富的用户界面...
1. 初始化压缩和解压缩流对象。 2. 使用`deflate()`或`inflate()`函数处理数据流。 3. 检查错误并释放资源。 ```c #include int main() { z_stream stream; stream.zalloc = Z_NULL; stream.zfree = Z_NULL; ...
首先,通过`BinaryFormatter`对对象进行序列化,然后用`GZipStream`压缩数据,减少网络传输的数据量。接着,创建一个`CryptoStream`,用它来包装`GZipStream`,以加密压缩后的数据。最后,通过`NetworkStream`将加密...
提供了对文件操作、网络通信、HTTP交互、多线程、用户界面控件、Office文档处理、输入/输出(IO)、JSON序列化与反序列化、压缩与解压缩、文本字符串处理、正则表达式匹配、HTML解析、邮件发送、操作系统交互、...
- 使用`ViewStateEncoder`类来自定义`ViewState`的序列化和反序列化过程,以优化存储效率。 - 考虑使用其他机制(如`Session`或数据库)存储部分数据,以减少`ViewState`的大小。 总之,`ViewState`是ASP.NET中的...
6. **序列化数据**:在跨进程或网络传输对象时,需要将对象序列化为字节流。Netty支持多种序列化方式,包括常用的JDK序列化、JBoss编组(Boss Marshalling)和Google的Protocol Buffers(ProtoBuf)。选择合适的序列...
5. 对象序列化:提供了对象到字节流和字节流到对象的转换,便于存储和传输Java对象。 6. 回行处理:支持不同操作系统下的回行换行符转换,使得跨平台的文本处理更加简单。 7. 数据编码解码:提供了Base64、Hex等编码...
这个类库可能包含了序列化和反序列化的功能,能够将C#对象转换为JSON字符串,或将JSON文本解析为C#对象,方便在网络间传输数据或者保存数据到文件。 条码类库则为应用程序增加了生成和识别条形码的能力。这在物流...
MongoDB.Bson.dll 文件是 Bson(Binary JSON)的实现,Bson 是一种二进制形式的 JSON,它提供了更高效的数据序列化和反序列化机制,是 MongoDB 内部数据交换的主要格式。 mongodb.driver.core.dll 是驱动的核心组件...
9. **压缩与解压缩**:System.IO.Compression命名空间中的GZipStream、DeflateStream和ZipArchive类,实现了GZIP、DEFLATE和ZIP格式的压缩和解压缩功能。 10. **文本处理**:String类提供了丰富的文本处理方法,如...
- 序列化与反序列化过程中,`BinaryFormatter`和`DataContractSerializer`等工具会用到流来读写对象的状态。 总的来说,C#流操作是处理数据的核心机制,理解和熟练运用流能够高效地实现各种数据操作,如文件处理、...