All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.open.capacity.redis.serializer.RedisObjectSerializer Maven / Gradle / Ivy

There is a newer version: 1.0.0.RC4
Show newest version
package com.open.capacity.redis.serializer;

/** 
* @author 作者 owen 
* @version 创建时间:2017年04月23日 下午20:01:06 类说明
* 类说明 
*/
import org.springframework.core.convert.converter.Converter;
import org.springframework.core.serializer.support.DeserializingConverter;
import org.springframework.core.serializer.support.SerializingConverter;
import org.springframework.data.redis.serializer.RedisSerializer;
import org.springframework.data.redis.serializer.SerializationException;

// 此时定义的序列化操作表示可以序列化所有类的对象,当然,这个对象所在的类一定要实现序列化接口
public class RedisObjectSerializer implements RedisSerializer {
	// 为了方便进行对象与字节数组的转换,所以应该首先准备出两个转换器
	private Converter serializingConverter = new SerializingConverter();
	private Converter deserializingConverter = new DeserializingConverter();
	// 做一个空数组,不是null
	private static final byte[] EMPTY_BYTE_ARRAY = new byte[0];

	@Override
	public byte[] serialize(Object obj) throws SerializationException {
		if (obj == null) {
			// 这个时候没有要序列化的对象出现,所以返回的字节数组应该就是一个空数组
			return EMPTY_BYTE_ARRAY;
		}
		// 将对象变为字节数组
		return this.serializingConverter.convert(obj);
	}

	@Override
	public Object deserialize(byte[] data) throws SerializationException {
		if (data == null || data.length == 0) {
			// 此时没有对象的内容信息
			return null;
		}
		return this.deserializingConverter.convert(data);
	}

}