dubbo 接口 序列化问题

本文探讨了在使用Dubbo框架进行服务间调用时,遇到的与Redis交互的问题。特别是当传递Java对象到未部署对应类的服务端时,如何避免出现ClassNotFound异常,并讨论了在不同场景下对象序列化为HashMap或List<HashMap>的现象。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

java.lang.ClassNotFoundException: com.tude.goods.po.TudeGoods
hset>>>>>>>>>>>>>calss=====class java.util.HashMap


dubbo 接口 

public <T> T hget(String key, String field, Class<T> t) throws Exception {
		// TODO Auto-generated method stub
		return redisService.hget(key, field, t);
	}
	
	@Override
	public Long hset(String key, String field, Object value) throws Exception {
		// TODO Auto-generated method stub
	    //System.out.println("hset>>>>>>>>>>>>>calss====="+value.getClass());
		return redisService.hset(key, field, value);
	}

hset 参数	
场景1:
Object 传过来的是java对象,但是dubbo服务端没有该java对象,value.getClass()类型就是hashMap,这是hessian把对象转行成了map。日志报出来
java.lang.ClassNotFoundException: com.tude.goods.po.TudeGoods
hset>>>>>>>>>>>>>calss=====class java.util.HashMap

存入到redis中,反序列化出来的也是一个hashMap

当hget 返回的时候,返回的也是一个hashMap,强制转杭成java对象报错。


场景2:
Object 传过来的是List<java对象>,但是dubbo服务端没有该java对象,value.getClass()类型就是List

存入到redis中,是list<hashMap>



当hget 返回的时候,返回的也是一个list<hashMap>,强制转杭成list<java对象>又没报错





 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值