使用WebSocket实现异地同步看电影

使用WebSocket实现异地同步看电影

项目地址:https://github.com/Fangnan700/Film_room

说明

放假回家之后,因为和女朋友不在同一个地方,又想着一起看电影,但市面上能够远程一起看电影的方法都无法满足现有的需求:

  • 方案一:使用“微光”等app,虽然能够同步播放和实时聊天,但片源太少,想要上传还要认证,pass掉。
  • 方案二:使用“腾讯会议”等软件,共享屏幕,这类方式对带宽有一定要求,网络延迟比较明显,体验不好,pass掉。

几番纠结,才想起来我就是学计算机的啊,有需求Coding就完了,于是折腾了一晚上,写出了[电影屋]这个小Demo。

目前已经实现的功能有:

  • 远程同步播放视频
  • 与腾讯云COS配合,播放任意视频(目前只支持mp4格式)
  • 房间验证,使用房间ID和房间密码才能进入对应房间
  • 多房间模式,使用唯一ID进行区分,房间之间互不干扰

仍待实现的功能:

  • 调用腾讯云COS的api实现一键上传

  • 增加实时聊天功能

  • 增加弹幕功能

    ……

实现思路

这里偷了个懒,省去了文件存储和文件解析的步骤,直接采用了在对象存储(COS)上存储视频文件,通过服务器将视频外链分发给进入房间的用户,这样每位用户都是直接访问对象存储上的文件,而不消耗服务器流量。服务器只负责创建房间、房间验证、信息分发和进度同步的功能。

技术栈:

  • 前端:Html + Css + Js
  • 后端:Java + Websocket

同步方式:

建立WebSocket通信之后,加入心跳机制防止断开。同步信息以房间创建者为准,每五分钟房间创建者的浏览器向服务器发送一次当前播放信息,服务器将接收到的播放信息广播给其它用户,其它用户接收到广播信息,对内容进行校验,校验通过后同步本地信息。当任意用户暂停/播放视频时,将事件发送到服务器进行广播,其它用户根据广播内容相应地做出动作。

效果图

image-20221228134402195

  • 5
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

YV_LING

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

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

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

打赏作者

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

抵扣说明:

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

余额充值