瀏覽代碼

fix: mq回调

lixuesong 3 年之前
父節點
當前提交
be11cb82e5

+ 55 - 55
hnqz-upms/hnqz-upms-biz/src/main/java/com/qunzhixinxi/hnqz/admin/mq/GigSignCertReceiver.java

@@ -75,68 +75,68 @@ public class GigSignCertReceiver extends BaseRabbiMqHandler<String> {
 			log.info("直接队列:接收用户签约认证的结果,手动ACK,接收消息TAG:{},消息内容:{}", deliveryTag, result);
 
 			Map<String, String> resMap = MapUtil.newHashMap(2);
+			try {
+				JSONObject jsonResult = JSONUtil.parseObj(result);
+				String username = jsonResult.getStr("username");
+				String entpriseCode = jsonResult.getStr("enterpriseCode");
+				JSONObject subjectTypes = jsonResult.getJSONObject("subjectTypes");
 
-			JSONObject jsonResult = JSONUtil.parseObj(result);
-			String username = jsonResult.getStr("username");
-			String entpriseCode = jsonResult.getStr("enterpriseCode");
-			JSONObject subjectTypes = jsonResult.getJSONObject("subjectTypes");
-
-			if (StrUtil.isBlank(username) || StrUtil.isBlank(entpriseCode) || subjectTypes.isEmpty()) {
-				log.error("必传参数空!");
-				resMap.put("key", String.format("%s_%s_%s", CacheConstants.USER_SIGN_CERT_RESPONSE_MQ_KEY, username, entpriseCode));
-				resMap.put("res", JSONUtil.toJsonStr(subjectTypes));
-				return resMap;
-			}
+				if (StrUtil.isBlank(username) || StrUtil.isBlank(entpriseCode) || subjectTypes.isEmpty()) {
+					log.error("必传参数空!");
+					resMap.put("key", String.format("%s_%s_%s", CacheConstants.USER_SIGN_CERT_RESPONSE_MQ_KEY, username, entpriseCode));
+					resMap.put("res", JSONUtil.toJsonStr(subjectTypes));
+					return resMap;
+				}
 				// 加redis锁 TODO
 //				redisTemplate.opsForValue().setIfAbsent()
 
-			List<SysDept> deptList = sysDeptService.list(Wrappers.<SysDept>lambdaQuery()
-					.eq(SysDept::getTaxCode, entpriseCode)
-					.eq(SysDept::getDelFlag, DelEnum.NOT_DEL.val())
-					.orderByDesc(SysDept::getCreateTime));
-			if (CollUtil.isNotEmpty(deptList)) {
-				SysDept dept = deptList.get(0);
-				SysUser user = sysUserService.getOne(Wrappers.<SysUser>lambdaQuery()
-						.eq(SysUser::getDeptId, dept.getDeptId())
-						.eq(SysUser::getUsername, username)
-						.eq(SysUser::getDelFlag, DelEnum.NOT_DEL.val())
-						.eq(SysUser::getLockFlag, LockEnum.UN_LOCK.val()));
-				if (user == null) {
-					log.error("用户不存在!");
-					return null;
-				}
-				// 根据不同渠道,更新对应的签约认证状态
-				subjectTypes.forEach((s, o) -> {
-					GigTypeEnum gigTypeEnum = Enum.valueOf(GigTypeEnum.class, s);
-					JSONObject subjectResult = (JSONObject) o;
-
-					switch (gigTypeEnum) {
-						case TAX_HELPOR:
-							taxHelperHandler(user, dept, subjectResult);
-							// 本次结果存入redis
-							redisTemplate.opsForValue().set(CacheConstants.USER_SIGN_CERT_RESPONSE_KEY + user.getUserId(),
-									JSONUtil.toJsonStr(subjectTypes), 1, TimeUnit.MINUTES);
-							break;
-						case REN_LI_JIA:
-							// TODO
-							break;
-						case OLADING:
-							oladingHandler(user, dept, subjectResult);
-							break;
-						case YEE:
-							yeeHandler(user, dept, subjectResult);
-							// 本次结果存入redis
-							redisTemplate.opsForValue().set(CacheConstants.USER_SIGN_CERT_RESPONSE_KEY + user.getUserId(),
-									JSONUtil.toJsonStr(subjectTypes), 1, TimeUnit.MINUTES);
-							break;
-						default:
+				List<SysDept> deptList = sysDeptService.list(Wrappers.<SysDept>lambdaQuery()
+						.eq(SysDept::getTaxCode, entpriseCode)
+						.eq(SysDept::getDelFlag, DelEnum.NOT_DEL.val())
+						.orderByDesc(SysDept::getCreateTime));
+				if (CollUtil.isNotEmpty(deptList)) {
+					SysDept dept = deptList.get(0);
+					SysUser user = sysUserService.getOne(Wrappers.<SysUser>lambdaQuery()
+							.eq(SysUser::getDeptId, dept.getDeptId())
+							.eq(SysUser::getUsername, username)
+							.eq(SysUser::getDelFlag, DelEnum.NOT_DEL.val())
+							.eq(SysUser::getLockFlag, LockEnum.UN_LOCK.val()));
+					if (user == null) {
+						log.error("用户不存在!");
+						return null;
 					}
-				});
+					// 根据不同渠道,更新对应的签约认证状态
+					subjectTypes.forEach((s, o) -> {
+						GigTypeEnum gigTypeEnum = Enum.valueOf(GigTypeEnum.class, s);
+						JSONObject subjectResult = (JSONObject) o;
 
-			}
+						switch (gigTypeEnum) {
+							case TAX_HELPOR:
+								taxHelperHandler(user, dept, subjectResult);
+								// 本次结果存入redis
+								redisTemplate.opsForValue().set(CacheConstants.USER_SIGN_CERT_RESPONSE_KEY + user.getUserId(),
+										JSONUtil.toJsonStr(subjectTypes), 1, TimeUnit.MINUTES);
+								break;
+							case REN_LI_JIA:
+								// TODO
+								break;
+							case OLADING:
+								oladingHandler(user, dept, subjectResult);
+								break;
+							case YEE:
+								yeeHandler(user, dept, subjectResult);
+								break;
+							default:
+						}
+					});
+
+				}
 
-			resMap.put("key", String.format("%s_%s_%s", CacheConstants.USER_SIGN_CERT_RESPONSE_MQ_KEY, username, entpriseCode));
-			resMap.put("res", JSONUtil.toJsonStr(subjectTypes));
+				resMap.put("key", String.format("%s_%s_%s", CacheConstants.USER_SIGN_CERT_RESPONSE_MQ_KEY, username, entpriseCode));
+				resMap.put("res", JSONUtil.toJsonStr(subjectTypes));
+			} catch (Exception e) {
+				log.error("mq回调处理失败", e);
+			}
 
 			return resMap;
         });