From 77bcea27bdd87b5ec1841068587b0e447abd8802 Mon Sep 17 00:00:00 2001 From: k94314517 <8417338+k94314517@user.noreply.gitee.com> Date: 星期四, 07 三月 2024 16:23:27 +0800 Subject: [PATCH] ERP接口 --- server/dmvisit_service/src/main/java/com/doumee/core/erp/ErpTool.java | 175 +++++++++++++++++++++++++++++++++++++--------------------- 1 files changed, 112 insertions(+), 63 deletions(-) diff --git a/server/dmvisit_service/src/main/java/com/doumee/core/erp/ErpTool.java b/server/dmvisit_service/src/main/java/com/doumee/core/erp/ErpTool.java index 1e15e58..08fda60 100644 --- a/server/dmvisit_service/src/main/java/com/doumee/core/erp/ErpTool.java +++ b/server/dmvisit_service/src/main/java/com/doumee/core/erp/ErpTool.java @@ -1,7 +1,9 @@ package com.doumee.core.erp; +import com.alibaba.fastjson.JSONArray; import com.alibaba.fastjson.JSONObject; import com.alibaba.fastjson.TypeReference; +import com.doumee.core.constants.ResponseStatus; import com.doumee.core.erp.model.openapi.request.erp.ApproveAddRequest; import com.doumee.core.erp.model.openapi.request.erp.OrgListRequest; import com.doumee.core.erp.model.openapi.request.erp.UserFailRequest; @@ -10,49 +12,84 @@ import com.doumee.core.erp.model.openapi.response.erp.ERPApiResponse; import com.doumee.core.erp.model.openapi.response.erp.ErpOrgListResponse; import com.doumee.core.erp.model.openapi.response.erp.ErpUserListResponse; +import com.doumee.core.exception.BusinessException; import com.doumee.core.model.PageData; import com.doumee.core.model.PageWrap; +import com.doumee.core.utils.Constants; import com.doumee.core.utils.HttpsUtil; +import com.doumee.dao.business.model.InterfaceLog; import com.doumee.dao.business.model.Member; +import com.doumee.service.business.InterfaceLogService; import com.github.pagehelper.PageInfo; import org.apache.commons.lang3.StringUtils; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.stereotype.Service; import java.util.ArrayList; +import java.util.Date; import java.util.List; +@Service public class ErpTool { + + @Autowired + private InterfaceLogService interfaceLogService; + + public void saveInterfaceLog(Object param, String path,String result,Integer type) { + InterfaceLog interfaceLog=new InterfaceLog(); + interfaceLog.setType(type); + interfaceLog.setCreateDate(new Date()); + interfaceLog.setIsdeleted(Constants.ZERO); + if(param!=null){ + interfaceLog.setRequest(JSONObject.toJSONString(param)); + } + interfaceLog.setPlat(Constants.ONE); + interfaceLog.setRepose(result); + interfaceLog.setName(path); + interfaceLog.setUrl(path); + interfaceLogService.create(interfaceLog); + } + + + /** * 鍚屾缁勭粐 * @param url * @param param * @return */ - public static List<ErpOrgListResponse> getErpOrgList(String url, OrgListRequest param){ - + public List<ErpOrgListResponse> getErpOrgList(String url, OrgListRequest param){ List<ErpOrgListResponse> list = new ArrayList<>(); - int page =1; - int pageSize = 100; - boolean hasLast = true; - while (hasLast){ - hasLast = false; - PageWrap<OrgListRequest> pageWrap = new PageWrap<>(); - pageWrap.setModel(param); - pageWrap.setPage(page); - pageWrap.setCapacity(pageSize); - String result = HttpsUtil.postJson(url, JSONObject.toJSONString(pageWrap)); - if(StringUtils.isNotBlank(result)){ - TypeReference typeReference = - new TypeReference<ERPApiResponse<PageData<ErpOrgListResponse>>>(){}; - ERPApiResponse<PageData<ErpOrgListResponse>> response = JSONObject.parseObject(result, typeReference.getType()); - if(response!=null && response.getData()!=null&& response.getData().getRecords()!=null){ - list.addAll(response.getData().getRecords()); - if(100*pageSize < response.getData().getTotal() ){ - hasLast =true;//杩樻湁涓嬩竴椤� + try { + int page = 1; + int pageSize = 100; + boolean hasLast = true; + while (hasLast) { + hasLast = false; + PageWrap<OrgListRequest> pageWrap = new PageWrap<>(); + pageWrap.setModel(param); + pageWrap.setPage(page); + pageWrap.setCapacity(pageSize); + String result = HttpsUtil.postJson(url, JSONObject.toJSONString(pageWrap)); + if (StringUtils.isNotBlank(result)) { + TypeReference typeReference = + new TypeReference<ERPApiResponse<PageData<ErpOrgListResponse>>>() { + }; + ERPApiResponse<PageData<ErpOrgListResponse>> response = JSONObject.parseObject(result, typeReference.getType()); + if (response != null && response.getData() != null && response.getData().getRecords() != null) { + list.addAll(response.getData().getRecords()); + if (page * pageSize < response.getData().getTotal()) { + hasLast = true;//杩樻湁涓嬩竴椤� } page++; } } } + }catch (Exception e){ + throw e; + }finally { + saveInterfaceLog(param,url,JSONArray.toJSONString(list),Constants.ZERO); + } return list; } @@ -62,31 +99,37 @@ * @param param * @return */ - public static List<ErpUserListResponse> getErpUserList(String url, UserListRequest param){ + public List<ErpUserListResponse> getErpUserList(String url, UserListRequest param){ List<ErpUserListResponse> list = new ArrayList<>(); - int page =1; - int pageSize = 100; - boolean hasLast = true; - while (hasLast){ - hasLast = false; - PageWrap<UserListRequest> pageWrap = new PageWrap<>(); - pageWrap.setModel(param); - pageWrap.setPage(page); - pageWrap.setCapacity(pageSize); - String result = HttpsUtil.postJson(url, JSONObject.toJSONString(pageWrap)); - if(StringUtils.isNotBlank(result)){ - TypeReference typeReference = - new TypeReference<ERPApiResponse<PageData<ErpUserListResponse>>>(){}; - ERPApiResponse<PageData <ErpUserListResponse>> response = JSONObject.parseObject(result, typeReference.getType()); - if(response!=null && response.getData()!=null && response.getData().getRecords()!=null){ - list.addAll(response.getData().getRecords()); - if(pageSize*page < response.getData().getTotal() ){ - hasLast =true;//杩樻湁涓嬩竴椤� + try{ + int page =1; + int pageSize = 100; + boolean hasLast = true; + while (hasLast){ + hasLast = false; + PageWrap<UserListRequest> pageWrap = new PageWrap<>(); + pageWrap.setModel(param); + pageWrap.setPage(page); + pageWrap.setCapacity(pageSize); + String result = HttpsUtil.postJson(url, JSONObject.toJSONString(pageWrap)); + if(StringUtils.isNotBlank(result)){ + TypeReference typeReference = + new TypeReference<ERPApiResponse<PageData<ErpUserListResponse>>>(){}; + ERPApiResponse<PageData <ErpUserListResponse>> response = JSONObject.parseObject(result, typeReference.getType()); + if(response!=null && response.getData()!=null && response.getData().getRecords()!=null){ + list.addAll(response.getData().getRecords()); + if(pageSize*page < response.getData().getTotal() ){ + hasLast =true;//杩樻湁涓嬩竴椤� + } } page++; } } + }catch (Exception e){ + throw e; + }finally { + saveInterfaceLog(param,url, JSONArray.toJSONString(list),Constants.ZERO); } return list; @@ -98,26 +141,26 @@ * @param param * @return */ - public static ApproveInfoResponse submitApprove(String url, ApproveAddRequest param){ + public ApproveInfoResponse submitApprove(String url, ApproveAddRequest param){ System.out.println(JSONObject.toJSONString(param)); String result = HttpsUtil.postJson(url, JSONObject.toJSONString(param)); - if(StringUtils.isNotBlank(result)){ -// TypeReference typeReference = -// new TypeReference<ERPApiResponse<ApproveInfoResponse>>(){}; -// ERPApiResponse<ApproveInfoResponse> response = JSONObject.parseObject(result, typeReference.getType()); -// if(response!=null && response.isSuccess()){ -// return response.getData(); -// } - TypeReference typeReference = - new TypeReference<ERPApiResponse<String>>(){}; - ERPApiResponse<String> response = JSONObject.parseObject(result, typeReference.getType()); - if(response!=null && response.isSuccess()){ - ApproveInfoResponse approveInfoResponse = new ApproveInfoResponse(); - approveInfoResponse.setId(response.getData()); - return approveInfoResponse; + try{ + if(StringUtils.isNotBlank(result)){ + TypeReference typeReference = + new TypeReference<ERPApiResponse<String>>(){}; + ERPApiResponse<String> response = JSONObject.parseObject(result, typeReference.getType()); + if(response!=null && response.isSuccess()){ + ApproveInfoResponse approveInfoResponse = new ApproveInfoResponse(); + approveInfoResponse.setId(response.getData()); + return approveInfoResponse; + }else if(response!=null && !response.isSuccess()){ + throw new BusinessException(ResponseStatus.SERVER_ERROR.getCode(),response.getMessage()); + } } - - + }catch (Exception e){ + throw e; + }finally { + saveInterfaceLog(param,url,JSONObject.toJSONString(result),Constants.ZERO); } return null; } @@ -128,15 +171,21 @@ * @param param * @return */ - public static ERPApiResponse noticeUserStatus(String url, UserFailRequest param){ + public ERPApiResponse noticeUserStatus(String url, UserFailRequest param){ String result = HttpsUtil.postJson(url, JSONObject.toJSONString(param)); - if(StringUtils.isNotBlank(result)){ - TypeReference typeReference = - new TypeReference<ERPApiResponse>(){}; - ERPApiResponse response = JSONObject.parseObject(result, typeReference.getType()); - if(response!=null){ - return response; + try{ + if(StringUtils.isNotBlank(result)){ + TypeReference typeReference = + new TypeReference<ERPApiResponse>(){}; + ERPApiResponse response = JSONObject.parseObject(result, typeReference.getType()); + if(response!=null){ + return response; + } } + }catch (Exception e){ + throw e; + }finally { + saveInterfaceLog(param,url,JSONObject.toJSONString(result),Constants.ZERO); } return null; } -- Gitblit v1.9.3