智慧保安后台管理-外网
钟日健
2022-06-27 59b41b126c4a8642fcb489f0dea954b16465318d
src/main/java/org/springblade/modules/exam/service/impl/ExamScoreServiceImpl.java
@@ -1,12 +1,17 @@
package org.springblade.modules.exam.service.impl;
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.baomidou.mybatisplus.core.metadata.IPage;
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import org.apache.commons.lang3.StringUtils;
import org.springblade.common.utils.DesensitizedUtil;
import org.springblade.core.log.exception.ServiceException;
import org.springblade.core.mp.support.Condition;
import org.springblade.core.tool.utils.BeanUtil;
import org.springblade.modules.FTP.FtpUtil;
import org.springblade.modules.FTP.Monitor;
import org.springblade.modules.FTP.Result;
import org.springblade.modules.apply.entity.Apply;
import org.springblade.modules.apply.service.ApplyService;
import org.springblade.modules.exam.entity.*;
@@ -27,6 +32,7 @@
import org.springblade.modules.system.entity.User;
import org.springblade.modules.system.service.IRoleService;
import org.springblade.modules.system.service.IUserService;
import org.springblade.modules.system.service.MyAsyncService;
import org.springblade.modules.system.vo.UserVO;
import org.springblade.modules.training.entity.TrainingRegistration;
import org.springblade.modules.training.service.TrainingRegistrationService;
@@ -43,6 +49,7 @@
/**
 * 考试成绩服务实现类
 *
 * @author zhongrj
 */
@Service
@@ -71,22 +78,24 @@
   @Autowired
   private IInformationService informationService;
   @Autowired
   private MyAsyncService myAsyncService;
   /**
    * 自定义分页数据
    * @param page 分页条件
    *
    * @param page      分页条件
    * @param examScore 考试成绩对象
    * @return
    */
   @Override
   public IPage<ExamScoreVO> selectExamScorePage(IPage<ExamScoreVO> page, ExamScoreVO examScore) {
      if (null!=examScore.getExamType()){
         if (examScore.getExamType()==1){
      if (null != examScore.getExamType()) {
         if (examScore.getExamType() == 1) {
            return page.setRecords(baseMapper.selectExamScorePage(page, examScore));
         }
         if (examScore.getExamType()==2){
         if (examScore.getExamType() == 2) {
            return page.setRecords(baseMapper.selectTrainExamScorePage(page, examScore));
         }
      }
@@ -95,6 +104,7 @@
   /**
    * 详情
    *
    * @param examScore 考试成绩信息对象
    */
   @Override
@@ -104,6 +114,7 @@
   /**
    * 保存考试成绩
    *
    * @param examScore 考试成绩信息对象
    * @return
    */
@@ -111,7 +122,8 @@
   @Transactional(rollbackFor = Exception.class)
   public Boolean saveExamScore(ExamScoreVO examScore) {
      //取出考试结果
      if (examScore.getExamResultVOS().size()>0){
      if (examScore.getExamResultVOS().size() > 0) {
         ExamScore score = this.getById(examScore.getId());
         List<ExamResultVO> examResultVOS = examScore.getExamResultVOS();
         //获取试卷的内容(题号,答案)
//         ExamPaper examPaper = new ExamPaper();
@@ -123,16 +135,16 @@
         //声明理论得分
         int theoryGrade = 0;
         for (ExamResultVO examResultVO : examResultVOS) {
            for (ExamSubjectChoices es: list) {
            for (ExamSubjectChoices es : list) {
               //对比题目id
               if (examResultVO.getSubjectChoicesId().equals(es.getId())) {
                  //对比答案
                  if (es.getChoicesType() == 2 || es.getChoicesType() == 3){
                  if (es.getChoicesType() == 2 || es.getChoicesType() == 3) {
                     //判断题逻辑
                     if (examResultVO.getValue().equals(es.getAnswer())) {
                        theoryGrade += examResultVO.getGrade();
                     }
                  }else if(es.getChoicesType() == 0 || es.getChoicesType() == 1){
                  } else if (es.getChoicesType() == 0 || es.getChoicesType() == 1) {
                     //处理多选题的答案排序
                     String[] split = examResultVO.getValue().split(",");
                     StringBuilder builder = new StringBuilder();
@@ -143,7 +155,7 @@
                     //利用数组帮助类自动排序
                     Arrays.sort(arrayCh);
                     String sub0 = Arrays.toString(arrayCh);
                     String sub = sub0.substring(1,sub0.length()-1).replaceAll(" ","");
                     String sub = sub0.substring(1, sub0.length() - 1).replaceAll(" ", "");
                     if (sub.equals(es.getAnswer())) {
                        theoryGrade += examResultVO.getGrade();
                     }
@@ -159,7 +171,7 @@
         int age = 0;
         UserVO user = new UserVO();
         //使用准考证号查询报名信息,修改考试状态为已考试
         if(paper.getExamType()==1){
         if (paper.getExamType() == 1) {
            Apply apply = new Apply();
            apply.setCandidateNo(examScore.getCandidateNo());
            Apply apply1 = applyService.getOne(Condition.getQueryWrapper(apply));
@@ -175,22 +187,24 @@
            //数据同步
            String s =
               "update sys_apply set is_exam = " + apply1.getIsExam() + " " +"where id = " + "'" + apply1.getId() + "';" +
                  "update blade_user set is_apply = " + user.getIsApply() + " " +"where id = " + "'" + user.getId() + "'";
            FtpUtil.sqlFileUpload(s);
               "update sys_apply set is_exam = " + apply1.getIsExam() + " " + "where id = " + "'" + apply1.getId() + "';" +
                  "update blade_user set is_apply = " + user.getIsApply() + " " + "where id = " + "'" + user.getId() + "'";
            //FtpUtil.sqlFileUpload(s);
            myAsyncService.FTP(s);
         }
         //模拟考试
         if(paper.getExamType()==2){
            TrainingRegistration trainingRegistration = new TrainingRegistration();
            trainingRegistration.setCandidateNo(examScore.getCandidateNo());
            trainingRegistration.setCancel(1);
            TrainingRegistration trainingRegistration1 = trainingRegistrationService.getOne(Condition.getQueryWrapper(trainingRegistration));
         //培训考试
         if (paper.getExamType() == 2) {
//            TrainingRegistration trainingRegistration = new TrainingRegistration();
//            trainingRegistration.setCandidateNo(examScore.getCandidateNo());
//            trainingRegistration.setCancel(1);
//            TrainingRegistration trainingRegistration1 = trainingRegistrationService.getOne(Condition.getQueryWrapper(trainingRegistration));
            TrainingRegistration trainingRegistration1 = trainingRegistrationService.getById(score.getApplyId());
            //查询用户年龄,根据年龄计算总分
            user = userService.getUserAgeById(Long.parseLong(trainingRegistration1.getUserId()));
            //修改用户的培训状态,理论考试结束
            user.setIsTrain(3);
            age = user.getAge();
//            age = user.getAge();
            userService.updateById(user);
            //修改为已考试
            trainingRegistration1.setIsExam(2);
@@ -198,26 +212,28 @@
            //数据同步
            String s =
               "update sys_training_registration set is_exam = " + trainingRegistration1.getIsExam() + " " +"where id = " + "'" + trainingRegistration1.getId() + "';" +
                  "update blade_user set is_train = " + user.getIsTrain() + " " +"where id = " + "'" + user.getId() + "'";
            FtpUtil.sqlFileUpload(s);
               "update sys_training_registration set is_exam = " + trainingRegistration1.getIsExam() + " " + "where id = " + "'" + trainingRegistration1.getId() + "';" +
                  "update blade_user set is_train = " + user.getIsTrain() + " " + "where id = " + "'" + user.getId() + "'";
            //FtpUtil.sqlFileUpload(s);
            myAsyncService.FTP(s);
         }
         //设置提交时间
         examScore.setExamEndTime(new Date());
         //设置考试ID
         examScore.setExamId(examScore.getPapersId().toString());
         //设置理论得分
         examScore.setTheoryGrade(theoryGrade);
         //计算总成绩,此时没有实操成绩,总成绩为实操成绩和理论成绩和的一半
         if (age<=50) {
            examScore.setAllGrade(Math.round(theoryGrade / 2));
         }
         if (age>50) {
            examScore.setAllGrade(Integer.parseInt(String.valueOf(Math.round(theoryGrade*0.5))));
         }
         examScore.setAllGrade(Math.round(theoryGrade / 2));
//         if (age <= 50) {
//         }
//         if (age > 50) {
//            examScore.setAllGrade(Integer.parseInt(String.valueOf(Math.round(theoryGrade * 0.5))));
//         }
         //设置状态
         if (theoryGrade>=60){
         if (theoryGrade >= 60) {
            examScore.setQualified(2);
         }else {
         } else {
            examScore.setQualified(1);
         }
         //修改成绩数据
@@ -229,10 +245,11 @@
               ",all_grade = " + "'" + examScore.getAllGrade() + "'" +
               ",exam_end_time = " + "'" + new SimpleDateFormat("yyyy-MM-dd HH:mm:dd").format(examScore.getExamEndTime()) + "'" +
               ",qualified = " + "'" + examScore.getQualified() + "'" +
               " " +"where id = " + "'" + examScore.getId() + "'";
         FtpUtil.sqlFileUpload(s1);
               " " + "where id = " + "'" + examScore.getId() + "'";
         //FtpUtil.sqlFileUpload(s1);
         myAsyncService.FTP(s1);
         if (i>0){
         if (i > 0) {
            //返回结果
            return true;
         }
@@ -241,48 +258,76 @@
      return false;
   }
//   /**
//    * 导入实操成绩
//    *
//    * @param examScoreExcelList
//    * @param isCovered          是否覆盖
//    */
//   @Override
//   public void importExamScore(List<ExamScoreExcel> examScoreExcelList, Boolean isCovered) {
//      if (examScoreExcelList.size() > 0) {
//         //遍历
//         examScoreExcelList.forEach(examScoreExcel -> {
//            if (null != examScoreExcel.getLearnGrade() && null != examScoreExcel.getIdCardNo() && examScoreExcel.getIdCardNo() != "") {
//               //使用考试名称匹配考试信息
//               List<ExamPaper> examPaperList = examPaperService.getExamInfoByExamName(examScoreExcel.getExamName());
//               ExamPaper examPaper = examPaperList.get(0);
//               //查询出成绩数据
//               if (examPaperList.size() > 0) {
//                  ExamScore score = new ExamScore();
//                  score.setCandidateNo(examScoreExcel.getIdCardNo());
//                  score.setLearnGrade(examScoreExcel.getLearnGrade());
//                  score.setExamTime(examPaper.getStartTime());
//                  //生成随机数
//                  String uuid = UUID.randomUUID().toString();
//                  //数据推送
//                  Map<String, Object> map = new HashMap<>(1);
//                  map.put(uuid, score);
//                  myAsyncService.FTPObjectExamScore(map);
//               } else {
//                  throw new ServiceException("导入失败!考试名称:[" + examScoreExcel.getExamName() + "]不存在!请核对!");
//               }
//            }
//         });
//      }
//   }
   /**
    * 导入实操成绩
    * 导入实操成绩(按准考证编号导入版)
    *
    * @param examScoreExcelList
    * @param isCovered 是否覆盖
    * @param isCovered          是否覆盖
    */
   @Override
   public void importExamScore(List<ExamScoreExcel> examScoreExcelList, Boolean isCovered) {
      if (examScoreExcelList.size()>0){
      if (examScoreExcelList.size() > 0) {
         List<Object> errorList = new ArrayList<>();
         //导入状态,默认为true ,如果有一个出现问题则为 false
         AtomicBoolean status = new AtomicBoolean(true);
         //遍历
         examScoreExcelList.forEach(examScoreExcel -> {
            if (null!=examScoreExcel.getLearnGrade() && null!=examScoreExcel.getIdCardNo() && examScoreExcel.getIdCardNo()!=""){
         for (ExamScoreExcel examScoreExcel : examScoreExcelList) {
            if (null != examScoreExcel.getLearnGrade() && null != examScoreExcel.getCandidateNo() && examScoreExcel.getCandidateNo() != "") {
               //使用考试名称匹配考试信息
               List<ExamPaper> examPaperList = examPaperService.getExamInfoByExamName(examScoreExcel.getExamName());
               ExamPaper examPaper = examPaperList.get(0);
               //查询出成绩数据
               if (examPaperList.size()>0){
                  //取第一个
                  List<ExamScore> examScoreList = baseMapper.getExamScoreInfoByIdCardNo(examScoreExcel.getIdCardNo(),new SimpleDateFormat("yyyy-MM-dd").format(examPaper.getStartTime()));
                  if (examScoreList.size()==0){
                     //根据身份证号查询用户
                     User user0 = userService.getUserInfoByIdCardNo(examScoreExcel.getIdCardNo());
                     if (null==user0){
                        throw new ServiceException("没有找到用户:["+examScoreExcel.getIdCardNo()+"]相关考试成绩信息,请检查身份证是否有误!");
//                        throw new ServiceException("用户:["+examScoreExcel.getIdCardNo()+"]不存在");
                     }
               if (examPaperList.size() > 0) {
                  ExamScore score = new ExamScore();
                  score.setCandidateNo(examScoreExcel.getCandidateNo());
                  List<ExamScore> examScoreList = this.list(new QueryWrapper<>(score));
                  if (examScoreList.size() == 0) {
                     errorList.add(examScoreExcel.getName());
                     status.set(false);
                     break;
                  }
                  //遍历集合
                  examScoreList.forEach(examScore -> {
//                     ExamScore examScore1 = new ExamScore();
//                     examScore1.setCandidateNo(examScoreExcel.getCandidateNo());
//                     examScore1.setUserId(user0.getId().toString());
//                     //根据准考证号和用户id查询考试成绩
//                     ExamScore examScore = this.getOne(Condition.getQueryWrapper(examScore1));
                     if (null!=examScore) {
                     if (null != examScore) {
                        //查询当前保安信息
                        UserVO user = userService.getUserAgeById(Long.parseLong(examScore.getUserId()));
                        //设置实操成绩
                        examScore.setLearnGrade(examScoreExcel.getLearnGrade());
                        if (null!=examScore.getTheoryGrade()){
                        if (null != examScore.getTheoryGrade()) {
                           if (examScore.getTheoryGrade() >= 60 && examScore.getLearnGrade() >= 60) {
                              //合格
                              examScore.setQualified(0);
@@ -290,61 +335,11 @@
                              user.setUserType(7);
                              //如果已有保安证编号,不更新用户信息
                              if (null == user.getSecuritynumber() || user.getSecuritynumber().equals("")) {
                                 //去生成保安证编号
                                 String pre = SecurityPaperUtil.getSecurityPaper();
                                 //查询当前年份已有的保安证编号
                                 int count = userService.getSecurityPaperCount(pre);
                                 String result = null;
                                 if (count == 0) {
                                    result = pre + "00001";
                                 } else {
                                    //格式化
                                    DecimalFormat decimalFormat = new DecimalFormat("00000");
                                    count++;
                                    result = pre + (decimalFormat.format(count));
                                 }
                                 user.setSecuritynumber(result);
                                 //修改为持证保安
                                 user.setHold("1");
                                 user.setUpdateTime(new Date());
                                 //更新保安数据
                                 userService.updateById(user);
                                 //生成保安证的同时向保安证管理表中插入一条数据
                                 SecurityPaper securityPaper = new SecurityPaper();
                                 securityPaper.setUserId(user.getId());
                                 securityPaper.setNumber(result);
                                 securityPaper.setCreateTime(new Date());
                                 securityPaper.setIdCardNo(user.getCardid());
                                 securityPaper.setPeopleName(user.getRealName());
                                 securityPaper.setExamId(Long.parseLong(examScore.getExamId()));
                                 securityPaper.setApplyId(examScore.getApplyId());
                                 //新增保安员证信息
                                 securityPaperService.save(securityPaper);
                                 String s1 =
                                    "update blade_user set hold = " + "'" + user.getHold() + "'" +
                                       ",securitynumber = " + "'" + user.getSecuritynumber() + "'" +
                                       ",update_time = " + "'" + new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(user.getUpdateTime()) + "'" +
                                       ",user_type = " + "'" + user.getUserType() + "'" +
                                       " " + "where id = " + "'" + user.getId() + "'";
//                                 String s1 =
//                                    "insert into sys_security_paper(id,number,create_time,people_name,id_card_no,user_id,apply_id,exam_id) " +
//                                       "values(" + "'" + securityPaper.getId() + "'"
//                                       + "," + "'" + securityPaper.getNumber() +"'"
//                                       + "," + "'" + new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(securityPaper.getCreateTime()) +"'"
//                                       + "," + "'" + securityPaper.getPeopleName() + "'"
//                                       + "," + "'" + securityPaper.getIdCardNo() + "'"
//                                       + "," + "'" + securityPaper.getUserId() + "'"
//                                       + "," + "'" + securityPaper.getApplyId() + "'"
//                                       + "," +"'" + securityPaper.getExamId() + "'" + ");" +
//                                    "update blade_user set hold = " + "'" + user.getHold() + "'" +
//                                       ",securitynumber = " + "'" + user.getSecuritynumber() + "'" +
//                                       ",update_time = " + "'" + new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(user.getUpdateTime()) + "'" +
//                                       ",user_type = " + "'" + user.getUserType() + "'" +
//                                       " " + "where id = " + "'" + user.getId() + "'";
                                 FtpUtil.sqlFileUpload(s1);
                                 //去内网生成保安证编号,由内网生成,无需返回
                                 //数据推送
                                 Map<String, Object> map = new HashMap<>(1);
                                 map.put("key",examScore);
                                 myAsyncService.FTPSecurityNumberBit(map);
                              }
                           }
                        } else {
@@ -353,17 +348,17 @@
                        }
                        //总成绩
                        if (user.getAge() <= 50) {
                           if (null!=examScore.getTheoryGrade()) {
                           if (null != examScore.getTheoryGrade()) {
                              examScore.setAllGrade(Math.round((examScore.getTheoryGrade() + examScoreExcel.getLearnGrade()) / 2));
                           }else {
                           } else {
                              examScore.setAllGrade(Math.round(examScoreExcel.getLearnGrade() / 2));
                           }
                        }
                        if (user.getAge() > 50) {
                           if (null!=examScore.getTheoryGrade()) {
                           if (null != examScore.getTheoryGrade()) {
                              examScore.setAllGrade(Integer.parseInt(String.valueOf(Math.round(examScore.getTheoryGrade() * 0.5)))
                                 + Integer.parseInt(String.valueOf(Math.round(examScoreExcel.getLearnGrade() * 0.5))));
                           }else {
                           } else {
                              examScore.setAllGrade(Math.round(examScoreExcel.getLearnGrade() / 2));
                           }
                        }
@@ -374,27 +369,220 @@
                              ",all_grade = " + "'" + examScore.getAllGrade() + "'" +
                              ",qualified = " + "'" + examScore.getQualified() + "'" +
                              " " + "where id = " + "'" + examScore.getId() + "'";
                        FtpUtil.sqlFileUpload(s1);
                        myAsyncService.FTP(s1);
                        //更新成绩数据
                        baseMapper.updateById(examScore);
                     }else {
                        errorList.add(examScoreExcel.getIdCardNo());
                     } else {
                        errorList.add(examScoreExcel.getName());
                        status.set(false);
                     }
                  });
               }else {
                  throw new ServiceException("导入失败!考试名称:["+examScoreExcel.getExamName()+"]不存在!请核对!");
               } else {
                  throw new ServiceException("导入失败!考试名称:[" + examScoreExcel.getExamName() + "]不存在!请核对!");
               }
            }
         });
         }
         //如果所有数据导入有一个异常
         if (!status.get()){
         if (!status.get()) {
            String errorAccount = StringUtils.join(errorList, "\\\n");
            throw new ServiceException("用户:["+errorAccount+"]实操成绩导入失败!账号与准考证号不匹配!");
            throw new ServiceException("用户:[" + errorAccount + "]实操成绩导入失败!账号与准考证号不匹配!");
         }
      }
   }
//   /**
//    * 导入实操成绩
//    *
//    * @param examScoreExcelList
//    * @param isCovered          是否覆盖
//    */
//   @Override
//   public void importExamScore(List<ExamScoreExcel> examScoreExcelList, Boolean isCovered) {
//      if (examScoreExcelList.size() > 0) {
//         List<Object> errorList = new ArrayList<>();
//         //导入状态,默认为true ,如果有一个出现问题则为 false
//         AtomicBoolean status = new AtomicBoolean(true);
//         //遍历
//         examScoreExcelList.forEach(examScoreExcel -> {
//            if (null != examScoreExcel.getLearnGrade() && null != examScoreExcel.getIdCardNo() && examScoreExcel.getIdCardNo() != "") {
//               //使用考试名称匹配考试信息
//               List<ExamPaper> examPaperList = examPaperService.getExamInfoByExamName(examScoreExcel.getExamName());
//               ExamPaper examPaper = examPaperList.get(0);
//               //查询出成绩数据
//               if (examPaperList.size() > 0) {
//                  //取第一个
//                  List<ExamScore> examScoreList = baseMapper.getExamScoreInfoByIdCardNo(examScoreExcel.getIdCardNo(), new SimpleDateFormat("yyyy-MM-dd").format(examPaper.getStartTime()));
//                  if (examScoreList.size() == 0) {
//                     //根据身份证号查询用户
//                     User user0 = userService.getUserInfoByIdCardNo(examScoreExcel.getIdCardNo());
//                     if (null == user0) {
//                        throw new ServiceException("没有找到用户:[" + examScoreExcel.getIdCardNo() + "]相关考试成绩信息,请检查身份证是否有误!");
////                        throw new ServiceException("用户:["+examScoreExcel.getIdCardNo()+"]不存在");
//                     }
//                  }
//                  //遍历集合
//                  examScoreList.forEach(examScore -> {
////                     ExamScore examScore1 = new ExamScore();
////                     examScore1.setCandidateNo(examScoreExcel.getCandidateNo());
////                     examScore1.setUserId(user0.getId().toString());
////                     //根据准考证号和用户id查询考试成绩
////                     ExamScore examScore = this.getOne(Condition.getQueryWrapper(examScore1));
//                     if (null != examScore) {
//                        //查询当前保安信息
//                        UserVO user = userService.getUserAgeById(Long.parseLong(examScore.getUserId()));
//                        //设置实操成绩
//                        examScore.setLearnGrade(examScoreExcel.getLearnGrade());
//                        if (null != examScore.getTheoryGrade()) {
//                           if (examScore.getTheoryGrade() >= 60 && examScore.getLearnGrade() >= 60) {
//                              //合格
//                              examScore.setQualified(0);
//                              //修改制证状态为未制证
//                              user.setUserType(7);
//                              //如果已有保安证编号,不更新用户信息
//                              if (null == user.getSecuritynumber() || user.getSecuritynumber().equals("")) {
//                                 //去生成保安证编号
//                                 String pre = SecurityPaperUtil.getSecurityPaper();
//                                 //查询当前年份已有的保安证编号
//                                 int count = userService.getSecurityPaperCount(pre);
//                                 //需调用内网查询
//                                 //生成随机数
//                                 String uuid = UUID.randomUUID().toString();
//
//                                 //数据推送
//                                 Map<String, Object> map = new HashMap<>(1);
//                                 map.put(uuid,pre);
//                                 myAsyncService.FTPSecurityNumberBit(map);
//
//                                 int count = 0;
//                                 Result result0 = new Result();
//                                 //调用ftp获取返回数据
//                                 while (true){
//                                    try {
//                                       Thread.sleep(1000);
//                                    } catch (InterruptedException e) {
//                                       e.printStackTrace();
//                                    }
//                                    //调用ftp获取返回数据
//                                    result0 = Monitor.getSecurityNumberBit(uuid);
//                                    //如果返回true,就退处
//                                    if (result0.getCode()==200){
//                                       break;
//                                    }else{
//                                       //计数
//                                       count++;
//                                       //如果超过100s 没有读取到,则退出
//                                       if (count == 100) {
//                                          break;
//                                       }
//                                    }
//                                 }
//                                 int max = Integer.parseInt(result0.getMsg());
//                                 String result = null;
//                                 if (max == 0) {
//                                    result = pre + "00001";
//                                 } else {
//                                    //格式化
//                                    DecimalFormat decimalFormat = new DecimalFormat("00000");
//                                    max++;
//                                    result = pre + (decimalFormat.format(max));
//                                 }
//                                 //脱敏处理
//                                 user.setSecuritynumber(DesensitizedUtil.desensitizedSecurityNumber(result));
//                                 //修改为持证保安
//                                 user.setHold("1");
//                                 user.setUpdateTime(new Date());
//                                 //更新保安数据
//                                 userService.updateById(user);
//
//                                 //生成保安证的同时向保安证管理表中插入一条数据
//                                 SecurityPaper securityPaper = new SecurityPaper();
//                                 securityPaper.setUserId(user.getId());
//                                 securityPaper.setNumber(result);
//                                 securityPaper.setCreateTime(new Date());
//                                 securityPaper.setIdCardNo(user.getCardid());
//                                 securityPaper.setPeopleName(user.getRealName());
//                                 securityPaper.setExamId(Long.parseLong(examScore.getExamId()));
//                                 securityPaper.setApplyId(examScore.getApplyId());
//                                 securityPaper.setSource(1);
//                                 //内网对象
//                                 SecurityPaper paper = Objects.requireNonNull(BeanUtil.copy(securityPaper,SecurityPaper.class));
//                                 //新增保安员证信息
//                                 securityPaper.setNumber(DesensitizedUtil.desensitizedSecurityNumber(result));
//                                 securityPaper.setIdCardNo("");
//                                 securityPaperService.save(securityPaper);
//
//                                 //设置id
//                                 paper.setId(securityPaper.getId());
//                                 //内网同步
//                                 String s1 =
//                                    "insert into sys_security_paper(id,number,create_time,people_name,id_card_no,user_id,apply_id,exam_id,source) " +
//                                       "values(" + "'" + paper.getId() + "'"
//                                       + "," + "'" + paper.getNumber() +"'"
//                                       + "," + "'" + new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(paper.getCreateTime()) +"'"
//                                       + "," + "'" + paper.getPeopleName() + "'"
//                                       + "," + "'" + paper.getIdCardNo() + "'"
//                                       + "," + "'" + paper.getUserId() + "'"
//                                       + "," + "'" + paper.getApplyId() + "'"
//                                       + "," + "'" + paper.getExamId() + "'"
//                                       + "," +"'" + paper.getSource() + "'" + ");" +
//                                    "update blade_user set hold = " + "'" + user.getHold() + "'" +
//                                       ",securitynumber = " + "'" + result + "'" +
//                                       ",update_time = " + "'" + new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(user.getUpdateTime()) + "'" +
//                                       ",user_type = " + "'" + user.getUserType() + "'" +
//                                       " " + "where id = " + "'" + user.getId() + "'";
//                                 myAsyncService.FTP(s1);
//                              }
//                           }
//                        } else {
//                           //不合格
//                           examScore.setQualified(1);
//                        }
//                        //总成绩
//                        if (user.getAge() <= 50) {
//                           if (null != examScore.getTheoryGrade()) {
//                              examScore.setAllGrade(Math.round((examScore.getTheoryGrade() + examScoreExcel.getLearnGrade()) / 2));
//                           } else {
//                              examScore.setAllGrade(Math.round(examScoreExcel.getLearnGrade() / 2));
//                           }
//                        }
//                        if (user.getAge() > 50) {
//                           if (null != examScore.getTheoryGrade()) {
//                              examScore.setAllGrade(Integer.parseInt(String.valueOf(Math.round(examScore.getTheoryGrade() * 0.5)))
//                                 + Integer.parseInt(String.valueOf(Math.round(examScoreExcel.getLearnGrade() * 0.5))));
//                           } else {
//                              examScore.setAllGrade(Math.round(examScoreExcel.getLearnGrade() / 2));
//                           }
//                        }
//
//                        //内网同步
//                        String s1 =
//                           "update exam_score set learn_grade = " + "'" + examScore.getLearnGrade() + "'" +
//                              ",all_grade = " + "'" + examScore.getAllGrade() + "'" +
//                              ",qualified = " + "'" + examScore.getQualified() + "'" +
//                              " " + "where id = " + "'" + examScore.getId() + "'";
//                        //FtpUtil.sqlFileUpload(s1);
//                        myAsyncService.FTP(s1);
//                        //更新成绩数据
//                        baseMapper.updateById(examScore);
//                     } else {
//                        errorList.add(examScoreExcel.getName());
//                        status.set(false);
//                     }
//                  });
//
//               } else {
//                  throw new ServiceException("导入失败!考试名称:[" + examScoreExcel.getExamName() + "]不存在!请核对!");
//               }
//            }
//         });
//         //如果所有数据导入有一个异常
//         if (!status.get()) {
//            String errorAccount = StringUtils.join(errorList, "\\\n");
//            throw new ServiceException("用户:[" + errorAccount + "]实操成绩导入失败!账号与准考证号不匹配!");
//         }
//      }
//   }
//   /**
@@ -466,23 +654,25 @@
//   }
   @Override
   public List<Map<String, Object>> scoreStatistics(String deptid,String jurisdiction) {
      return baseMapper.scoreStatistics(deptid,jurisdiction);
   public List<Map<String, Object>> scoreStatistics(String deptid, String jurisdiction) {
      return baseMapper.scoreStatistics(deptid, jurisdiction);
   }
   @Override
   public List<Map<String, Object>> scoreStatisticssc(String deptid,String jurisdiction) {
      return baseMapper.scoreStatisticssc(deptid,jurisdiction);
   public List<Map<String, Object>> scoreStatisticssc(String deptid, String jurisdiction) {
      return baseMapper.scoreStatisticssc(deptid, jurisdiction);
   }
   /**
    * 修改成绩信息
    *
    * @param examScore
    * @return
    */
   @Override
   public boolean updateByIdAndQualifiee(ExamScore examScore) {
      int result = baseMapper.updateByIdAndQualifiee(examScore);
      if (result>0){
      if (result > 0) {
         return true;
      }
      return false;
@@ -490,17 +680,18 @@
   @Override
   public IPage<ExamScoreVO> scorePage(IPage page, ExamScoreVO examScore) {
      return page.setRecords(baseMapper.scorePage(page,examScore));
      return page.setRecords(baseMapper.scorePage(page, examScore));
   }
   /**
    * 考试成绩及状态修改
    *
    * @param updateParamVo
    */
   @Override
   @Transactional(rollbackFor = Exception.class)
   public boolean updateExamScore(UpdateParamVo updateParamVo) {
      if (updateParamVo.getType()==1){
      if (updateParamVo.getType() == 1) {
         //查询所有无成绩的数据
         List<ExamScore> noScoreInfoList = baseMapper.getNoScoreInfo();
         noScoreInfoList.forEach(examScore1 -> {
@@ -511,7 +702,7 @@
            //修改考试状态
            trainingRegistration1.setIsExam(2);
            trainingRegistrationService.updateById(trainingRegistration1);
            if (null!=trainingRegistration1){
            if (null != trainingRegistration1) {
               //修改用户培训状态信息
               User user = new User();
               user.setIsTrain(3);
@@ -522,10 +713,10 @@
            //修改考试成绩
            //生成随机数,在60-79 之间
            int score = (int)(Math.random()*20);
            int score = (int) (Math.random() * 20);
            int sc = score + 60;
            examScore1.setTheoryGrade(sc);
            examScore1.setTheoryGrade(score/2);
            examScore1.setTheoryGrade(score / 2);
            //设置为合格
            examScore1.setQualified(2);
            examScore1.setCandidateNo(trainingRegistration1.getCandidateNo());
@@ -541,15 +732,15 @@
         });
      }
      if (updateParamVo.getType()==2) {
      if (updateParamVo.getType() == 2) {
         //查询所有成绩不合格的数据(准考证号)
         List<ExamScore> list = baseMapper.getDisqualificationExamInfo();
         if (list.size() > 0) {
            list.forEach(examScore1 -> {
               //修改考试成绩为合格
               //生成随机数,在60-79 之间
               int score = (int)((Math.random() * 20));
               int sc = score+60;
               int score = (int) ((Math.random() * 20));
               int sc = score + 60;
               examScore1.setTheoryGrade(sc);
               //设置为合格
               examScore1.setQualified(2);
@@ -576,15 +767,15 @@
         }
      }
      if (updateParamVo.getType()==3) {
      if (updateParamVo.getType() == 3) {
         //查询所有成绩不合格的数据(准考证号)
         List<ExamScore> list = baseMapper.getLheoryGradeLess60();
         if (list.size() > 0) {
            list.forEach(examScore1 -> {
               //修改考试成绩为合格
               //生成随机数,在60-79 之间
               int score = (int)((Math.random() * 20));
               int sc = score+60;
               int score = (int) ((Math.random() * 20));
               int sc = score + 60;
               examScore1.setTheoryGrade(sc);
               //设置为合格
               examScore1.setQualified(2);
@@ -601,19 +792,20 @@
   /**
    * 考试重置
    *
    * @param updateParamVo
    * @return
    */
   @Override
   public boolean refreshTrainExamInfo(UpdateParamVo updateParamVo) {
      if (null!=updateParamVo.getScoreId()){
      if (null != updateParamVo.getScoreId()) {
         ExamScore examScore = this.getById(updateParamVo.getScoreId());
         //获取成绩数据,准考证号,用户id,报名培训id,考试id
         if (null!=examScore){
         if (null != examScore) {
            ExamPaper paper = examPaperService.getById(examScore.getExamId());
            //判断考试类型
            //考试
            if (paper.getExamType()==1){
            if (paper.getExamType() == 1) {
               //1.修改培训报名信息
               Apply apply = new Apply();
               apply.setId(examScore.getApplyId());
@@ -634,16 +826,17 @@
               //4.内网数据同步
               String s1 =
                  "update sys_apply set is_exam = " + "'" + apply.getIsExam() + "'" +
                     " " + "where id = " + "'" + apply.getId() + "';"+
                     " " + "where id = " + "'" + apply.getId() + "';" +
                     "update blade_user set is_train = " + "'" + user.getIsTrain() + "'" +
                     " " + "where id = " + "'" + user.getId() + "';"+
                     " " + "where id = " + "'" + user.getId() + "';" +
                     "delete from exam_score where id = " + "'" + updateParamVo.getScoreId() + "'";
               FtpUtil.sqlFileUpload(s1);
               //FtpUtil.sqlFileUpload(s1);
               myAsyncService.FTP(s1);
               return true;
            }
            //培训考试
            if (paper.getExamType()==2){
            if (paper.getExamType() == 2) {
               //1.修改培训报名信息
               TrainingRegistration trainingRegistration = new TrainingRegistration();
               trainingRegistration.setId(examScore.getApplyId());
@@ -664,11 +857,12 @@
               //4.内网数据同步
               String s1 =
                  "update sys_training_registration set is_exam = " + "'" + trainingRegistration.getIsExam() + "'" +
                     " " + "where id = " + "'" + trainingRegistration.getId() + "';"+
                  "update blade_user set is_train = " + "'" + user.getIsTrain() + "'" +
                     " " + "where id = " + "'" + user.getId() + "';"+
                  "delete from exam_score where id = " + "'" + updateParamVo.getScoreId() + "'";
               FtpUtil.sqlFileUpload(s1);
                     " " + "where id = " + "'" + trainingRegistration.getId() + "';" +
                     "update blade_user set is_train = " + "'" + user.getIsTrain() + "'" +
                     " " + "where id = " + "'" + user.getId() + "';" +
                     "delete from exam_score where id = " + "'" + updateParamVo.getScoreId() + "'";
               //FtpUtil.sqlFileUpload(s1);
               myAsyncService.FTP(s1);
               return true;
            }
@@ -679,6 +873,7 @@
   /**
    * 按条件查询成绩数据
    *
    * @param examScoreVO
    * @return
    */
@@ -690,6 +885,7 @@
   /**
    * 考试状态修改,考试成绩恢复
    *
    * @param
    * @return
    */
@@ -698,14 +894,14 @@
      int a = 654;
      List<Integer> list = new ArrayList<>();
      list.add(a);
      while (a>=654 && a<=702){
      while (a >= 654 && a <= 702) {
         a++;
         list.add(a);
      }
      //遍历集合
      list.forEach(b->{
      list.forEach(b -> {
         //查询考试记录
         if (b!=698) {
         if (b != 698) {
            ExamAnswerRecord examAnswerRecord = new ExamAnswerRecord();
            examAnswerRecord.setScoreId(Long.parseLong(b.toString()));
            //查询考试成绩
@@ -714,23 +910,23 @@
            List<ExamAnswerRecord> examAnswerRecords = examAnswerRecordService.list(Condition.getQueryWrapper(examAnswerRecord));
            //遍历考试记录
            int socre = 2;
            if (examAnswerRecords.size()>0){
            if (examAnswerRecords.size() > 0) {
               for (ExamAnswerRecord answerRecord : examAnswerRecords) {
                  //计算分数
                  socre = socre + answerRecord.getAnswerScore();
               }
               //修改考试成绩
               examScore.setTheoryGrade(socre);
               examScore.setAllGrade(socre/2);
               examScore.setAllGrade(socre / 2);
               String endDate = "2021-10-16 15:30:25";
               try {
                  examScore.setExamEndTime(new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").parse(endDate));
               } catch (ParseException e) {
                  e.printStackTrace();
               }
               if (socre>=60){
               if (socre >= 60) {
                  examScore.setQualified(2);
               }else {
               } else {
                  examScore.setQualified(1);
               }
               //更新数据
@@ -753,6 +949,7 @@
   /**
    * 点击了开始考试后超过60分钟后再考试的,计算之前的考试成绩
    *
    * @param examScore
    * @return
    */
@@ -767,11 +964,11 @@
      //设置默认理论成绩为0
      int count = 0;
      //计算成绩
      if (list.size()>0){
      if (list.size() > 0) {
         //成绩相加
         count = list.stream().mapToInt(ExamAnswerRecord::getAnswerScore).sum();
      }else {
      } else {
         //没有考试记录,本次考试理论成绩为 0
         count = 0;
      }
@@ -794,23 +991,24 @@
      //数据同步
      String s =
         "update sys_training_registration set is_exam = " + trainingRegistration1.getIsExam() + " " +"where id = " + "'" + trainingRegistration1.getId() + "';" +
            "update blade_user set is_train = " + user.getIsTrain() + " " +"where id = " + "'" + user.getId() + "'";
      FtpUtil.sqlFileUpload(s);
         "update sys_training_registration set is_exam = " + trainingRegistration1.getIsExam() + " " + "where id = " + "'" + trainingRegistration1.getId() + "';" +
            "update blade_user set is_train = " + user.getIsTrain() + " " + "where id = " + "'" + user.getId() + "'";
      //FtpUtil.sqlFileUpload(s);
      myAsyncService.FTP(s);
      //设置理论得分
      score.setTheoryGrade(count);
      //计算总成绩,此时没有实操成绩,总成绩为实操成绩和理论成绩和的一半
      if (age<=50) {
      if (age <= 50) {
         score.setAllGrade(Math.round(count / 2));
      }
      if (age>50) {
         score.setAllGrade(Integer.parseInt(String.valueOf(Math.round(count*0.5))));
      if (age > 50) {
         score.setAllGrade(Integer.parseInt(String.valueOf(Math.round(count * 0.5))));
      }
      //设置状态
      if (count>=60){
      if (count >= 60) {
         score.setQualified(2);
      }else {
      } else {
         score.setQualified(1);
      }
      //修改成绩数据
@@ -822,10 +1020,11 @@
            ",all_grade = " + "'" + score.getAllGrade() + "'" +
            ",exam_end_time = " + "'" + new SimpleDateFormat("yyyy-MM-dd HH:mm:dd").format(new Date()) + "'" +
            ",qualified = " + "'" + score.getQualified() + "'" +
            " " +"where id = " + "'" + score.getId() + "'";
      FtpUtil.sqlFileUpload(s1);
            " " + "where id = " + "'" + score.getId() + "'";
      //FtpUtil.sqlFileUpload(s1);
      myAsyncService.FTP(s1);
      if (i>0){
      if (i > 0) {
         //返回结果
         return true;
      }
@@ -834,6 +1033,7 @@
   /**
    * 考试情况统计,按月统计各个培训学校考试合格人数和不合格人数
    *
    * @param
    */
   @Override
@@ -846,7 +1046,7 @@
      List<Object> objectList = new ArrayList<>();
      for (Information information1 : informationList) {
         //查询各个培训学校本年每月考试情况统计,不是测试学校
         if(!information1.getId().equals(469)) {
         if (!information1.getId().equals(469)) {
            //合格和不合格
            ExamSocreStatisVo statisVo = new ExamSocreStatisVo();
            ExamSocreStatisVo statisVo1 = new ExamSocreStatisVo();
@@ -879,4 +1079,23 @@
      //返回数据
      return objectList;
   }
   /**
    * 查询考试成绩
    * @return
    */
   @Override
   public List<ExamScore> getExamScoreList() {
      return baseMapper.getExamScoreLists();
   }
   /**
    * 查询考试成绩
    * @param time
    * @return
    */
   @Override
   public List<ExamScore> getExamScoreListByTime(String time) {
      return baseMapper.getExamScoreListByTime(time);
   }
}