| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394 |
- package com.xjrsoft.module.personnel.controller;
- import cn.dev33.satoken.annotation.SaCheckPermission;
- import cn.dev33.satoken.stp.StpUtil;
- import cn.hutool.core.bean.BeanUtil;
- import cn.hutool.core.util.IdUtil;
- import cn.hutool.core.util.ObjectUtil;
- import cn.hutool.core.util.StrUtil;
- import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
- import com.baomidou.mybatisplus.core.metadata.IPage;
- import com.baomidou.mybatisplus.core.toolkit.IdWorker;
- import com.baomidou.mybatisplus.core.toolkit.StringPool;
- import com.github.yulichang.toolkit.MPJWrappers;
- import com.github.yulichang.wrapper.MPJLambdaWrapper;
- import com.google.gson.JsonArray;
- import com.google.gson.JsonObject;
- import com.google.gson.JsonParser;
- import com.xjrsoft.common.enums.DeleteMark;
- import com.xjrsoft.common.model.result.RT;
- import com.xjrsoft.common.page.ConventPage;
- import com.xjrsoft.common.page.PageOutput;
- import com.xjrsoft.common.utils.FileZipUtil;
- import com.xjrsoft.common.utils.ImageUtil;
- import com.xjrsoft.common.utils.UploadUtil;
- import com.xjrsoft.common.utils.VoToColumnUtil;
- import com.xjrsoft.module.hikvision.util.ApiUtil;
- import com.xjrsoft.module.organization.entity.Department;
- import com.xjrsoft.module.organization.entity.UserDeptRelation;
- import com.xjrsoft.module.personnel.dto.AddTeacherFaceProcessDto;
- import com.xjrsoft.module.personnel.dto.TeacherFaceProcessPageDto;
- import com.xjrsoft.module.personnel.dto.UpdateTeacherFaceProcessDto;
- import com.xjrsoft.module.personnel.entity.FaceManagement;
- import com.xjrsoft.module.personnel.entity.TeacherFaceProcess;
- import com.xjrsoft.module.personnel.service.IFaceManagementService;
- import com.xjrsoft.module.personnel.service.ITeacherFaceProcessService;
- import com.xjrsoft.module.personnel.vo.TeacherFaceProcessPageVo;
- import com.xjrsoft.module.personnel.vo.TeacherFaceProcessVo;
- import com.xjrsoft.module.system.entity.DictionaryDetail;
- import com.xjrsoft.module.system.entity.File;
- import com.xjrsoft.module.system.service.IFileService;
- import com.xjrsoft.module.teacher.entity.XjrUser;
- import com.xjrsoft.module.teacher.service.ITeacherbaseManagerService;
- import com.xjrsoft.module.teacher.vo.XjrUserPageVo;
- import io.swagger.annotations.Api;
- import io.swagger.annotations.ApiOperation;
- import lombok.AllArgsConstructor;
- import org.apache.commons.lang3.StringUtils;
- import org.springframework.web.bind.annotation.*;
- import org.springframework.web.multipart.MultipartFile;
- import javax.validation.Valid;
- import java.io.ByteArrayOutputStream;
- import java.io.FileOutputStream;
- import java.io.InputStream;
- import java.nio.file.Files;
- import java.time.LocalDateTime;
- import java.util.*;
- import java.util.zip.ZipEntry;
- import java.util.zip.ZipFile;
- /**
- * @title: 人脸信息审核
- * @Author dzx
- * @Date: 2024-05-10
- * @Version 1.0
- */
- @RestController
- @RequestMapping("/personnel" + "/teacherFaceProcess")
- @Api(value = "/personnel" + "/teacherFaceProcess",tags = "人脸信息审核代码")
- @AllArgsConstructor
- public class TeacherFaceProcessController {
- private final ITeacherFaceProcessService teacherFaceProcessService;
- private final ITeacherbaseManagerService teacherbaseManagerService;
- private final IFaceManagementService faceManagementService;
- private final IFileService fileService;
- @GetMapping(value = "/page")
- @ApiOperation(value="人脸信息审核列表(分页)")
- @SaCheckPermission("teacherfaceprocess:detail")
- public RT<PageOutput<TeacherFaceProcessPageVo>> page(@Valid TeacherFaceProcessPageDto dto){
- if(ObjectUtil.isNull(dto.getStatus())){
- dto.setStatus(1);
- }
- MPJLambdaWrapper<TeacherFaceProcess> queryWrapper =MPJWrappers.<TeacherFaceProcess>lambdaJoin()
- .orderByDesc(TeacherFaceProcess::getId)
- .disableSubLogicDel()
- .like(StrUtil.isNotBlank(dto.getName()),XjrUser::getName,dto.getName())
- .like(StrUtil.isNotBlank(dto.getUserName()),XjrUser::getUserName,dto.getUserName())
- .like(StrUtil.isNotBlank(dto.getMobile()),XjrUser::getMobile,dto.getMobile())
- .eq(TeacherFaceProcess::getExamStatus,dto.getStatus())
- .select(TeacherFaceProcess::getId,TeacherFaceProcess::getUserId,TeacherFaceProcess::getDepId,TeacherFaceProcess::getFacePhoto)
- .innerJoin(XjrUser.class,XjrUser::getId, TeacherFaceProcess::getUserId)
- .leftJoin(File.class,File::getFolderId,TeacherFaceProcess::getFacePhoto)
- .leftJoin(FaceManagement.class,FaceManagement::getFileId,TeacherFaceProcess::getFacePhoto)
- .leftJoin(DictionaryDetail.class,DictionaryDetail::getCode,TeacherFaceProcess::getGender, ext->ext.selectAs(DictionaryDetail::getName, TeacherFaceProcessPageVo::getGender))
- .selectAs(XjrUser::getName,TeacherFaceProcessPageVo::getName)
- .select("t2.file_url AS face_photo_url,t1.user_name AS user_name,t1.mobile")
- ;
- if(ObjectUtil.isNotNull(dto.getDepId())&&dto.getDepId()!=0) { // 要用用户关联部门查询
- queryWrapper.leftJoin(UserDeptRelation.class, UserDeptRelation::getUserId, TeacherFaceProcess::getUserId)
- .eq(UserDeptRelation::getDeptId, dto.getDepId());
- }
- IPage<TeacherFaceProcessPageVo> page=teacherFaceProcessService.selectJoinListPage(ConventPage.getPage(dto),TeacherFaceProcessPageVo.class,queryWrapper);
- PageOutput<TeacherFaceProcessPageVo> pageOutput = ConventPage.getPageOutput(page, TeacherFaceProcessPageVo.class);
- return RT.ok(pageOutput);
- }
- @GetMapping(value = "/info")
- @ApiOperation(value="根据id查询人脸信息审核信息")
- @SaCheckPermission("teacherfaceprocess:detail")
- public RT<TeacherFaceProcessVo> info(@RequestParam Long id){
- TeacherFaceProcess teacherFaceProcess = teacherFaceProcessService.getById(id);
- if (teacherFaceProcess == null) {
- return RT.error("找不到此数据!");
- }
- return RT.ok(BeanUtil.toBean(teacherFaceProcess, TeacherFaceProcessVo.class));
- }
- @PostMapping
- @ApiOperation(value = "新增人脸信息审核")
- @SaCheckPermission("teacherfaceprocess:add")
- public RT<Boolean> add(@Valid @RequestBody AddTeacherFaceProcessDto dto){
- TeacherFaceProcess teacherFaceProcess = BeanUtil.toBean(dto, TeacherFaceProcess.class);
- boolean isSuccess = teacherFaceProcessService.save(teacherFaceProcess);
- return RT.ok(isSuccess);
- }
- @PutMapping
- @ApiOperation(value = "修改人脸信息审核")
- @SaCheckPermission("teacherfaceprocess:edit")
- public RT<Boolean> update(@Valid @RequestBody UpdateTeacherFaceProcessDto dto){
- TeacherFaceProcess teacherFaceProcess = BeanUtil.toBean(dto, TeacherFaceProcess.class);
- return RT.ok(teacherFaceProcessService.updateById(teacherFaceProcess));
- }
- @DeleteMapping
- @ApiOperation(value = "删除人脸信息审核")
- @SaCheckPermission("teacherfaceprocess:delete")
- public RT<Boolean> delete(@Valid @RequestBody List<Long> ids){
- return RT.ok(teacherFaceProcessService.removeByIds(ids));
- }
- @PostMapping(value = "/batch-import")
- @ApiOperation(value = "批量新增教师人脸")
- @SaCheckPermission("stundentfaceprocess:batch-upload")
- public RT<Boolean> batchUpload(@RequestParam("file") MultipartFile file) throws Exception {
- List<XjrUserPageVo> list = teacherbaseManagerService.selectJoinList(XjrUserPageVo.class,
- new MPJLambdaWrapper<XjrUser>()
- .distinct()
- .select(XjrUser::getId)
- .selectAs(Department::getId, XjrUserPageVo::getDeptId)
- .selectAs(Department::getName, XjrUserPageVo::getDeptIdCn)
- .select(XjrUser.class, x -> VoToColumnUtil.fieldsToColumns(XjrUserPageVo.class).contains(x.getProperty()))
- .leftJoin(UserDeptRelation.class, UserDeptRelation::getUserId, XjrUser::getId)
- .leftJoin(Department.class, Department::getId, UserDeptRelation::getDeptId)
- .eq(XjrUser::getDeleteMark, DeleteMark.NODELETE.getCode())
- .eq(Department::getDeleteMark, DeleteMark.NODELETE.getCode())
- );
- Map<String, XjrUserPageVo> teacherMap = new HashMap<>();
- for (XjrUserPageVo teacher : list) {
- teacherMap.put(teacher.getCredentialNumber(), teacher);
- }
- List<TeacherFaceProcess> faceList = teacherFaceProcessService.list(
- new QueryWrapper<TeacherFaceProcess>().lambda()
- .eq(TeacherFaceProcess::getDeleteMark, DeleteMark.NODELETE.getCode())
- );
- Map<Long, TeacherFaceProcess> faceMap = new HashMap<>();
- for (TeacherFaceProcess faceProcess : faceList) {
- faceMap.put(faceProcess.getUserId(), faceProcess);
- }
- List<FaceManagement> faceManagementList = faceManagementService.list(
- new QueryWrapper<FaceManagement>().lambda()
- .select(FaceManagement.class, face -> !face.getColumn().equals("registerBase64"))
- .select(FaceManagement.class, face -> !face.getColumn().equals("register_base64"))
- .eq(FaceManagement::getDeleteMark, DeleteMark.NODELETE.getCode())
- .eq(FaceManagement::getUserType, 1)
- );
- Map<Long, FaceManagement> faceManagementMap = new HashMap<>();
- for (FaceManagement management : faceManagementList) {
- faceManagementMap.put(management.getUserId(), management);
- }
- JsonParser parser = new JsonParser();
- ApiUtil apiUtil = new ApiUtil();
- ZipFile zipFile = FileZipUtil.convertToZipFile(file);
- Enumeration<? extends ZipEntry> entries = zipFile.entries();
- while (entries.hasMoreElements()){
- ZipEntry entry = entries.nextElement();
- String filename = entry.getName();
- InputStream inputStream = zipFile.getInputStream(entry); //读取文件内容
- String[] split = filename.split("\\.");
- String idNumber = split[0].substring(split[0].length() - 18);
- XjrUserPageVo teacherUser = teacherMap.get(idNumber);
- if(teacherUser == null){
- continue;
- }
- //将照片转换成base64
- ByteArrayOutputStream outputStream = new ByteArrayOutputStream();
- byte[] buffer = new byte[4096];
- int bytesRead;
- while ((bytesRead = inputStream.read(buffer)) != -1) {
- outputStream.write(buffer, 0, bytesRead);
- }
- byte[] imageBytes = outputStream.toByteArray();
- //压缩到200k
- imageBytes = ImageUtil.compressUnderSize(imageBytes, 204800);
- //压缩之后,存入本地
- String suffix = StringUtils.substringAfterLast(filename, StringPool.DOT);
- String tempFilePath = "/" + IdUtil.getSnowflakeNextId() + "." + suffix;
- FileOutputStream fos = new FileOutputStream(tempFilePath);
- fos.write(imageBytes);
- fos.close();
- //再读取出来
- java.io.File tempFile = new java.io.File(tempFilePath);
- imageBytes = Files.readAllBytes(tempFile.toPath());
- //删除文件
- if(tempFile.exists()){
- tempFile.delete();
- }
- String base64String = Base64.getEncoder().encodeToString(imageBytes);
- inputStream.close();
- outputStream.close();
- //保存到云服务器
- String filePath = UploadUtil.uploadFileByte(filename, imageBytes);
- //存入数据库
- long fileId = IdUtil.getSnowflakeNextId();
- Long folderId = IdWorker.getId();
- File fileEntity = new File();
- fileEntity.setId(fileId);
- fileEntity.setFolderId(folderId);
- fileEntity.setFileName(filename);
- fileEntity.setCreateDate(LocalDateTime.now());
- fileEntity.setCreateUserId(StpUtil.getLoginIdAsLong());
- fileEntity.setDeleteMark(0);
- fileEntity.setFileUrl(filePath);
- fileEntity.setFileSize(file.getSize());
- fileEntity.setFileSuffiex(StringPool.DOT + suffix);
- fileEntity.setFileType(suffix);
- fileService.save(fileEntity);
- TeacherFaceProcess process = faceMap.get(Long.parseLong(teacherUser.getId()));
- if(process == null){
- long baseFaceId = IdUtil.getSnowflakeNextId();
- FaceManagement baseFace = new FaceManagement();
- baseFace.setId(baseFaceId);
- baseFace.setRegisterBase64(base64String);
- baseFace.setUserId(Long.parseLong(teacherUser.getId()));
- baseFace.setSex(teacherUser.getGender());
- baseFace.setName(teacherUser.getName());
- baseFace.setIdno(teacherUser.getCredentialNumber());
- baseFace.setVerifyStatus(1);
- baseFace.setCreateDate(LocalDateTime.now());
- baseFace.setCreateUserId(StpUtil.getLoginIdAsLong());
- baseFace.setDeleteMark(0);
- baseFace.setStatus(1);
- baseFace.setFileId(folderId);
- baseFace.setUserType(2L);
- faceManagementService.save(baseFace);
- TeacherFaceProcess teacherFace = new TeacherFaceProcess();
- teacherFace.setStatus(1);
- teacherFace.setCreateDate(new Date());
- teacherFace.setCreateUserId(StpUtil.getLoginIdAsLong());
- teacherFace.setDeleteMark(0);
- teacherFace.setGender(teacherUser.getGender());
- teacherFace.setFacePhoto(folderId);
- teacherFace.setName(teacherUser.getName());
- teacherFace.setDepId(Long.parseLong(teacherUser.getDeptId()));
- teacherFace.setDepCn(teacherUser.getDeptIdCn());
- teacherFace.setIdentityCard(teacherUser.getCredentialNumber());
- teacherFace.setStatus(1);
- teacherFace.setUserId(Long.parseLong(teacherUser.getId()));
- teacherFace.setExamStatus(1);
- //将人脸上传海康
- JsonObject paramJson = new JsonObject();
- paramJson.addProperty("personId", teacherUser.getId());
- paramJson.addProperty("faceData", base64String);
- Map<String, String> querys = new HashMap<>();
- querys.put("tagId", "frs");
- String apiPath = "/api/resource/v1/face/single/add";
- String response = apiUtil.doPost(apiPath, String.valueOf(paramJson), querys);
- teacherFace.setHikvisionResult(response);
- teacherFaceProcessService.save(teacherFace);
- } else {
- process.setStatus(1);
- process.setExamStatus(1);
- process.setModifyDate(new Date());
- process.setModifyUserId(StpUtil.getLoginIdAsLong());
- process.setDeleteMark(0);
- process.setFacePhoto(folderId);
- String faceId = null;
- if(process.getHikvisionResult() != null && process.getHikvisionResult().startsWith("{") && process.getHikvisionResult().endsWith("}")){
- JsonObject object = parser.parse(process.getHikvisionResult()).getAsJsonObject();
- if("0".equals(object.get("code").getAsString()) && "success".equals(object.get("msg").getAsString()) && !object.get("data").isJsonNull()){
- faceId = object.get("data").getAsJsonObject().get("faceId").getAsString();
- }
- }
- if(faceId == null){
- String apiUrl = "/api/resource/v1/person/condition/personInfo";
- JsonObject paramsJson = new JsonObject();
- paramsJson.addProperty("paramName", "personId");
- JsonArray array = new JsonArray();
- array.add(teacherUser.getId());
- paramsJson.add("paramValue", array);
- String personInfoRes = apiUtil.doPost(apiUrl, paramsJson.toString(), null);
- JsonObject personInfoData = parser.parse(personInfoRes).getAsJsonObject();
- if("0".equals(personInfoData.get("code").getAsString()) && "success".equals(personInfoData.get("msg").getAsString())){
- JsonObject dataJson = personInfoData.get("data").getAsJsonObject();
- if(dataJson.get("total").getAsInt() > 0){
- JsonArray personPhoto = dataJson.get("list").getAsJsonArray().get(0)
- .getAsJsonObject().get("personPhoto").getAsJsonArray();
- if(personPhoto.size() > 0){
- faceId = personPhoto.get(0).getAsJsonObject().get("personPhotoIndexCode").getAsString();
- }
- }
- }
- }
- //更新海康数据
- JsonObject paramJson = new JsonObject();
- String apiPath;
- if(faceId != null){
- apiPath = "/api/resource/v1/face/single/update";
- paramJson.addProperty("faceId", faceId);
- paramJson.addProperty("faceData", base64String);
- }else{
- apiPath = "/api/resource/v1/face/single/add";
- paramJson.addProperty("personId", teacherUser.getId());
- paramJson.addProperty("faceData", base64String);
- }
- String result = apiUtil.doPost(apiPath, paramJson.toString(), null);
- if(result.startsWith("{") && result.endsWith("}")){
- JsonObject object = parser.parse(result).getAsJsonObject();
- if("0".equals(object.get("code").getAsString()) && "success".equals(object.get("msg").getAsString())){
- process.setHikvisionResult(result);
- }
- }
- teacherFaceProcessService.updateById(process);
- FaceManagement faceManagement = faceManagementMap.get(Long.parseLong(teacherUser.getId()));
- if(faceManagement == null){
- faceManagement = new FaceManagement();
- faceManagement.setUserType(2L);
- faceManagement.setUserId(Long.parseLong(teacherUser.getId()));
- faceManagement.setFileId(folderId);
- faceManagement.setIdno(teacherUser.getCredentialNumber());
- faceManagement.setName(teacherUser.getName());
- faceManagement.setSyncStatus(1);
- faceManagement.setSex(teacherUser.getGender());
- faceManagement.setVerifyStatus(2);
- faceManagement.setRegisterBase64(base64String);
- faceManagementService.save(faceManagement);
- }else{
- faceManagement.setVerifyStatus(2);
- faceManagement.setRegisterBase64(base64String);
- faceManagementService.update(faceManagement);
- }
- }
- }
- return RT.ok(true);
- }
- }
|