
解决 redis 存储数据时参数类型转换的问题
问题描述
在尝试将点赞数据存储到 redis 时,遇到了参数类型转换的问题。具体参数如下:
@param likeuserid:点赞用户 id@param likepostid:被点赞文章 id@param likeanswerid:被点赞回答 id
尽管后端传入的数据已经是字符串类型,但后端仍然报出 java.lang.classcastexception 错误。
错误信息
java.lang.classcastexception: java.lang.integer cannot be cast to java.lang.string
原因分析
问题在于,redis 在存储值时会将值序列化成字符串,而 constant.redis_like_code 的类型是 integer,不是字符串。
解决方法
解决方法是将 constant.redis_like_code 的类型改为字符串,例如:
怪兽AI数字人
数字人短视频创作,数字人直播,实时驱动数字人
44 查看详情
public static final string redis_like_code = "1";
您还可以(可选)在 redis 的配置中指定不同的序列化程序,以便 redis 可以将非字符串值存储为字符串。但是,这会导致性能下降,因此不推荐这样做。
修改后的代码
redisserviceimpl.java
@overridepublic void saveliked2redis(string likeuserid, string likepostid, string likeanswerid) { string key = rediskeyutils.getlikedkey(likeuserid, likepostid, likeanswerid); redistemplate.opsforhash().put(rediskeyutils.map_key_user_liked, key, constant.redis_like_code);}
userlike.java
public class UserLike { private String likeUserID;//点赞人ID private String likePostID;//被点赞文章ID private String likeAnswerID;//被点赞回答ID private Integer status = 0;//点赞的状态,默认未点赞0 0:未点赞 1:已点赞 // 省略了构造部分}
以上就是Redis存储点赞数据时,如何避免参数类型转换错误?的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/383554.html
微信扫一扫
支付宝扫一扫