TeacherFaceProcessController.java 18 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377
  1. package com.xjrsoft.module.personnel.controller;
  2. import cn.dev33.satoken.annotation.SaCheckPermission;
  3. import cn.dev33.satoken.stp.StpUtil;
  4. import cn.hutool.core.bean.BeanUtil;
  5. import cn.hutool.core.util.IdUtil;
  6. import cn.hutool.core.util.ObjectUtil;
  7. import cn.hutool.core.util.StrUtil;
  8. import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
  9. import com.baomidou.mybatisplus.core.metadata.IPage;
  10. import com.baomidou.mybatisplus.core.toolkit.IdWorker;
  11. import com.baomidou.mybatisplus.core.toolkit.StringPool;
  12. import com.github.yulichang.toolkit.MPJWrappers;
  13. import com.github.yulichang.wrapper.MPJLambdaWrapper;
  14. import com.google.gson.JsonArray;
  15. import com.google.gson.JsonObject;
  16. import com.google.gson.JsonParser;
  17. import com.xjrsoft.common.enums.DeleteMark;
  18. import com.xjrsoft.common.model.result.RT;
  19. import com.xjrsoft.common.page.ConventPage;
  20. import com.xjrsoft.common.page.PageOutput;
  21. import com.xjrsoft.common.utils.FileZipUtil;
  22. import com.xjrsoft.common.utils.ImageUtil;
  23. import com.xjrsoft.common.utils.UploadUtil;
  24. import com.xjrsoft.common.utils.VoToColumnUtil;
  25. import com.xjrsoft.module.hikvision.util.ApiUtil;
  26. import com.xjrsoft.module.organization.entity.Department;
  27. import com.xjrsoft.module.organization.entity.UserDeptRelation;
  28. import com.xjrsoft.module.personnel.dto.AddTeacherFaceProcessDto;
  29. import com.xjrsoft.module.personnel.dto.TeacherFaceProcessPageDto;
  30. import com.xjrsoft.module.personnel.dto.UpdateTeacherFaceProcessDto;
  31. import com.xjrsoft.module.personnel.entity.FaceManagement;
  32. import com.xjrsoft.module.personnel.entity.TeacherFaceProcess;
  33. import com.xjrsoft.module.personnel.service.IFaceManagementService;
  34. import com.xjrsoft.module.personnel.service.ITeacherFaceProcessService;
  35. import com.xjrsoft.module.personnel.vo.TeacherFaceProcessPageVo;
  36. import com.xjrsoft.module.personnel.vo.TeacherFaceProcessVo;
  37. import com.xjrsoft.module.system.entity.DictionaryDetail;
  38. import com.xjrsoft.module.system.entity.File;
  39. import com.xjrsoft.module.system.service.IFileService;
  40. import com.xjrsoft.module.teacher.entity.XjrUser;
  41. import com.xjrsoft.module.teacher.service.ITeacherbaseManagerService;
  42. import com.xjrsoft.module.teacher.vo.XjrUserPageVo;
  43. import io.swagger.annotations.Api;
  44. import io.swagger.annotations.ApiOperation;
  45. import lombok.AllArgsConstructor;
  46. import org.apache.commons.lang3.StringUtils;
  47. import org.springframework.web.bind.annotation.*;
  48. import org.springframework.web.multipart.MultipartFile;
  49. import javax.validation.Valid;
  50. import java.io.ByteArrayOutputStream;
  51. import java.io.InputStream;
  52. import java.time.LocalDateTime;
  53. import java.util.*;
  54. import java.util.zip.ZipEntry;
  55. import java.util.zip.ZipFile;
  56. /**
  57. * @title: 人脸信息审核
  58. * @Author dzx
  59. * @Date: 2024-05-10
  60. * @Version 1.0
  61. */
  62. @RestController
  63. @RequestMapping("/personnel" + "/teacherFaceProcess")
  64. @Api(value = "/personnel" + "/teacherFaceProcess",tags = "人脸信息审核代码")
  65. @AllArgsConstructor
  66. public class TeacherFaceProcessController {
  67. private final ITeacherFaceProcessService teacherFaceProcessService;
  68. private final ITeacherbaseManagerService teacherbaseManagerService;
  69. private final IFaceManagementService faceManagementService;
  70. private final IFileService fileService;
  71. @GetMapping(value = "/page")
  72. @ApiOperation(value="人脸信息审核列表(分页)")
  73. @SaCheckPermission("teacherfaceprocess:detail")
  74. public RT<PageOutput<TeacherFaceProcessPageVo>> page(@Valid TeacherFaceProcessPageDto dto){
  75. if(ObjectUtil.isNull(dto.getStatus())){
  76. dto.setStatus(1);
  77. }
  78. MPJLambdaWrapper<TeacherFaceProcess> queryWrapper =MPJWrappers.<TeacherFaceProcess>lambdaJoin()
  79. .orderByDesc(TeacherFaceProcess::getId)
  80. .disableSubLogicDel()
  81. .like(StrUtil.isNotBlank(dto.getName()),XjrUser::getName,dto.getName())
  82. .like(StrUtil.isNotBlank(dto.getUserName()),XjrUser::getUserName,dto.getUserName())
  83. .like(StrUtil.isNotBlank(dto.getMobile()),XjrUser::getMobile,dto.getMobile())
  84. .eq(TeacherFaceProcess::getExamStatus,dto.getStatus())
  85. .select(TeacherFaceProcess::getId,TeacherFaceProcess::getUserId,TeacherFaceProcess::getDepId,TeacherFaceProcess::getFacePhoto)
  86. .innerJoin(XjrUser.class,XjrUser::getId, TeacherFaceProcess::getUserId)
  87. .leftJoin(File.class,File::getFolderId,TeacherFaceProcess::getFacePhoto)
  88. .leftJoin(FaceManagement.class,FaceManagement::getFileId,TeacherFaceProcess::getFacePhoto)
  89. .leftJoin(DictionaryDetail.class,DictionaryDetail::getCode,TeacherFaceProcess::getGender, ext->ext.selectAs(DictionaryDetail::getName, TeacherFaceProcessPageVo::getGender))
  90. .selectAs(XjrUser::getName,TeacherFaceProcessPageVo::getName)
  91. .select("t2.file_url AS face_photo_url,t1.user_name AS user_name,t1.mobile")
  92. ;
  93. if(ObjectUtil.isNotNull(dto.getDepId())&&dto.getDepId()!=0) { // 要用用户关联部门查询
  94. queryWrapper.leftJoin(UserDeptRelation.class, UserDeptRelation::getUserId, TeacherFaceProcess::getUserId)
  95. .eq(UserDeptRelation::getDeptId, dto.getDepId());
  96. }
  97. IPage<TeacherFaceProcessPageVo> page=teacherFaceProcessService.selectJoinListPage(ConventPage.getPage(dto),TeacherFaceProcessPageVo.class,queryWrapper);
  98. PageOutput<TeacherFaceProcessPageVo> pageOutput = ConventPage.getPageOutput(page, TeacherFaceProcessPageVo.class);
  99. return RT.ok(pageOutput);
  100. }
  101. @GetMapping(value = "/info")
  102. @ApiOperation(value="根据id查询人脸信息审核信息")
  103. @SaCheckPermission("teacherfaceprocess:detail")
  104. public RT<TeacherFaceProcessVo> info(@RequestParam Long id){
  105. TeacherFaceProcess teacherFaceProcess = teacherFaceProcessService.getById(id);
  106. if (teacherFaceProcess == null) {
  107. return RT.error("找不到此数据!");
  108. }
  109. return RT.ok(BeanUtil.toBean(teacherFaceProcess, TeacherFaceProcessVo.class));
  110. }
  111. @PostMapping
  112. @ApiOperation(value = "新增人脸信息审核")
  113. @SaCheckPermission("teacherfaceprocess:add")
  114. public RT<Boolean> add(@Valid @RequestBody AddTeacherFaceProcessDto dto){
  115. TeacherFaceProcess teacherFaceProcess = BeanUtil.toBean(dto, TeacherFaceProcess.class);
  116. boolean isSuccess = teacherFaceProcessService.save(teacherFaceProcess);
  117. return RT.ok(isSuccess);
  118. }
  119. @PutMapping
  120. @ApiOperation(value = "修改人脸信息审核")
  121. @SaCheckPermission("teacherfaceprocess:edit")
  122. public RT<Boolean> update(@Valid @RequestBody UpdateTeacherFaceProcessDto dto){
  123. TeacherFaceProcess teacherFaceProcess = BeanUtil.toBean(dto, TeacherFaceProcess.class);
  124. return RT.ok(teacherFaceProcessService.updateById(teacherFaceProcess));
  125. }
  126. @DeleteMapping
  127. @ApiOperation(value = "删除人脸信息审核")
  128. @SaCheckPermission("teacherfaceprocess:delete")
  129. public RT<Boolean> delete(@Valid @RequestBody List<Long> ids){
  130. return RT.ok(teacherFaceProcessService.removeByIds(ids));
  131. }
  132. @PostMapping(value = "/batch-import")
  133. @ApiOperation(value = "批量新增教师人脸")
  134. @SaCheckPermission("stundentfaceprocess:batch-upload")
  135. public RT<Boolean> batchUpload(@RequestParam("file") MultipartFile file) throws Exception {
  136. List<XjrUserPageVo> list = teacherbaseManagerService.selectJoinList(XjrUserPageVo.class,
  137. new MPJLambdaWrapper<XjrUser>()
  138. .distinct()
  139. .select(XjrUser::getId)
  140. .selectAs(Department::getId, XjrUserPageVo::getDeptId)
  141. .selectAs(Department::getName, XjrUserPageVo::getDeptIdCn)
  142. .select(XjrUser.class, x -> VoToColumnUtil.fieldsToColumns(XjrUserPageVo.class).contains(x.getProperty()))
  143. .leftJoin(UserDeptRelation.class, UserDeptRelation::getUserId, XjrUser::getId)
  144. .leftJoin(Department.class, Department::getId, UserDeptRelation::getDeptId)
  145. .eq(XjrUser::getDeleteMark, DeleteMark.NODELETE.getCode())
  146. .eq(Department::getDeleteMark, DeleteMark.NODELETE.getCode())
  147. );
  148. Map<String, XjrUserPageVo> teacherMap = new HashMap<>();
  149. for (XjrUserPageVo teacher : list) {
  150. teacherMap.put(teacher.getCredentialNumber(), teacher);
  151. }
  152. List<TeacherFaceProcess> faceList = teacherFaceProcessService.list(
  153. new QueryWrapper<TeacherFaceProcess>().lambda()
  154. .eq(TeacherFaceProcess::getDeleteMark, DeleteMark.NODELETE.getCode())
  155. );
  156. Map<Long, TeacherFaceProcess> faceMap = new HashMap<>();
  157. for (TeacherFaceProcess faceProcess : faceList) {
  158. faceMap.put(faceProcess.getUserId(), faceProcess);
  159. }
  160. List<FaceManagement> faceManagementList = faceManagementService.list(
  161. new QueryWrapper<FaceManagement>().lambda()
  162. .select(FaceManagement.class, face -> !face.getColumn().equals("registerBase64"))
  163. .select(FaceManagement.class, face -> !face.getColumn().equals("register_base64"))
  164. .eq(FaceManagement::getDeleteMark, DeleteMark.NODELETE.getCode())
  165. .eq(FaceManagement::getUserType, 1)
  166. );
  167. Map<Long, FaceManagement> faceManagementMap = new HashMap<>();
  168. for (FaceManagement management : faceManagementList) {
  169. faceManagementMap.put(management.getUserId(), management);
  170. }
  171. JsonParser parser = new JsonParser();
  172. ApiUtil apiUtil = new ApiUtil();
  173. ZipFile zipFile = FileZipUtil.convertToZipFile(file);
  174. Enumeration<? extends ZipEntry> entries = zipFile.entries();
  175. while (entries.hasMoreElements()){
  176. ZipEntry entry = entries.nextElement();
  177. String filename = entry.getName();
  178. InputStream inputStream = zipFile.getInputStream(entry); //读取文件内容
  179. String[] split = filename.split("\\.");
  180. String idNumber = split[0].substring(split[0].length() - 18);
  181. XjrUserPageVo teacherUser = teacherMap.get(idNumber);
  182. if(teacherUser == null){
  183. continue;
  184. }
  185. //将照片转换成base64
  186. ByteArrayOutputStream outputStream = new ByteArrayOutputStream();
  187. byte[] buffer = new byte[4096];
  188. int bytesRead;
  189. while ((bytesRead = inputStream.read(buffer)) != -1) {
  190. outputStream.write(buffer, 0, bytesRead);
  191. }
  192. byte[] imageBytes = outputStream.toByteArray();
  193. //压缩到200k
  194. imageBytes = ImageUtil.compressUnderSize(imageBytes, 204800);
  195. String base64String = Base64.getEncoder().encodeToString(imageBytes);
  196. inputStream.close();
  197. outputStream.close();
  198. //保存到云服务器
  199. String filePath = UploadUtil.uploadFileByte(filename, imageBytes);
  200. //存入数据库
  201. long fileId = IdUtil.getSnowflakeNextId();
  202. String suffix = StringUtils.substringAfterLast(filename, StringPool.DOT);
  203. Long folderId = IdWorker.getId();
  204. File fileEntity = new File();
  205. fileEntity.setId(fileId);
  206. fileEntity.setFolderId(folderId);
  207. fileEntity.setFileName(filename);
  208. fileEntity.setCreateDate(LocalDateTime.now());
  209. fileEntity.setCreateUserId(StpUtil.getLoginIdAsLong());
  210. fileEntity.setDeleteMark(0);
  211. fileEntity.setFileUrl(filePath);
  212. fileEntity.setFileSize(file.getSize());
  213. fileEntity.setFileSuffiex(StringPool.DOT + suffix);
  214. fileEntity.setFileType(suffix);
  215. fileService.save(fileEntity);
  216. TeacherFaceProcess process = faceMap.get(Long.parseLong(teacherUser.getId()));
  217. if(process == null){
  218. long baseFaceId = IdUtil.getSnowflakeNextId();
  219. FaceManagement baseFace = new FaceManagement();
  220. baseFace.setId(baseFaceId);
  221. baseFace.setRegisterBase64(base64String);
  222. baseFace.setUserId(Long.parseLong(teacherUser.getId()));
  223. baseFace.setSex(teacherUser.getGender());
  224. baseFace.setName(teacherUser.getName());
  225. baseFace.setIdno(teacherUser.getCredentialNumber());
  226. baseFace.setVerifyStatus(1);
  227. baseFace.setCreateDate(LocalDateTime.now());
  228. baseFace.setCreateUserId(StpUtil.getLoginIdAsLong());
  229. baseFace.setDeleteMark(0);
  230. baseFace.setStatus(1);
  231. baseFace.setFileId(folderId);
  232. baseFace.setUserType(2L);
  233. faceManagementService.save(baseFace);
  234. TeacherFaceProcess teacherFace = new TeacherFaceProcess();
  235. teacherFace.setStatus(1);
  236. teacherFace.setCreateDate(new Date());
  237. teacherFace.setCreateUserId(StpUtil.getLoginIdAsLong());
  238. teacherFace.setDeleteMark(0);
  239. teacherFace.setGender(teacherUser.getGender());
  240. teacherFace.setFacePhoto(folderId);
  241. teacherFace.setName(teacherUser.getName());
  242. teacherFace.setDepId(Long.parseLong(teacherUser.getDeptId()));
  243. teacherFace.setDepCn(teacherUser.getDeptIdCn());
  244. teacherFace.setIdentityCard(teacherUser.getCredentialNumber());
  245. teacherFace.setStatus(1);
  246. teacherFace.setUserId(Long.parseLong(teacherUser.getId()));
  247. teacherFace.setExamStatus(1);
  248. //将人脸上传海康
  249. JsonObject paramJson = new JsonObject();
  250. paramJson.addProperty("personId", teacherUser.getId());
  251. paramJson.addProperty("faceData", base64String);
  252. Map<String, String> querys = new HashMap<>();
  253. querys.put("tagId", "frs");
  254. String apiPath = "/api/resource/v1/face/single/add";
  255. String response = apiUtil.doPost(apiPath, String.valueOf(paramJson), querys);
  256. teacherFace.setHikvisionResult(response);
  257. teacherFaceProcessService.save(teacherFace);
  258. } else {
  259. process.setStatus(1);
  260. process.setExamStatus(1);
  261. process.setModifyDate(new Date());
  262. process.setModifyUserId(StpUtil.getLoginIdAsLong());
  263. process.setDeleteMark(0);
  264. process.setFacePhoto(folderId);
  265. String faceId = null;
  266. if(process.getHikvisionResult() != null && process.getHikvisionResult().startsWith("{") && process.getHikvisionResult().endsWith("}")){
  267. JsonObject object = parser.parse(process.getHikvisionResult()).getAsJsonObject();
  268. if("0".equals(object.get("code").getAsString()) && "success".equals(object.get("msg").getAsString())){
  269. faceId = object.get("data").getAsJsonObject().get("faceId").getAsString();
  270. }
  271. }
  272. if(faceId == null){
  273. String apiUrl = "/api/resource/v1/person/condition/personInfo";
  274. JsonObject paramsJson = new JsonObject();
  275. paramsJson.addProperty("paramName", "personId");
  276. JsonArray array = new JsonArray();
  277. array.add(teacherUser.getId());
  278. paramsJson.add("paramValue", array);
  279. String personInfoRes = apiUtil.doPost(apiUrl, paramsJson.toString(), null);
  280. JsonObject personInfoData = parser.parse(personInfoRes).getAsJsonObject();
  281. if("0".equals(personInfoData.get("code").getAsString()) && "success".equals(personInfoData.get("msg").getAsString())){
  282. JsonObject dataJson = personInfoData.get("data").getAsJsonObject();
  283. if(dataJson.get("total").getAsInt() > 0){
  284. JsonArray personPhoto = dataJson.get("list").getAsJsonArray().get(0)
  285. .getAsJsonObject().get("personPhoto").getAsJsonArray();
  286. if(personPhoto.size() > 0){
  287. faceId = personPhoto.get(0).getAsJsonObject().get("personPhotoIndexCode").getAsString();
  288. }
  289. }
  290. }
  291. }
  292. //更新海康数据
  293. JsonObject paramJson = new JsonObject();
  294. String apiPath;
  295. if(faceId != null){
  296. apiPath = "/api/resource/v1/face/single/update";
  297. paramJson.addProperty("faceId", faceId);
  298. paramJson.addProperty("faceData", base64String);
  299. }else{
  300. apiPath = "/api/resource/v1/face/single/add";
  301. paramJson.addProperty("personId", teacherUser.getId());
  302. paramJson.addProperty("faceData", base64String);
  303. }
  304. String result = apiUtil.doPost(apiPath, paramJson.toString(), null);
  305. if(result.startsWith("{") && result.endsWith("}")){
  306. JsonObject object = parser.parse(result).getAsJsonObject();
  307. if("0".equals(object.get("code").getAsString()) && "success".equals(object.get("msg").getAsString())){
  308. process.setHikvisionResult(result);
  309. }
  310. }
  311. teacherFaceProcessService.updateById(process);
  312. FaceManagement faceManagement = faceManagementMap.get(Long.parseLong(teacherUser.getId()));
  313. if(faceManagement == null){
  314. faceManagement = new FaceManagement();
  315. faceManagement.setUserType(2L);
  316. faceManagement.setUserId(Long.parseLong(teacherUser.getId()));
  317. faceManagement.setFileId(folderId);
  318. faceManagement.setIdno(teacherUser.getCredentialNumber());
  319. faceManagement.setName(teacherUser.getName());
  320. faceManagement.setSyncStatus(1);
  321. faceManagement.setSex(teacherUser.getGender());
  322. faceManagement.setVerifyStatus(2);
  323. faceManagement.setRegisterBase64(base64String);
  324. faceManagementService.save(faceManagement);
  325. }else{
  326. faceManagement.setVerifyStatus(2);
  327. faceManagement.setRegisterBase64(base64String);
  328. faceManagementService.update(faceManagement);
  329. }
  330. }
  331. }
  332. return RT.ok(true);
  333. }
  334. }