情况介绍

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

简要分析

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

初步的解决方案

根据以上的分析一个简单的思路就是判断视频暂停的同时是否出现了B站的登录弹窗。通过审查元素可以发现,当视频暂停时,一些模块class会出现变化,可以利用这一点,监听元素属性变化。经过检查最后发现比较适合的是一个classbpxplayerrowdm-wrap元素,其在暂停和播放状态切换只涉及到一个class的增加和减少(即bilipaused),比较适合监听。其他元素,如bpxplayercontainer状态变化较多,有时监听会出现一些意外情况。而弹窗的元素较为好判断,会伴随着覆盖网页的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/复写相关函数难度还是比较大的,简单方法就是文中所提到的检测暂停并自动续播。这里把自用的脚本分享一下(我自己只是开个页面挂着听歌,偶尔看个视频,用起来没什么问题,总比歌放了一分钟就要暂停然后回去点两下好多了,不过离完全解决肯定还是差挺多的,凑合用吧):

去安装浏览器脚本

原文地址:https://blog.csdn.net/weixin_43331420/article/details/129659049

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任

如若转载,请注明出处:http://www.7code.cn/show_14933.html

如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱suwngjj01@126.com进行投诉反馈,一经查实,立即删除

发表回复

您的电子邮箱地址不会被公开。 必填项已用 * 标注