看讲课比较慢的老师的视频,无疑是一种煎熬。过于慢的速度,反而会影响效率。
教程由简单到难逐渐递增,不过玩法也越来越多,所以还请斟酌着看。
利用 IDM 下载#
来自知乎用户 cxy ↗(方法及其简单粗暴,一看便懂。博主测试直播回看界面失效)
首先,下载一个 IDM(internet download manager),这个软件平时当多核下载器拿来下浏览器里的文件也是非常不错的。百度一下网上都有 IDM 的下载链接,浏览器插件也行。
安装完成以后在后台运行,点开你的课堂网址,右上角就会出现这样的标识:
如果没有出现,多刷新几次页面就可以了
下载到你电脑的视频就可以任你宰割了,你只需要随便用一个支持倍速播放的播放器即可
使用 HttpCanary 抓取#
来自知乎用户 solstice23 ↗,方法比较中矩,还是有一些参考价值的。
下载 HttpCanary 软件(这里提供一个下载链接 ↗)
进入钉钉,先不要打开云课堂视频。
打开 HttpCanary,点击右下角的开始捕获按钮。
切回钉钉,打开云课堂视频,播放几秒
切回 HttpCanary,点击右下角按钮暂停抓包
点击右上角搜索按钮,选择类别 “视频”
筛选出来几个数据包,地址都是相同的。随便点进去一个,长按地址复制。
使用下载器下载该视频(例如 ADM 下载器),并使用支持倍速播放的播放器播放即可。
利用 Fiddler 注入 JS#
可以说这里开始才是正文。同时也对作者 樱花赞 ↗ 表示感谢!
PS.他并不是原创,最初原创的是 solstice23 ↗
思路#
云课堂的本质是一个(套壳的)网页,可以用抓包软件分析记录学习进度请求,再通过修改这个请求并重发来修改学习进度。
提示#
该方法仅 PC 端可用(其实手机也不是不行)。
教程#
安装 Fiddler#
点击这里 ↗下载安装。
设置 Fiddler 捕获 HTTPS 流量#
打开 Fiddler,点击顶栏 “Tools”,在弹出的菜单中点击 “Options…”。
在弹出的窗口中切换到顶部的 “HTTPS” 菜单,勾选 “Capture HTTPS CONNECTs” 和 “Decrypt HTTPS traffic” 复选框,然后点击 OK。
勾选后会弹出安装证书的窗口,确认即可。
如果出现下面这样的黄条,点击黄条即可。
写入脚本#
在 Fiddler 中按下 Ctrl+R
。弹出一个代码编辑器窗口。
在代码编辑器窗口按下 Ctrl+F
,在弹出的窗口中输入 OnBeforeResponse 并按下回车。找到 OnBeforeResponse 函数(下图所示)。
把图中的下面这段:
static function OnBeforeResponse(oSession: Session) {
if (m_Hide304s && oSession.responseCode == 304) {
oSession["ui-hide"] = "true";
}
}
typescript替换成下面的代码,然后按下 Ctrl+S
来保存。
下方代码已经整合 【一劳永逸】钉钉云课堂倍速播放教程 ↗ 中的代码(看过这篇教程的,可以把原来的代码删掉用下面的)。
以下代码部分来自 HTML5 播放器增强插件 ↗,对原作者深表感谢!
以下代码参考 aneasystone’s blog: 通过 FiddlerScript 实现根据条件重发请求 ↗,对博主深表感谢!
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);
}
}
}
typescript看视频#
看视频的时候,每次刷新页面(包括第一次进入视频页面时的加载)程序会花 10 s 时间给视频增加 10 min 的学习进度。保险起见,请不要频繁刷新。
Log 选项卡中,每出现一条Resquest has been Send.
说明学习进度增加了 1 min。快速出现大量Resquest has been Send.
时,可能是刷新过于频繁或程序错误,请立刻关闭 Fiddler。如果 Fiddler 未响应,可能是陷入死循环,立刻在任务管理器里结束进程。
在 Rules 中可以启用或关闭 视频增强插件
和 自动学习
。
快捷键说明#
播放速度调节#
按键 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
来保存。
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)
javascript直接在钉钉内倍速播放#
打开钉钉的云课堂,点开一个视频,可以看到右下角多了一个绿色按钮。点击它。
点击之后,弹出了一个菜单。
将下面的代码粘贴进下图中标明的位置并点击右侧的 “OK” 按钮。
在点击右下角绿色按钮弹出的控制台按照上一步的方法输入以下代码:
document.querySelector('video').playbackRate = 2.0
javascript点击 OK。可以将钉钉内的视频变为二倍速。代码中的 2.0 可以换成其他的数字。
获取视频地址和下载视频#
还是右下角的绿色按钮弹出的菜单,输入下面的代码
console.log(document.querySelector('video').src)
javascript点击 OK 后,上面的列表出现了一个地址,这个地址就是该云课堂视频的源文件地址。复制这个地址,在浏览器打开即可下载该视频。或者,也可以用 Potplayer 直接打开该地址来倍速播放。
附:使用 Potplayer 倍速观看视频#
推荐使用 Potplayer 来倍速观看视频。Potplayer 是一款很好用的播放器。
下载并安装 Potplayer 后,在 Potplayer 的左上角点击如图的菜单,或者直接按下 Ctrl+U
。
在弹出的窗口中粘贴刚才的复制的那个视频链接,点击确定。
可以看到,视频已经开始播放。
按下 C
键来加速,按下 X
键来减速,按下 Z
键来恢复原速。
按下按键后在视频左上角可以看到当前的倍速速率。
尾声#
这里已经推荐了很多钟方法,相信总有一种方法适合你。希望能好好利用工具,做些有利于学习的事,而不是仅仅用来刷分数ヾ(≧▽≦*)o