Java tutorial
/* * Copyright (C) 2014 The Calrissian Authors * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package org.calrissian.mango.io; import java.io.*; import java.util.zip.GZIPInputStream; import java.util.zip.GZIPOutputStream; import static org.apache.commons.codec.binary.Base64.decodeBase64; import static org.apache.commons.codec.binary.Base64.encodeBase64; public class Serializables { private Serializables() { } public static byte[] serialize(Serializable serializable) throws IOException { return serialize(serializable, false); } public static byte[] serialize(Serializable serializable, boolean compress) throws IOException { ByteArrayOutputStream baos = new ByteArrayOutputStream(); ObjectOutputStream o; if (compress) o = new ObjectOutputStream(new GZIPOutputStream(baos)); else o = new ObjectOutputStream(baos); o.writeObject(serializable); o.flush(); o.close(); return baos.toByteArray(); } public static <T extends Serializable> T deserialize(byte[] bytes) throws IOException, ClassNotFoundException { return deserialize(bytes, false); } public static <T extends Serializable> T deserialize(byte[] bytes, boolean compressed) throws IOException, ClassNotFoundException { InputStream i = new ByteArrayInputStream(bytes); if (compressed) i = new GZIPInputStream(i); ObjectInputStream ois = new ObjectInputStream(i); T retVal = (T) ois.readObject(); ois.close(); return retVal; } public static byte[] toBase64(Serializable serializable) throws IOException { return encodeBase64(serialize(serializable)); } public static <T extends Serializable> T fromBase64(byte[] bytes) throws IOException, ClassNotFoundException { return deserialize(decodeBase64(bytes)); } }