123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255 |
- 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<OWbInveMng> 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<String,String> 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;
- }
- }
|