ImageCheckServiceImpl.java 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104
  1. package cn.com.qmth.scancentral.service.impl;
  2. import java.util.List;
  3. import org.apache.commons.collections.CollectionUtils;
  4. import org.apache.commons.lang3.StringUtils;
  5. import org.slf4j.Logger;
  6. import org.slf4j.LoggerFactory;
  7. import org.springframework.beans.factory.annotation.Autowired;
  8. import org.springframework.stereotype.Component;
  9. import com.baomidou.mybatisplus.core.metadata.IPage;
  10. import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
  11. import com.qmth.boot.core.collection.PageResult;
  12. import cn.com.qmth.scancentral.dao.StudentDao;
  13. import cn.com.qmth.scancentral.service.ImageCheckService;
  14. import cn.com.qmth.scancentral.service.ToolExportService;
  15. import cn.com.qmth.scancentral.util.MathUtil;
  16. import cn.com.qmth.scancentral.util.PageUtil;
  17. import cn.com.qmth.scancentral.vo.imagecheck.ImageCheckDetailVo;
  18. import cn.com.qmth.scancentral.vo.imagecheck.ImageCheckFailedQuery;
  19. import cn.com.qmth.scancentral.vo.imagecheck.ImageCheckVo;
  20. @Component
  21. public class ImageCheckServiceImpl implements ImageCheckService {
  22. private static final Logger log = LoggerFactory.getLogger(ImageCheckServiceImpl.class);
  23. @Autowired
  24. private ToolExportService toolExportService;
  25. @Autowired
  26. private StudentDao studentDao;
  27. @Override
  28. public List<ImageCheckVo> list(Long examId) {
  29. if (examId == null) {
  30. throw new IllegalArgumentException("考试ID不能为空");
  31. }
  32. List<ImageCheckVo> result = studentDao.countImageCheck(examId);
  33. for (ImageCheckVo vo : result) {
  34. if (vo.getTotalCount() == null || vo.getTotalCount() == 0) {
  35. vo.setImageCheckProgress(null);
  36. } else {
  37. double progress = MathUtil.percentage(vo.getDisposedCount(), vo.getTotalCount());
  38. vo.setImageCheckProgress(progress);
  39. }
  40. }
  41. return result;
  42. }
  43. @Override
  44. public PageResult<ImageCheckDetailVo> failedPage(ImageCheckFailedQuery query) {
  45. if (query.getExamId() == null) {
  46. throw new IllegalArgumentException("考试ID不能为空");
  47. }
  48. if (StringUtils.isBlank(query.getSubjectCode())) {
  49. throw new IllegalArgumentException("科目代码不能为空");
  50. }
  51. IPage<ImageCheckDetailVo> page = studentDao.failedPage(new Page<>(query.getPageNumber(), query.getPageSize()),
  52. query);
  53. for (ImageCheckDetailVo vo : page.getRecords()) {
  54. vo.setFailed(vo.getFailedCount() > 0);
  55. }
  56. return PageUtil.of(page);
  57. }
  58. /**
  59. * 图片检查
  60. */
  61. @Override
  62. public void check(Long examId) {
  63. log.warn("图片检查开始... examId:{}", examId);
  64. long startTime = System.currentTimeMillis();
  65. int batchSize = 1000;
  66. int checkedSize = 0;
  67. Long startId = 0L;
  68. while (true) {
  69. List<Long> studentIds = studentDao.queryImageCheckWaitingList(examId, startId, batchSize);
  70. if (CollectionUtils.isEmpty(studentIds)) {
  71. break;
  72. }
  73. for (Long studentId : studentIds) {
  74. toolExportService.studentCheck(studentId);
  75. }
  76. checkedSize += studentIds.size();
  77. log.info("图片检查中... examId:{} checkedSize:{} startId:{}", examId, checkedSize, startId);
  78. startId = studentIds.get(studentIds.size() - 1);
  79. }
  80. long cost = (System.currentTimeMillis() - startTime) / 1000;
  81. log.warn("图片检查结束... examId:{} checkedSize:{} cost:{}s", examId, checkedSize, cost);
  82. }
  83. }