Browse Source

Merge remote-tracking branch 'remotes/origin/dev_repeat_aop' into dev

dev_shibei_match
jianjun 4 years ago
parent
commit
1f437a8db6
  1. 4
      epmet-commons/epmet-commons-tools/src/main/java/com/epmet/commons/tools/aop/NoRepeatSubmit.java
  2. 66
      epmet-commons/epmet-commons-tools/src/main/java/com/epmet/commons/tools/aop/NoRepeatSubmitAop.java
  3. 23
      epmet-commons/epmet-commons-tools/src/main/java/com/epmet/commons/tools/distributedlock/DistributedLock.java
  4. 1
      epmet-commons/epmet-commons-tools/src/main/java/com/epmet/commons/tools/exception/EpmetErrorCode.java
  5. 9
      epmet-commons/epmet-commons-tools/src/main/java/com/epmet/commons/tools/redis/RedisKeys.java
  6. 10
      epmet-module/gov-access/gov-access-server/src/main/java/com/epmet/controller/AccessConfigController.java
  7. 51
      epmet-module/gov-access/gov-access-server/src/main/java/com/epmet/controller/TestController.java
  8. 6
      epmet-user/epmet-user-server/src/main/java/com/epmet/controller/UserController.java
  9. 2
      epmet-user/epmet-user-server/src/main/java/com/epmet/service/impl/UserServiceImpl.java

4
epmet-commons/epmet-commons-tools/src/main/java/com/epmet/commons/tools/aop/NoRepeatSubmit.java

@ -13,5 +13,9 @@ import java.lang.annotation.Target;
@Target(ElementType.METHOD) @Target(ElementType.METHOD)
@Retention(RetentionPolicy.RUNTIME) @Retention(RetentionPolicy.RUNTIME)
public @interface NoRepeatSubmit { public @interface NoRepeatSubmit {
/**
* 持锁时长 单位毫秒 默认10秒
*/
long leaseTime() default 10*1000;
} }

66
epmet-commons/epmet-commons-tools/src/main/java/com/epmet/commons/tools/aop/NoRepeatSubmitAop.java

@ -1,15 +1,16 @@
package com.epmet.commons.tools.aop; package com.epmet.commons.tools.aop;
import com.epmet.commons.tools.constant.NumConstant; import com.epmet.commons.tools.constant.NumConstant;
import com.epmet.commons.tools.distributedlock.DistributedLock;
import com.epmet.commons.tools.exception.EpmetErrorCode; import com.epmet.commons.tools.exception.EpmetErrorCode;
import com.epmet.commons.tools.exception.RenException; import com.epmet.commons.tools.exception.RenException;
import com.google.common.cache.Cache; import com.epmet.commons.tools.redis.RedisKeys;
import com.google.common.cache.CacheBuilder;
import lombok.extern.slf4j.Slf4j; import lombok.extern.slf4j.Slf4j;
import org.aspectj.lang.JoinPoint; import org.aspectj.lang.ProceedingJoinPoint;
import org.aspectj.lang.annotation.Around;
import org.aspectj.lang.annotation.Aspect; import org.aspectj.lang.annotation.Aspect;
import org.aspectj.lang.annotation.Before; import org.redisson.api.RLock;
import org.aspectj.lang.annotation.Pointcut; import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.context.annotation.Configuration; import org.springframework.context.annotation.Configuration;
import org.springframework.web.context.request.RequestContextHolder; import org.springframework.web.context.request.RequestContextHolder;
import org.springframework.web.context.request.ServletRequestAttributes; import org.springframework.web.context.request.ServletRequestAttributes;
@ -18,6 +19,7 @@ import javax.servlet.http.HttpServletRequest;
import java.util.concurrent.TimeUnit; import java.util.concurrent.TimeUnit;
/** /**
* desc:利用用户token及请求url 防止用户重复提交需要在没有唯一索引的保存或修改操作 方法入口上加上@NoRepeatSubMit注解
* @author zhaoqifeng * @author zhaoqifeng
* @dscription * @dscription
* @date 2020/11/24 9:59 * @date 2020/11/24 9:59
@ -26,37 +28,39 @@ import java.util.concurrent.TimeUnit;
@Configuration @Configuration
@Slf4j @Slf4j
public class NoRepeatSubmitAop { public class NoRepeatSubmitAop {
private static final String AUTHORIZATION_TOKEN_HEADER_KEY = "Authorization";
@Autowired
private DistributedLock distributedLock;
/** @Around("@annotation(noRepeatSubmit)")
* 重复提交判断时间为2s public Object around(ProceedingJoinPoint pjp,NoRepeatSubmit noRepeatSubmit) {
*/
private static final Cache<String, Integer> CACHES = CacheBuilder.newBuilder()
// 最大缓存 100 个
.maximumSize(100)
// 设置写缓存后 5 秒钟过期
.expireAfterWrite(5, TimeUnit.SECONDS)
.build();
@Pointcut("@annotation(com.epmet.commons.tools.aop.NoRepeatSubmit)")
public void doAspect() {
}
@Before("doAspect()")
public void around(JoinPoint pjp) {
try { try {
ServletRequestAttributes attributes = (ServletRequestAttributes) RequestContextHolder.getRequestAttributes(); ServletRequestAttributes attributes = (ServletRequestAttributes) RequestContextHolder.getRequestAttributes();
assert attributes != null; assert attributes != null;
HttpServletRequest request = attributes.getRequest(); HttpServletRequest request = attributes.getRequest();
String key = getKey(request.getRequestURI(), pjp.getArgs()); String internalToken = request.getHeader(AUTHORIZATION_TOKEN_HEADER_KEY);
String key = getKey(request.getRequestURI(), internalToken);
// 如果缓存中有这个url视为重复提交 // 如果缓存中有这个url视为重复提交
if (CACHES.getIfPresent(key) == null) { Object result = null;
CACHES.put(key, NumConstant.ZERO); try {
} else { long leaseTime = noRepeatSubmit.leaseTime();
log.error("重复提交"); //如果获取不到锁等待0秒直接返回 持锁时间为leaseTime
throw new RenException(EpmetErrorCode.REPEATED_SUBMIT_ERROR.getCode()); RLock lock = distributedLock.getLock(RedisKeys.getNoRepeatSubmitKey(key), leaseTime, NumConstant.ZERO_L, TimeUnit.MILLISECONDS);
try {
//因为getLock如果获取失败抛异常 所以不做锁状态的判断
result = pjp.proceed();
} finally {
distributedLock.unLock(lock);
}
} catch (Exception e) {
log.warn("noRepeatSubmit exception",e);
//"未获取到锁,重复提交了
throw new RenException(EpmetErrorCode.REPEAT_SUBMIT.getCode());
} }
return result;
} catch (RenException e) { } catch (RenException e) {
throw e; throw e;
} catch (Throwable e) { } catch (Throwable e) {
@ -65,12 +69,8 @@ public class NoRepeatSubmitAop {
} }
} }
private String getKey(String keyExpress, Object[] args) { private String getKey(String keyExpress,String token) {
for (int i = 0; i < args.length; i++) { return keyExpress+token;
keyExpress = keyExpress.replace("arg[" + i + "]", args[i].toString());
} }
return keyExpress;
}
} }

23
epmet-commons/epmet-commons-tools/src/main/java/com/epmet/commons/tools/distributedlock/DistributedLock.java

@ -1,6 +1,7 @@
package com.epmet.commons.tools.distributedlock; package com.epmet.commons.tools.distributedlock;
import com.epmet.commons.tools.exception.RenException; import com.epmet.commons.tools.exception.RenException;
import lombok.extern.slf4j.Slf4j;
import org.apache.commons.lang3.StringUtils; import org.apache.commons.lang3.StringUtils;
import org.redisson.api.RLock; import org.redisson.api.RLock;
import org.redisson.api.RedissonClient; import org.redisson.api.RedissonClient;
@ -13,6 +14,7 @@ import java.util.concurrent.TimeUnit;
* @Author zxc * @Author zxc
* @DateTime 2020/10/28 9:05 上午 * @DateTime 2020/10/28 9:05 上午
*/ */
@Slf4j
@Component @Component
public class DistributedLock { public class DistributedLock {
@ -45,9 +47,7 @@ public class DistributedLock {
* @return * @return
*/ */
public RLock getLock(String name, Long leaseTime, Long waitTime, TimeUnit timeUnit) { public RLock getLock(String name, Long leaseTime, Long waitTime, TimeUnit timeUnit) {
RLock lock = null; RLock lock = redissonClient.getLock(name);
if (StringUtils.isNotBlank(name) && leaseTime > 0 && waitTime > 0) {
lock = redissonClient.getLock(name);
Boolean lockStatus; Boolean lockStatus;
try { try {
lockStatus = lock.tryLock(waitTime, leaseTime, timeUnit); lockStatus = lock.tryLock(waitTime, leaseTime, timeUnit);
@ -55,8 +55,23 @@ public class DistributedLock {
throw new RenException("获取锁🔒失败了......"); throw new RenException("获取锁🔒失败了......");
} }
} catch (InterruptedException e) { } catch (InterruptedException e) {
e.printStackTrace(); log.error("getLock interruptedException"+name,e);
} }
return lock;
}
/**
* 取锁
*
* @param name 锁key
* @return
*/
public RLock tryLock(String name) {
RLock lock = redissonClient.getLock(name);
Boolean lockStatus = lock.tryLock();
if (!lockStatus) {
throw new RenException("获取锁🔒失败了......");
} }
return lock; return lock;
} }

1
epmet-commons/epmet-commons-tools/src/main/java/com/epmet/commons/tools/exception/EpmetErrorCode.java

@ -64,6 +64,7 @@ public enum EpmetErrorCode {
ACTUAL_TIME(8124,"请录入实际开始时间,实际结束时间"), ACTUAL_TIME(8124,"请录入实际开始时间,实际结束时间"),
ACTUAL_NOT_FINISHED(8125,"请先结束活动"), ACTUAL_NOT_FINISHED(8125,"请先结束活动"),
ACT_SIGN_UP_END_TIME_EARLIER_NOW_EERROR(8121,"活动报名截止时间应晚于当前时间"), ACT_SIGN_UP_END_TIME_EARLIER_NOW_EERROR(8121,"活动报名截止时间应晚于当前时间"),
REPEAT_SUBMIT(8126,"重复请求,请稍后重试"),
CANNOT_AUDIT_WARM(8201, "请完善居民信息"), CANNOT_AUDIT_WARM(8201, "请完善居民信息"),
NOT_DEL_AGENCY(8202, "该机关存在下级机关,不允许删除"), NOT_DEL_AGENCY(8202, "该机关存在下级机关,不允许删除"),

9
epmet-commons/epmet-commons-tools/src/main/java/com/epmet/commons/tools/redis/RedisKeys.java

@ -481,4 +481,13 @@ public class RedisKeys {
public static String getProjectChangedMsgDistinceKey(String customerId) { public static String getProjectChangedMsgDistinceKey(String customerId) {
return rootPrefix.concat("project_changed:consume:").concat(customerId); return rootPrefix.concat("project_changed:consume:").concat(customerId);
} }
/**
* desc:获取防重复提交redis key
* @param key
* @return
*/
public static String getNoRepeatSubmitKey(String key) {
return rootPrefix.concat("no_repeat_submit:").concat(key);
}
} }

10
epmet-module/gov-access/gov-access-server/src/main/java/com/epmet/controller/AccessConfigController.java

@ -1,5 +1,6 @@
package com.epmet.controller; package com.epmet.controller;
import com.epmet.commons.tools.aop.NoRepeatSubmit;
import com.epmet.commons.tools.utils.Result; import com.epmet.commons.tools.utils.Result;
import com.epmet.commons.tools.validator.ValidatorUtils; import com.epmet.commons.tools.validator.ValidatorUtils;
import com.epmet.dto.form.*; import com.epmet.dto.form.*;
@ -8,11 +9,9 @@ import com.epmet.dto.result.AccessConfigOpesResultDTO;
import com.epmet.dto.result.AccessConfigOptionsResultDTO; import com.epmet.dto.result.AccessConfigOptionsResultDTO;
import com.epmet.dto.result.RoleOperationDefaultResultDTO; import com.epmet.dto.result.RoleOperationDefaultResultDTO;
import com.epmet.service.AccessConfigService; import com.epmet.service.AccessConfigService;
import oracle.jdbc.proxy.annotation.Post;
import org.springframework.beans.factory.annotation.Autowired; import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.*; import org.springframework.web.bind.annotation.*;
import javax.validation.constraints.NotBlank;
import java.util.List; import java.util.List;
import java.util.Set; import java.util.Set;
@ -49,6 +48,7 @@ public class AccessConfigController {
* 保存角色的操作权限列表 * 保存角色的操作权限列表
* @return * @return
*/ */
@NoRepeatSubmit
@PostMapping("saveroleopes") @PostMapping("saveroleopes")
public Result saveRoleOpes(@RequestBody AccessConfigOpesFormDTO formDTO) { public Result saveRoleOpes(@RequestBody AccessConfigOpesFormDTO formDTO) {
accessConfigService.saveRoleOpes(formDTO.getRoleId(), formDTO.getOpes(), formDTO.getCustomerId()); accessConfigService.saveRoleOpes(formDTO.getRoleId(), formDTO.getOpes(), formDTO.getCustomerId());
@ -71,6 +71,7 @@ public class AccessConfigController {
* @param config * @param config
* @return * @return
*/ */
@NoRepeatSubmit
@PostMapping("saveconfig") @PostMapping("saveconfig")
public Result saveSettings(@RequestBody AccessConfigSaveConfigDTO config) { public Result saveSettings(@RequestBody AccessConfigSaveConfigDTO config) {
ValidatorUtils.validateEntity(config); ValidatorUtils.validateEntity(config);
@ -87,6 +88,7 @@ public class AccessConfigController {
* @param form * @param form
* @return * @return
*/ */
@NoRepeatSubmit
@PostMapping("roledefaultopes/save") @PostMapping("roledefaultopes/save")
public Result saveRoleDefaultOperations(@RequestBody AccessConfigRoleDefaultOpesFormDTO form) { public Result saveRoleDefaultOperations(@RequestBody AccessConfigRoleDefaultOpesFormDTO form) {
ValidatorUtils.validateEntity(form); ValidatorUtils.validateEntity(form);
@ -111,6 +113,7 @@ public class AccessConfigController {
* @param form * @param form
* @return * @return
*/ */
@NoRepeatSubmit
@PostMapping("opedefaultscopes/save") @PostMapping("opedefaultscopes/save")
public Result saveOpeDefaultScopes(@RequestBody AccessConfigOpeDefaultScopesFormDTO form) { public Result saveOpeDefaultScopes(@RequestBody AccessConfigOpeDefaultScopesFormDTO form) {
ValidatorUtils.validateEntity(form, AccessConfigOpeDefaultScopesFormDTO.SaveOpeDefaultScopesGroup.class); ValidatorUtils.validateEntity(form, AccessConfigOpeDefaultScopesFormDTO.SaveOpeDefaultScopesGroup.class);
@ -124,6 +127,7 @@ public class AccessConfigController {
* @author wxz * @author wxz
* @date 2020.11.17 17:41 * @date 2020.11.17 17:41
*/ */
@NoRepeatSubmit
@PostMapping("add-ope-and-scopes-4role") @PostMapping("add-ope-and-scopes-4role")
public Result addOpeAndScopes4Role(@RequestBody AccessConfigAdd4RoletFormDTO form) { public Result addOpeAndScopes4Role(@RequestBody AccessConfigAdd4RoletFormDTO form) {
ValidatorUtils.validateEntity(form, AccessConfigAdd4RoletFormDTO.AddSingleOperation4RoleGroup.class); ValidatorUtils.validateEntity(form, AccessConfigAdd4RoletFormDTO.AddSingleOperation4RoleGroup.class);
@ -141,6 +145,7 @@ public class AccessConfigController {
* @author wxz * @author wxz
* @date 2021.07.01 16:07 * @date 2021.07.01 16:07
*/ */
@NoRepeatSubmit
@PostMapping("add-ope-and-scopes-4role/by-default-conf") @PostMapping("add-ope-and-scopes-4role/by-default-conf")
public Result addOpeAndScopes4RoleByDefaultConf(@RequestBody AccessConfigAdd4RoletFormDTO form) { public Result addOpeAndScopes4RoleByDefaultConf(@RequestBody AccessConfigAdd4RoletFormDTO form) {
ValidatorUtils.validateEntity(form, AccessConfigAdd4RoletFormDTO.AddSingleOperations4RoleByDefault.class); ValidatorUtils.validateEntity(form, AccessConfigAdd4RoletFormDTO.AddSingleOperations4RoleByDefault.class);
@ -157,6 +162,7 @@ public class AccessConfigController {
* @author wxz * @author wxz
* @date 2020.12.02 16:20 * @date 2020.12.02 16:20
*/ */
@NoRepeatSubmit
@PostMapping("add-opes-and-scopes-4role") @PostMapping("add-opes-and-scopes-4role")
public Result addOpesAndScopes4Role(@RequestBody AccessConfigAdd4RoletFormDTO form) { public Result addOpesAndScopes4Role(@RequestBody AccessConfigAdd4RoletFormDTO form) {
ValidatorUtils.validateEntity(form, AccessConfigAdd4RoletFormDTO.AddMultiOperations4RoleGroup.class); ValidatorUtils.validateEntity(form, AccessConfigAdd4RoletFormDTO.AddMultiOperations4RoleGroup.class);

51
epmet-module/gov-access/gov-access-server/src/main/java/com/epmet/controller/TestController.java

@ -1,11 +1,22 @@
package com.epmet.controller; package com.epmet.controller;
import com.epmet.commons.tools.annotation.ExternalRequestAuth; import com.epmet.commons.tools.annotation.ExternalRequestAuth;
import com.epmet.commons.tools.exception.RenException; import com.epmet.commons.tools.aop.NoRepeatSubmit;
import com.epmet.commons.tools.utils.HttpClientManager;
import com.epmet.commons.tools.utils.Result;
import com.epmet.service.TestService; import com.epmet.service.TestService;
import lombok.Data; import lombok.Data;
import org.springframework.beans.factory.annotation.Autowired; import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.*; import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import java.util.HashMap;
import java.util.Map;
import java.util.concurrent.CountDownLatch;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
@RestController @RestController
@RequestMapping("test") @RequestMapping("test")
@ -14,13 +25,41 @@ public class TestController {
@Autowired @Autowired
private TestService testService; private TestService testService;
@NoRepeatSubmit
@ExternalRequestAuth @ExternalRequestAuth
@PostMapping("test") @PostMapping("test")
public void test(@RequestBody Input input) { public Result<String> test(@RequestBody(required = false) Input input) {
if (true) { try {
throw new RenException("测试报错"); Thread.sleep(5000);
} catch (InterruptedException e) {
e.printStackTrace();
}
String s = "这里是测试结果!";
return new Result<String>().ok(s);
}
@PostMapping("repeat")
public Result testRepeatSubmit(){
System.out.println("开始执行多线程==========");
CountDownLatch countDownLatch = new CountDownLatch(1);
ExecutorService executorService = Executors.newFixedThreadPool(10);
String url = "http://localhost:8099/gov/access/test/test";
for (int i = 0; i < 10 ; i++) {
executorService.submit(()->{
try {
countDownLatch.await();
Map<String,String> headersMap = new HashMap<>();
headersMap.put("Authorization","token");
Result<String> stringResult = HttpClientManager.getInstance().sendPostByJSONAndHeader(url, "", headersMap);
System.out.println(stringResult.getData());
} catch (InterruptedException e) {
e.printStackTrace();
}
});
} }
testService.test(); countDownLatch.countDown();
return new Result().ok(true);
} }
@Data @Data

6
epmet-user/epmet-user-server/src/main/java/com/epmet/controller/UserController.java

@ -1,6 +1,7 @@
package com.epmet.controller; package com.epmet.controller;
import com.epmet.commons.tools.annotation.LoginUser; import com.epmet.commons.tools.annotation.LoginUser;
import com.epmet.commons.tools.aop.NoRepeatSubmit;
import com.epmet.commons.tools.security.dto.TokenDto; import com.epmet.commons.tools.security.dto.TokenDto;
import com.epmet.commons.tools.utils.Result; import com.epmet.commons.tools.utils.Result;
import com.epmet.commons.tools.validator.ValidatorUtils; import com.epmet.commons.tools.validator.ValidatorUtils;
@ -50,6 +51,7 @@ public class UserController {
* @Description * @Description
* @Date 2020/3/16 15:49 * @Date 2020/3/16 15:49
**/ **/
@NoRepeatSubmit
@PostMapping("saveOrUpdateUserWechatDTO") @PostMapping("saveOrUpdateUserWechatDTO")
public Result<UserDTO> saveOrUpdateUserWechatDTO(@RequestBody UserWechatDTO userWechatDTO) { public Result<UserDTO> saveOrUpdateUserWechatDTO(@RequestBody UserWechatDTO userWechatDTO) {
//效验数据 //效验数据
@ -77,6 +79,7 @@ public class UserController {
* @Author sun * @Author sun
* @Description 居民端个人信息-同步用户微信信息 * @Description 居民端个人信息-同步用户微信信息
**/ **/
@NoRepeatSubmit
@PostMapping("updatewxuserinfo") @PostMapping("updatewxuserinfo")
public Result updateWxUserInfo(@LoginUser TokenDto tokenDTO, @RequestBody WxUserInfoFormDTO wxUserInfoFormDTO) { public Result updateWxUserInfo(@LoginUser TokenDto tokenDTO, @RequestBody WxUserInfoFormDTO wxUserInfoFormDTO) {
wxUserInfoFormDTO.setUserId(tokenDTO.getUserId()); wxUserInfoFormDTO.setUserId(tokenDTO.getUserId());
@ -124,6 +127,7 @@ public class UserController {
* @Author sun * @Author sun
* @Description 小程序微信用户登陆新增或更新用户信息 * @Description 小程序微信用户登陆新增或更新用户信息
**/ **/
@NoRepeatSubmit
@PostMapping("savewxuser") @PostMapping("savewxuser")
public Result<UserDTO> saveWxUser(@RequestBody WxUserFormDTO formDTO){ public Result<UserDTO> saveWxUser(@RequestBody WxUserFormDTO formDTO){
return new Result<UserDTO>().ok(userService.saveWxUser(formDTO)); return new Result<UserDTO>().ok(userService.saveWxUser(formDTO));
@ -138,6 +142,7 @@ public class UserController {
* @Author zhangyong * @Author zhangyong
* @Date 14:51 2020-07-23 * @Date 14:51 2020-07-23
**/ **/
@NoRepeatSubmit
@PostMapping("updateUserBaseAndWxUserInfo") @PostMapping("updateUserBaseAndWxUserInfo")
public Result updateUserBaseAndWxUserInfo(@RequestBody WxUserInfoFormDTO wxUserInfoFormDTO) { public Result updateUserBaseAndWxUserInfo(@RequestBody WxUserInfoFormDTO wxUserInfoFormDTO) {
ValidatorUtils.validateEntity(wxUserInfoFormDTO); ValidatorUtils.validateEntity(wxUserInfoFormDTO);
@ -160,6 +165,7 @@ public class UserController {
* @author zxc * @author zxc
* @date 2021/1/19 上午10:35 * @date 2021/1/19 上午10:35
*/ */
@NoRepeatSubmit
@PostMapping("saveuserinfo") @PostMapping("saveuserinfo")
public Result<UserDTO> saveUserInfo(@RequestBody UserInfoFormDTO formDTO){ public Result<UserDTO> saveUserInfo(@RequestBody UserInfoFormDTO formDTO){
ValidatorUtils.validateEntity(formDTO, UserInfoFormDTO.UserInfoForm.class); ValidatorUtils.validateEntity(formDTO, UserInfoFormDTO.UserInfoForm.class);

2
epmet-user/epmet-user-server/src/main/java/com/epmet/service/impl/UserServiceImpl.java

@ -182,7 +182,7 @@ public class UserServiceImpl extends BaseServiceImpl<UserDao, UserEntity> implem
if(null != myselfMsg){ if(null != myselfMsg){
MyResiUserInfoResultDTO result = ConvertUtils.sourceToTarget(myselfMsg,MyResiUserInfoResultDTO.class); MyResiUserInfoResultDTO result = ConvertUtils.sourceToTarget(myselfMsg,MyResiUserInfoResultDTO.class);
//registerFlag 是否已注册居民,true ,false //registerFlag 是否已注册居民,true ,false
result.setRegisterFlag(StringUtils.isNotBlank(myselfMsg.getResiId()) ? true : false); result.setRegisterFlag(StringUtils.isNotBlank(myselfMsg.getResiId()));
result.setRegisterGridName(ModuleConstant.EMPTY_STR); result.setRegisterGridName(ModuleConstant.EMPTY_STR);
if(StringUtils.isNotBlank(myselfMsg.getGridId())){ if(StringUtils.isNotBlank(myselfMsg.getGridId())){
//registerGridName 当前在哪个网格,显示哪个网格的名称 //registerGridName 当前在哪个网格,显示哪个网格的名称

Loading…
Cancel
Save