用JS写一个可以自动挂学习通视频课的插件+自动答题


近期选课太多了,一个个看太麻烦,如果你还在因为要老老实实一分一秒的看视频,那么你可以花几分钟看一下这篇文章教程,也许这短短几分钟可以改变很多。

欢迎 点赞,关注,评论 以及各种交流~


写在前面:


此软件仅供学习使用,请勿商用! 转载请注明出处!


软件功能:

自动播放

自动下一集

自动1.25倍速率

自动答题就是走一个形式,并不会用来算分数,本脚本多选题可能会选错,请悉知。


注意事项:  

    1.  刷新网页、人工跳转课程等操作都会使代码停止,需要重新输入。

    2. 建议一次刷一个章节,单次刷课时间不要超过四个小时,否则可能会被后台锁定!  

    3. 章节之间可能出现无法跳转,是学习通防止刷课机制。


软件链接:

https://wws.lanzous.com/b01hkgoze  不卖关子了,软件链接已经附上,请按需下载。

脚本有bug请私信博主解决。欢迎大家共同建设脚本。


软件实现截图:

 


如果有研究的习惯,附上源代码参考:

// ==UserScript==
// @name         超星学习通刷课
// @namespace    rainerosion
// @version      1.3.2
// @description  超星学习通刷课脚本 自动静音 自动1.25倍播放 自动答题(超星学习通视频弹出的题目随便选择没事)
// @author       rainerosion
// @match      *://studyh5.zhihuishu.com/videoStudy.html*
// @require      https://base1.zhihuishu.com/able-commons/resources/uploader/client/js/jquery/jquery-1.7.2.min.js
// @grant        unsafeWindow
// @license      GPL3.0
// @supportURL   https://github.com/rainerosion/zhihuishu
// ==/UserScript==
 
(function($) {
    //监听点击事件
    $("html").on("click","#rains", function () {
        StartOrStop();
    });
 
    $.noConflict(true);
    //定时器
    var timer;
    //++++++++ 以下为可设置的参数 ++++++++++
    //初始状态 0 开启 1关闭
    var startstatus = 0;
    //次数
    var number = 0;
    //视频播放到91%时候切换下一个
    var percent = 91;
    //速率
    var speed = "1.25";
    //静音
    var vol = true;
    //答题?不答题将会移除答题框
    var answer = true;
    //++++++++ 可设置的参数结束 ++++++++++
    //查找节点
    var tips = $("body");
    console.log(tips[0])
    //创建新节点
    var option = $("<div>");
    //添加样式
    var args = {
        "color":"DarkOrange",
        "text-align":"center",
        "line-height":"90px",
        "font-size":"30px",
        "background-image": "url()",
        "background-repeat": "no-repeat",
        "background-size": "100%",
        "width": "90px",
        "height": "90px",
        "border-radius": "45px",
        "position":"fixed",
        "left":"60px",
        "top":"200px",
        "z-index":"999"
    };
    option.css(args);
    option.attr("id","rains");
    option.text("Rains");
    //插入节点到页面
    tips[0].parentNode.insertBefore(option[0],tips[0]);
    //函数
    function start(){
        if(number % 20 == 0){
            console.clear();
        }
        number += 1;
 
        //获取视频速率
        var speedSpan = $(".speedBox>span").text().replace("X ","");
        if(speedSpan != speed){
            switch(speed){
                case "1.0":
                    $("div[rate='1.0']").click();
                    break;
                case "1.25":
                    $("div[rate='1.25']").click();
                    break;
                case "1.5":
                    $("div[rate='1.5']").click();
                    break;
            }
        }
        //判断音量
        var volume = parseInt($(".volumeBox .passVolume")[0].style.height);
        if(volume > 0 && vol == true){
            $(".volumeIcon").click();
        }
        //获取进度条
        var pass = $(".passTime");
        //获取答题框状态
        var dialog = $(".el-dialog__wrapper.dialog-test")[0];
        if(dialog != undefined){
            if(answer == false){
                //移除答题框
                $(".v-modal").remove();
                $(".el-dialog__wrapper.dialog-test")[0].remove();
                $("body").removeClass("el-popup-parent--hidden");
            }else{
                //如果是单选题或者判断题选择一个答案否则移除答题框
                if($(".title-tit").text() == "【单选题】" || $(".title-tit").text() == "【判断题】"|| $(".title-tit").text() == "【多选题】"){
                    //选择选项的第一个用于获取正确答案
                    let list = $(".topic-list .topic-option-item");
                    list[0].click();
                    //取消已经选择的
                    list.each(function(){
                        if($(this).hasClass("active")){
                            $(this).click();
                        }
                    })
                    //选择答案
                    let answer = $(".answer span").text().split(",");
                    for(let i in answer){
                        let option = answer[i].charCodeAt() - 65;
                        $(".topic-list .topic-option-item")[option].click();
                    }
                    //延时关闭弹窗
                    setTimeout("$(\".el-dialog__wrapper.dialog-test .el-dialog__footer .dialog-footer .btn\")[0].click();",1000);
                }else{
                    //如果不是这3个选项移除答题框以后弹框将不会出现
                    $(".v-modal").remove();
                    $(".el-dialog__wrapper.dialog-test")[0].remove();
                    $("body").removeClass("el-popup-parent--hidden");
                }
            }
            let play  = $(".bigPlayButton.pointer")[0];
            //如果暂停继续播放
            if(play.style.display == "block"){
                play.click();
            }
        }else{
            let play  = $(".bigPlayButton.pointer")[0];
            //如果暂停继续播放
            if(play.style.display == "block"){
                play.click();
            }
        }
        //判断播放进度是否大于83%
        if(parseInt(pass[0].style.width) > percent){
            //切换下一个视频
            $("#nextBtn").click();
        }
        console.log("执行第"+ number + "次");
    }
    function StartOrStop(){
        var rains = $("#rains");
        //获取播放状态
        var play  = $(".bigPlayButton.pointer")[0];
        if (startstatus == 0){
            //开始脚本
            timer = setInterval(start, 3000);
            //已经暂停 点击开始按钮 block时视频播放暂停
            startstatus = 1;
            rains.text("已开");
            rains.css("color","blue");
            console.log("刷课开始执行");
            if(play.style.display == "block"){
                play.click();
            }
        }else if (startstatus == 1) {
            //停止脚本
            clearInterval(timer);
            //已经播放 暂停播放
            startstatus = 0;
            rains.text("已关");
            rains.css("color","red");
            console.log("刷课已停止");
            if(play.style.display == "none"){
                play.click();
            }
        }
    }
    //执行监听方法 默认填入代码后开启脚本
    StartOrStop();
 
 
})(jQuery);

如有遇到BUG可留言反馈,看到会及时回复,欢迎互相学习!


更新记录:

2020-7-12有网友留言说2倍播放不能用,我之前没太注意,然后自己试了一下的确有问题,近些天尝试看能不能修复。
2020-7-29新超星测试脚本,适配多视频的课程。解决了以前一个章节下多个视频无法播放的问题。
2020-8-6不知道为什么之前用jquery语法写的用了一段时间会报错,索性直接改成了用原生javascript语法
2020-8-12删除多次反馈 已经不能用的原第一段代码,以及更新旧版等功能

 

评论将由博主筛选后显示,对所有人可见 | 还能输入1000个字符 “速评一下”
©️2020 CSDN 皮肤主题: 游动-白 设计师:上身试试 返回首页