meng521215 发表于 2024-10-6 22:42

【油猴脚本】第九届全国学生宪法小卫士,答题脚本 更新了下大神版本,基本可以自动

登录页面https://static.qspfw.moe.gov.cn/user/#/user/login?backUrl=http%3A%2F%2Fstatic.qspfw.moe.gov.cn%2Fxf2024%2Flearn_practice_list.html 在这里导入Excel表格 表格里是三列,学校账号,学生姓名,密码
。去年用过的应该都会,感谢https://www.52pojie.cn/forum.php?mod=viewthread&tid=1964190&highlight=%CF%DC%B7%A8 原贴作者
// ==UserScript==
// @name         普法网(宪法小卫士)课后练习、考试自动答题
// @namespace    Ne-21
// @version      1.3.9
// @description全国学生“学宪法 讲宪法”活动自动答题脚本,因缺少测试账号无法保证每年都能用,欢迎大家提供测试账号以支持此脚本长期可用,测试账号登录信息请发送至我们的邮箱nawlgzs@gmail.com
// @AuThor       Ne-21
// @match      *://static.qspfw.moe.gov.cn/*
// @Icon         
// @run-at       document-end
// @grant      unsafeWindow
// @grant      GM_setValue
// @grant      GM_getValue
// @license      MIT
// @require      https://lf9-cdn-tos.bytecdntp.com/cdn/expire-1-M/jquery/3.6.0/jquery.min.js
// @require      https://lf26-cdn-tos.bytecdntp.com/cdn/expire-1-M/limonte-sweetalert2/11.0.1/sweetalert2.all.min.js
// @require      https://lf26-cdn-tos.bytecdntp.com/cdn/expire-1-M/crypto-js/4.1.1/crypto-js.min.js
// @require      https://cdnjs.cloudflare.com/ajax/libs/xlsx/0.17.0/xlsx.full.min.js
// @downloadURL https://update.greasyfork.org/scripts/430038/%E6%99%AE%E6%B3%95%E7%BD%91%EF%BC%88%E5%AE%AA%E6%B3%95%E5%B0%8F%E5%8D%AB%E5%A3%AB%EF%BC%89%E8%AF%BE%E5%90%8E%E7%BB%83%E4%B9%A0%E3%80%81%E8%80%83%E8%AF%95%E8%87%AA%E5%8A%A8%E7%AD%94%E9%A2%98.user.js
// @updateURL https://update.greasyfork.org/scripts/430038/%E6%99%AE%E6%B3%95%E7%BD%91%EF%BC%88%E5%AE%AA%E6%B3%95%E5%B0%8F%E5%8D%AB%E5%A3%AB%EF%BC%89%E8%AF%BE%E5%90%8E%E7%BB%83%E4%B9%A0%E3%80%81%E8%80%83%E8%AF%95%E8%87%AA%E5%8A%A8%E7%AD%94%E9%A2%98.meta.js
// ==/UserScript==

var _self = unsafeWindow,
    $ = _self.jQuery || top.jQuery,
    Swal = Swal || window.Swal,
    columnId = getQueryVariable("columnId"),
    answer_list = [],
    exam_list = [],
    time = 2e3, // 答题间隔时间,最好为5秒
    save_key = "xfxws2024",
    num = {"A": 1,"B": 2, "C": 3, "D": 4};

(function() {
    //alert(window.location.pathname);

    if (window.location.pathname.indexOf('learn_exam.html') != -1) {
       // Swal.fire('宪法小助手提示','点击确定开始考试','info').then(()=>{
            Swal.fire({
                position: 'top-end',
                title: '脚本将在2秒后开始自动作答!',
                showConfirmButton: false,
                timer: 2000
            })
            getExam();
            let t = setInterval( function() {
                doExam(t)
            },time);
      //})
    } else if (window.location.pathname.indexOf('learn-practice.html') != -1) {
   //   Swal.fire('宪法小助手提示','点击确定开始练习,脚本会自动收录本练习题目数据','info').then(()=>{
            getAnswer(columnId);
            let t = setInterval( function() {
                doQuestion(t)
            },time);
      //})
    } else if (window.location.pathname.indexOf('learn_practice_list.html') != -1) {
       // Swal.fire('宪法小助手提示','<div style="font-size: 13px;">脚本最后更新时间:2024.09.12<br />使用说明:<br /><div><span style="color: red;">1.脚本题库数据托管于本地,请在做综合评价前逐个完成练习,收集答案!!!</span><br />2.脚本运行故障如综合测评无操作等,请使用Edge浏览器+ScriptCat。<br />3.问题联系邮箱nawlgzs@gmail.com<br />4.脚本数据来自本网站后端返回的明文JSON数据包,脚本不涉及任何逆向操作!<br />5.脚本仅供学习交流,请勿用于商业用途,否则后果自负!</div></div>')
   //toLearning(this);
      setTimeout(function(){ $(".red").click();},time / 2);
    } else if (window.location.pathname.indexOf('evaluation.html') != -1) {
      
    }
    else if (window.location.pathname.indexOf('learning-page.html') != -1) {
   //   alert(111);
      $('#afterClassPractice').click();
    }
    else if (window.location.pathname.indexOf('/user/') != -1) {
      // alert(111);
      //$('#afterClassPractice').click();

      setTimeout(function(){
             createFileInput();
            readFile();
            readAndWriteStudentInfo();

          //$(".ant-radio-input").click();
      },2000);
    }
})();

// 解析url参数
function getQueryVariable(variable) {
       var query = window.location.search.substring(1);
       var vars = query.split("&");
       for (var i=0;i<vars.length;i++) {
               var pair = vars.split("=");
               if(pair == variable){return pair;}
       }
       return(false);
};

// 正则匹配
function getStr(str, start, end) {
    let res = str.match(new RegExp(`${start}(.*?)${end}`))
    return res ? res : null
}

// 获取答案
function getAnswer(columnId) {
    // var html = $("html").html(),
    //   taskId = getStr(html,'&taskId=','`,')

    $.ajax({
      url: _self.config.practice.host + _self.config.practice.practice + "?columnId="+ columnId + "&taskId=" + _self.config.taskId,
      headers: _self.config.apiConfig.header,
      async: false,
      success: function (res) {
            const { data, status } = res;
            if (status === "0") {
                var question_data = res.data
                var questionBankList = data.questionBankList
                answer_list = questionBankList;
                upload(answer_list)
            } else if (status === "1") {
                //无效的columnId(下个接口是chapterId)
                alert("请先学习当前模块");
                window.history.go(-1);
            } else if (status === "-2") {
                alert("请重新登陆");
            } else {

            }
      },
      error: function (err) {
      }
    });
}

// 答题操作
function doQuestion(t) {
    var cur_topic = $('#currentTopic').text(),
      tol_topic = $('#totalTopic').text(),
      answer = answer_list.answer;
    $('#exam_answer > div:nth-child(' + num + ')').click();
    if (cur_topic == tol_topic) {
      // 清除Interval的定时器
      clearInterval(t);
      setTimeout(function(){
$('#next_eval').click()
         // $('#next_exam').click()
const nextColumnId = $("#next_exam").attr("data-nextColumnId");
    if (nextColumnId) {
      window.location.href = `./learning-page.html?columnId=${nextColumnId}`;
    }
         // Swal.fire('宪法小助手提示','答题完成','info')

      },time / 2);
    } else{
      setTimeout(function(){$('#next_question').click()},time / 2);
    };
}

// 获取考试题目
function getExam(){
    // var html = $("html").html(),
    //   taskId = getStr(html,'taskId=','`,');
    $.ajax({
      url: _self.config.wexam.host + _self.config.wexam.getPaper + "?taskId=" + _self.config.taskId,
      headers: _self.config.apiConfig.header,
      async: false,
      success: function (res) {
            const { data, status, message } = res;
            if (status === "0") {
                var question_data = res.data;
                var paper = question_data.paper;
                var paperInfo = paper.paperInfo;
                exam_list = paperInfo;
            } else {
                alert('获取考试题目失败!')
            }
      },
      error: function (err) {
      }
    });
}
// 考试答题操作
function doExam(t){
    let db_json = []
    if (GM_getValue(save_key) && JSON.parse(GM_getValue(save_key)).length >= 0) {
      db_json = JSON.parse(GM_getValue(save_key))
    } else {
      Swal.fire('宪法小助手提示','无题库数据,请先收集答案或自己作答!','info')
      return
    }

    $('#ne21ans') ? $('#ne21ans').html('<p style="color: red;">正在搜索答案~</p>') : $('#exam_question').append('<div id="ne21ans"><p style="color: red;">正在搜索答案~</p></div>')

    var cur_topic = $('#currentTopic').text(),
      tol_topic = $('#totalTopic').text(),
      questionInfo = exam_list;


    ans_index = []
    ops = questionInfo.answerOptions.split("@!@")
    for (var i = 0; i < ops.length; i++) {
      hash_tmp = MD555(questionInfo.content+"|"+ops)
      db_json.forEach((item)=>{
            if (item.hash == hash_tmp) {
                ans_index.push(i)
            }
      })
    }

    if (ans_index.length == 0) {
      Swal.fire('宪法小助手提示','无题库数据,请先收集答案或自己作答!','info')
      return
    }

    ans_index.forEach((item1)=>{
      $('#ne21ans').html('<p style="color: red;">参考答案:'+ ops + '</p>')
      $('#exam_answer > div:nth-child(' + (item1+1) + ')').click();
    })

    if (cur_topic == tol_topic) {
         // 清除Interval的定时器
         clearInterval(t);
         setTimeout(function(){
            // Swal.fire('宪法小助手提示','答题完成,请自己点击交卷!','info')
         //$('#submit').click()
             saveResult();
         },time / 2);
    } else{
         setTimeout(function(){$('#next_question').click()},time / 2);
    };

}

function upload(question_data) {
    let db_json = []
    if (GM_getValue(save_key) && JSON.parse(GM_getValue(save_key)).length >= 0) {
      db_json = JSON.parse(GM_getValue(save_key))
    }
    question_data.forEach((item)=>{
      let question = item.content
      let ans_index = []
      item.answer.split().forEach(((item1)=>{
            let index_tmp = "ABCDEFG".indexOf(item1)
            ans_index.push(index_tmp)
      }))
      let ans_ops = item.answerOptions.split("@!@")
      ans_index.forEach((item3)=>{
            db_json.push({
                "hash":MD555(question+"|"+ans_ops),
                "question": question,
                "answer": ans_ops
                })
      })
    })

    let dbJson = uniqueByField(db_json,"hash")
    GM_setValue(save_key,JSON.stringify(dbJson))
    console.log(JSON.parse(GM_getValue(save_key)))
}

function MD555(str) {
    return CryptoJS.MD5(str).toString()
}

function uniqueByField(array, field) {
    const seen = new Set();
    return array.filter((item) => {
      const key = item;
      return seen.has(key) ? false : seen.add(key);
    });
}

function nextExam() {
    const nextColumnId = $("#next_exam").attr("data-nextColumnId");
    if (nextColumnId) {
      window.location.href = `./learning-page.html?columnId=${nextColumnId}`;
    } else {
      //alert("没有下一章节了")
    }
}



function createFileInput() {
    var courseGradeDetail = document.querySelector(".main");
    var fileInputHTML = '<div><input type="file" id="file-input" accept=".xls,.xlsx"></div>';
    courseGradeDetail.insertAdjacentHTML("afterbegin", fileInputHTML);
    var clearButton = document.createElement("button");
    clearButton.textContent = "清除缓存";
    clearButton.addEventListener("click", function() {
      localStorage.removeItem("students");
    });
    var file = document.querySelector("#file-input");
    file.parentNode.appendChild(clearButton);
}

function readFile() {
var fileInput = document.getElementById("file-input");
fileInput.addEventListener("change", function() {
    var file = fileInput.files;
    var reader = new FileReader();
    reader.onload = function(e) {
      var data = e.target.result;
      //alert(data);
      parseExcelData(data);
    };
    reader.readAsBinaryString(file);
});
}

function parseExcelData(data) {
var workbook = XLSX.read(data, {type: "binary"});
var sheetName = workbook.SheetNames;
var sheet = workbook.Sheets;
var json = XLSX.utils.sheet_to_json(sheet, {header: 1});
   // console.log(json);
var students = {};
for (var i = 2; i < json.length; i++) {
    var row = json;
    var id = row;
    var name = row;
    //console.log(name);
    var password = row;
    if (students) {
      continue;
    }
    students = {name: name, password: password};
   // alert(sheetName);
}
var studentsString = JSON.stringify(students);
localStorage.setItem("students", studentsString);
}

function readAndWriteStudentInfo() {
//alert(111);
var students = JSON.parse(localStorage.getItem("students") || "{}");
var keys = Object.keys(students || []);
if (keys.length == 0) {
    return;
}
   //alert(222);
var id = keys;
   // console.log(id);
    console.log(students);
var name = students.name; console.log(name);
var paw = students.password;
varcopy_text = id;
var loginInfo = document.getElementById("formLogin_loginInfo");
var userName = document.getElementById("formLogin_userName");
var password = document.getElementById("formLogin_password");
var captcha = document.getElementById("formLogin_captcha");
   // console.log(password);

//$("#formLogin_loginInfo").val("需赋值的内容");
    //document.getElementById("formLogin_loginInfo").value = "要设置的值";

loginInfo.onfocus = async function() {
    await navigator.clipboard.writeText(id);
};
userName.onfocus = async function() {
    await navigator.clipboard.writeText(name);
};
password.onfocus = async function() {
   await navigator.clipboard.writeText(paw);
};

    console.log("shancghu"+id);
   $(".ant-radio-input").click();
delete students;
localStorage.setItem("students", JSON.stringify(students));
}

meng521215 发表于 2024-10-7 10:25

zxxiaopi 发表于 2024-10-7 09:54
都是为了应付检查!搞这种形式上的东西,也不是一年两年了,很久很久很久了……

是的,学生又做不好,苦了班主任

qianyu666 发表于 2024-10-7 01:13

还要做?    投诉完好多网上作业都不布置了

ruanxiaoqi 发表于 2024-10-8 19:36

信息技术老师有福了,可以快速完成上级布置的任务。

swl0515 发表于 2024-10-6 23:09

66666{:1_937:}

Kane1 发表于 2024-10-7 01:28

看起来好像很厉害的样子,但是我不用做{:1_918:}

zp820710 发表于 2024-10-7 07:54

压力来了

luodeman 发表于 2024-10-7 08:09

感谢楼主分享,辛苦了

jzx765 发表于 2024-10-7 08:11

学一下思路,虽然不用做了

xlycaq1 发表于 2024-10-7 09:41

qianyu666 发表于 2024-10-7 01:13
还要做?    投诉完好多网上作业都不布置了

支持!!

zxxiaopi 发表于 2024-10-7 09:54

都是为了应付检查!搞这种形式上的东西,也不是一年两年了,很久很久很久了……
页: [1] 2 3 4 5
查看完整版本: 【油猴脚本】第九届全国学生宪法小卫士,答题脚本 更新了下大神版本,基本可以自动