Login
网站首页 > 文章中心 > 其它

Redis 自定义对象 cannot be cast to java.lang.String

作者:小编 更新时间:2023-08-16 17:51:19 浏览量:319人看过

Redis 自定义对象 cannot be cast to java.lang.String-图1

Redis序列化对象的时候报错如下

java.lang.ClassCastException: com.ppdai.cbd.ddp.thirdparty.contract.bhxtzx.BHXTZXTask cannot be cast to java.lang.String
    at org.springframework.data.redis.serializer.StringRedisSerializer.serialize(StringRedisSerializer.java:33)
    at org.springframework.data.redis.core.AbstractOperations.rawValue(AbstractOperations.java:117)
    at org.springframework.data.redis.core.DefaultListOperations.leftPush(DefaultListOperations.java:71)
    at org.springframework.data.redis.core.DefaultBoundListOperations.leftPush(DefaultBoundListOperations.java:60)
    at com.ppdai.realtime.datachannel.pullservice.entity.RedisQueue.pushFromHead(RedisQueue.java:63)
    at com.ppdai.realtime.datachannel.pullservice.redisconfig.RedisTaskSender.sendTask(RedisTaskSender.java:35)
    at org.codehaus.groovy.runtime.callsite.CallSiteArray.defaultCall(CallSiteArray.java:48)
    at org.codehaus.groovy.runtime.callsite.AbstractCallSite.call(AbstractCallSite.java:113)
    at org.codehaus.groovy.runtime.callsite.AbstractCallSite.call(AbstractCallSite.java:125)
BHXTZXTask是自己定义的Bean,所以呢问题就变成了自定义的对象不能转成String对象,为什么会需要转成String对象呢

因为redis默认使用jdkSerializer,看RedisTemplate的代码如下,

afterPropertiesSet函数
public class RedisTemplate extends RedisAccessor implements RedisOperations, BeanClassLoaderAware {

public void afterPropertiesSet() {

    super.afterPropertiesSet();

    boolean defaultUsed = false;

    if (defaultSerializer == null) {

        defaultSerializer = new JdkSerializationRedisSerializer(
                classLoader != null ? classLoader : this.getClass().getClassLoader());
    if (enableDefaultSerializer) {

        if (keySerializer == null) {
            keySerializer = defaultSerializer;
            defaultUsed = true;
        if (valueSerializer == null) {
            valueSerializer = defaultSerializer;
            defaultUsed = true;
        if (hashKeySerializer == null) {
            hashKeySerializer = defaultSerializer;
            defaultUsed = true;
        if (hashValueSerializer == null) {
            hashValueSerializer = defaultSerializer;
            defaultUsed = true;
    if (enableDefaultSerializer  defaultUsed) {
        Assert.notNull(defaultSerializer, "default serializer null and not all serializers initialized");
    if (scriptExecutor == null) {
        this.scriptExecutor = new DefaultScriptExecutor(this);
    initialized = true;
}
}

查看源码,如下,通过rawValue()函数获取序列化之后的字节码

public Long leftPush(K key, V value) {
    final byte[] rawKey = rawKey(key);
    final byte[] rawValue = rawValue(value);
    return execute(new RedisCallback() {

        public Long doInRedis(RedisConnection connection) {
            return connection.lPush(rawKey, rawValue);
    }, true);
}

private byte[] rawValue(Object value) {

if (valueSerializer == null value instanceof byte[]) {

return (byte[]) value;

}

return valueSerializer.serialize(value);

?

通过?valueSerializer序列化来序列化对象, redis如果不配置,默认?valueSerializer的序列化是会使用

StringRedisSerializer stringRedisSerializer = new StringRedisSerializer();
    JdkSerializationRedisSerializer jdkSerializationRedisSerializer = new JdkSerializationRedisSerializer();

    System.out.println(redisTemplate.hasKey("bohai_credit"));
    redisTemplate.delete("bohai_credit");

    System.out.println(stringRedisSerializer.serialize("bohai_credit"));
    System.out.println(jdkSerializationRedisSerializer.serialize("bohai_credit"));
[B@21831984
[B@4488db1f

运行结果如上所示.

以上就是土嘎嘎小编为大家整理的Redis 自定义对象 cannot be cast to java.lang.String相关主题介绍,如果您觉得小编更新的文章只要能对粉丝们有用,就是我们最大的鼓励和动力,不要忘记讲本站分享给您身边的朋友哦!!

版权声明:倡导尊重与保护知识产权。未经许可,任何人不得复制、转载、或以其他方式使用本站《原创》内容,违者将追究其法律责任。本站文章内容,部分图片来源于网络,如有侵权,请联系我们修改或者删除处理。

编辑推荐

热门文章