// ==UserScript== // @name 成都文理学院刷课助手|自动刷课|考试自动答题 // @version 2.1.3 // @description 成都文理学院刷课助手,(虽不止成文理,但仅在成文理做了测试)🚀目前已支持平台:【数字化实习实训平台、公益课程、在线学堂、英华学堂】。😀目前已具有功能包括:视频自动播放、自动识别填充验证码、考试自动答题等功能。如有bug请留言。🐧QQ交流群:878643471 // @author iFulling // @match *://zxshixun.cdcas.com/* // @match *://*.zjxkeji.com/* // @match *://mooc.cdcas.com/* // @match *://*.rurenkj.com/* // @match *://*/* // @icon  // @grant GM_xmlhttpRequest // @grant GM_setValue // @grant GM_getValue // @grant GM_listValues // @license MIT // @namespace https://github.com/iFulling/cdcasSK // @connect 119.8.102.43 // @connect 119.8.102.43:5000 // @connect ark.cn-beijing.volces.com // @downloadURL https://update.greasyfork.icu/scripts/512596/%E6%88%90%E9%83%BD%E6%96%87%E7%90%86%E5%AD%A6%E9%99%A2%E5%88%B7%E8%AF%BE%E5%8A%A9%E6%89%8B%7C%E8%87%AA%E5%8A%A8%E5%88%B7%E8%AF%BE%7C%E8%80%83%E8%AF%95%E8%87%AA%E5%8A%A8%E7%AD%94%E9%A2%98.user.js // @updateURL https://update.greasyfork.icu/scripts/512596/%E6%88%90%E9%83%BD%E6%96%87%E7%90%86%E5%AD%A6%E9%99%A2%E5%88%B7%E8%AF%BE%E5%8A%A9%E6%89%8B%7C%E8%87%AA%E5%8A%A8%E5%88%B7%E8%AF%BE%7C%E8%80%83%E8%AF%95%E8%87%AA%E5%8A%A8%E7%AD%94%E9%A2%98.meta.js // ==/UserScript== let videoElement = null; let checkCaptchaTimer = null; let containerTextElement = null; let examTextElement = null; let sponsorElement = null; let statementElement = null; let layuiLayerContent = null; let links = null; let current = 0; let timerCnt = 0; let version = "2.1.3" let endpoint_id = ""; let apikey = ""; let examCurrent = 0; let startFlag = false; // 获取当前课程 function getCurrent() { links = $('a[target="_self"]'); links.each((index, item) => { if ($(item).hasClass("on")) { return current = index } }); } // 下一个视频 async function playNext() { clearInterval(checkCaptchaTimer); if (current === links.length - 1) { addText("最后一个已看完!") } else { addText("准备播放下一个视频...") await pause(3) links[current + 1].click(); } } // 输入验证码 async function inputCaptcha() { if (layuiLayerContent.length && layuiLayerContent.is(':visible')) { addText("验证码弹窗出现,准备填写验证码..."); await pause(2, 5) // 获取图片 let imgs = layuiLayerContent.find("img") let img = imgs[0].style.opacity === '0' ? imgs[1] : imgs[0] // 图片转base64 let canvas = document.createElement("canvas"); let ctx = canvas.getContext("2d"); canvas.width = img.width; canvas.height = img.height; ctx.drawImage(img, 0, 0, img.width, img.height); let code = canvas.toDataURL("image/png").split("base64,")[1]; // 调用接口,识别验证码 let ans = await getCode(code) // 获取input,填入验证码 let inputs = layuiLayerContent.find("input") let input = inputs[0].style.display === 'none' ? inputs[1] : inputs[0] $(input).mousedown() input.value = ans // 点击开始播放按钮 await pause(2, 5) const playButton = $('.layui-layer-btn0'); if (playButton.length) { playButton.click(); checkCaptchaTimer = setInterval(playVideo, 1000); addText("已自动点击开始播放按钮!"); } else { addText("未找到开始播放按钮,尝试刷新页面...."); location.reload(); // 刷新当前页面 } } } async function test(){ let img = $("#codeImg")[0] // 图片转base64 let canvas = document.createElement("canvas"); let ctx = canvas.getContext("2d"); canvas.width = img.width; canvas.height = img.height; ctx.drawImage(img, 0, 0, img.width, img.height); let code = canvas.toDataURL("image/png").split("base64,")[1]; // 调用接口,识别验证码 let ans = await getCode(code) console.log(ans) } function getCode(code) { return new Promise((resolve, reject) => { const datas = { "ImageBase64": String(code), } GM_xmlhttpRequest({ method: "POST", url: "http://119.8.102.43:5000/get_captcha", data: JSON.stringify(datas), headers: { "Content-Type": "application/json", }, responseType: "json", timeout: 10000, ontimeout: async function (e) { addText("验证码获取超时,刷新页面..."); await pause(3) location.reload(); // 刷新当前页面 }, onload: function (response) { if (response.status == 200) { let result = response.response["message"]; addText("识别结果:" + result); return resolve(result); } else { let result = JSON.parse(response.response)["message"]; addText(result); addText("识别失败,请勿开启代理,或联系管理员。🐧群:878643471"); } }, onerror: function (error) { addText(`${error.statusText} ${error.status} - 出错了`) }, }); }); } // 播放视频,同时检测验证码 async function playVideo() { timerCnt++; if (timerCnt % 5 === 0) { addText("等待加载,已加载:" + timerCnt + "秒") } if (timerCnt > 20) { addText("刷新页面") location.reload(); return } if (!videoElement) { if (links[current].title && current === links.length - 1) { addText("课程已看完,自动停止!") clearInterval(checkCaptchaTimer) }else if (links[current].title && /考试|章节作业|自学教材/.test(links[current].title)){ addText("没有视频,准备跳过...") clearInterval(checkCaptchaTimer) await playNext(); }else { getVideoElement(); } return } // 验证码弹窗 layuiLayerContent = $('.layui-layer-content'); if (layuiLayerContent.length > 0) { clearInterval(checkCaptchaTimer); await inputCaptcha() return; } // 检测视频是否加载成功且暂停 // if (!videoElement) return; if (videoElement.paused) { videoElement.play(); if (videoElement.readyState === 4) { const message = containerTextElement.text().includes("视频加载完成") ? "请将浏览器置于前台运行。(若学时会增加可忽略)" : "视频加载完成,准备播放"; addText(message); } } else { timerCnt = 0; } } // 获取视频元素 const getVideoElement = () => { videoElement = document.querySelector("video"); videoElement.muted = true; videoElement.playbackRate = 1.0; videoElement.volume = 0; videoElement.onended = async function () { await playNext(); }; } // 添加交互显示 const addContainer = () => { const mini = $("