吾爱破解 - 52pojie.cn

 找回密码
 注册[Register]

QQ登录

只需一步,快速开始

查看: 23357|回复: 37
上一主题 下一主题
收起左侧

[其他转载] 原创知到智慧树刷课脚本

  [复制链接]
跳转到指定楼层
楼主
yushangwl 发表于 2020-4-15 21:50 回帖奖励
本帖最后由 yushangwl 于 2020-4-16 00:11 编辑

近期选课太多了,一个个看太麻烦,于是写了这段代码。之前我写的是js代码用在浏览器console控制台的。但是由于那些代码写的早了,早就失效了,我看到论坛之前也有人发过基于我的代码的修改版本,但是早就失效了。现在我重新弄了一个tampermonkey版本的出来供大家参考。console控制台版本的当然也有提供。

  • 自动播放
  • 自动下一集
  • 自动1.25倍速率

自动答题就是走一个形式,智慧树并不会用来算分数,本脚本多选题可能会选错,请悉知。由于智慧树有学习习惯分,一次刷完所有课程将没有学习习惯分,请注意。
tampermonkey版本的代码如下:
[JavaScript] 纯文本查看 复制代码
// ==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);

浏览器Console运行版本的代码如下
[JavaScript] 纯文本查看 复制代码
/**
 *  author: 雨落凋殇
 *  description: 自动播放、自动下一集、自动选择视频弹窗题目、自动关闭答题窗口、刷智慧树网课必备
 *  use-method: 打开智慧树播放课程界面 按F12 -> Console -> 粘贴本代码 ->按回车键
 *  use-method: 视频左上方出现一个图标点击图标开始刷课 显示‘已开’脚本开始监听 再次点击图标关闭
 *  upadteTime: 2019/04/03 21:36:00
 */
//定时器
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 = $(".video-study");
//创建新节点
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("onClick","StartOrStop()");
option.attr("id","rains");
option.text("Rains");
//插入节点到页面
tips[0].parentNode.insertBefore(option[0],tips[0]);
//函数
function start(){
    if(number % 200 == 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() == "【多选题】"){
                //选择选项的第一个用于获取正确答案
                $(".topic-list .topic-option-item")[0].click();
                //取消已经选择的
                $(".topic-list .topic-option-item").each(function(){
                    if($(this).hasClass("active")){
                        $(this).click();
                    }
                })
                //选择答案
                let answer = $(".answer span").text().split(",");
                $.each(answer,function(index,value){
                    let option = value.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时视频播放暂停
        if(play.style.display == "block"){
            play.click();
        }
        startstatus = 1;
        rains.text("已开");
        rains.css("color","blue");
        console.log("刷课开始执行");
    }else if (startstatus == 1) {
        //停止脚本
        clearInterval(timer);
        //已经播放 暂停播放
        if(play.style.display == "none"){
            play.click();
        }
        startstatus = 0;
        rains.text("已关");
        rains.css("color","red");
        console.log("刷课已停止");
    }
}
//执行监听方法 默认填入代码后开启脚本
StartOrStop();


使用方法一:Tampermonkey脚本使用方法

  • 打开浏览器

  • 安装tampermonkey插件

  • 打开Tampermonkey实用工具

  • Install from URL中填入https://raw.githubusercontent.com/rainerosion/zhihuishu/master/zhihuishu-tampermonkey.js

  • 点击安装按钮

  • 在弹出的窗口中点击安装,窗口自动关闭

  • 进入智慧树课程播放界面自动开始刷课

使用方法二:浏览器console运行方法

  • 打开智慧树播放网课的界面

  • F12 选择console选项卡

  • 复制zhihuishu-console.js中的内容

  • 粘贴脚本内容到控制台console输入框后回车。

  • 关闭开发者工具弹框(页面重新刷新后需要重复以上步骤)


如果本代码帮助到了你,请给我一个免费的评分吧,谢谢!

免费评分

参与人数 33吾爱币 +28 热心值 +29 收起 理由
Shunbaba + 1 + 1 谢谢@Thanks!
汪汪汪 + 1 热心回复!
mdzzz0 + 1 作者的分享很有用
fly4 + 1 + 1 我很赞同!
wyt884211024 + 1 + 1 我很赞同!
zjw00 + 1 谢谢@Thanks!
耗子扛刀 + 1 + 1 热心回复!
yueyueyue16 + 1 + 1 谢谢@Thanks!
西瓜国王 + 1 + 1 我很赞同!
狙击 + 1 谢谢@Thanks!
hello-jack + 1 热心回复!
nxg0916 + 1 我很赞同!
51528098 + 1 + 1 用心讨论,共获提升!
linzi0713 + 2 + 1 谢谢大佬,希望能继续更新安卓或电脑自动刷课的。
风待葬 + 1 + 1 用心讨论,共获提升!
mei78532027 + 1 感谢您的宝贵建议,我们会努力争取做得更好!
q2580777860 + 1 + 1 谢谢@Thanks!
查拉图斯托特 + 1 + 1 谢谢@Thanks!
EA7_AY + 1 谢谢@Thanks!
烤得酥脆 + 1 + 1 我很赞同!
19884303209 + 1 感谢分享
yanglixing + 1 我很赞同!
不开的唇 + 1 我很赞同!
Pppppp + 1 + 1 我很赞同!
ljn000 + 1 + 1 热心回复!
keddo + 1 + 1 上学期用过,还帮别人刷过 一晚刷完一个课程,没有封号,不过现在不知道会.
fangfang_ + 1 + 1 谢谢@Thanks!
Vince0371 + 1 谢谢@Thanks!
魏亚楠 + 1 + 1 谢谢@Thanks!
fyypll + 1 + 1 谢谢@Thanks!
那年夏天52 + 2 + 1 感谢发布原创作品,吾爱破解论坛因你更精彩!
WLy0214 + 2 + 1 感谢发布原创作品,吾爱破解论坛因你更精彩!
红颜世家、 + 1 + 1 谢谢@Thanks!

查看全部评分

本帖被以下淘专辑推荐:

发帖前要善用论坛搜索功能,那里可能会有你要找的答案或者已经有人发布过相同内容了,请勿重复发帖。

推荐
 楼主| yushangwl 发表于 2020-4-15 23:09 |楼主
E式丶男孩 发表于 2020-4-15 22:44
应该加个定时暂停的,哈哈

这个可以有,就是懒啊。懒得加,哈哈·
头像被屏蔽
推荐
yufei1 发表于 2020-9-2 17:50
3#
qwq1 发表于 2020-4-15 22:15
4#
Avein 发表于 2020-4-15 22:15
走个形式回复一下
5#
xiaog 发表于 2020-4-15 22:32
介绍一下是什么东西啊
6#
私心作怪 发表于 2020-4-15 22:33
当初不知道有学习习惯分 一天看了快半个课时
7#
hs_f 发表于 2020-4-15 22:35
学习进步!感谢
8#
E式丶男孩 发表于 2020-4-15 22:44
应该加个定时暂停的,哈哈
9#
梦他梦她 发表于 2020-4-15 23:23
不错谢谢分享
10#
超圣 发表于 2020-4-16 00:04
感谢分享
您需要登录后才可以回帖 登录 | 注册[Register]

本版积分规则

返回列表

RSS订阅|小黑屋|处罚记录|联系我们|吾爱破解 - LCG - LSG ( 京ICP备16042023号 | 京公网安备 11010502030087号 )

GMT+8, 2025-1-16 14:21

Powered by Discuz!

Copyright © 2001-2020, Tencent Cloud.

快速回复 返回顶部 返回列表