解决 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 的类型改为字符串,例如:

public static final string redis_like_code = "1";
登录后复制

您还可以(可选)在 redis 的配置中指定不同的序列化程序,以便 redis 可以将非字符串值存储为字符串。但是,这会导致性能下降,因此不推荐这样做。

修改后的代码

redisserviceimpl.java

@override
public 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存储点赞数据时,如何避免参数类型转换错误?的详细内容,更多请关注慧达安全导航其它相关文章!

点赞(0)

评论列表 共有 0 条评论

暂无评论
立即
投稿
发表
评论
返回
顶部