CWorld

Stay hungry, Stay foolish. 求知若愚,虚怀若谷。

钉钉云课堂提取视频 & 倍速播放 & 学习进度

2020年7月12日教程

钉钉的云课堂比较反人类,不仅有水印影响观看体验,而且不支持倍速播放。看讲课比较慢的老师的视频,无疑是一种煎熬。过于慢的速度,反而会影响效率。

教程由简单到难逐渐递增,不过玩法也越来越多,所以还请斟酌着看。

利用 IDM 下载

来自知乎用户 cxy(方法及其简单粗暴,一看便懂。博主测试直播回看界面失效)

首先,下载一个IDM(internet download manager),这个软件平时当多核下载器拿来下浏览器里的文件也是非常不错的。百度一下网上都有IDM的下载链接,浏览器插件也行。

image

安装完成以后在后台运行,点开你的课堂网址,右上角就会出现这样的标识:

image

如果没有出现,多刷新几次页面就可以了

下载到你电脑的视频就可以任你宰割了,你只需要随便用一个支持倍速播放的播放器即可

image

使用 HttpCanary 抓取

来自知乎用户 solstice23,方法比较中矩,还是有一些参考价值的。

下载 HttpCanary 软件(这里提供一个下载链接

  1. 进入钉钉,先不要打开云课堂视频。

  2. 打开 HttpCanary,点击右下角的开始捕获按钮。

  3. 切回钉钉,打开云课堂视频,播放几秒

  4. 切回 HttpCanary,点击右下角按钮暂停抓包

  5. 点击右上角搜索按钮,选择类别 “视频”

  6. 筛选出来几个数据包,地址都是相同的。随便点进去一个,长按地址复制。

  7. 使用下载器下载该视频(例如 ADM 下载器),并使用支持倍速播放的播放器播放即可。

未标题-1

利用 Fiddler 注入 JS

可以说这里开始才是正文。同时也对作者 樱花赞 表示感谢!

PS.他并不是原创,最初原创的是 solstice23

思路

云课堂的本质是一个(套壳的)网页,可以用抓包软件分析记录学习进度请求,再通过修改这个请求并重发来修改学习进度。

提示

该方法仅 PC 端可用(其实手机也不是不行)。

教程

安装 Fiddler

点击这里下载安装。

设置 Fiddler 捕获 HTTPS 流量

打开 Fiddler,点击顶栏 “Tools”,在弹出的菜单中点击 “Options…”。

image

在弹出的窗口中切换到顶部的 “HTTPS” 菜单,勾选 “Capture HTTPS CONNECTs” 和 “Decrypt HTTPS traffic” 复选框,然后点击 OK。

勾选后会弹出安装证书的窗口,确认即可。

image

如果出现下面这样的黄条,点击黄条即可。

image

写入脚本

在 Fiddler 中按下 Ctrl+R 。弹出一个代码编辑器窗口。

image

在代码编辑器窗口按下 Ctrl+F ,在弹出的窗口中输入 OnBeforeResponse 并按下回车。找到 OnBeforeResponse 函数(下图所示)。

image

把图中的下面这段:

1
2
3
4
5
static function OnBeforeResponse(oSession: Session) {
if (m_Hide304s && oSession.responseCode == 304) {
oSession["ui-hide"] = "true";
}
}

替换成下面的代码,然后按下 Ctrl+S 来保存。

下方代码已经整合 【一劳永逸】钉钉云课堂倍速播放教程 中的代码(看过这篇教程的,可以把原来的代码删掉用下面的)。
以下代码部分来自 HTML5播放器增强插件,对原作者深表感谢!
以下代码参考 aneasystone’s blog: 通过FiddlerScript实现根据条件重发请求,对博主深表感谢!

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
public static RulesOption("视频增强插件")
var m_H5VideoPlayerExtension: boolean = true;
public static RulesOption("自动学习")
var m_AutoLearn: boolean = true;
static function OnBeforeResponse(oSession: Session) {
if (m_Hide304s && oSession.responseCode == 304) {
oSession["ui-hide"] = "true";
}
if (m_H5VideoPlayerExtension) {
var sToInsert = "<script src=data:application/javascript;base64,(function(){var html_player_enhance={fontSize:20,player:function(){return document.querySelector("video")},tips:function(str){var style=document.querySelector("#html_player_enhance_tips").style;document.querySelector("#html_player_enhance_tips").innerText=str;for(var i=0;i<3;i++){if(this.on_off[i]){clearTimeout(this.on_off[i])}}style.display="block";this.on_off[0]=setTimeout(function(){style.opacity=1},50);this.on_off[1]=setTimeout(function(){style.opacity=0},2000);this.on_off[2]=setTimeout(function(){style.display="none"},2800)},on_off:new Array(3),rotate:0,fps:30,filter:{key:new Array(5),setup:function(){var view="brightness({0}) contrast({1}) saturate({2}) hue-rotate({3}deg) blur({4}px)";for(var i=0;i<5;i++){view=view.replace("{"+i+"}",String(this.key[i]));this.key[i]=Number(this.key[i])}html_player_enhance.player().style.WebkitFilter=view},reset:function(){this.key[0]=1;this.key[1]=1;this.key[2]=1;this.key[3]=0;this.key[4]=0;this.setup()}},settips:function(){var tips=document.createElement("div");this.player().parentNode.appendChild(tips);tips.setAttribute("id","html_player_enhance_tips");tips.setAttribute("style","position: absolute;z-index: 999999;padding: 10px;background: rgba(0,0,0,0.8);color:white;top: 50%;left: 50%;transform: translate(-50%,-50%);transition: all 500ms ease;opacity: 0;display: none; -webkit-font-smoothing: subpixel-antialiased;font-family: 'microsoft yahei', Verdana, Geneva, sans-serif;-webkit-user-select: none;");if(this.fontSize!==0){tips.style.fontSize=this.fontSize+"px"}if(location.hostname==="www.youtube.com"){this.player().parentNode.style.height="100%"}},_isFoucs:false,isFoucs:function(){this.player().onmouseover=function(){html_player_enhance._isFoucs=true};this.player().onmouseout=function(){html_player_enhance._isFoucs=false}},button:function(event){var _this=html_player_enhance;if(event.altKey||event.ctrlKey||event.shiftKey){return}if(!_this._isFoucs){return}event.stopPropagation();event.preventDefault();if(event.keyCode===39){_this.player().currentTime+=3;_this.tips("快进：3秒")}if(event.keyCode===37){_this.player().currentTime-=3;_this.tips("后退：3秒")}if(event.keyCode===38){if(_this.player().volume<1){_this.player().volume+=0.01}_this.player().volume=_this.player().volume.toFixed(2);_this.tips("音量："+parseInt(_this.player().volume*100)+"%")}if(event.keyCode===40){if(_this.player().volume>0){_this.player().volume-=0.01}_this.player().volume=_this.player().volume.toFixed(2);_this.tips("音量："+parseInt(_this.player().volume*100)+"%")}if(event.keyCode===32){if(_this.player().paused){_this.player().play();_this.tips("播放")}else{_this.player().pause();_this.tips("暂停")}}if(event.keyCode===88){if(_this.player().playbackRate>0){_this.player().playbackRate-=0.1;_this.player().playbackRate=_this.player().playbackRate.toFixed(1);_this.tips("播放速度："+_this.player().playbackRate+"倍")}}if(event.keyCode===67){if(_this.player().playbackRate<16){_this.player().playbackRate+=0.1;_this.player().playbackRate=_this.player().playbackRate.toFixed(1);_this.tips("播放速度："+_this.player().playbackRate+"倍")}}if(event.keyCode===90){_this.player().playbackRate=1;_this.tips("播放速度：1倍")}if(event.keyCode==70){if(!_this.player().paused){_this.player().pause()}_this.player().currentTime+=Number(1/_this.fps);_this.tips("定位：下一帧")}if(event.keyCode==68){if(!_this.player().paused){_this.player().pause()}_this.player().currentTime-=Number(1/_this.fps);_this.tips("定位：上一帧")}if(event.keyCode==69){if(_this.filter.key[0]>1){_this.filter.key[0]+=1}else{_this.filter.key[0]+=0.1}_this.filter.key[0]=_this.filter.key[0].toFixed(2);_this.filter.setup();_this.tips("图像亮度增加："+parseInt(_this.filter.key[0]*100)+"%")}if(event.keyCode==87){if(_this.filter.key[0]>0){if(_this.filter.key[0]>1){_this.filter.key[0]-=1}else{_this.filter.key[0]-=0.1}_this.filter.key[0]=_this.filter.key[0].toFixed(2);_this.filter.setup()}_this.tips("图像亮度减少："+parseInt(_this.filter.key[0]*100)+"%")}if(event.keyCode==84){if(_this.filter.key[1]>1){_this.filter.key[1]+=1}else{_this.filter.key[1]+=0.1}_this.filter.key[1]=_this.filter.key[1].toFixed(2);_this.filter.setup();_this.tips("图像对比度增加："+parseInt(_this.filter.key[1]*100)+"%")}if(event.keyCode==82){if(_this.filter.key[1]>0){if(_this.filter.key[1]>1){_this.filter.key[1]-=1}else{_this.filter.key[1]-=0.1}_this.filter.key[1]=_this.filter.key[1].toFixed(2);_this.filter.setup()}_this.tips("图像对比度减少："+parseInt(_this.filter.key[1]*100)+"%")}if(event.keyCode==85){if(_this.filter.key[2]>1){_this.filter.key[2]+=1}else{_this.filter.key[2]+=0.1}_this.filter.key[2]=_this.filter.key[2].toFixed(2);_this.filter.setup();_this.tips("图像饱和度增加："+parseInt(_this.filter.key[2]*100)+"%")}if(event.keyCode==89){if(_this.filter.key[2]>0){if(_this.filter.key[2]>1){_this.filter.key[2]-=1}else{_this.filter.key[2]-=0.1}_this.filter.key[2]=_this.filter.key[2].toFixed(2);_this.filter.setup()}_this.tips("图像饱和度减少："+parseInt(_this.filter.key[2]*100)+"%")}if(event.keyCode==79){_this.filter.key[3]+=1;_this.filter.setup();_this.tips("图像色相增加："+_this.filter.key[3]+"度")}if(event.keyCode==73){_this.filter.key[3]-=1;_this.filter.setup();_this.tips("图像色相减少："+_this.filter.key[3]+"度")}if(event.keyCode==75){_this.filter.key[4]+=1;_this.filter.setup();_this.tips("图像模糊增加："+_this.filter.key[4]+"PX")}if(event.keyCode==74){if(_this.filter.key[4]>0){_this.filter.key[4]-=1;_this.filter.setup()}_this.tips("图像模糊减少："+_this.filter.key[4]+"PX")}if(event.keyCode==81){_this.filter.reset();_this.tips("图像属性：复位")}if(event.keyCode==83){_this.rotate+=90;if(_this.rotate%360===0){_this.rotate=0}_this.player().style.transform="rotate("+_this.rotate+"deg)";_this.tips("画面旋转："+_this.rotate+"度")}if(event.keyCode==13){if(location.hostname==="www.bilibili.com"){if(document.querySelector('[data-text="进入全屏"]')){document.querySelector('[data-text="进入全屏"]').click()}}if(location.hostname==="www.youtube.com"){if(document.querySelector('[class="ytp-fullscreen-button ytp-button"]')){document.querySelector('[class="ytp-fullscreen-button ytp-button"]').click()}}}},init:function(){if(document.querySelectorAll("#html_player_enhance_tips").length>1){document.querySelector("#html_player_enhance_tips").parentNode.removeChild(document.querySelectorAll("#html_player_enhance_tips")[1])}if(document.querySelectorAll("video").length===1&&document.querySelectorAll("#html_player_enhance_tips").length===0){if(!this.load){var _this=html_player_enhance;this.load=true;setTimeout(function(){console.log("检测到HTML5视频！");console.log(!_this.load);_this.load=false;_this.filter.reset();_this.settips();_this.isFoucs();document.onkeydown=_this.button},1000)}}},load:false};html_player_enhance.init();document.addEventListener("DOMNodeInserted",function(){html_player_enhance.init()})})();></script>";
oSession.utilDecodeResponse();
oSession.utilReplaceOnceInResponse('</head>', sToInsert + '</head>', 0);
}
if (m_AutoLearn && !oSession.GetRequestBodyAsString().Contains("\"courseTime\":9990,\"learnTime\":60,\"type\":2")
&& oSession.hostname == "saas.daxue.dingtalk.com" && oSession.PathAndQuery == "/dingtalk/course/record.jhtml"){
var raw = "";
var method:String = oSession.RequestMethod;
var url:String = oSession.fullUrl;
var protocol = "HTTP/1.1";
raw += method + " " + url + " " + protocol + "\r\n";
var body = oSession.GetRequestBodyAsString();
for (var i:int = 0; i < oSession.oRequest.headers.Count(); i++) {
var header = oSession.oRequest.headers[i];
header = header.ToString()
if(header.Contains("Content-Length")){
header = "Content-Length: "+(body.Length+4).ToString()
}
raw += header + "\r\n";
}
body = body.replace(/"courseTime":\d+,"learnTime":\d+,"type":\d/g,"\"courseTime\":9990,\"learnTime\":60,\"type\":2");
raw += "\r\n" + body;
for (var j:int = 0; j < 10; j++) {
FiddlerObject.utilIssueRequest(raw);
FiddlerApplication.Log.LogString("Request has been Send.");
System.Threading.Thread.Sleep(1000);
}
}
}

看视频

看视频的时候,每次刷新页面(包括第一次进入视频页面时的加载)程序会花 10 s 时间给视频增加 10 min 的学习进度。保险起见,请不要频繁刷新。

Log 选项卡中,每出现一条Resquest has been Send.说明学习进度增加了 1 min。快速出现大量Resquest has been Send.时,可能是刷新过于频繁或程序错误,请立刻关闭 Fiddler。如果 Fiddler 未响应,可能是陷入死循环,立刻在任务管理器里结束进程。

image

在 Rules 中可以启用或关闭 视频增强插件自动学习

image

快捷键说明

image

播放速度调节

按键C:加速播放 +0.1
按键X:减速播放 -0.1
按键Z:正常速度播放

播放时间定位

方向键右→:快进3秒
方向键左←:后退3秒
按键F:下一帧
按键D:上一帧

音量调节

方向键上↑:音量升高 1%
方向键下↓:音量降低 1%

图像参数调节

按键E:亮度增加%
按键W:亮度减少%
按键T:对比度增加%
按键R:对比度减少%
按键U:饱和度增加%
按键Y:饱和度减少%
按键O:色相增加 1 度
按键I:色相减少 1 度
按键K:模糊增加 1 px
按键J:模糊减少 1 px
按键Q:图像复位

画面调节

按键S:画面旋转 90 度
按键回车:进入全屏(只支持部分网站 B站,油管)

兼容性问题

可以使用组合键临时停用插件,例如 播放/暂停 默认为空格键,那么使用Ctrl+space(空格键)即可暂停使用一次插件。

备用方案

与上一个类似。从粘贴代码的一步发生了变化。下面就从那一步开始好了。

中间人注入

复制下面的代码,并粘贴到下图中的位置,然后按下 Ctrl+S 来保存。

1
2
3
var sToInsert = "<script src='https://res.wx.qq.com/mmbizwap/zh_CN/htmledition/js/vconsole/3.0.0/vconsole.min.js'></script><script>var vConsole = new VConsole();</script>"
oSession.utilDecodeResponse();
oSession.utilReplaceOnceInResponse('</head>', sToInsert + '</head>', 0);

image

image

直接在钉钉内倍速播放

打开钉钉的云课堂,点开一个视频,可以看到右下角多了一个绿色按钮。点击它。

image

image

点击之后,弹出了一个菜单。

将下面的代码粘贴进下图中标明的位置并点击右侧的 “OK” 按钮。

在点击右下角绿色按钮弹出的控制台按照上一步的方法输入以下代码:

1
document.querySelector("video").playbackRate=2.0

点击 OK。可以将钉钉内的视频变为二倍速。代码中的 2.0 可以换成其他的数字。

获取视频地址和下载视频

还是右下角的绿色按钮弹出的菜单,输入下面的代码

1
console.log(document.querySelector("video").src);

点击 OK 后,上面的列表出现了一个地址,这个地址就是该云课堂视频的源文件地址。复制这个地址,在浏览器打开即可下载该视频。或者,也可以用 Potplayer 直接打开该地址来倍速播放。

image

附:使用 Potplayer 倍速观看视频

推荐使用 Potplayer 来倍速观看视频。Potplayer 是一款很好用的播放器。

下载并安装 Potplayer 后,在 Potplayer 的左上角点击如图的菜单,或者直接按下 Ctrl+U

image

在弹出的窗口中粘贴刚才的复制的那个视频链接,点击确定。

image

可以看到,视频已经开始播放。

image

按下 C 键来加速,按下 X 键来减速,按下 Z 键来恢复原速。

按下按键后在视频左上角可以看到当前的倍速速率。

image

尾声

这里已经推荐了很多钟方法,相信总有一种方法适合你。希望能好好利用工具,做些有利于学习的事,而不是仅仅用来刷分数ヾ(≧▽≦*)o

不妨用打赏💰再伤我一次

:D 获取中...