package com.java110.api.smo.impl; import com.alibaba.fastjson.JSONObject; import com.java110.api.smo.DefaultAbstractComponentSMO; import com.java110.api.smo.INavServiceSMO; import com.java110.core.context.IPageData; import com.java110.core.log.LoggerFactory; import com.java110.utils.cache.MappingCache; import com.java110.utils.util.StringUtil; import org.slf4j.Logger; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.http.HttpMethod; import org.springframework.http.HttpStatus; import org.springframework.http.ResponseEntity; import org.springframework.stereotype.Service; import org.springframework.util.Assert; import org.springframework.web.client.RestTemplate; /** * 导航栏业务处理类 * Created by Administrator on 2019/4/1. */ @Service("navServiceSMOImpl") public class NavServiceSMOImpl extends DefaultAbstractComponentSMO implements INavServiceSMO { private static Logger logger = LoggerFactory.getLogger(NavServiceSMOImpl.class); @Autowired private RestTemplate restTemplate; /** * 用户退出 * * @param pd * @return */ @Override public ResponseEntity doExit(IPageData pd) { ResponseEntity responseEntity = null; JSONObject exitInfo = new JSONObject(); exitInfo.put("token", pd.getToken()); responseEntity = this.callCenterService(restTemplate, pd, exitInfo.toJSONString(), "user.service.logout", HttpMethod.POST); return responseEntity; } /** * 获取用户信息 * * @param pd * @return */ @Override public ResponseEntity getUserInfo(IPageData pd) { Assert.hasLength(pd.getUserId(), "用户未登录请先登录"); ResponseEntity responseEntity = null; responseEntity = super.getUserInfo(pd, restTemplate); if (responseEntity.getStatusCode() != HttpStatus.OK) { return responseEntity; } JSONObject tmpUserInfo = JSONObject.parseObject(responseEntity.getBody().toString()); JSONObject resultUserInfo = new JSONObject(); responseEntity = super.getStoreInfo(pd, restTemplate); if (responseEntity.getStatusCode() == HttpStatus.OK && StringUtil.jsonHasKayAndValue(responseEntity.getBody().toString(),"storeTypeCd")) { String storeTypeCd = JSONObject.parseObject(responseEntity.getBody().toString()).getString("storeTypeCd"); resultUserInfo.put("storeTypeCd", storeTypeCd); } resultUserInfo.put("name", tmpUserInfo.getString("name")); resultUserInfo.put("address", tmpUserInfo.getString("address")); resultUserInfo.put("sex", tmpUserInfo.getString("sex")); resultUserInfo.put("localtionCd", tmpUserInfo.getString("localtionCd")); resultUserInfo.put("levelCd", tmpUserInfo.getString("levelCd")); //resultUserInfo.put("tel", CommonUtil.mobileEncrypt(tmpUserInfo.getString("tel"))); resultUserInfo.put("tel", tmpUserInfo.getString("tel")); // 这里不加密了 因为前台很多地方直接 关联出 用户的手机号 所以 加密了 没法处理 modify by wuxw 2022-07-04 resultUserInfo.put("email", tmpUserInfo.getString("email")); resultUserInfo.put("userId",tmpUserInfo.getString("userId")); String watermark = MappingCache.getValue("watermark"); resultUserInfo.put("watermark",watermark); responseEntity = new ResponseEntity(resultUserInfo.toJSONString(), HttpStatus.OK); return responseEntity; } }