| | |
| | | |
| | | import com.alibaba.fastjson.JSONArray; |
| | | import com.alibaba.fastjson.JSONObject; |
| | | import com.auth0.jwt.algorithms.Algorithm; |
| | | import com.java110.common.cache.JWTCache; |
| | | import com.java110.common.cache.MappingCache; |
| | | import com.java110.common.constant.CommonConstant; |
| | | import com.java110.common.constant.MappingConstant; |
| | | import com.java110.common.constant.ResponseConstant; |
| | | import com.java110.common.constant.ServiceCodeConstant; |
| | | import com.java110.common.exception.SMOException; |
| | | import com.java110.common.factory.AuthenticationFactory; |
| | | import com.java110.common.factory.DataTransactionFactory; |
| | | import com.java110.common.log.LoggerEngine; |
| | | import com.java110.common.util.Assert; |
| | | import com.java110.console.smo.IConsoleServiceSMO; |
| | | import com.java110.entity.service.PageData; |
| | | import org.springframework.beans.factory.annotation.Autowired; |
| | | import org.springframework.http.HttpEntity; |
| | | import org.springframework.http.HttpHeaders; |
| | |
| | | */ |
| | | @Override |
| | | public List<Map> getMenuItemsByManageId(String manageId) throws SMOException,IllegalArgumentException{ |
| | | |
| | | //获取组件 |
| | | String appId = MappingCache.getValue(MappingConstant.KEY_CONSOLE_SERVICE_APP_ID); |
| | | |
| | | Assert.hasLength(appId, "组件不能为空"); |
| | | |
| | | String centerServiceUrl = MappingCache.getValue(MappingConstant.KEY_CENTER_SERVICE_URL); |
| | | |
| | | Assert.hasLength(centerServiceUrl, "中心服务器地址没有配置"); |
| | | |
| | | String securityCode = MappingCache.getValue(MappingConstant.KEY_CONSOLE_SECURITY_CODE); |
| | | Assert.hasLength(securityCode, "签名秘钥没有配置"); |
| | | Map paramIn = new HashMap(); |
| | | paramIn.put("manageId", manageId); |
| | | paramIn.put("menuGroup",CommonConstant.MENU_GROUP_LEFT); |
| | | String responseMsg = ""; |
| | | String requestBody = DataTransactionFactory.createQueryOneCenterServiceRequestJson(appId, manageId, securityCode, |
| | | DataTransactionFactory.createQueryOneBusinessRequestJson(ServiceCodeConstant.SERVICE_CODE_QUERY_MENU_ITEM, |
| | | ServiceCodeConstant.SERVICE_CODE_QUERY_MENU_ITEM_NAME, paramIn)); |
| | | if (MappingConstant.VALUE_ON.equals(MappingCache.getValue(MappingConstant.KEY_CONSOLE_SERVICE_SECURITY_ON_OFF))) { |
| | | try { |
| | | requestBody = DataTransactionFactory.encrypt(requestBody, 2048); |
| | | //调用查询菜单信息 |
| | | HttpHeaders header = new HttpHeaders(); |
| | | header.add(CommonConstant.ENCRYPT, MappingConstant.VALUE_ON); |
| | | header.add(CommonConstant.ENCRYPT_KEY_SIZE, "2048"); |
| | | HttpEntity<String> httpEntity = new HttpEntity<String>(requestBody, header); |
| | | responseMsg = restTemplate.postForObject(centerServiceUrl, httpEntity, String.class); |
| | | responseMsg = DataTransactionFactory.decrypt(responseMsg, 2048); |
| | | }catch (Exception e){ |
| | | logger.error("调用接口失败",e); |
| | | throw new SMOException(ResponseConstant.RESULT_CODE_NO_AUTHORITY_ERROR,"调用接口失败"+e); |
| | | } |
| | | } else { |
| | | responseMsg = restTemplate.postForObject(centerServiceUrl,requestBody,String.class); |
| | | } |
| | | |
| | | JSONObject businessObj = DataTransactionFactory.getOneBusinessFromCenterServiceResponseJson(responseMsg); |
| | | Map paramIn = new HashMap(); |
| | | paramIn.put("manageId", manageId); |
| | | paramIn.put("menuGroup", CommonConstant.MENU_GROUP_LEFT); |
| | | paramIn.put(CommonConstant.ORDER_USER_ID,manageId); |
| | | paramIn.put(ServiceCodeConstant.SERVICE_CODE,ServiceCodeConstant.SERVICE_CODE_QUERY_MENU_ITEM); |
| | | paramIn.put(ServiceCodeConstant.SERVICE_CODE_NAME,ServiceCodeConstant.SERVICE_CODE_QUERY_MENU_ITEM_NAME); |
| | | JSONObject businessObj = doExecute(paramIn); |
| | | JSONArray menus = businessObj.getJSONArray("menus"); |
| | | return menus.toJavaList(Map.class); |
| | | } |
| | | |
| | | /** |
| | | * 用户登录 |
| | | * @param userObj |
| | | * @param pd |
| | | * @return |
| | | * @throws SMOException |
| | | */ |
| | | @Override |
| | | public String login(JSONObject userObj) throws SMOException { |
| | | return null; |
| | | public void login(PageData pd) throws SMOException { |
| | | String userCode = pd.getParam().getString("userCode"); |
| | | String userPwd = pd.getParam().getString("userPwd"); |
| | | String pageSign = pd.getParam().getString("pageSign"); |
| | | |
| | | Assert.hasText(userCode,"用户编码不能为空"); |
| | | Assert.hasText(userPwd,"用户密码不能为空"); |
| | | |
| | | Map paramIn = new HashMap(); |
| | | paramIn.put("userCode", userCode); |
| | | paramIn.put(CommonConstant.ORDER_USER_ID,CommonConstant.ORDER_DEFAULT_USER_ID); |
| | | paramIn.put(ServiceCodeConstant.SERVICE_CODE,ServiceCodeConstant.SERVICE_CODE_QUERY_USER_LOGIN); |
| | | paramIn.put(ServiceCodeConstant.SERVICE_CODE_NAME,ServiceCodeConstant.SERVICE_CODE_QUERY_USER_LOGIN_NAME); |
| | | //paramIn.put("userPwd", userPwd); |
| | | JSONObject businessObj = doExecute(paramIn); |
| | | |
| | | JSONObject user = businessObj.getJSONObject("user"); |
| | | //String newPwd = AuthenticationFactory.md5UserPassword(userPwd); |
| | | if(!AuthenticationFactory.md5UserPassword(userPwd).equals(user.getString("userPwd"))){ |
| | | throw new SMOException(ResponseConstant.RESULT_CODE_NO_AUTHORITY_ERROR,"密码不正确"); |
| | | } |
| | | String token = ""; |
| | | try { |
| | | Map userMap = new HashMap(); |
| | | userMap.put(CommonConstant.LOGIN_USER_ID,user.getString("userId")); |
| | | userMap.put(CommonConstant.LOGIN_USER_NAME,user.getString("userName")); |
| | | token = AuthenticationFactory.createAndSaveToken(userMap); |
| | | pd.setToken(token); |
| | | }catch (Exception e){ |
| | | logger.error("登录异常:",e); |
| | | throw new SMOException(ResponseConstant.RESULT_CODE_INNER_ERROR,"系统内部错误,请联系管理员"); |
| | | } |
| | | |
| | | //封装成功信息 |
| | | pd.setResJson(DataTransactionFactory.pageResponseJson(pd.getTransactionId(),ResponseConstant.RESULT_CODE_SUCCESS,"登录成功 ",null)); |
| | | |
| | | } |
| | | |
| | | private JSONObject doExecute(Map paramIn) { |
| | | //获取组件 |
| | | String appId = MappingCache.getValue(MappingConstant.KEY_CONSOLE_SERVICE_APP_ID); |
| | | |
| | | Assert.hasLength(appId, "组件不能为空"); |
| | | |
| | | String centerServiceUrl = MappingCache.getValue(MappingConstant.KEY_CENTER_SERVICE_URL); |
| | | |
| | | Assert.hasLength(centerServiceUrl, "中心服务器地址没有配置"); |
| | | |
| | | String securityCode = MappingCache.getValue(MappingConstant.KEY_CONSOLE_SECURITY_CODE); |
| | | Assert.hasLength(securityCode, "签名秘钥没有配置"); |
| | | |
| | | String serviceCode = paramIn.get(ServiceCodeConstant.SERVICE_CODE).toString(); |
| | | String serviceCodeName = paramIn.get(ServiceCodeConstant.SERVICE_CODE_NAME).toString(); |
| | | String userId = paramIn.get(CommonConstant.ORDER_USER_ID).toString(); |
| | | if(paramIn.containsKey(ServiceCodeConstant.SERVICE_CODE)){ |
| | | paramIn.remove(ServiceCodeConstant.SERVICE_CODE); |
| | | } |
| | | if(paramIn.containsKey(ServiceCodeConstant.SERVICE_CODE_NAME)){ |
| | | paramIn.remove(ServiceCodeConstant.SERVICE_CODE_NAME); |
| | | } |
| | | |
| | | if(paramIn.containsKey(CommonConstant.ORDER_USER_ID)){ |
| | | paramIn.remove(CommonConstant.ORDER_USER_ID); |
| | | } |
| | | |
| | | String responseMsg = ""; |
| | | String requestBody = DataTransactionFactory.createQueryOneCenterServiceRequestJson(appId, userId, securityCode, |
| | | DataTransactionFactory.createQueryOneBusinessRequestJson(serviceCode, |
| | | serviceCodeName, paramIn)); |
| | | if (MappingConstant.VALUE_ON.equals(MappingCache.getValue(MappingConstant.KEY_CONSOLE_SERVICE_SECURITY_ON_OFF))) { |
| | | try { |
| | | requestBody = DataTransactionFactory.encrypt(requestBody, 2048); |
| | | //调用查询菜单信息 |
| | | HttpHeaders header = new HttpHeaders(); |
| | | header.add(CommonConstant.ENCRYPT, MappingConstant.VALUE_ON); |
| | | header.add(CommonConstant.ENCRYPT_KEY_SIZE, "2048"); |
| | | HttpEntity<String> httpEntity = new HttpEntity<String>(requestBody, header); |
| | | responseMsg = restTemplate.postForObject(centerServiceUrl, httpEntity, String.class); |
| | | responseMsg = DataTransactionFactory.decrypt(responseMsg, 2048); |
| | | }catch (Exception e){ |
| | | logger.error("调用接口失败",e); |
| | | throw new SMOException(ResponseConstant.RESULT_CODE_NO_AUTHORITY_ERROR,"调用接口失败"+e); |
| | | } |
| | | } else { |
| | | responseMsg = restTemplate.postForObject(centerServiceUrl,requestBody,String.class); |
| | | } |
| | | |
| | | return DataTransactionFactory.getOneBusinessFromCenterServiceResponseJson(responseMsg); |
| | | } |
| | | |
| | | |
| | | public RestTemplate getRestTemplate() { |
| | | return restTemplate; |
| | | } |