From 0915f9c21ee26c3b52a763eed9000d3b165e19ce Mon Sep 17 00:00:00 2001 From: kaiyu <404897439@qq.com> Date: Fri, 27 Nov 2020 11:22:15 +0800 Subject: [PATCH] BS登陆接口增加返回数据regionCode 开通mapPath接口,通过token获取用户地图 --- src/main/java/com/moral/service/impl/AccountServiceImpl.java | 85 ++++++++++++++++++++++++++++++++++++++++-- 1 files changed, 80 insertions(+), 5 deletions(-) diff --git a/src/main/java/com/moral/service/impl/AccountServiceImpl.java b/src/main/java/com/moral/service/impl/AccountServiceImpl.java index 69752c4..39f4669 100644 --- a/src/main/java/com/moral/service/impl/AccountServiceImpl.java +++ b/src/main/java/com/moral/service/impl/AccountServiceImpl.java @@ -12,6 +12,8 @@ import javax.annotation.Resource; +import com.moral.entity.*; +import com.moral.mapper.DictionaryDataMapper; import org.apache.commons.lang3.StringUtils; import org.springframework.security.crypto.bcrypt.BCryptPasswordEncoder; import org.springframework.stereotype.Service; @@ -25,10 +27,6 @@ import com.moral.common.exception.BusinessException; import com.moral.common.util.ResourceUtil; import com.moral.common.util.ValidateUtil; -import com.moral.entity.Account; -import com.moral.entity.Menu; -import com.moral.entity.Organization; -import com.moral.entity.Role; import com.moral.mapper.AccountMapper; import com.moral.mapper.OrganizationMapper; import com.moral.service.AccountService; @@ -58,7 +56,6 @@ private OrganizationMapper organizationMapper; - @Override public Map<String, Object> getAccountInfoById(String accountId) { Map<String, Object> result = new HashMap<String, Object>(); @@ -81,6 +78,7 @@ } return result; } + @Override public Map<String, Object> webLogin(Map<String, Object> parameters) { @@ -382,5 +380,82 @@ return result; } + @Resource + DictionaryDataMapper dictionaryDataMapper; + @Override + public Map<String, Object> bsWebLogin(Map<String, Object> parameters) { + Map<String, Object> result = new HashMap<String, Object>(); + Account account = new Account(); + account.setAccountName((String) parameters.get("account")); + String rawPassword = (String) parameters.get("password"); + account = accountMapper.selectOne(account); + boolean isValid = account == null ? false : encoder.matches(rawPassword, account.getPassword()); + if (!isValid) { + result.put("msg", "���������������������������������"); + result.put("accountId", -1); + } else { + result = judgeAccountInfo(account); + if (!result.get("accountId").equals(-1)){ + String regionCode = getRegionCodeByAccount(account); + if(!ObjectUtils.isEmpty(regionCode)) + result.put("regionCode",regionCode); + } + + } + return result; + } + + /** + * @Description: ������id������������������������������ + * @Param: [params] + * @return: java.util.Map<java.lang.String , java.lang.Object> + * @Author: ������������ + * @Date: 2020/11/25 + */ + private String getRegionCodeByAccount(Account account) { + Organization organization = new Organization(); + organization.setId(account.getOrganizationId()); + organization = organizationMapper.selectOne(organization); + Map<String, Object> regionCodeAndType = getRegionCodeAndTypeByOrg(organization); + if(ObjectUtils.isEmpty(regionCodeAndType)) + return null; + return (String) regionCodeAndType.get("regionCode"); + } + + public static Map<String,Object> getRegionCodeAndTypeByOrg(Organization organization){ + Map<String,Object> result = new HashMap<>(); + String regionCode = ""; + String regionType = ""; + Long villageCode = organization.getVillageCode(); + Long townCode = organization.getTownCode(); + Integer areaCode = organization.getAreaCode(); + Integer cityCode = organization.getCityCode(); + Integer provinceCode = organization.getProvinceCode(); + + if(!ObjectUtils.isEmpty(villageCode)){ + regionCode = String.valueOf(villageCode); + regionType = "village"; + }else if(!ObjectUtils.isEmpty(townCode)){ + regionCode = String.valueOf(townCode); + regionType = "town"; + }else if(!ObjectUtils.isEmpty(areaCode)){ + regionCode = String.valueOf(areaCode); + regionType = "area"; + }else if(!ObjectUtils.isEmpty(cityCode)){ + regionCode = String.valueOf(cityCode); + regionType = "city"; + }else if(!ObjectUtils.isEmpty(provinceCode)){ + regionCode = String.valueOf(provinceCode); + regionType = "province"; + }else{ + return null; + } + result.put("regionCode",regionCode); + result.put("regionType",regionType); + return result; + } } + + + -- Gitblit v1.8.0