普法网(宪法小卫士)课后练习、考试自动答题

全国学生“学宪法 讲宪法”活动自动答题脚本,因缺少测试账号无法保证每年都能用,欢迎大家提供测试账号以支持此脚本长期可用,测试账号登录(不可用)信息请发送至我们的邮箱nawlgzs@gmail.com

目前為 2024-10-28 提交的版本,檢視 最新版本

  1. // ==UserScript==
  2. // @name 普法网(宪法小卫士)课后练习、考试自动答题
  3. // @namespace Ne-21
  4. // @version 1.4.0
  5. // @description 全国学生“学宪法 讲宪法”活动自动答题脚本,因缺少测试账号无法保证每年都能用,欢迎大家提供测试账号以支持此脚本长期可用,测试账号登录(不可用)信息请发送至我们的邮箱nawlgzs@gmail.com
  6. // @author Ne-21
  7. // @match *://static.qspfw.moe.gov.cn/*
  8. // @icon 
  9. // @run-at document-end
  10. // @grant unsafeWindow
  11. // @grant GM_setValue
  12. // @grant GM_getValue
  13. // @license MIT
  14. // @require https://lf9-cdn-tos.bytecdntp.com/cdn/expire-1-M/jquery/3.6.0/jquery.min.js
  15. // @require https://lf26-cdn-tos.bytecdntp.com/cdn/expire-1-M/limonte-sweetalert2/11.0.1/sweetalert2.all.min.js
  16. // @require https://lf26-cdn-tos.bytecdntp.com/cdn/expire-1-M/crypto-js/4.1.1/crypto-js.min.js
  17. // ==/UserScript==
  18.  
  19. var _self = unsafeWindow,
  20. $ = _self.jQuery || top.jQuery,
  21. Swal = Swal || window.Swal,
  22. columnId = getQueryVariable("columnId"),
  23. answer_list = [],
  24. exam_list = [],
  25. time = 3e3, // 答题间隔时间,最好为5秒
  26. save_key = "xfxws2024",
  27. num = {"A": 1,"B": 2, "C": 3, "D": 4};
  28.  
  29. // 去除字符串中的空格、换行、制表符
  30. const filterStr = (str) => str.replace(/\s/g, "").replace(/[\r\n]/g, "").trim()
  31.  
  32. (function() {
  33. // 题目切换其实可以不依靠定时器,不过懒得改了,能用就行。。。
  34. if (window.location.pathname.indexOf('learn_exam.html') != -1) {
  35. Swal.fire('宪法小助手提示','点击确定开始考试','info').then(()=>{
  36. Swal.fire({
  37. position: 'top-end',
  38. title: '脚本将在3秒后开始自动作答!',
  39. showConfirmButton: false,
  40. timer: 3000
  41. })
  42. getExam();
  43. let t = setInterval( function() {
  44. doExam(t)
  45. },time);
  46. })
  47. } else if (window.location.pathname.indexOf('learn-practice.html') != -1) {
  48. Swal.fire('宪法小助手提示','点击确定开始练习,脚本会自动收录本练习题目数据','info').then(()=>{
  49. getAnswer(columnId);
  50. let t = setInterval( function() {
  51. doQuestion(t)
  52. },time);
  53. })
  54. } else if (window.location.pathname.indexOf('learn_practice_list.html') != -1) {
  55. Swal.fire('宪法小助手提示','<div style="font-size: 13px;">脚本最后更新时间:2024.10.26<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>')
  56. } else if (window.location.pathname.indexOf('evaluation.html') != -1) {
  57. }
  58. })();
  59.  
  60. // 解析url参数
  61. function getQueryVariable(variable) {
  62. var query = window.location.search.substring(1);
  63. var vars = query.split("&");
  64. for (var i=0;i<vars.length;i++) {
  65. var pair = vars[i].split("=");
  66. if(pair[0] == variable){return pair[1];}
  67. }
  68. return(false);
  69. };
  70.  
  71. // 正则匹配
  72. function getStr(str, start, end) {
  73. let res = str.match(new RegExp(`${start}(.*?)${end}`))
  74. return res ? res[1] : null
  75. }
  76.  
  77. // 获取答案
  78. function getAnswer(columnId) {
  79. $.ajax({
  80. url: _self.config.practice.host + _self.config.practice.practice + "?columnId="+ columnId + "&taskId=" + _self.config.taskId,
  81. headers: _self.config.apiConfig.header,
  82. async: false,
  83. success: function (res) {
  84. const { data, status } = res;
  85. if (status === "0") {
  86. var question_data = res.data
  87. var questionBankList = data.questionBankList
  88. answer_list = questionBankList;
  89. upload(answer_list)
  90. } else if (status === "1") {
  91. alert("请先学习当前模块");
  92. window.history.go(-1);
  93. } else if (status === "-2") {
  94. alert("请重新登陆");
  95. } else {
  96.  
  97. }
  98. },
  99. error: function (err) {
  100. }
  101. });
  102. }
  103.  
  104. // 答题操作
  105. function doQuestion(t) {
  106. var cur_topic = $('#currentTopic').text(),
  107. tol_topic = $('#totalTopic').text(),
  108. answer = answer_list[cur_topic - 1].answer;
  109. $('#exam_answer > div:nth-child(' + num[answer] + ')').click();
  110. if (cur_topic == tol_topic) {
  111. clearInterval(t);
  112. setTimeout(function(){Swal.fire('宪法小助手提示','答题完成','info')},time / 2);
  113. } else{
  114. setTimeout(function(){$('#next_question').click()},time / 2);
  115. };
  116. }
  117.  
  118. // 获取考试题目
  119. function getExam(){
  120. $.ajax({
  121. url: _self.config.wexam.host + _self.config.wexam.getPaper + "?taskId=" + _self.config.taskId,
  122. headers: _self.config.apiConfig.header,
  123. async: false,
  124. success: function (res) {
  125. const { data, status, message } = res;
  126. if (status === "0") {
  127. var question_data = res.data;
  128. var paper = question_data.paper;
  129. var paperInfo = paper.paperInfo;
  130. exam_list = paperInfo;
  131. } else {
  132. alert('获取考试题目失败!')
  133. }
  134. },
  135. error: function (err) {
  136. }
  137. });
  138. }
  139.  
  140. // 考试答题操作
  141. function doExam(t){
  142. let db_json = []
  143. if (GM_getValue(save_key) && JSON.parse(GM_getValue(save_key)).length >= 0) {
  144. db_json = JSON.parse(GM_getValue(save_key))
  145. } else {
  146. $('#ne21ans')[0] ? $('#ne21ans').html('<p style="color: red;">未匹配到答案,请手动作答~</p>') : $('#exam_question').append('<div id="ne21ans"><p style="color: red;">未匹配到答案,请手动作答~</p></div>')
  147. return
  148. }
  149.  
  150. $('#ne21ans')[0] ? $('#ne21ans').html('<p style="color: red;">正在搜索答案~</p>') : $('#exam_question').append('<div id="ne21ans"><p style="color: red;">正在搜索答案~</p></div>')
  151.  
  152. var cur_topic = $('#currentTopic').text(),
  153. tol_topic = $('#totalTopic').text(),
  154. questionInfo = exam_list[cur_topic - 1];
  155.  
  156.  
  157. ans_index = []
  158. let question = filterStr(questionInfo.content)
  159. let ops = questionInfo.answerOptions.split("@!@")
  160. ops.map((el)=> filterStr(el) )
  161. for (var i = 0; i < ops.length; i++) {
  162. hash_tmp = MD555(question+"|"+ops[i])
  163. db_json.forEach((item)=>{
  164. if (item.hash == hash_tmp) {
  165. ans_index.push(i)
  166. }
  167. })
  168. }
  169.  
  170. if (ans_index.length == 0) {
  171. Swal.fire('宪法小助手提示','无题库数据,请先收集答案或自己作答!','info')
  172. return
  173. }
  174.  
  175. ans_index.forEach((item1)=>{
  176. $('#ne21ans').html('<p style="color: red;">参考答案:'+ ops[item1] + '</p>')
  177. $('#exam_answer > div:nth-child(' + (item1+1) + ')').click();
  178. })
  179.  
  180. if (cur_topic == tol_topic) {
  181. clearInterval(t);
  182. setTimeout(function(){Swal.fire('宪法小助手提示','答题完成,请自己点击交卷!','info')},time / 2);
  183. } else{
  184. setTimeout(function(){$('#next_question').click()},time / 2);
  185. };
  186.  
  187. }
  188.  
  189. function upload(question_data) {
  190. let db_json = []
  191. if (GM_getValue(save_key) && JSON.parse(GM_getValue(save_key)).length >= 0) {
  192. db_json = JSON.parse(GM_getValue(save_key))
  193. }
  194. question_data.forEach((item)=>{
  195. let question = filterStr(item.content)
  196. let ans_index = []
  197. item.answer.split().forEach(((item1)=>{
  198. let index_tmp = "ABCDEFG".indexOf(item1)
  199. ans_index.push(index_tmp)
  200. }))
  201. let ans_ops = item.answerOptions.split("@!@")
  202. ans_ops.map((el)=> filterStr(el) )
  203. ans_index.forEach((item3)=>{
  204. db_json.push({
  205. "hash":MD555(question+"|"+ans_ops[item3]),
  206. "question": question,
  207. "answer": ans_ops[item3]
  208. })
  209. })
  210. })
  211.  
  212. let dbJson = uniqueByField(db_json,"hash")
  213. GM_setValue(save_key,JSON.stringify(dbJson))
  214. // console.log(JSON.parse(GM_getValue(save_key)))
  215. }
  216.  
  217. function MD555(str) {
  218. return CryptoJS.MD5(str).toString()
  219. }
  220.  
  221. // 重复数据过滤
  222. function uniqueByField(array, field) {
  223. const seen = new Set();
  224. return array.filter((item) => {
  225. const key = item[field];
  226. return seen.has(key) ? false : seen.add(key);
  227. });
  228. }

QingJ © 2025

镜像随时可能失效,请加Q群300939539或关注我们的公众号极客氢云获取最新地址