From 8546b3d285af4235a0ef615a0c6e89486ae2c806 Mon Sep 17 00:00:00 2001 From: fuliqi <fuliqi@qq.com> Date: 星期四, 17 十月 2024 21:01:37 +0800 Subject: [PATCH] 达梦不支持value改为values --- src/main/java/com/ycl/jxkg/service/impl/ExamServiceImpl.java | 527 ++++++++++++++++++++++++++++++++++++++++++---------------- 1 files changed, 383 insertions(+), 144 deletions(-) diff --git a/src/main/java/com/ycl/jxkg/service/impl/ExamServiceImpl.java b/src/main/java/com/ycl/jxkg/service/impl/ExamServiceImpl.java index 43b3573..904e0e2 100644 --- a/src/main/java/com/ycl/jxkg/service/impl/ExamServiceImpl.java +++ b/src/main/java/com/ycl/jxkg/service/impl/ExamServiceImpl.java @@ -1,27 +1,31 @@ package com.ycl.jxkg.service.impl; import com.alibaba.fastjson2.JSON; +import com.alibaba.fastjson2.JSONArray; +import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; import com.baomidou.mybatisplus.core.metadata.IPage; import com.baomidou.mybatisplus.core.toolkit.CollectionUtils; import com.baomidou.mybatisplus.extension.conditions.query.LambdaQueryChainWrapper; import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; import com.ycl.jxkg.base.Result; import com.ycl.jxkg.base.SystemCode; +import com.ycl.jxkg.constants.ExamScoreConstant; import com.ycl.jxkg.context.WebContext; +import com.ycl.jxkg.domain.base.AbsVo; import com.ycl.jxkg.domain.entity.*; import com.ycl.jxkg.domain.exam.PaperFixQuestionDTO; +import com.ycl.jxkg.domain.exam.PaperQuestion; import com.ycl.jxkg.domain.exam.PaperQuestionSettingDTO; +import com.ycl.jxkg.domain.exam.PaperSettingItem; import com.ycl.jxkg.domain.form.AddTimeForm; import com.ycl.jxkg.domain.form.ExamForm; import com.ycl.jxkg.domain.form.ForceSubmitForm; import com.ycl.jxkg.domain.query.ExamQuery; +import com.ycl.jxkg.domain.question.QuestionItemObject; import com.ycl.jxkg.domain.question.QuestionObject; import com.ycl.jxkg.domain.vo.*; -import com.ycl.jxkg.domain.vo.admin.exam.ExamPaperEditRequestVO; -import com.ycl.jxkg.domain.vo.admin.exam.ExamPaperMarkAnswerVO; +import com.ycl.jxkg.domain.vo.admin.exam.ExamPaperMarkNavbarVO; import com.ycl.jxkg.domain.vo.admin.exam.ExamPaperMarkVO; -import com.ycl.jxkg.domain.vo.student.exam.ExamPaperReadVO; -import com.ycl.jxkg.domain.vo.student.exam.ExamPaperSubmitVO; import com.ycl.jxkg.enums.DeductTypeEnum; import com.ycl.jxkg.enums.ExamPaperTypeEnum; import com.ycl.jxkg.enums.QuestionTypeEnum; @@ -29,14 +33,16 @@ import com.ycl.jxkg.enums.general.ExamStatusEnum; import com.ycl.jxkg.enums.general.ExamSubmitTempStatusEnum; import com.ycl.jxkg.mapper.*; +import com.ycl.jxkg.rabbitmq.msg.ExamStatusMsg; +import com.ycl.jxkg.rabbitmq.product.Producer; import com.ycl.jxkg.server.WebsocketServer; +import com.ycl.jxkg.service.ExamPaperScoreService; import com.ycl.jxkg.service.ExamPaperService; import com.ycl.jxkg.service.ExamService; -import com.ycl.jxkg.utils.JsonUtil; +import com.ycl.jxkg.utils.DateTimeUtil; import com.ycl.jxkg.utils.PageUtil; import lombok.RequiredArgsConstructor; import org.springframework.beans.BeanUtils; -import org.springframework.context.annotation.Bean; import org.springframework.transaction.annotation.Transactional; import org.springframework.stereotype.Service; import org.springframework.util.Assert; @@ -57,6 +63,8 @@ @RequiredArgsConstructor public class ExamServiceImpl extends ServiceImpl<ExamMapper, Exam> implements ExamService { + private static final String ANSWER_SPLIT = ","; + private final ExamMapper examMapper; private final WebContext webContext; private final QuestionMapper questionMapper; @@ -67,7 +75,9 @@ private final WebsocketServer websocketServer; private final UserMapper userMapper; private final ExamPaperScoreMapper examPaperScoreMapper; - private final ExamPaperScoreDetailMapper examPaperScoreDetailMapper; + private final ExamPaperScoreService examPaperScoreService; + + private final Producer producer; /** * 娣诲姞 @@ -80,7 +90,11 @@ Exam entity = ExamForm.getEntityByForm(form, null); entity.setStatus(ExamStatusEnum.getStatusByTime(form.getStartTime(), form.getEndTime(), null)); entity.setTeacherId(webContext.getCurrentUser().getId()); - baseMapper.insert(entity); + // 璁剧疆涔愯閿佺増鏈� + entity.setUpdateVersion(0); + if (baseMapper.insert(entity) > 0) { + this.sendMQ(entity, 0); + } return Result.ok("娣诲姞鎴愬姛"); } @@ -95,10 +109,62 @@ Exam entity = baseMapper.selectById(form.getId()); // 涓虹┖鎶汭llegalArgumentException锛屽仛鍏ㄥ眬寮傚父澶勭悊 Assert.notNull(entity, "璁板綍涓嶅瓨鍦�"); + // 鍒ゆ柇鑰冭瘯鐘舵�� + if (!ExamStatusEnum.NOT_START.equals(entity.getStatus())) { + throw new RuntimeException("鍙兘淇敼杩樻湭寮�濮嬬殑鑰冭瘯"); + } BeanUtils.copyProperties(form, entity); entity.setStatus(ExamStatusEnum.getStatusByTime(form.getStartTime(), form.getEndTime(), null)); - baseMapper.updateById(entity); + // 濡傛灉淇敼鎴愬姛鍙戦�乵q娑堟伅 + if (baseMapper.updateById(entity) > 0) { + this.sendMQ(entity, entity.getUpdateVersion()); + } return Result.ok("淇敼鎴愬姛"); + } + + /** + * 鍙戦�乵q娑堟伅 + * + * @param entity 鑰冭瘯瀹炰綋绫� + * @param version 涔愯閿佺増鏈� + */ + public void sendMQ(Exam entity, Integer version) { + // 濡傛灉褰撳墠鐘舵�佷负鏈紑濮嬶紝鍒欏彂閫佷袱鏉q娑堟伅锛屼竴鏉¤缃姸鎬佷负杩涜涓紝涓�鏉¤缃姸鎬佷负宸茬粨鏉� + if (ExamStatusEnum.NOT_START.equals(entity.getStatus())) { + // 杩涜鐘舵�佹秷鎭� + ExamStatusMsg ingMsg = new ExamStatusMsg(); + ingMsg.setVersion(version); + ingMsg.setExamId(entity.getId()); + ingMsg.setTargetStatus(ExamStatusEnum.ING); + producer.examMsg(entity.getId(), JSON.toJSONString(ingMsg), DateTimeUtil.getTwoTimeDiffMS(entity.getStartTime(), new Date())); + // 缁撴潫鐘舵�佹秷鎭� + ExamStatusMsg finishedMsg = new ExamStatusMsg(); + finishedMsg.setVersion(version); + finishedMsg.setExamId(entity.getId()); + finishedMsg.setTargetStatus(ExamStatusEnum.FINISHED); + producer.examMsg(entity.getId(), JSON.toJSONString(finishedMsg), DateTimeUtil.getTwoTimeDiffMS(entity.getEndTime(), new Date())); + } else if (ExamStatusEnum.ING.equals(entity.getStatus())) { // 褰撳墠鏄繘琛屼腑鐘舵�佸垯鍙渶鍙戦�佺粨鏉熸秷鎭� + // 缁撴潫鐘舵�佹秷鎭� + ExamStatusMsg finishedMsg = new ExamStatusMsg(); + finishedMsg.setVersion(0); + finishedMsg.setExamId(entity.getId()); + finishedMsg.setTargetStatus(ExamStatusEnum.FINISHED); + producer.examMsg(entity.getId(), JSON.toJSONString(finishedMsg), DateTimeUtil.getTwoTimeDiffMS(entity.getEndTime(), new Date())); + } + } + + /** + * 鏍规嵁鑰冭瘯鐨勫綋鍓嶇姸鎬侊紝寰楀埌涓嬩竴涓姸鎬� + * + * @param currentStatus + * @return + */ + public ExamStatusEnum getNextStatus(ExamStatusEnum currentStatus) { + if (ExamStatusEnum.NOT_START.equals(currentStatus)) { + return ExamStatusEnum.ING; + } else { + return ExamStatusEnum.FINISHED; + } } /** @@ -184,6 +250,10 @@ .eq(ExamSubmitTemp::getUserId, webContext.getCurrentUser().getId()) .one(); if (Objects.nonNull(hasJoin)) { + // 鍏佽鎻愪氦鍚庣户缁綔绛� +// if(ExamSubmitTempStatusEnum.finish.equals(hasJoin.getStatus())){ +// throw new RuntimeException("鎮ㄥ凡鎻愪氦璇曞嵎锛岃鍕块噸澶嶄綔绛�"); +// } StartExamVO startExamVO = new StartExamVO(); startExamVO.setExamName(exam.getExamName()); startExamVO.setId(hasJoin.getExamId()); @@ -192,77 +262,108 @@ startExamVO.setDoTime(hasJoin.getDoTime()); return Result.ok(startExamVO); } + // 鍝嶅簲鏁版嵁 + StartExamVO startExamVO = new StartExamVO(); + startExamVO.setExamName(exam.getExamName()); + startExamVO.setId(exam.getId()); + startExamVO.setSuggestTime(examPaper.getSuggestTime()); + // 璇曞嵎鍐呭 + List<PaperFixQuestionVO> examData = new ArrayList<>(); + // 鎷垮埌棰樼洰鍓湰鏁版嵁 + List<QuestionAnswerCopyVO> questionAnswerCopyVOList = new ArrayList<>(32); // 灏嗛鐩浆鎹负鍙复鏃朵繚瀛樼殑棰樼洰缁撴瀯銆傚浐瀹氳瘯鍗峰拰闅忓簭璇曞嵎鐨勯鐩槸鐩存帴淇濆瓨鍒癱ontent瀛楁鐨� if (ExamPaperTypeEnum.Fixed.getCode().equals(examPaper.getPaperType()) || ExamPaperTypeEnum.RandomOrder.getCode().equals(examPaper.getPaperType())) { - if (StringUtils.hasText(examPaper.getContent())) { + if (!StringUtils.hasText(examPaper.getContent())) { throw new RuntimeException("璇曞嵎棰樼洰涓虹┖"); } // 杞崲 - List<PaperFixQuestionVO> data = this.coverTo(examPaper); - return Result.ok().data(data); + examData = this.coverTo(examPaper, questionAnswerCopyVOList); } else if (ExamPaperTypeEnum.Random.getCode().equals(examPaper.getPaperType())) { // 鏍规嵁闅忔満璇曞嵎鐨勯厤缃紝闅忔満鐢熸垚瀵瑰簲棰樼洰 if (!StringUtils.hasText(examPaper.getContent())) { throw new RuntimeException("璇曞嵎閰嶇疆寮傚父锛岃鑱旂郴鑰佸笀"); } List<PaperQuestionSettingDTO> paperSettingList = JSON.parseArray(examPaper.getContent(), PaperQuestionSettingDTO.class); - - // 璇曞嵎鍐呭 - List<PaperFixQuestionVO> examData = new ArrayList<>(8); + examData = new ArrayList<>(8); for (PaperQuestionSettingDTO paperSetting : paperSettingList) { PaperFixQuestionVO paperFixQuestionVO = new PaperFixQuestionVO(); paperFixQuestionVO.setTitle(paperSetting.getTitle()); paperFixQuestionVO.setQuestionType(paperSetting.getQuestionType()); - // 鎷垮埌璇剧洰涓嬫煇绫婚鍨嬬殑x閬撻殢鏈洪 - List<Question> questions = questionMapper.getRandomQuestion(examPaper.getSubjectId(), paperSetting.getQuestionType(), paperSetting.getNum()); - if (paperSetting.getNum() > questions.size()) { - throw new RuntimeException("閰嶇疆鐨勯鐩暟涓嶈冻浠ョ敓鎴愯瘯鍗�"); - } - // 鎷垮埌棰樼洰鍚庣粍瑁呬负鍙复鏃朵繚瀛樼殑棰樼洰缁撴瀯 - List<DoQuestionVO> childQuestions = questions.stream().map(item -> { - DoQuestionVO doQuestionVO = new DoQuestionVO(); - doQuestionVO.setTitle(item.getTitle()); - doQuestionVO.setQuestionType(item.getQuestionType()); - if (StringUtils.hasText(item.getContent())) { - QuestionObject questionObject = JSON.parseObject(item.getContent(), QuestionObject.class); - doQuestionVO.setQuestionItemList(questionObject.getQuestionItemObjects()); + //涓�涓被鍨嬬殑棰樼洰list + List<DoQuestionVO> childQuestionList = new ArrayList<>(); + List<PaperSettingItem> settingList = paperSetting.getSettingList(); + for (PaperSettingItem settingItem : settingList) { + Integer num = settingItem.getNum(); + Integer difficult = settingItem.getDifficult(); + //闇�瑕侀厤缃殑棰樼洰鏁伴噺涓�0鍒欒烦杩� + if (num == null || num == 0) continue; + List<Question> questions = questionMapper.getRandomQuestion(settingItem.getSubjectId(), paperSetting.getQuestionType(), difficult, settingItem.getNum()); + if (org.springframework.util.CollectionUtils.isEmpty(questions) || settingItem.getNum() > questions.size()) { + throw new RuntimeException("閰嶇疆鐨勯鐩暟涓嶈冻浠ョ敓鎴愯瘯鍗�"); } - doQuestionVO.setId(item.getId()); - doQuestionVO.setOriginalFile(item.getOriginalFile()); - doQuestionVO.setAudioFile(item.getAudioFile()); - return doQuestionVO; - }).collect(Collectors.toList()); - paperFixQuestionVO.setQuestionList(childQuestions); + // 鎷垮埌棰樼洰鍚庣粍瑁呬负鍙复鏃朵繚瀛樼殑棰樼洰缁撴瀯 + List<DoQuestionVO> childQuestions = questions.stream().map(item -> { + DoQuestionVO doQuestionVO = new DoQuestionVO(); + doQuestionVO.setQuestionType(item.getQuestionType()); + //浠庨厤缃噷鎷块鐩垎鏁� + doQuestionVO.setQuestionScore(settingItem.getScore()); + if (StringUtils.hasText(item.getContent())) { + QuestionObject questionObject = JSON.parseObject(item.getContent(), QuestionObject.class); + doQuestionVO.setQuestionItemList(questionObject.getQuestionItemObjects()); + doQuestionVO.setTitle(questionObject.getTitleContent()); + } + doQuestionVO.setId(item.getId()); + doQuestionVO.setOriginalFile(item.getOriginalFile()); + doQuestionVO.setAudioFile(item.getAudioFile()); + + // 棰樼洰鍓湰 + QuestionAnswerCopyVO copy = new QuestionAnswerCopyVO(); + copy.setId(item.getId()); + copy.setDifficult(item.getDifficult()); + copy.setAnalyze(JSON.parseObject(item.getContent(), PaperQuestion.class).getAnalyze()); + //濉┖鐨勭瓟妗堝湪Json閲� + if (QuestionTypeEnum.GapFilling.getCode().equals(item.getQuestionType())) { + List<String> gapAnswer = new ArrayList<>(); + for (QuestionItemObject questionItemObject : doQuestionVO.getQuestionItemList()) { + gapAnswer.add(questionItemObject.getContent()); + } + copy.setCorrect(String.join(ANSWER_SPLIT, gapAnswer)); + } else { + copy.setCorrect(item.getCorrect()); + } + questionAnswerCopyVOList.add(copy); + + return doQuestionVO; + }).collect(Collectors.toList()); + //娣诲姞鍒拌繖涓被鍨嬬殑list涓� + childQuestionList.addAll(childQuestions); + } + paperFixQuestionVO.setQuestionList(childQuestionList); examData.add(paperFixQuestionVO); } - ExamSubmitTemp examSubmitTemp = new ExamSubmitTemp(); - examSubmitTemp.setExamId(id); - //TODO - examSubmitTemp.setStatus(ExamSubmitTempStatusEnum.temp); - examSubmitTemp.setExamSubmit(JSON.toJSONString(examData)); - examSubmitTemp.setCreateTime(new Date()); - examSubmitTemp.setUserId(webContext.getCurrentUser().getId()); - //TODO - examSubmitTemp.setMarkPaperStatus(ExamSubmitTempStatusEnum.temp); - examSubmitTempMapper.insert(examSubmitTemp); - StartExamVO startExamVO = new StartExamVO(); - startExamVO.setExamName(exam.getExamName()); - startExamVO.setId(exam.getId()); - startExamVO.setTitleList(examData); - startExamVO.setSuggestTime(examPaper.getSuggestTime()); - return Result.ok(startExamVO); } - return Result.ok(); + ExamSubmitTemp examSubmitTemp = new ExamSubmitTemp(); + examSubmitTemp.setExamId(id); + examSubmitTemp.setStatus(ExamSubmitTempStatusEnum.temp); + examSubmitTemp.setExamSubmit(JSON.toJSONString(examData)); + examSubmitTemp.setCreateTime(new Date()); + examSubmitTemp.setUserId(webContext.getCurrentUser().getId()); + examSubmitTemp.setMarkPaperStatus(ExamSubmitTempStatusEnum.temp); + examSubmitTemp.setQuestionAnswerCopy(JSON.toJSONString(questionAnswerCopyVOList)); + examSubmitTempMapper.insert(examSubmitTemp); + startExamVO.setTitleList(examData); + return Result.ok(startExamVO); } /** * 灏嗘暟鎹簱瀛樺偍鐨勯鐩紝杞负鍙复鏃朵繚瀛樼殑棰樼洰缁撴瀯 * - * @param examPaper 璇曞嵎 + * @param examPaper 璇曞嵎 + * @param questionAnswerCopyVOList 棰樼洰鍓湰闆嗗悎 * @return */ - private List<PaperFixQuestionVO> coverTo(ExamPaper examPaper) { + private List<PaperFixQuestionVO> coverTo(ExamPaper examPaper, List<QuestionAnswerCopyVO> questionAnswerCopyVOList) { if (!StringUtils.hasText(examPaper.getContent())) { throw new RuntimeException("璇曞嵎鏈厤缃鐩紝璇疯仈绯昏�佸笀"); } @@ -275,6 +376,26 @@ DoQuestionVO doQuestionVO = new DoQuestionVO(); doQuestionVO.setTitle(question.getTitle()); doQuestionVO.setQuestionType(item.getQuestionType()); + //澧炲姞棰樼洰鍒嗘暟 + doQuestionVO.setQuestionScore(question.getScore()); + + // 棰樼洰鍓湰 + QuestionAnswerCopyVO copy = new QuestionAnswerCopyVO(); + copy.setId(question.getId()); + copy.setAnalyze(question.getAnalyze()); + copy.setDifficult(question.getDifficult()); + //濉┖鐨勭瓟妗堝湪Json閲� + if (QuestionTypeEnum.GapFilling.getCode().equals(item.getQuestionType())) { + List<String> gapAnswer = new ArrayList<>(); + for (QuestionItemObject questionItemObject : question.getItems()) { + gapAnswer.add(questionItemObject.getContent()); + } + copy.setCorrect(String.join(ANSWER_SPLIT, gapAnswer)); + } else { + copy.setCorrect(question.getCorrect()); + } + questionAnswerCopyVOList.add(copy); + // 濉┖棰橀渶瑕佹姽闄ontent(鍥犱负鏄瓟妗�) if (QuestionTypeEnum.GapFilling.getCode().equals(doQuestionVO.getQuestionType())) { question.getItems().stream().forEach(option -> { @@ -364,7 +485,6 @@ // 闃呭嵎鍚庢墠寰�exam_paper_answer淇濆瓨鑰冭瘯鎴愮哗銆佷互鍙婁繚瀛樺埌exam_paper_customer_answer // 鐜板湪鍙渶瑕佷繚瀛樺埌涓�寮犱复鏃惰〃 // 璇ユ帴鍙f槸涓诲姩鎻愪氦锛屾墍浠ョ姸鎬侀兘璁剧疆涓哄畬鎴愶紝浠ヤ究鍚庣画鑰佸笀闃呭嵎 - //TODO saveTempExam(submitData, ExamSubmitTempStatusEnum.finish); return Result.ok(); } @@ -377,7 +497,6 @@ */ @Override public Result timingSubmit(StartExamVO submitData) { - //TODO saveTempExam(submitData, ExamSubmitTempStatusEnum.temp); return Result.ok(); } @@ -392,19 +511,18 @@ ExamSubmitTemp one = new LambdaQueryChainWrapper<>(examSubmitTempMapper) .eq(ExamSubmitTemp::getExamId, submitData.getId()) .eq(ExamSubmitTemp::getUserId, webContext.getCurrentUser().getId()) - .eq(ExamSubmitTemp::getDeleted,0) + .eq(ExamSubmitTemp::getDeleted, 0) .one(); if (Objects.nonNull(one)) { - long doTimeL = one.getUpdateTime().getTime() - one.getCreateTime().getTime(); - Integer doTime = (int) doTimeL; - //TODO if (ExamSubmitTempStatusEnum.finish.equals(one.getStatus())) { return; } - one.setDoTime(doTime); + Date now = new Date(); one.setExamSubmit(JSON.toJSONString(submitData.getTitleList())); - one.setUpdateTime(new Date()); + one.setUpdateTime(now); + int doTimeInSeconds = (int) (now.getTime() - one.getCreateTime().getTime()) / 1000; + one.setDoTime(doTimeInSeconds); one.setStatus(status); examSubmitTempMapper.updateById(one); } else { @@ -414,7 +532,6 @@ examSubmitTemp.setStatus(status); examSubmitTemp.setUserId(webContext.getCurrentUser().getId()); examSubmitTemp.setExamSubmit(JSON.toJSONString(submitData.getTitleList())); - //TODO examSubmitTemp.setMarkPaperStatus(ExamSubmitTempStatusEnum.temp); examSubmitTempMapper.insert(examSubmitTemp); } @@ -431,23 +548,38 @@ throw new RuntimeException("鑰冭瘯璇曞嵎涓嶅瓨鍦�"); } List<ExamSubmitTemp> examSubmitTempList = new LambdaQueryChainWrapper<>(examSubmitTempMapper) + .eq(ExamSubmitTemp::getDeleted, 0) .eq(ExamSubmitTemp::getExamId, id) .list(); // 鍙傝�冧汉鏁� Integer joinExamNum = examSubmitTempList.size(); // 鍙傝�冧絾鏈畬鎴愭彁浜や汉鏁� - //TODO Integer joinButNotFinishedNum = Math.toIntExact(examSubmitTempList.stream().filter(item -> ExamSubmitTempStatusEnum.temp.equals(item.getStatus())).count()); List<StudentExamInfoVO> studentExamList = classesUserMapper.getClassesUserList(exam.getClassesId()); // 搴旇�冧汉鏁� Integer shouldUserNum = studentExamList.size(); - - studentExamList.stream().forEach(item -> { - if (StringUtils.hasText(item.getExamSubmit())) { - item.setQuestionList(JSON.parseArray(item.getExamSubmit(), DoQuestionVO.class)); + for (StudentExamInfoVO studentExamInfoVO : studentExamList) { + Integer userId = studentExamInfoVO.getUserId(); + Optional<ExamSubmitTemp> first = examSubmitTempList.stream().filter(examSubmitTemp -> examSubmitTemp.getUserId().equals(userId)).findFirst(); + if (first.isPresent()) { + ExamSubmitTemp examSubmitTemp = first.get(); + studentExamInfoVO.setMarkPaperStatus(examSubmitTemp.getMarkPaperStatus()); + studentExamInfoVO.setStatus(examSubmitTemp.getStatus()); + studentExamInfoVO.setDoTime(examSubmitTemp.getDoTime()); + } else { + //涓嶅瓨鍦ㄨ�冭瘯璁板綍 + studentExamInfoVO.setStatus(ExamSubmitTempStatusEnum.temp); + //鏍规嵁Score琛ㄥ垽鏂� + ExamPaperScore paperScore = examPaperScoreMapper.getByExamIdUserId(exam.getId(), userId); + if(paperScore==null) { + studentExamInfoVO.setMarkPaperStatus(ExamSubmitTempStatusEnum.temp); + }else { + studentExamInfoVO.setMarkPaperStatus(ExamSubmitTempStatusEnum.finish); + } + studentExamInfoVO.setDoTime(0); } - }); + } MarkPaperVO markPaperVO = new MarkPaperVO(); markPaperVO.setExamName(exam.getExamName()); @@ -465,89 +597,110 @@ @Override public Result getMarkPaperInfo(Integer examId, Integer userId) { + User student = userMapper.getUserById(userId); + //濡傛灉宸茬粡闃呰繃鍗蜂簡锛屾煡鎴愮哗琛� + Result<ExamPaperMarkVO> paperMarkVO1 = checkHasJudge(examId, student); + if (paperMarkVO1 != null) return paperMarkVO1; + + ExamVO exam = examMapper.getById(examId); //瀛︾敓绛旈琛� ExamSubmitTemp userExam = new LambdaQueryChainWrapper<>(examSubmitTempMapper) .eq(ExamSubmitTemp::getExamId, examId) .eq(ExamSubmitTemp::getUserId, userId) .one(); if (Objects.isNull(userExam)) { - throw new RuntimeException("璇ュ鍛樿�冭瘯璁板綍涓嶅瓨鍦�"); + //缂鸿�冿紝瀛︾敓娌℃湁鍋氶淇℃伅 + ExamPaperMarkVO paperMarkVO = createVO(null, exam, student); + return Result.ok(paperMarkVO); } - ExamVO exam = examMapper.getById(examId); - User student = userMapper.getUserById(userId); //灏佽闃呭嵎鍩烘湰鏁版嵁 ExamPaperMarkVO paperMarkVO = createVO(userExam, exam, student); - //TODO:琛ュ厖棰樼洰绛旀銆佽В鏋� - List<PaperFixQuestionVO> titleItems = paperMarkVO.getTitleItems(); - for (PaperFixQuestionVO titleItem : titleItems) { - for (DoQuestionVO doQuestionVO : titleItem.getQuestionList()) { - - } - } + List<QuestionAnswerCopyVO> answerList = JSONArray.parseArray(userExam.getQuestionAnswerCopy(), QuestionAnswerCopyVO.class); + //琛ュ厖棰樼洰绛旀銆佽В鏋� + addAnswer(paperMarkVO, answerList); //闃呭嵎锛屽瑙傞鎵撳垎 Result InnerError = markPaper(paperMarkVO); if (InnerError != null) return InnerError; return Result.ok(paperMarkVO); } - //鎻愪氦鎵规敼 - @Override - @Transactional(rollbackFor = Exception.class) - public Result submitMarkPaper(ExamPaperMarkVO examPaperMark) { - Integer userId = webContext.getCurrentUser().getId(); - //鎻掑叆exam_paper_answer(鎴愮哗琛�) - ExamPaperScore examPaperScore = new ExamPaperScore(); - BeanUtils.copyProperties(examPaperMark,examPaperScore); - examPaperScore.setUserScore(new BigDecimal(examPaperMark.getScore())); - examPaperScore.setPaperScore(new BigDecimal(examPaperMark.getTotalScore())); - examPaperScore.setJudgeUser(userId); - examPaperScore.setCreateUser(examPaperMark.getUserId()); - examPaperScore.setAnswerTime(examPaperMark.getSubmitTime()); - examPaperScore.setPaperContent(JSON.toJSONString(examPaperMark.getTitleItems())); - long questionCorrect =0; - long questionCount=0; - if(!CollectionUtils.isEmpty(examPaperMark.getAnswers())){ - questionCorrect = examPaperMark.getAnswers().stream().filter(ExamPaperMarkAnswerVO::getRight).count(); - questionCount = examPaperMark.getAnswers().size(); + + //琛ュ厖棰樼洰绛旀銆佽В鏋� + private void addAnswer(ExamPaperMarkVO paperMarkVO, List<QuestionAnswerCopyVO> answerList) { + List<PaperFixQuestionVO> titleItems = paperMarkVO.getTitleItems(); + for (PaperFixQuestionVO titleItem : titleItems) { + for (DoQuestionVO doQuestionVO : titleItem.getQuestionList()) { + Integer questionId = doQuestionVO.getId(); + Optional<QuestionAnswerCopyVO> first = answerList.stream().filter(answer -> questionId.equals(answer.getId())).findFirst(); + if (first.isPresent()) { + QuestionAnswerCopyVO answerCopyVO = first.get(); + doQuestionVO.setQuestionAnswer(answerCopyVO.getCorrect()); + doQuestionVO.setAnalyze(answerCopyVO.getAnalyze()); + doQuestionVO.setDifficult(answerCopyVO.getDifficult()); + } + } } - examPaperScore.setQuestionCorrect(Integer.valueOf(questionCorrect+"")); - examPaperScore.setQuestionCount(Integer.valueOf(questionCount+"")); - examPaperScoreMapper.insert(examPaperScore); - return Result.ok(); } + + //妫�鏌ユ槸鍚﹂槄鍗� + private Result<ExamPaperMarkVO> checkHasJudge(Integer examId, User student) { + ExamPaperScore examPaperScore = examPaperScoreMapper.getByExamIdUserId(examId, student.getId()); + if (examPaperScore != null) { + ExamPaperMarkVO paperMarkVO = new ExamPaperMarkVO(); + BeanUtils.copyProperties(examPaperScore, paperMarkVO); + paperMarkVO.setUserName(student.getRealName()); + paperMarkVO.setTotalScore(examPaperScore.getTotalScore() + ""); + paperMarkVO.setScore(examPaperScore.getScore() + ""); + if (!StringUtils.isEmpty(examPaperScore.getPaperContent())) { + List<PaperFixQuestionVO> paperFixQuestionVOS = JSONArray.parseArray(examPaperScore.getPaperContent(), PaperFixQuestionVO.class); + paperMarkVO.setTitleItems(paperFixQuestionVOS); + } + if (!StringUtils.isEmpty(examPaperScore.getNavbar())) { + paperMarkVO.setNavbar(JSONArray.parseArray(examPaperScore.getNavbar(), ExamPaperMarkNavbarVO.class)); + } + return Result.ok(paperMarkVO); + } + return null; + } + //闃呭嵎 private Result markPaper(ExamPaperMarkVO paperMarkVO) { List<PaperFixQuestionVO> titleItems = paperMarkVO.getTitleItems(); //鍒濆鍖栭鐩簭鍙� Integer num = 1; - List<ExamPaperMarkAnswerVO> answers = new ArrayList<>(); + BigDecimal score = BigDecimal.ZERO; + //鍓嶇瀵艰埅鏁扮粍 + List<ExamPaperMarkNavbarVO> navbar = new ArrayList<>(); + //杩囨护鎺夐鐩负绌虹殑棰樼洰绫诲瀷 + titleItems = titleItems.stream().filter(paperFixQuestionVO -> !CollectionUtils.isEmpty(paperFixQuestionVO.getQuestionList())).collect(Collectors.toList()); + for (PaperFixQuestionVO titleItem : titleItems) { for (DoQuestionVO doQuestionVO : titleItem.getQuestionList()) { //鍑嗗棰樼洰搴忓彿渚涘墠绔烦杞娇鐢� - ExamPaperMarkAnswerVO answerVO = new ExamPaperMarkAnswerVO(); + ExamPaperMarkNavbarVO navbarVO = new ExamPaperMarkNavbarVO(); //鑾峰彇璇曞嵎绫诲瀷 Integer questionType = doQuestionVO.getQuestionType(); /* 濡傛灉鏄畝绛斻�佽绠椼�佸垎鏋愶紝涓嶈缃畆ight鍙缃鐩簭鍙� */ if (QuestionTypeEnum.ShortAnswer.getCode().equals(questionType) || QuestionTypeEnum.Calculate.getCode().equals(questionType) || QuestionTypeEnum.Analysis.getCode().equals(questionType)) { - answerVO.setItemOrder(num); + navbarVO.setItemOrder(num); doQuestionVO.setItemOrder(num); } /* 濡傛灉鏄崟閫夈�佽闊炽�佸垽鏂�(鍒ゆ柇绛旀鏄疉銆丅) */ else if (QuestionTypeEnum.SingleChoice.getCode().equals(questionType) || QuestionTypeEnum.Audio.getCode().equals(questionType) || QuestionTypeEnum.TrueFalse.getCode().equals(questionType)) { - answerVO.setItemOrder(num); + navbarVO.setItemOrder(num); doQuestionVO.setItemOrder(num); if (StringUtils.isEmpty(doQuestionVO.getQuestionAnswer())) { - return Result.fail(SystemCode.InnerError.getCode(), doQuestionVO.getTitle() + ",姝ら鐩己灏戠瓟妗堬紝璇峰厛瀹屽杽"); + return Result.fail(SystemCode.InnerError.getCode(), "棰樼洰id涓猴細" + doQuestionVO.getId() + "鐨勯鐩己灏戠瓟妗堬紝璇峰厛瀹屽杽"); } - trueOrFalse(doQuestionVO, answerVO, doQuestionVO.getQuestionAnswer().equals(doQuestionVO.getAnswer())); + score = trueOrFalse(score, doQuestionVO, navbarVO, doQuestionVO.getQuestionAnswer().equals(doQuestionVO.getAnswer())); } /* 濡傛灉鏄閫� */ else if (QuestionTypeEnum.MultipleChoice.getCode().equals(questionType)) { - answerVO.setItemOrder(num); + navbarVO.setItemOrder(num); doQuestionVO.setItemOrder(num); if (StringUtils.isEmpty(doQuestionVO.getQuestionAnswer())) { - return Result.fail(SystemCode.InnerError.getCode(), doQuestionVO.getTitle() + ",姝ら鐩己灏戠瓟妗堬紝璇峰厛瀹屽杽"); + return Result.fail(SystemCode.InnerError.getCode(), "棰樼洰id涓猴細" + doQuestionVO.getId() + "鐨勯鐩己灏戠瓟妗堬紝璇峰厛瀹屽杽"); } //瀛︾敓绛旀 List<String> answerList = doQuestionVO.getAnswerList(); @@ -556,7 +709,9 @@ List<String> questionAnswerList = Arrays.asList(questionAnswer.split(",")); //瀛︾敓绛旀涓虹┖锛屽垽鏂负閿� if (CollectionUtils.isEmpty(answerList)) { - trueOrFalse(doQuestionVO, answerVO, false); + score = trueOrFalse(score, doQuestionVO, navbarVO, false); + num++; + navbar.add(navbarVO); continue; } //绛旀鏁伴噺锛屼笉闇�瑕佽�冭檻椤哄簭 @@ -565,7 +720,9 @@ Set<String> set2 = new HashSet<>(questionAnswerList); //绛旀瀹屽叏涓�鑷达紝婊″垎 if (set1.equals(set2)) { - trueOrFalse(doQuestionVO, answerVO, true); + score = trueOrFalse(score, doQuestionVO, navbarVO, true); + num++; + navbar.add(navbarVO); continue; } if (paperMarkVO.getDeductType() == null) { @@ -573,19 +730,20 @@ } //濡傛灉澶氶�夊緱鍒嗙被鍨嬩负 绛旈敊涓嶅緱鍒� if (Integer.valueOf(DeductTypeEnum.AllCorrect.getCode()).equals(paperMarkVO.getDeductType())) { - trueOrFalse(doQuestionVO, answerVO, false); + score = trueOrFalse(score, doQuestionVO, navbarVO, false); } //濡傛灉澶氶�夊緱鍒嗙被鍨嬩负 婕忛�夊緱鍥哄畾鍒嗗��,鍖呭惈閿欒閫夐」涓嶅緱鍒� else if (Integer.valueOf(DeductTypeEnum.PartCorrect.getCode()).equals(paperMarkVO.getDeductType())) { //瀛︾敓绛旀绉婚櫎鎵�鏈夋纭瓟妗堬紝濡傛灉杩樻湁鍏冪礌璇存槑鍖呭惈閿欒閫夐」 answerList.removeAll(questionAnswerList); if (!CollectionUtils.isEmpty(answerList)) { - trueOrFalse(doQuestionVO, answerVO, false); + score = trueOrFalse(score, doQuestionVO, navbarVO, false); } else { - answerVO.setRight(false); + navbarVO.setRight(false); doQuestionVO.setRight(false); //婕忛�夊緱鍥哄畾鍒� doQuestionVO.setScore(paperMarkVO.getDeductScore()); + score = score.add(doQuestionVO.getScore()); } } //濡傛灉澶氶�夊緱鍒嗙被鍨嬩负 姣忓涓�棰樺緱鐩稿簲鍒嗗��,鍖呭惈閿欒閫夐」涓嶅緱鍒� @@ -593,21 +751,22 @@ //瀛︾敓绛旀绉婚櫎鎵�鏈夋纭瓟妗堬紝濡傛灉杩樻湁鍏冪礌璇存槑鍖呭惈閿欒閫夐」 answerList.removeAll(questionAnswerList); if (!CollectionUtils.isEmpty(answerList)) { - trueOrFalse(doQuestionVO, answerVO, false); + score = trueOrFalse(score, doQuestionVO, navbarVO, false); } else { - answerVO.setRight(false); + navbarVO.setRight(false); doQuestionVO.setRight(false); //婕忛�夊緱鍒� doQuestionVO.setScore(paperMarkVO.getDeductScore().multiply(new BigDecimal(answerCount))); + score = score.add(doQuestionVO.getScore()); } } } /* 濡傛灉鏄~绌� */ else if (QuestionTypeEnum.GapFilling.getCode().equals(questionType)) { - answerVO.setItemOrder(num); + navbarVO.setItemOrder(num); doQuestionVO.setItemOrder(num); if (StringUtils.isEmpty(doQuestionVO.getQuestionAnswer())) { - return Result.fail(SystemCode.InnerError.getCode(), doQuestionVO.getTitle() + ",姝ら鐩己灏戠瓟妗堬紝璇峰厛瀹屽杽"); + return Result.fail(SystemCode.InnerError.getCode(), "棰樼洰id涓猴細" + doQuestionVO.getId() + "鐨勯鐩己灏戠瓟妗堬紝璇峰厛瀹屽杽"); } //瀛︾敓绛旀 List<String> answerList = doQuestionVO.getAnswerList(); @@ -616,21 +775,23 @@ List<String> questionAnswerList = Arrays.asList(questionAnswer.split(",")); //瀛︾敓绛旀涓虹┖锛屽垽鏂负閿� if (CollectionUtils.isEmpty(answerList)) { - trueOrFalse(doQuestionVO, answerVO, false); + score = trueOrFalse(score, doQuestionVO, navbarVO, false); + num++; + navbar.add(navbarVO); continue; } //鎬荤┖鐨勬暟閲� int questionAnswerCount = questionAnswerList.size(); //绛旀瀹屽叏涓�鑷达紝婊″垎 if (answerList.equals(questionAnswerList)) { - trueOrFalse(doQuestionVO, answerVO, true); + score = trueOrFalse(score, doQuestionVO, navbarVO, true); } else { - answerVO.setRight(false); + navbarVO.setRight(false); doQuestionVO.setRight(false); //鍋氬鐨勬暟閲�,闇�瑕佹寜椤哄簭姣旇緝 int count = 0; for (int i = 0; i < answerList.size(); i++) { - if(answerList.get(i).equals(questionAnswerList.get(i))){ + if (answerList.get(i).equals(questionAnswerList.get(i))) { count++; } } @@ -638,74 +799,152 @@ BigDecimal questionScore = doQuestionVO.getQuestionScore(); //姣忎釜绌虹殑鍒嗘暟 BigDecimal scoreEach = questionScore.divide(new BigDecimal(questionAnswerCount), 1, RoundingMode.DOWN); - BigDecimal score = scoreEach.multiply(new BigDecimal(count)); - doQuestionVO.setScore(score); + //濉┖寰楀垎 + BigDecimal gapScore = scoreEach.multiply(new BigDecimal(count)); + doQuestionVO.setScore(gapScore); + score = score.add(doQuestionVO.getScore()); } } num++; - answers.add(answerVO); + navbar.add(navbarVO); } } - paperMarkVO.setAnswers(answers); + paperMarkVO.setTitleItems(titleItems); + paperMarkVO.setNavbar(navbar); + paperMarkVO.setScore(score + ""); return null; } //璁剧疆鍏ㄥ鎴栧叏閿� - private void trueOrFalse(DoQuestionVO doQuestionVO, ExamPaperMarkAnswerVO answerVO, Boolean isCorrect) { + private BigDecimal trueOrFalse(BigDecimal score, DoQuestionVO doQuestionVO, ExamPaperMarkNavbarVO orderVO, Boolean isCorrect) { if (isCorrect) { //姝g‘ - answerVO.setRight(isCorrect); + orderVO.setRight(isCorrect); doQuestionVO.setRight(isCorrect); doQuestionVO.setScore(doQuestionVO.getQuestionScore()); + score = score.add(doQuestionVO.getQuestionScore()); } else { //閿欒 - answerVO.setRight(isCorrect); + orderVO.setRight(isCorrect); doQuestionVO.setRight(isCorrect); doQuestionVO.setScore(BigDecimal.ZERO); } + return score; } //灏佽闃呭嵎杩斿洖鏁版嵁 private ExamPaperMarkVO createVO(ExamSubmitTemp userExam, ExamVO exam, User student) { ExamPaperMarkVO paperMarkVO = new ExamPaperMarkVO(); - BeanUtils.copyProperties(userExam, paperMarkVO); - paperMarkVO.setPaperId(exam.getExamPaperId()); - //TODO: 璇曞嵎鎬诲垎銆�(澶氶�夊緱鍒嗙被鍨嬨�佸閫夊緱鍒嗗垎鏁�)闇�瑕佸彇ExamSubmitTemp - paperMarkVO.setExamName(exam.getExamName()); - paperMarkVO.setPaperType(exam.getExamPaperType()); - paperMarkVO.setSubmitTime(userExam.getUpdateTime()); + if (userExam != null) { + BeanUtils.copyProperties(userExam, paperMarkVO); + paperMarkVO.setSubmitTime(userExam.getUpdateTime()); + paperMarkVO.setTitleItems(JSON.parseArray(userExam.getExamSubmit(), PaperFixQuestionVO.class)); + } else { + //缂鸿�冿紝瀛︾敓娌℃湁鍋氶淇℃伅 + paperMarkVO.setExamId(exam.getId()); + paperMarkVO.setUserId(student.getId()); + paperMarkVO.setScore(BigDecimal.ZERO + ""); + paperMarkVO.setDoTime(0); + } paperMarkVO.setUserName(student.getRealName()); - paperMarkVO.setTitleItems(JSON.parseArray(userExam.getExamSubmit(), PaperFixQuestionVO.class)); - paperMarkVO.setTotalScore("100"); - paperMarkVO.setDeductType(DeductTypeEnum.AllCorrect.getCode()); - paperMarkVO.setDeductScore(BigDecimal.ZERO); + paperMarkVO.setExamName(exam.getExamName()); + paperMarkVO.setPaperId(exam.getExamPaperId()); + paperMarkVO.setPaperType(exam.getExamPaperType()); + ExamPaper examPaper = examPaperMapper.selectById(exam.getExamPaperId()); + paperMarkVO.setTotalScore(examPaper.getScore() + ""); + paperMarkVO.setDeductType(examPaper.getDeductType()); + paperMarkVO.setDeductScore(examPaper.getDeductTypeScore()); return paperMarkVO; } + + //鎻愪氦鎵规敼 + @Override + @Transactional(rollbackFor = Exception.class) + public Result submitMarkPaper(ExamPaperMarkVO examPaperMark) { + Integer userId = webContext.getCurrentUser().getId(); + //鎻掑叆exam_paper_answer(鎴愮哗琛�) + ExamPaperScore examPaperScore = new ExamPaperScore(); + BeanUtils.copyProperties(examPaperMark, examPaperScore); + examPaperScore.setScore(new BigDecimal(examPaperMark.getScore())); + examPaperScore.setTotalScore(new BigDecimal(examPaperMark.getTotalScore())); + examPaperScore.setJudgeUser(userId); + examPaperScore.setJudgeTime(new Date()); + if (!StringUtils.isEmpty(examPaperMark.getTitleItems())) { + examPaperScore.setPaperContent(JSON.toJSONString(examPaperMark.getTitleItems())); + } + if (!StringUtils.isEmpty(examPaperMark.getNavbar())) { + examPaperScore.setNavbar(JSON.toJSONString(examPaperMark.getNavbar())); + } + long questionCorrect = 0; + long questionCount = 0; + if (!CollectionUtils.isEmpty(examPaperMark.getNavbar())) { + examPaperScore.setStatus(ExamScoreConstant.PRESENT); + questionCorrect = examPaperMark.getNavbar().stream().filter(vo -> vo.getRight() != null && vo.getRight()).count(); + questionCount = examPaperMark.getNavbar().size(); + } else { + //缂鸿�冩煡璇曞嵎閰嶇疆 + Integer paperId = examPaperMark.getPaperId(); + ExamPaper examPaper = examPaperMapper.selectById(paperId); + questionCount = examPaper.getNum(); + examPaperScore.setStatus(ExamScoreConstant.ABSENT); + } + examPaperScore.setQuestionCorrect(Integer.valueOf(questionCorrect + "")); + examPaperScore.setQuestionCount(Integer.valueOf(questionCount + "")); + //鎵句箣鍓嶆湁鏃犳壒鏀硅褰� + ExamPaperScore score = examPaperScoreMapper.getByExamIdUserId(examPaperMark.getExamId(), examPaperMark.getUserId()); + if (score != null) { + examPaperScore.setId(score.getId()); + examPaperScoreMapper.updateById(examPaperScore); + } else { + examPaperScoreMapper.insert(examPaperScore); + //淇敼鑰冭瘯閲岃瘯鍗风姸鎬佷负宸查槄鍗� + ExamSubmitTemp userExam = new LambdaQueryChainWrapper<>(examSubmitTempMapper) + .eq(ExamSubmitTemp::getExamId, examPaperMark.getExamId()) + .eq(ExamSubmitTemp::getUserId, examPaperMark.getUserId()) + .one(); + if (userExam != null) { + userExam.setMarkPaperStatus(ExamSubmitTempStatusEnum.finish); + examSubmitTempMapper.updateById(userExam); + } + } + return Result.ok(); + } + @Override public Result monitorList(ExamQuery query) { IPage<ExamSubmitTempVO> page = PageUtil.getPage(query, ExamSubmitTempVO.class); - return Result.ok((examSubmitTempMapper.monitorList(page, query))); + IPage<ExamSubmitTempVO> vo = examSubmitTempMapper.monitorList(page, query); + + return Result.ok(vo); } @Override public Result addTime(AddTimeForm form) { + if (!websocketServer.checkUserOnline(form.getUserId())) { + throw new RuntimeException("璇ュ鍛樹笉鍦ㄧ嚎锛屾棤娉曟墽琛岃鎿嶄綔"); + } WebsocketDataVO websocket = new WebsocketDataVO(); - websocket.setCommend(WebsocketCommendEnum.DELAYED.getCommend()); + websocket.setCommend(WebsocketCommendEnum.DELAYED.getCommand()); + BigDecimal sed = BigDecimal.valueOf(60).multiply(form.getAddTimeM()); + form.setAddTimeM(sed); websocket.setData(form); // 鍙戦�亀ebsocket娑堟伅 - websocketServer.sendOneMessage(form.getUserId(), JSON.toJSONString(form)); + websocketServer.sendOneMessage(form.getUserId(), JSON.toJSONString(websocket)); return Result.ok("鎿嶄綔鎴愬姛"); } @Override public Result forceSubmit(ForceSubmitForm form) { + if (!websocketServer.checkUserOnline(form.getUserId())) { + throw new RuntimeException("璇ュ鍛樹笉鍦ㄧ嚎锛屾棤娉曟墽琛岃鎿嶄綔"); + } WebsocketDataVO websocket = new WebsocketDataVO(); - websocket.setCommend(WebsocketCommendEnum.FORCE_SUBMIT.getCommend()); + websocket.setCommend(WebsocketCommendEnum.FORCE_SUBMIT.getCommand()); websocket.setData(form); // 鍙戦�亀ebsocket娑堟伅 - websocketServer.sendOneMessage(form.getUserId(), JSON.toJSONString(form)); + websocketServer.sendOneMessage(form.getUserId(), JSON.toJSONString(websocket)); return Result.ok("鎿嶄綔鎴愬姛"); } } -- Gitblit v1.8.0