TeacherFaceProcessController.java 19 KB

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