super chutou出頭湖南繼續教育網課平臺掛視訊時長教程
每個平臺的網課都有相應的測試,然鵝這些測試對於那些堅持快樂學習至上原則的同學就不是那麼友好了,本著讓這部分同學也能享受考高分的樂趣,找到了一些讓網課學習更快樂的小幫手。
正式教程:
使用暴力猴外掛管理器,新增下列指令碼,實現自動刷課(不會下載安裝的我給整了份視訊教程,包括需要用的的外掛都放在裡邊)
連結:https://wws.lanzous.com/b01hkr0qh
因為某些原因,應用商店是打不開的,所以這裡我們選擇離線新增
第一步:檢視說明(重點)
第二步:解壓外掛
第三步:在瀏覽器上安裝
========================================================================
1.開啟擴充程式
==========================================================================
2.將解壓後的crx檔案拖入到擴充套件程式介面
============================================================================
3.點選新增
===============================================================================
4.新增完成之後,可以看到瀏覽器右上角就會出現這樣的圖示,點選後再點選新增新指令碼即可完成
===============================================================================
5.複製程式碼到編輯器後點選儲存
指令碼程式碼如下:
// ==UserScript==
// @name 超星網課助手
// @version 3.0.0
// @description 自動搜尋MOOC考試答案,支援自動答題、自動切換題目、隱藏答案搜尋提示框等,解除各類功能限制,開放自定義引數
// @author wyn665817
// @match *://*.chaoxing.com/exam/test/reVersionTestStartNew*
// @match *://*.edu.cn/exam/test/reVersionTestStartNew*
// @connect forestpolice.org
// @run-at document-end
// @grant unsafeWindow
// @grant GM_xmlhttpRequest
// @grant GM_setClipboard
// @supportURL https://greasyfork.org/zh-CN/scripts/373131/feedback
// @license MIT
// ==/UserScript==
// 設定修改後,需要重新整理或重新開啟網課頁面才會生效
var setting = {
// 5E3 == 5000,科學記數法,表示毫秒數
time: 5E3 // 預設響應速度為5秒,不建議小於3秒
,token: '' // 捐助使用者可以使用定製功能,更精準的匹配答案,此處填寫捐助後獲取的識別碼
// 1代表開啟,0代表關閉
,none: 0 // 未找到答案或無匹配答案時執行預設操作,預設關閉
,jump: 0 // 答題完成後自動切換,預設關閉
,copy: 0 // 自動複製答案到剪貼簿,也可以通過手動點選按鈕或答案進行復制,預設關閉
// 非自動化操作
,hide: 0 // 不載入答案搜尋提示框,鍵盤↑和↓可以臨時移除和載入,預設關閉
,scale: 0 // 富文字編輯器高度自動拉伸,用於文字類題目,答題框根據內容自動調整大小,預設關閉
},
_self = unsafeWindow,
$ = _self.jQuery,
UE = _self.UE;
String.prototype.toCDB = function() {
return this.replace(/\s/g, '').replace(/[\uff01-\uff5e]/g, function(str) {
return String.fromCharCode(str.charCodeAt(0) - 65248);
}).replace(/[“”]/g, '"').replace(/[‘’]/g, "'").replace(/。/g, '.');
};
// setting.time += Math.ceil(setting.time * Math.random()) - setting.time / 2;
setting.TiMu = [
filterImg('.Cy_TItle .clearfix').replace(/\s*(\d+\.\d+分)$/, ''),
$('[name^=type]:not([id])').val() || '-1',
$('.cur a').text().trim() || '無',
$('li .clearfix').map(function() {
return filterImg(this);
})
];
setting.div = $(
'<div style="border: 2px dashed rgb(0, 85, 68); width: 330px; position: fixed; top: 0; right: 0; z-index: 99999; background-color: rgba(70, 196, 38, 0.6); overflow-x: auto;">' +
'<span style="font-size: medium;"></span>' +
'<div style="font-size: medium;">正在搜尋答案...</div>' +
'<button style="margin-right: 10px;">暫停答題</button>' +
'<button style="margin-right: 10px;' + (setting.jump ? '' : ' display: none;') + '">點選停止本次切換</button>' +
'<button style="margin-right: 10px;">重新查詢</button>' +
'<button style="margin-right: 10px; display: none;">複製答案</button>' +
'<button>答題詳情</button>' +
'<div style="max-height: 200px; overflow-y: auto;">' +
'<table border="1" style="font-size: 12px;">' +
'<thead>' +
'<tr>' +
'<th colspan="2">' + ($('#randomOptions').val() == 'false' ? '' : '<font color="red">本次考試的選項為亂序 指令碼會選擇正確的選項</font>') + '</th>' +
'</tr>' +
'<tr>' +
'<th style="width: 60%; min-width: 130px;">題目(點選可複製)</th>' +
'<th style="min-width: 130px;">答案(點選可複製)</th>' +
'</tr>' +
'</thead>' +
'<tfoot style="' + (setting.jump ? ' display: none;' : '') + '">' +
'<tr>' +
'<th colspan="2">已關閉 本次自動切換</th>' +
'</tr>' +
'</tfoot>' +
'<tbody>' +
'<tr>' +
'<td colspan="2" style="display: none;"></td>' +
'</tr>' +
'</tbody>' +
'</table>' +
'</div>' +
'</div>'
).appendTo('body').on('click', 'button, td', function() {
var num = setting.$btn.index(this);
if (num == -1) {
GM_setClipboard($(this).text());
} else if (num === 0) {
if (setting.loop) {
clearInterval(setting.loop);
delete setting.loop;
num = ['已暫停搜尋', '繼續答題'];
} else {
setting.loop = setInterval(findTiMu, setting.time);
num = ['正在搜尋答案...', '暫停答題'];
}
setting.$div.html(function() {
return $(this).data('html') || num[0];
}).removeData('html');
$(this).html(num[1]);
} else if (num == 1) {
setting.jump = 0;
setting.$div.html(function() {
return arguments[1].replace('即將切換下一題', '未開啟自動切換');
});
setting.div.find('tfoot').add(this).toggle();
} else if (num == 2) {
location.reload();
} else if (num == 3) {
GM_setClipboard(setting.div.find('td:last').text());
} else if (num == 4) {
($('.leftCard .saveYl')[0] || $()).click();
}
}).detach(setting.hide ? '*' : 'html');
setting.$btn = setting.div.children('button');
setting.$div = setting.div.children('div:eq(0)');
$(document).keydown(function(event) {
if (event.keyCode == 38) {
setting.div.detach();
} else if (event.keyCode == 40) {
setting.div.appendTo('body');
}
});
if (setting.scale) _self.UEDITOR_CONFIG.scaleEnabled = false;
$.each(UE.instants, function() {
var key = this.key;
this.ready(function() {
this.destroy();
UE.getEditor(key);
});
});
setting.loop = setInterval(findTiMu, setting.time);
function findTiMu() {
GM_xmlhttpRequest({
method: 'POST',
url: 'http://mooc.forestpolice.org/cxk/' + (setting.token || 0) + '/' + encodeURIComponent(setting.TiMu[0]),
headers: {
'Content-type': 'application/x-www-form-urlencoded'
},
data: 'question=' + encodeURIComponent(setting.TiMu[0]) + '&type=' + setting.TiMu[1],
timeout: setting.time,
onload: function(xhr) {
if (!setting.loop) {
} else if (xhr.status == 200) {
var obj = $.parseJSON(xhr.responseText) || {};
if (obj.code) {
var data = String(obj.data).replace(/&/g, '&').replace(/<(?!img)/g, '<'),
que = setting.TiMu[0].match('<img') ? setting.TiMu[0] : setting.TiMu[0].replace(/&/g, '&').replace(/</g, '<');
obj.data = /^http/.test(data) ? '<img src="' + obj.data + '">' : obj.data;
setting.div.find('tbody').append(
'<tr>' +
'<td title="點選可複製">' + que + '</td>' +
'<td title="點選可複製">' + (/^http/.test(data) ? obj.data : '') + data + '</td>' +
'</tr>'
);
setting.copy && GM_setClipboard(obj.data);
setting.$btn.eq(3).show();
fillAnswer(obj);
} else {
setting.$div.html(obj.data || '伺服器繁忙,正在重試...');
}
setting.div.children('span').html(obj.msg || '');
} else if (xhr.status == 403) {
var html = xhr.responseText.indexOf('{') ? '請求過於頻繁,建議稍後再試' : $.parseJSON(xhr.responseText).data;
setting.$div.data('html', html).siblings('button:eq(0)').click();
} else {
setting.$div.text('伺服器異常,正在重試...');
}
},
ontimeout: function() {
setting.loop && setting.$div.text('伺服器超時,正在重試...');
}
});
}
function fillAnswer(obj, tip) {
var $input = $(':radio, :checkbox', '.Cy_ulBottom'),
str = String(obj.data).toCDB() || new Date().toString(),
data = str.split(/#|\x01|\|/),
opt = obj.opt || str,
btn = $('.saveYl:contains(下一題)').offset();
// $input.filter(':radio:checked').prop('checked', false);
obj.code > 0 && $input.each(function(index) {
if (this.value == 'true') {
data.join().match(/(^|,)(正確|是|對|√|T|ri)(,|$)/) && this.click();
} else if (this.value == 'false') {
data.join().match(/(^|,)(錯誤|否|錯|×|F|wr)(,|$)/) && this.click();
} else {
index = setting.TiMu[3][index].toCDB() || new Date().toString();
index = $.inArray(index, data) + 1 || (setting.TiMu[1] == '1' && str.indexOf(index) + 1);
Boolean(index) == this.checked || this.click();
}
}).each(function() {
if (!/^A?B?C?D?E?F?G?$/.test(opt)) return false;
Boolean(opt.match(this.value)) == this.checked || this.click();
});
if (setting.TiMu[1].match(/^[013]$/)) {
tip = $input.is(':checked') || setting.none && (($input[Math.floor(Math.random() * $input.length)] || $()).click(), ' ');
} else if (setting.TiMu[1].match(/^(2|[4-9]|1[08])$/)) {
data = String(obj.data).split(/#|\x01|\|/);
tip = $('.Cy_ulTk textarea').each(function(index) {
index = (obj.code > 0 && data[index]) || '';
UE.getEditor(this.name).setContent(index.trim());
}).length;
tip = (obj.code > 0 && data.length == tip) || setting.none && ' ';
setting.len = str.length * setting.time / 10;
}
if (tip == ' ') {
tip = '已執行預設操作';
} else if (tip) {
tip = '自動答題已完成';
} else if (tip === undefined) {
tip = '該題型不支援自動答題';
} else {
tip = '未找到有效答案';
}
if (btn) {
tip += setting.jump ? ',即將切換下一題' : ',未開啟自動切換';
setInterval(function() {
if (!setting.jump) return;
var mouse = document.createEvent('MouseEvents'),
arr = [btn.left + Math.ceil(Math.random() * 80), btn.top + Math.ceil(Math.random() * 26)];
mouse.initMouseEvent('click', true, true, document.defaultView, 0, 0, 0, arr[0], arr[1], false, false, false, false, 0, null);
_self.event = $.extend(true, {}, mouse);
delete _self.event.isTrusted;
_self.getTheNextQuestion(1);
}, setting.len || Math.ceil(setting.time * Math.random()) * 2);
} else {
setting.$btn.eq(1).hide();
tip = '答題已完成,請自行檢視答題詳情';
}
setting.$div.data('html', tip).siblings('button:eq(0)').hide().click();
}
function filterImg(dom) {
return $(dom).clone().find('img[src]').replaceWith(function() {
return $('<p></p>').text('<img src="' + $(this).attr('src') + '">');
}).end().find('iframe[src]').replaceWith(function() {
return $('<p></p>').text('<iframe src="' + $(this).attr('src') + '"></irame>');
}).end().text().trim();
第四步:點選開始答題後可在網頁上看到當前章節測試的答案了。
注:此版本僅供內部學習研究之用,請勿商用,如有入到BUG可留言反饋,看到會及時回覆!
相關文章
- CDH構建企業大資料平臺視訊教程-曹金博-專題視訊課程大資料
- TP FANS線上教育系統|慕課網|線上視訊|
- 西南大學網路與繼續教育學院課程考試試題卷
- TP開發的視訊課程學習平臺
- RTSP網路攝像頭網頁無外掛直播視訊平臺EasyNVR自定義標題和CopyRight步驟網頁VR
- 繼續教育-支援網站應用程式的下載網站
- 視訊分享平臺
- 基於KVM架構虛擬化平臺(RHEV)安裝及配置視訊教程-黃波-專題視訊課程架構
- 短視訊平臺原始碼,平臺顯示時間,時間格式的轉換原始碼
- thinkphp開發 網易雲課堂-線上IT學習|視訊教程|慕課網PHP
- Github視訊教程-黃棒清-專題視訊課程Github
- OpenGL視訊教程-黃棒清-專題視訊課程
- 網頁版影片遠端教育平臺網頁
- Google Drive 視訊教程-黃棒清-專題視訊課程Go
- 短視訊平臺中明星賬號氾濫 需加強對網路短視訊平臺的監管力度
- java讀取視訊時長Java
- 短視訊平臺開發,在上傳圖片時,自動新增平臺的水印
- Python全棧視訊教程-尹成-專題視訊課程Python全棧
- 10小時掌握區塊鏈開發教程-CSDN公開課-專題視訊課程區塊鏈
- 北風網 web全棧視訊教程 前端全套視訊教程Web全棧前端
- 短視訊平臺有哪些?什麼平臺收益高?
- 短視訊平臺開發,點選輸入框時自動彈出軟鍵盤
- 短視訊平臺原始碼,長按視訊、對話方塊彈出操作可選按鈕原始碼
- chrome瀏覽器視訊教程-黃棒清-專題視訊課程Chrome瀏覽器
- 線上教育網校、教育SaaS平臺實現數字化轉型
- iOS AVPlayer之後臺連續播放視訊iOS
- 國家智慧教育平臺上線 一站搜尋全網2萬門好課
- iNeuOS工業互聯平臺,WEB組態(iNeuView)整合rtmp和websocket視訊元件,支援海康、大華等攝像頭實時顯示視訊WebView元件
- ios平臺cocos2d-x播放音訊、視訊、音效的Demo(支援網路視訊)iOS音訊
- 慕課平臺
- 視訊通話 - 時信魔方教程
- 程式設計教育平臺程式設計
- 短視訊的平臺有哪些?哪些平臺適合新手?
- 短視訊平臺搭建,選擇年月日時間軸日期
- 短視訊系統原始碼,平臺的時間處理方式原始碼
- java繼承-super的用法Java繼承
- 尚矽谷Doris視訊教程釋出
- 尚矽谷SeaTunnel視訊教程釋出