zoukankan      html  css  js  c++  java
  • 智慧树刷课

    网课比较麻烦,但是也比较容易,仅仅需要几段代码就可以实现自动刷课。由于本人初学爬虫,对于JavaScript也不是太熟悉,因此在网上找了一些代码,对其进行一下汇总。

    打开浏览器,在智慧树网课播放界面按F12 在第二个Console界面复制下面的任意一段代码按enter就可以了,挂着就能自动刷了。

    代码一:

    写在前面,改代码可以实现1.5倍速播放,静音播放,自动播放下一集,但是不能跳过弹出的习题

    (function () {
    	const MAX_DELAY = 60 // 切课时的最大延迟,单位:秒
    
    	const sleep = (time) => new Promise((resolve) => setTimeout(resolve, time))
    
    	const start = async function () {
    		console.log('智慧树助手已启动')
    
    		while (true) {
    			console.log('正在检查')
    			const delay = Math.floor(Math.random() * MAX_DELAY * 1000) + 1000
    
    			if (!/1.5/.test($('.speedBox').attr('style'))) {
    				console.log('提升到1.5倍速')
    				$('.speedTab15').click()
    			}
    
    			if (!/liuchang/.test($('.definiBox').attr('style'))) {
    				console.log('更改画质')
    				$('.line1bq').click()
    			}
    
    			if ($('.volumeBox').find('.passVolume').width() != 0) {
    				console.log('静音')
    				$('.volumeIcon').click()
    			}
    			
    			if ($('.playButton').length > 0) {
    				console.log('点击播放')
    				$('.playButton').click()
    			}
    
    			if ($('.popbtn_cancel')[0]) {
    				console.log('发现弹题,将在' + delay / 1000 + ' 秒后点击关闭')
    				await sleep(delay)
    				$('.popbtn_cancel').click()
    			}
    
    			if ($('.current_play').find('.progressbar').width() == $('.current_play').find('.progressbar_box').width()) {
    				console.log('本节完成,' + delay / 1000 + ' 秒后将切到下一课')
    				await sleep(delay)
    				$('.current_play').nextAll('.video')[0].click()
    			}
    
    			await sleep(1000)
    		}
    	}
    
    	start()
    }())
    

    代码二:

    写在前面,改代码可以实现1.5倍速播放,静音播放,自动播放下一集,并且可以自动跳过习题。

    var ti = $("body");
    var video = $(".catalogue_ul1 li[id*=video-]");
    var i = 1;
    var v = 1;
    video.css("color", "blue");
    console.log("已选取" + video.length + "个小节,并已用蓝色标明,请检查是否有遗漏,如有遗漏,概不负责");
    setTimeout(function () {
        $('.speedTab15').click();
        $('.volumeIcon').click();
        console.log("已进行静音和1.5倍加速");
    }, 3000);
    ti.on("DOMNodeInserted", function (e) {
        if (e.target.textContent == "关闭") {
            console.log("检测到第" + i + "个弹题窗口");
            window.setTimeout(function () {
                document.getElementById("tmDialog_iframe").contentWindow.document.getElementsByClassName("answerOption")[0].getElementsByTagName("input")[0].click();
                $(".popbtn_cancel").click();
                console.log("已关闭");
            }, 3000);
            i++;
        } else if (e.target.textContent == "本节视频,累计观看时间『100%』") {
            console.log("检测到视频观看完成,准备跳到下一节");
            $('.next_lesson_bg').find('a').trigger('click');
            console.log("已跳转");
            setTimeout(function () {
                $('.volumeIcon').click();
                $('.speedTab15').click();
                console.log("已进行静音和1.5倍加速");
            }, 6000);
            v++;
            console.log("目前播放了" + v + "个视频");
        }
    });
    

    代码三:

    写在前面,改代码可以实现1.5倍速播放,不能静音播放,自动播放下一集,并且可以自动跳过习题。

    function timeCount()
    {
        if(document.getElementById('popbox_title')) {
            var x = document.getElementsByClassName('popbtn_cancel');
            window.clearInterval();
            x[0].click();
            console.log('关闭窗口');
    
        }
    
    }
    var time=0;
    var father=document.getElementById("my");
    var divs = document.createElement("div");
    divs.id='mybutton';
    divs.style.position='fixed';
    divs.style.left='150px';
    divs.style.top='100px';
    divs.style.width='72px';
    divs.style.height='72px';
    divs.style.backgroundImage="url('')";
    divs.onclick=function(){
        setTimeout(function(){
            console.log('切换到1.5倍');
            document.getElementsByClassName('speedTab15')[0].click();
        },5000);
        if(time===0){
            alert('已经启动,可以最小化了');
        }else{
            console.log('第二次初始化');
        }
    
        //视频播放暂停
        document.getElementById("vjs_mediaplayer_html5_api").onpause = function() {
            console.log('已暂停');
            window.setInterval(timeCount(),700);
    
        };
    
        //视频播放结束
        document.getElementById("vjs_mediaplayer_html5_api").onended=function(){
            console.log('已结束');
            setTimeout(function(){
                //document.getElementsByClassName('next_lesson_bg tm_next_lesson')[0].click();
                document.getElementById('nextBtn').click();
    
                setTimeout(function(){
                    time=1;
                    divs.click();
                },5000);
    
    
    
            },2500);
    
        };
    
    
    };
    document.body.appendChild(divs);
    
  • 相关阅读:
    css自定义字体
    nuxt按需引入 element-UI、自定义主题色(终极按需引入)
    Vue 拖拽组件 vuedraggable 和 awe-dnd
    css 0.5px
    react取消监听scroll事件
    vue使用jsonp
    nuxt使用QRCode.js 生成二维码
    阻止冒泡
    nuxt.js配置BASE_URL(基本域名)和NODE_ENV(环境变量)
    Numpy基础学习笔记1
  • 原文地址:https://www.cnblogs.com/mach-pupil/p/12535348.html
Copyright © 2011-2022 走看看