关于B站(bilibili)对未登录用户视频观看进行暂停和弹窗的分析与简单解决方案

news/2025/2/12 12:32:25/

关于B站(bilibili)对未登录用户视频观看进行暂停和弹窗的分析与简单解决方案

  • 情况介绍
  • 简要分析
  • 初步的解决方案
  • 总结(太长不看点这里)

情况介绍

于近日的某次更新后,B站(bilibili)网页端出现了一个新功能:当用户没有登录时,将对每个视频间隔性地(目前的情况是视频开始播放后的1分钟)进行自动暂停并弹出登录窗口。不得不说,这个功能使得使用体验极差,每个视频都要经历暂停和弹窗实在是让人不爽。有些时候,仅仅只是在B站上看几个视频,或是挂着听听歌,再者也可能试着避开大数据推送和账号的绑定。总之,登录也许不是时时刻刻必须的,而通过恶心用户、严重降低用户体验来迫使用户进行某些操作从而为在线或推广等做出贡献,也许并不是一个好主意。通过一些简单的探索和尝试,这里给出一个非常初级的分析和解决方案,供没有意愿次次登录的用户们参考。

简要分析

通过浏览器F12的网络模块,暂停弹窗事件发生的前后没有特殊的网络请求,可以初步判断出这个功能是在页面加载时引入的JS实现的,并不存在使用与远程服务器交互的内容,如使用心跳包报告用户情况并实时加载JS等,暂时没有发现。也就是说,不太能通过阻止网页向某个URL发送请求或是修改数据包内容来解决这一问题。
既然很可能是网页加载时引入的JS实现的,于是通过edge禁止部分JS加载的debug模式,排查出所属的文件。经验证,该功能存在于来自s1.hdslb.com的stardust-video.****的js文件。当禁止该js加载时,不再出现自动暂停和弹窗的情况。然而,虽然视频可以继续播放,弹幕也没有问题,但是评论区、头像、及右侧推送区的加载出现了异常。这也是可以预见的,很显然是一个压缩后的综合性JS文件,并不可能单独实现这一功能。也因此,禁止该文件的引入虽然能解决所述的问题,但仍然影响着用户的正常使用和体验。
于是想到换一下思路,如通过重写同名函数覆盖该功能。遗憾的是该文件是经过压缩混淆的生产环境文件,内容太多太杂,实现的功能较多,难以定位(例如,搜索setTimeoutset和setInterval可以得到成百上千的结果)。尝试过简单的反混淆工具,也未能得到易于解读的效果。
由于精力有限,上面几条不易走通的道路没有继续尝试了,想做一个简单的用户脚本自己凑合用吧。虽然B站使用了特殊的架构,与一般的video属性不太一致,但是模拟点击操作总是没问题的,能使得视频继续播放就是。唯一需要操心的是如何分别用户自行的暂停和被脚本进行的暂停,一个简单的方式就是判断弹窗,用户自行暂停一般不会出现弹窗,而网页进行的暂停和弹窗总是伴随出现的。

初步的解决方案

根据以上的分析,一个简单的思路就是判断视频暂停的同时是否出现了B站的登录弹窗。通过审查元素可以发现,当视频暂停时,一些模块的class会出现变化,可以利用这一点,监听该元素的属性变化。经过检查,最后发现比较适合的是一个class为bpx-player-row-dm-wrap的元素,其在暂停和播放状态切换只涉及到一个class的增加和减少(即bili-paused),比较适合监听。其他元素,如bpx-player-container,状态变化较多,有时监听会出现一些意外情况。而弹窗的元素较为好判断,会伴随着覆盖网页的mask出现。关闭弹窗和续播视频的功能直接调用click来完成,应该可以初步实现正常续播的功能。

这里使用MutationObserver来监听元素属性变化完成相关功能:

var target = document.getElementsByClassName("bpx-player-row-dm-wrap")[0];
var config = {attributes: true, attributeFilter: ["class"]};
var observer = new MutationObserver(function(motationList, observer) {// console.log("captured!");setTimeout(function(){if (document.getElementsByClassName("bili-mini-mask").length > 0) {document.getElementsByClassName("bili-mini-close-icon")[0].click();document.getElementsByClassName("bpx-player-ctrl-btn bpx-player-ctrl-play")[0].click();// observer.takeRecorders();} }, 1000);
});
observer.observe(target, config);

需要解释的是,MutationObserver回调函数使用setTimeout是为了等待属性加载,调试发现视频会先暂停然后网页弹窗,第一时间检测元素有时并不能检测到。好吧这个策略并不优雅,但是实际用起来还行。

总结(太长不看点这里)

目前来看,阻止网络请求/禁用部分JS/复写相关函数的难度还是比较大的,简单的方法就是文中所提到的检测暂停并自动续播。这里把自用的脚本分享一下(我自己只是开个页面挂着听歌,偶尔看个视频,用起来没什么问题,总比歌放了一分钟就要暂停然后回去点两下好多了,不过离完全解决肯定还是差挺多的,凑合用吧):

去安装浏览器脚本


http://www.ppmy.cn/news/409612.html

相关文章

如何快速爬取B站全站视频信息

專 欄 ❈ 陈键冬,Python中文社区专栏作者,知乎专栏:尽瞎扯 GitHub: https://github.com/chenjiandongx ❈ B站我想大家都熟悉吧,其实 B 站的爬虫网上一搜一大堆。不过纸上得来终觉浅,绝知此事要躬行&…

10秒解决B站没有视频音效调节问题

有这个问题的话估计播放策略是默认的 改成AV1 或者AVG 刷新网页就好了 在设置改一下就好了 别选默认的和HEVG 选AV1 AVG即可 改完就可以了

爬取b站最火up主及其粉丝信息

爬取b站最火up主及其粉丝信息 编译环境:python3、Firefox Developer Edition 使用技术:bs4、json、selenium、pymysql 输出预览: 代码:链接: https://pan.baidu.com/s/1SSqMrMr_IVni-Tb6Yx40vQ 提取码: hnu6 使用前请修改数据库…

一场胆战心惊的B站面试,哔哩哔哩也太难进了

此次哔哩哔哩Java开发面试之旅可谓惊险,不过通过对大部分面试题套路的掌握,不出意外还是拿下了,下面我们来看看这些题是不是常见的不能再常见的了。这些面试题看了就能面上?当然不是,只是通过这些题让自己知道所欠缺的…

Miko二次元动漫视频网站源码 视频播放带仿哔哩哔哩视频字幕弹幕

非常大气漂亮的Miko动漫视频网站整站源码,二次元动漫网源码。Dz后台管理方便,整站数据都设置好了,传上即可制作一个完整的动漫网。 安装教程: 1.源码上传到空间 2.自己修改里面数据库信息(错一个网站就打不开&#xff…

B站,被扫黄了!B站变P站?

月活用户达1.97亿的B站,又惹麻烦了。 作为全国乃至全球最大的二次元社区,B站如今的市值已经超过300亿美元,而曾经把B站按在地上摩擦的爱奇艺还一直在130亿美元徘徊。 众所周知,最初的B站只是一个小众的追番网站,后来它…

B站频繁暂停并弹出登录框

场景回顾 现在在没有登录的情况下,使用PC网页版B站观看视频时,会时不时(大概1分钟)自动暂停,并弹出登录框,非常影响用户体验。咱就偶尔想随便看点东西还这么麻烦,笔者印象里以前还没有这种机制的…

https://b23.tv/av...【相关研究】

参考链接 Fiddler教程:fiddler抓包时,出现的 tunnel tohttp tunnel && http connect methodfiddler的columns添加HTTPMethod 网络安全设备Bypass功能介绍及分析 (旁路) 特殊的B站链接研究 - 相关小记 前言 可能没啥有技…