张晓波
2023-10-19 6d60391f65633383bfcf2f1ec7c52ca5d3d7fe93
hd/pipe/StaffManage/src/main/java/com/thhy/staff/modules/biz/face/service/impl/FaceServerImpl.java
@@ -5,6 +5,7 @@
import com.alibaba.fastjson.JSONObject;
import com.alibaba.nacos.api.utils.StringUtils;
import com.thhy.staff.config.EmqxConfig;
import com.thhy.staff.config.FaceConfig;
import com.thhy.staff.modules.biz.face.entity.FaceDevice;
import com.thhy.staff.modules.biz.face.entity.FaceResult;
import com.thhy.staff.modules.biz.face.entity.UserFaceVo;
@@ -12,10 +13,12 @@
import com.thhy.staff.modules.biz.face.service.FaceServer;
import com.thhy.staff.modules.biz.platuser.entity.DoorLis;
import com.thhy.staff.modules.biz.platuser.mapper.PlatUserMapper;
import com.thhy.staff.utils.MqUtils;
import org.checkerframework.checker.units.qual.A;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.stereotype.Service;
import java.util.ArrayList;
@@ -32,6 +35,12 @@
    @Autowired
    private EmqxConfig emqxConfig;
    @Value("${file.vfprefix}")
    private String vfPrefix;
    @Autowired
    private FaceConfig faceConfig;
    private Logger logger = LoggerFactory.getLogger(FaceServer.class);
@@ -77,6 +86,10 @@
        UserFaceVo userFaceVo = userMapper.queryUserFaceSingle(userId);
        List<String> url = new ArrayList<>();
        url.add(vfPrefix+userFaceVo.getPhoto());
        userFaceVo.setTemplateImgUrl(url);
        JSONObject jsonObject = new JSONObject();
        jsonObject.put("code",0);
        jsonObject.put("msg","OK");
@@ -85,12 +98,14 @@
        List<UserFaceVo> faceVoList = new ArrayList<>();
        faceVoList.add(userFaceVo);
        jsonObject.put("person_list",faceVoList);
        logger.info("设备查询人员结果:"+JSON.toJSONString(faceVoList));
        return jsonObject;
    }
    @Override
    public void personNotify(String mess) {
        JSONObject reqJson = JSONObject.parseObject(mess);
        logger.info("接收设备下发结果通知################"+mess);
        if(reqJson.containsKey("success")&&reqJson.getBooleanValue("success")){
            String userIds = reqJson.getString("successful");
            if(!StringUtils.isEmpty(userIds)){
@@ -106,7 +121,8 @@
                    JSONObject failUserInfo = JSON.parseObject(obj.toString());
                    String userId = failUserInfo.getString("person_id");
                    JSONArray failInfoArray = failUserInfo.getJSONArray("info");
                    String failReason = failInfoArray.getJSONObject(0).getString("reason");
                    String failReason = "";
                    if(failInfoArray.size()>0) failReason = failInfoArray.getJSONObject(0).getString("reason");
                    userMapper.syncFail(userId,failReason);
                }
            }
@@ -120,4 +136,19 @@
        DoorLis doorLis = new DoorLis(jsonObject);
        userMapper.insertDoorLis(doorLis);
    }
    @Override
    public void queryPer(String perId) {
        JSONObject jsonObject = new JSONObject();
        jsonObject.put("method","get_person");
        jsonObject.put("params",new JSONObject());
        JSONObject dataJson = new JSONObject();
        dataJson.put("path",faceConfig.getUrlPrefix()+"getPersonDetail");
        dataJson.put("person_id",perId);
        jsonObject.put("data",dataJson);
        List<String> sns = faceDeviceMapper.queryDevSn();
        String content = jsonObject.toJSONString();
        logger.info("查询人员"+perId+":"+content);
        MqUtils.createClient(emqxConfig,sns,content);
    }
}