package com.emato.biz.service.impl; import java.io.IOException; import java.util.*; import com.alibaba.fastjson.JSON; import com.alibaba.fastjson.JSONArray; import com.alibaba.fastjson.JSONObject; import com.emato.biz.config.OmsConfig; import com.emato.common.utils.DateUtils; import com.emato.common.utils.oms.OkHttpUtils; import com.emato.common.utils.oms.request.OmsSign; import okhttp3.Request; import org.apache.http.HttpStatus; import org.apache.http.client.methods.CloseableHttpResponse; import org.apache.http.client.methods.HttpPost; import org.apache.http.entity.StringEntity; import org.apache.http.impl.client.CloseableHttpClient; import org.apache.http.impl.client.HttpClients; import org.apache.http.util.EntityUtils; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; import com.emato.biz.mapper.warehouse.OWbInveMngMapper; import com.emato.biz.domain.warehouse.OWbInveMng; import com.emato.biz.service.warehouse.IOWbInveMngService; import org.springframework.transaction.annotation.Transactional; /** * 库存管理,wms入库回传时,增加库存数Service业务层处理 * * @author yangbo * @date 2021-02-01 */ @Service public class OWbInveMngServiceImpl implements IOWbInveMngService { @Autowired private OWbInveMngMapper oWbInveMngMapper; private static final Logger LOGGER = LoggerFactory.getLogger(OWbInveMngServiceImpl.class); /** * 查询库存管理,wms入库回传时,增加库存数 * * @param inveSn 库存管理,wms入库回传时,增加库存数ID * @return 库存管理,wms入库回传时,增加库存数 */ @Override public OWbInveMng selectOWbInveMngById(String inveSn) { return oWbInveMngMapper.selectOWbInveMngById(inveSn); } /** * 查询库存管理,wms入库回传时,增加库存数列表 * * @param oWbInveMng 库存管理,wms入库回传时,增加库存数 * @return 库存管理,wms入库回传时,增加库存数 */ @Override public List selectOWbInveMngList(OWbInveMng oWbInveMng) { return oWbInveMngMapper.selectOWbInveMngList(oWbInveMng); } /** * 新增库存管理,wms入库回传时,增加库存数 * * @param oWbInveMng 库存管理,wms入库回传时,增加库存数 * @return 结果 */ @Override public int insertOWbInveMng(OWbInveMng oWbInveMng) { oWbInveMng.setCreateTime(DateUtils.getNowDate()); return oWbInveMngMapper.insertOWbInveMng(oWbInveMng); } /** * 修改库存管理,wms入库回传时,增加库存数 * * @param oWbInveMng 库存管理,wms入库回传时,增加库存数 * @return 结果 */ @Override public int updateOWbInveMng(OWbInveMng oWbInveMng) { return oWbInveMngMapper.updateOWbInveMng(oWbInveMng); } /** * 批量删除库存管理,wms入库回传时,增加库存数 * * @param inveSns 需要删除的库存管理,wms入库回传时,增加库存数ID * @return 结果 */ @Override public int deleteOWbInveMngByIds(String[] inveSns) { return oWbInveMngMapper.deleteOWbInveMngByIds(inveSns); } /** * 删除库存管理,wms入库回传时,增加库存数信息 * * @param inveSn 库存管理,wms入库回传时,增加库存数ID * @return 结果 */ @Override public int deleteOWbInveMngById(String inveSn) { return oWbInveMngMapper.deleteOWbInveMngById(inveSn); } /** * 根据商户编号去拉取数据 * * @param merchSn * @return */ @Override @Transactional public int pullInveMng(String merchSn) { int page = 1; Integer querySize = OmsConfig.getQuerySize(); int resultCode = pullInveMngFromOms(merchSn,page, querySize); while(resultCode != 1){ page = page + 1; resultCode = pullInveMngFromOms(merchSn, page, querySize); } return resultCode==0?1:resultCode; } private int pullInveMngFromOms(String merchSn, int page, Integer querySize) { Map data = new HashMap(); data.put("merchId",merchSn); data.put("page",page+""); data.put("limit",querySize.toString()); Map sParaTemp = new TreeMap(); sParaTemp.put("data", JSON.toJSONString(data)); sParaTemp.put("merchId",OmsConfig.getMerchSn()); String timestamp = String.valueOf(System.currentTimeMillis()/1000); sParaTemp.put("timestamp", timestamp); //生成要请求给oms秘钥 // String sign = OmsSign.sign(sParaTemp,cus.getWaybill().get("secret-key")); LOGGER.info("md5混淆码参数:" + OmsConfig.getMd5Salt()); String sign = OmsSign.sign(sParaTemp,OmsConfig.getMd5Salt()); sParaTemp.put("sign", sign); //构建Request String url = OmsConfig.getQueryMngInveUrl(); // url = "http://127.0.0.1:8680/al/shop/order/query"; String jsonParam = JSONObject.toJSONString(sParaTemp); Request request = OkHttpUtils.buildRequest(jsonParam,url,""); LOGGER.info("oms的请求报文:" + request); // 同步访问,返回结果字符串 String responseString = null; try { url = "http://120.76.26.84:8680/al/queryOmsInfo/queryInveMng"; JSONObject jsonObject = httpPost(url,JSONObject.parseObject(jsonParam)); // responseString = OkHttpUtils.post(request,null); LOGGER.info("oms的响应报文"+jsonObject.toString()); //解析响应数据 // JSONObject jsonObject = JSONObject.parseObject(responseString); JSONArray result = (JSONArray) jsonObject.get("data"); Object msg = jsonObject.get("msg"); Object code = jsonObject.get("code"); if(result == null || result.size() == 0){ return 1; } for(int i = 0 ; i < result.size(); i ++){ JSONObject o = (JSONObject) result.get(i); OWbInveMng oWbInveMng = o.toJavaObject(OWbInveMng.class); // OWbInveMng wb = (OWbInveMng) o; oWbInveMngMapper.saveOrUpdate(oWbInveMng); } if("202".equals(code)){ return 1; } } catch (Exception e) { e.printStackTrace(); LOGGER.error(e.getMessage()); return 1; } return 0; } public static JSONObject httpPost(String url, JSONObject jsonParam) { // post请求返回结果 CloseableHttpClient httpClient = HttpClients.createDefault(); JSONObject jsonResult = null; HttpPost httpPost = new HttpPost(url); // 设置请求和传输超时时间 // httpPost.setConfig(requestConfig); try { if (null != jsonParam) { // 解决中文乱码问题 StringEntity entity = new StringEntity(jsonParam.toString(), "utf-8"); entity.setContentEncoding("UTF-8"); entity.setContentType("application/json"); httpPost.setEntity(entity); } CloseableHttpResponse result = httpClient.execute(httpPost); // 请求发送成功,并得到响应 if (result.getStatusLine().getStatusCode() == HttpStatus.SC_OK) { String str = ""; try { // 读取服务器返回过来的json字符串数据 str = EntityUtils.toString(result.getEntity(), "utf-8"); // 把json字符串转换成json对象 jsonResult = JSONObject.parseObject(str); } catch (Exception e) { LOGGER.error("post请求提交失败:" + url, e); } } } catch (IOException e) { LOGGER.error("post请求提交失败:" + url, e); } finally { httpPost.releaseConnection(); } return jsonResult; } }