从零开始搭建仿抖音短视频APP-后端消息业务模块开发(2)-基础版完结篇

项目持续更新中:

仿抖音短视频APP专栏

目录

系统消息入库保存

MongoDB分页查询系统消息列表

删除系统消息


系统消息入库保存

这里还剩下最后一个点赞评论没有完成

这里如果点赞了你的评论,你们视频的封面是会被传回来的

 找到CommentController的like路由

需要注入两个Service: 

 这里我们复制一下之前写好的代码,再进行一下修改:

 

 这里我们需要获得一个vlogId,此处是没有的,所以我们要编写一个接口去获取:

 

 实现: 

随后我们就能通过commentService去调用了:

 //系统消息:点赞评论
        Comment comment =commentService.getComment(commentId);
        Vlog vlog = vlogService.getVlog(comment.getVlogId());
        Map msgContent = new HashMap();
        msgContent.put("vlogId",vlog.getId());
        msgContent.put("vlogCover",vlog.getCover());
        msgContent.put("commentId",commentId);

        msgService.createMsg(userId,
                comment.getCommentUserId(),
                MessageEnum.LIKE_COMMENT.type,
                msgContent);

编写完之后,我们做一个测试,点赞评论的和点赞回复的

 然后到我们的MongoDB查看

 

 

MongoDB分页查询系统消息列表

在完成系统消息发送的操作之后,我们在消息界面需要有一个查询操作 ,并且查询是有分页的

我们先来写我们的service层:

 在这里我们通过实现Repository,自定义条件查询

接着在Service实现中:

 这里其实还需要做一个判断,判断我之前是否关注过它,如果没有这里会有一个回粉的标志

我们只需要在扩展在MO在的字段isFriend,

 @Override
    public List<MessageMO> queryList(String toUserId, Integer page, Integer pageSize) {

        Pageable pageable = (Pageable) PageRequest.of(page,
                                                        pageSize,
                                                        Sort.Direction.DESC,
                                                        "CreateTime");
        List<MessageMO> list = messageRepository.findAllByToUserIdOrderByCreateTimeDesc(toUserId,pageable);

        for(MessageMO msg: list){
            //如果类型是关注消息,则需要查询我之前是否关注过他,用于在前端标记“互粉”
            if(msg.getMsgType() != null &&msg.getMsgType() == MessageEnum.FOLLOW_YOU.type){
              Map map =   msg.getMsgContent();
              if(map == null){
                  map = new HashMap();
              }
            String relationship = redis.get(REDIS_FANS_AND_VLOGGER_RELATIONSHIP+":"+msg.getToUserId()+":"+msg.getFromUserId());
            if(StringUtils.isNotBlank(relationship)&&relationship.equalsIgnoreCase("1")){
              map.put("isFriend",true);
            }else {
                map.put("isFriend",false);
            }
            msg.setMsgContent(map);
            }
        }
        return list;
    }

 这里前端我们也可以查看一下

 这里就可以构建我们后端的接口

 我们在后端构建一个MsgController:

@Slf4j
@Api(tags = "MsgController 消息功能模块接口")
@RequestMapping("Msg")
@RestController
public class MsgController {

    @Autowired
    private MsgService msgService;

    @GetMapping("list")
    public GraceJSONResult list(@RequestParam String userId,
                                @RequestParam Integer page,
                                @RequestParam Integer pageSize){

        //mongoDB 从0分页,区别于数据库
        if(page == null){
            page = COMMON_START_PAGE_ZERO;
        }
        if(pageSize == null){
            pageSize=COMMON_PAGE_SIZE;
        }
        List<MessageMO> list = msgService.queryList(userId, page, pageSize);
        return GraceJSONResult.ok(list);
        
    }


}

启动测试:

 

删除系统消息

我们可以先思考一下删除可以从哪里出发

第一种,我们可以在我们的消息页长按或者右滑进行一个删除

第二种和我们用户的行为绑定在一起,如果我取关你,那么就把这条关注消息给去掉

两种消息的触发删除都可以,大家可以自己去尝试一下。

我们这里可以使用长按删除,方法大家自己尝试一下。

 

截至目前为止,基础版的仿抖音短视频APP的制作已经到了尾声,该专栏的第一篇到现在,从零开始搭建项目,到编写我们的代码,完成测试,历时了一个月左右,那么后期我会更新进阶版本,希望将它上传到服务器。

以往代码有疑问,不懂的地方都可以私信我。想要源代码的友友们也可以私聊我~

  • 4
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
vue 仿抖音视频列表(兼容微信内置X5浏览器) 新增留言功能,优化安卓微信环境境下播放不流畅问题,添加请求下一页数据效果 制作 仿抖音视频列表遇到很多坑,特别是安卓微信内置浏览器,让人脑壳疼,核心代码不多 便于理解 图标css使用的事iconfot字体库,优化页面加载速度 http://at.alicdn.com/t/font_1048614_mi5i5ba1uag.css 组件用到了vant 中的swiper滑动组件 ———————————————— 权声明:本文为CSDN博主「superKM」的原创文章,遵循CC 4.0 BY-SA权协议,转载请附上原文出处链接及本声明。 原文链接:https://blog.csdn.net/superKM/article/details/87603255 h5 原生 video 属性 webkit-playsinline ios 小窗播放,使视频不脱离文本流,安卓则无效 微信内置x5内核, x5-video-player-type="h5-page" 启用H5播放器,是wechat安卓特性,添加此属性,微信浏览器会自动将视频置为全屏 x5-video-player-fullscreen="true" 全屏设置,设置为 true 是防止横屏 x5-video-orientation 控制横竖屏 landscape 横屏,portrain竖屏; 默认portrain poster:封面 src:播放地址 loop防止播放视频结束后,显示腾讯的广告 ———————————————— 权声明:本文为CSDN博主「superKM」的原创文章,遵循CC 4.0 BY-SA权协议,转载请附上原文出处链接及本声明。 原文链接:https://blog.csdn.net/superKM/article/details/87603255

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

什么时候养猫猫

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值