| | |
| | | package com.moral.controller; |
| | | |
| | | import com.auth0.jwt.exceptions.JWTDecodeException; |
| | | import com.moral.common.exception.WebAuthException; |
| | | import com.moral.common.util.BeanUtils; |
| | | import com.moral.common.util.RedisHashUtil; |
| | | import com.moral.common.util.WebTokenUtils; |
| | | import com.moral.common.webAnno.UserLoginToken; |
| | | import com.moral.entity.AreaNames; |
| | | import com.moral.entity.Organization; |
| | |
| | | import com.moral.service.DictionaryDataService; |
| | | import com.moral.service.OrganizationService; |
| | | import com.moral.service.WebTokenService; |
| | | import org.springframework.web.bind.annotation.CrossOrigin; |
| | | import org.springframework.web.bind.annotation.GetMapping; |
| | | import org.springframework.web.bind.annotation.RequestMapping; |
| | | import org.springframework.web.bind.annotation.RestController; |
| | | import com.moral.util.LatLngTransformation; |
| | | import jdk.nashorn.internal.runtime.logging.Logger; |
| | | import org.springframework.web.bind.annotation.*; |
| | | |
| | | import javax.annotation.Resource; |
| | | import javax.servlet.http.HttpServletRequest; |
| | | import javax.servlet.http.HttpServletResponse; |
| | | import java.util.HashMap; |
| | | import java.util.List; |
| | | import java.util.Map; |
| | |
| | | OrganizationService organizationService; |
| | | @Resource |
| | | WebTokenService webTokenService; |
| | | @Resource |
| | | RedisHashUtil redisHashUtil; |
| | | |
| | | @RequestMapping("login") |
| | | public Map<String, Object> login(HttpServletRequest request){ |
| | | @PostMapping("login") |
| | | public Map<String, Object> login(@RequestBody Map<String, Object> parameters) { |
| | | Map<String, Object> resultMap = new HashMap<String, Object>(); |
| | | Map<String, Object> parameters = getParametersStartingWith(request, null); |
| | | if (!(parameters.containsKey("account") && parameters.containsKey("password"))) { |
| | | resultMap.put("msg", "用户名及密码不允许为空!"); |
| | | resultMap.put("accountId", -1); |
| | | } else { |
| | | resultMap = accountService.webLogin(parameters); |
| | | String accountId = String.valueOf(resultMap.get("accountId")); |
| | | if (!accountId.equals("-1")) { |
| | | redisHashUtil.deleteMapVal("webToken",accountId); |
| | | resultMap.put("token", webTokenService.getToken(accountId)); |
| | | } |
| | | } |
| | | return resultMap; |
| | | } |
| | | |
| | | @UserLoginToken |
| | | @PostMapping("logout") |
| | | public Map<String, Object> logout(HttpServletRequest request) { |
| | | Map<String, Object> resultMap = new HashMap<>(); |
| | | String token = request.getHeader("token"); |
| | | String id = WebTokenUtils.getIdBytoken(token); |
| | | redisHashUtil.addMapOne("webToken", String.valueOf(id),token); |
| | | resultMap.put("msg", "退出成功!"); |
| | | return resultMap; |
| | | } |
| | | |
| | | @UserLoginToken |
| | | @GetMapping("getAccountInfo") |
| | | public Map<String, Object> getAccountInfo(HttpServletRequest request) { |
| | | String token = request.getHeader("token"); |
| | | String id = ""; |
| | | try { |
| | | id = WebTokenUtils.getIdBytoken(token); |
| | | } catch (JWTDecodeException e) { |
| | | throw new WebAuthException("401,token无效"); |
| | | } |
| | | Map<String, Object> resultMap = accountService.getAccountInfoById(id); |
| | | Object orgId = resultMap.get("orgId"); |
| | | if (resultMap.get("orgId") != null && resultMap.get("orgId") instanceof Integer) { |
| | | StringBuilder areaNamesBuilder = new StringBuilder("中国"); |
| | | //判断是否为本公司开发者 |
| | | if (!((Integer) orgId).equals(dictionaryDataService.querySupperOrgId())) { |
| | | //不是本公司开发者则获取用户所属地区 |
| | | Organization organization = organizationService.getOrganizationById((Integer) orgId); |
| | | if (organization.getAreaNames() != null) { |
| | | Map<String, String> areaNameMap = BeanUtils.beanToMap(organization.getAreaNames()); |
| | | List<String> names = areaNameMap.entrySet().stream().filter(item -> { |
| | | return item.getValue() != null; |
| | | }).map(item -> { |
| | | return item.getValue(); |
| | | }).collect(Collectors.toList()); |
| | | AreaNames areaNames = organization.getAreaNames(); |
| | | areaNamesBuilder.append("/"); |
| | | areaNamesBuilder.append(String.join("/", names)); |
| | | } |
| | | // 企业用户 |
| | | if (organization.getRank() != null && organization.getRank() == 0) { |
| | | resultMap.put("type", "enterprise"); |
| | | } else { |
| | | resultMap.put("type", "government"); |
| | | } |
| | | Number mapAreaCode = null; |
| | | if (organization.getVillageCode() != null) { |
| | | mapAreaCode = organization.getVillageCode(); |
| | | } else if (organization.getTownCode() != null) { |
| | | mapAreaCode = organization.getTownCode(); |
| | | } else if (organization.getAreaCode() != null) { |
| | | mapAreaCode = organization.getAreaCode(); |
| | | } else if (organization.getCityCode() != null) { |
| | | mapAreaCode = organization.getCityCode(); |
| | | } else if (organization.getProvinceCode() != null) { |
| | | mapAreaCode = organization.getProvinceCode(); |
| | | } |
| | | resultMap.put("mapAreaCode", mapAreaCode.toString()); |
| | | } |
| | | resultMap.put("mapPath", areaNamesBuilder.toString()); |
| | | String accountId = String.valueOf(resultMap.get("accountId")); |
| | | resultMap.put("token", webTokenService.getToken(accountId)); |
| | | } |
| | | return resultMap; |
| | | } |
| | | |
| | | //弃用 |
| | | @UserLoginToken |
| | | @RequestMapping("getAccountInfoTest") |
| | | public Map<String, Object> getAccountInfoTest(@RequestBody Map<String, Object> parameters) { |
| | | Map<String, Object> resultMap = new HashMap<String, Object>(); |
| | | System.out.println(parameters); |
| | | if (!(parameters.containsKey("account") && parameters.containsKey("password"))) { |
| | | resultMap.put("msg", "用户名及密码不允许为空!"); |
| | | resultMap.put("accountId", -1); |
| | |
| | | resultMap.put("mapAreaCode", mapAreaCode.toString()); |
| | | } |
| | | resultMap.put("mapPath", areaNamesBuilder.toString()); |
| | | String accountId= String.valueOf(resultMap.get("accountId")); |
| | | resultMap.put("token",webTokenService.getToken(accountId)); |
| | | String accountId = String.valueOf(resultMap.get("accountId")); |
| | | resultMap.put("token", webTokenService.getToken(accountId)); |
| | | } |
| | | } |
| | | return resultMap; |
| | |
| | | |
| | | @UserLoginToken |
| | | @GetMapping("test") |
| | | public String add(){ |
| | | public String add() { |
| | | return "test success!"; |
| | | } |
| | | } |