SalesDetaiServicelImpl.java 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335
  1. package com.emato.biz.service.impl;
  2. import com.alibaba.fastjson.JSON;
  3. import com.alibaba.fastjson.JSONObject;
  4. import com.emato.biz.domain.OmsUtils;
  5. import com.emato.biz.domain.mall.InventoryDataPushVo;
  6. import com.emato.biz.domain.mall.InventoryDataVo;
  7. import com.emato.biz.domain.mall.NewSystemFormatEntiy;
  8. import com.emato.biz.domain.merchant.MerchantSecret;
  9. import com.emato.biz.mapper.mall.InventoryDataMapper;
  10. import com.emato.biz.mapper.mall.MallMngChangeMapper;
  11. import com.emato.biz.mapper.merchant.MerchantSecretMapper;
  12. import com.emato.biz.service.mall.ISalesDetaiServicel;
  13. import com.emato.common.core.Result;
  14. import com.emato.common.utils.DateUtils;
  15. import com.emato.common.utils.StringUtils;
  16. import com.emato.common.utils.sign.Md5Utils;
  17. import com.emato.system.mapper.SysConfigMapper;
  18. import org.slf4j.Logger;
  19. import org.slf4j.LoggerFactory;
  20. import org.springframework.beans.factory.annotation.Autowired;
  21. import org.springframework.stereotype.Service;
  22. import javax.servlet.http.HttpServletRequest;
  23. import java.sql.*;
  24. import java.util.ArrayList;
  25. import java.util.Date;
  26. import java.util.HashMap;
  27. import java.util.List;
  28. import java.util.Map;
  29. /**
  30. * CW推送数据接口
  31. */
  32. @Service
  33. public class SalesDetaiServicelImpl implements ISalesDetaiServicel {
  34. private final Logger logger = LoggerFactory.getLogger(SalesDetaiServicelImpl.class);
  35. @Autowired
  36. private InventoryDataMapper inventoryDataMapper;
  37. @Autowired
  38. private MallMngChangeMapper mallMngChangeMapper;
  39. @Autowired
  40. private SysConfigMapper configMapper;
  41. @Autowired
  42. private MerchantSecretMapper merchantSecretMapper;
  43. @Autowired
  44. private OmsUtils omsUtils;
  45. /**
  46. * kmall向eccs系统推送数据
  47. * @param newSystemFormatEntiy
  48. * @return
  49. */
  50. @Override
  51. public int pushSalesDetaiServicel(NewSystemFormatEntiy newSystemFormatEntiy) {
  52. return mallMngChangeMapper.pushSalesDetaiDate(newSystemFormatEntiy);
  53. }
  54. /**
  55. * 外部系统查询订单销售数据
  56. * @param msg
  57. * @return
  58. */
  59. @Override
  60. public Result getSalesDetaiData(JSONObject msg, HttpServletRequest httpServletRequest) {
  61. try {
  62. //校验签名
  63. Map<String, Object> weChatMapSalesMsg = JSONObject.toJavaObject(msg, Map.class);
  64. //签名验证
  65. String strSign = weChatMapSalesMsg.get("sign").toString().trim();
  66. String merchId = weChatMapSalesMsg.get("merchId").toString().trim()==null?"":weChatMapSalesMsg.get("merchId").toString().trim();
  67. String timestamp = weChatMapSalesMsg.get("timestamp").toString().trim()==null?"":weChatMapSalesMsg.get("timestamp").toString().trim();
  68. // String str = configMapper.getConfigValue("salesdetai").trim();
  69. if(StringUtils.isEmpty(merchId)){
  70. return Result.error("900051","merchId为空");
  71. }
  72. // 改为使用密钥配置
  73. MerchantSecret merchantSecret = new MerchantSecret();
  74. merchantSecret.setMerchSn(merchId);
  75. List<MerchantSecret> merchantSecrets = merchantSecretMapper.selectMerchantSecretList(merchantSecret);
  76. if (null == merchantSecrets || merchantSecrets.isEmpty()) {
  77. return Result.error("900051","merchId参数错误");
  78. }
  79. MerchantSecret MerchantSecret_2 = merchantSecrets.get(0);
  80. String str = MerchantSecret_2.getMd5Salt();
  81. if(StringUtils.isEmpty(timestamp)){
  82. return Result.error("900051","timestamp为空");
  83. }
  84. String md5CheckCode = checkType(weChatMapSalesMsg.get("data").toString(), timestamp, str);
  85. logger.debug("--- getSalesDetaiData md5CheckCode:", md5CheckCode);
  86. if (!strSign.trim().equals(md5CheckCode)) {
  87. return Result.error("900052", "签名错误");
  88. }
  89. Map<String, Object> weSalesMsg = JSONObject.toJavaObject(JSON.parseObject(weChatMapSalesMsg.get("data").toString()), Map.class);
  90. String starTime = (String) weSalesMsg.get("starTime");
  91. String endTime = (String) weSalesMsg.get("endTime");
  92. Integer pageIndex = Integer.parseInt(weSalesMsg.get("pageIndex")+"");
  93. pageIndex = pageIndex <= 1 ? 1 : pageIndex;
  94. Integer pageSize = Integer.parseInt(weSalesMsg.get("pageSize")+"");
  95. pageSize = pageSize <= 0 ? 1 : pageSize;
  96. pageSize = pageSize >= 500 ? 500 : pageSize;
  97. weSalesMsg.put("starTime", DateUtils.getStrDate((String) weSalesMsg.get("starTime")));
  98. weSalesMsg.put("endTime",DateUtils.getStrDate((String)weSalesMsg.get("endTime")));
  99. if(pageIndex>500){
  100. return Result.error("900053","请求总数或时间区间过大");
  101. }
  102. pageIndex = (pageIndex-1)*pageSize;
  103. weSalesMsg.put("offset",pageIndex);
  104. weSalesMsg.put("limit",pageSize);
  105. //记录调用参数接口日志
  106. long diff=(Long.parseLong(endTime) - Long.parseLong(starTime))/1000/60/60;
  107. if(diff<=24){
  108. pullQueryData(weChatMapSalesMsg);
  109. List<NewSystemFormatEntiy> list = mallMngChangeMapper.getSalesDetaiData(weSalesMsg);
  110. Integer total = mallMngChangeMapper.getTotalRecord(weSalesMsg);
  111. //desList = DesUtils.encode(JSON.toJSONString(list));
  112. if(list.size()==0){
  113. return Result.error("900054","该条件下无数据");
  114. }else{
  115. Map<String,Object> map = new HashMap<>();
  116. map.put("total",total);
  117. map.put("rows",list);
  118. return Result.success(map);
  119. }
  120. }else{
  121. return Result.error("900053","请求总数或时间区间过大");
  122. }
  123. }catch (Exception e){
  124. logger.error("外部系统查询订单销售数据错误="+ JSON.toJSONString(msg),e);
  125. return Result.error("900051","参数错误");
  126. }
  127. }
  128. /**
  129. * 记录外部调用接口参数,时间和调用方
  130. * @param msg
  131. */
  132. private void pullQueryData(Map msg) {
  133. Map<String,Object> map = new HashMap<>();
  134. map.put("tranDirection",msg.get("merchId"));
  135. map.put("msg",msg.toString());
  136. mallMngChangeMapper.pullQueryData(map);
  137. }
  138. /**
  139. * 插入来源于oms的库存数据
  140. * @param inventoryDataVo
  141. */
  142. @Override
  143. public Result inserInventory(InventoryDataVo inventoryDataVo) {
  144. try{
  145. logger.error("插入来源于oms的库存数据");
  146. //查询是否存在该库存信息
  147. Integer checkStuts = inventoryDataMapper.queryOneInventory(inventoryDataVo);
  148. if(checkStuts>0){
  149. inventoryDataMapper.updateInventory(inventoryDataVo);
  150. }else{
  151. inventoryDataMapper.inserInventory(inventoryDataVo);
  152. }
  153. return Result.success();
  154. }catch (Exception e){
  155. logger.error("插入来源于oms的库存数据"+JSON.toJSONString(inventoryDataVo),e);
  156. return Result.error("1001","数据插入出错");
  157. }
  158. }
  159. /**
  160. * 查询库存数据提供给外部系统
  161. * @param msg
  162. * @param httpServletRequest
  163. * @return
  164. */
  165. @Override
  166. public Result queryInventory(JSONObject msg, HttpServletRequest httpServletRequest) {
  167. try{
  168. //校验签名
  169. Map<String, Object> weChatMapMsg = JSONObject.toJavaObject(msg, Map.class);
  170. //签名验证
  171. String strSign = weChatMapMsg.get("sign").toString().trim();
  172. String merchId = weChatMapMsg.get("merchId").toString().trim()==null?"":weChatMapMsg.get("merchId").toString().trim();
  173. String timestamp = weChatMapMsg.get("timestamp").toString().trim()==null?"":weChatMapMsg.get("timestamp").toString().trim();
  174. // String str = configMapper.getConfigValue("inventory");
  175. if(StringUtils.isEmpty(merchId)){
  176. return Result.error("900051","merchId为空");
  177. }
  178. // 改为使用密钥配置
  179. MerchantSecret merchantSecret = new MerchantSecret();
  180. merchantSecret.setMerchSn(merchId);
  181. List<MerchantSecret> merchantSecrets = merchantSecretMapper.selectMerchantSecretList(merchantSecret);
  182. if (null == merchantSecrets || merchantSecrets.isEmpty()) {
  183. return Result.error("900051","merchId参数错误");
  184. }
  185. MerchantSecret MerchantSecret_2 = merchantSecrets.get(0);
  186. String str = MerchantSecret_2.getMd5Salt();
  187. if(StringUtils.isEmpty(timestamp)){
  188. return Result.error("900051","timestamp为空");
  189. }
  190. String md5CheckCode = checkType(weChatMapMsg.get("data").toString(), timestamp, str);
  191. logger.debug("--- queryInventory md5CheckCode:", md5CheckCode);
  192. if (!strSign.trim().equals(md5CheckCode)) {
  193. return Result.error("900002", "签名错误");
  194. }
  195. Map<String, Object> weDtilMsg = JSONObject.toJavaObject(JSON.parseObject(weChatMapMsg.get("data").toString()), Map.class);
  196. Integer pageIndex = Integer.parseInt(weDtilMsg.get("pageIndex")+"");
  197. pageIndex = pageIndex <= 1 ? 1 : pageIndex;
  198. Integer pageSize = Integer.parseInt(weDtilMsg.get("pageSize")+"");
  199. pageSize = pageSize <= 0 ? 1 : pageSize;
  200. pageSize = pageSize >= 500 ? 500 : pageSize;
  201. pageIndex = (pageIndex-1)*pageSize;
  202. weChatMapMsg.put("offset",pageIndex);
  203. weChatMapMsg.put("limit",pageSize);
  204. weChatMapMsg.put("merchId",merchId);
  205. weChatMapMsg.put("sign",strSign);
  206. String merchSn = weDtilMsg.get("merchSn").toString().trim()==null?"":weDtilMsg.get("merchSn").toString().trim();
  207. if(merchSn.equals("")){
  208. return Result.error("900001","参数错误");
  209. }
  210. if(pageSize>3000){
  211. return Result.error("900003","请求数量过大");
  212. }
  213. pullQueryData(weChatMapMsg);
  214. // 数据查询
  215. //List<InventoryDataPushVo> list = inventoryDataMapper.getInventoryData(weChatMapMsg);
  216. List<InventoryDataPushVo> list = getOmsData(weDtilMsg,weChatMapMsg);
  217. Integer total = inventoryDataMapper.getInventoryTotal();
  218. if(list.size()==0){
  219. return Result.error("900004","该条件下无数据");
  220. }else{
  221. Map<String,Object> map = new HashMap<>();
  222. map.put("total",total);
  223. map.put("invTime",DateUtils.dateToStrLong(new Date()));
  224. map.put("rows",list);
  225. return Result.success(map);
  226. }
  227. }catch (Exception e){
  228. logger.error("外部系统查询库存系统条件="+JSON.toJSONString(msg),e);
  229. return Result.error("900001","参数错误");
  230. }
  231. }
  232. //签名加密校验
  233. public String checkType(String data,String timestamp,String sekey) {
  234. String sign = sekey+"data" + data + "timestamp" + timestamp;
  235. return Md5Utils.encryption(sign);
  236. }
  237. public List<InventoryDataPushVo> getOmsData(Map<String, Object> weDtilMsg,Map<String, Object> weChatMapMsg){
  238. String driver=omsUtils.getOmsDriver();
  239. String user=omsUtils.getOmsUser();
  240. String password=omsUtils.getOmsPassword();
  241. String url=omsUtils.getOmsUrl();
  242. List<InventoryDataPushVo> inventoryDataPushVos = null;
  243. try{
  244. //加载数据库驱动
  245. Class.forName(driver);
  246. //连接数据库
  247. Connection conn = DriverManager.getConnection(url,user,password);
  248. //创建Statement对象
  249. Statement stmt = conn.createStatement();
  250. String sql = "SELECT wmsi.merch_sn,ppr.prod_barcode,ppr.prod_name,wmsi.shop_sn,wim.valid_num,wmsi.shop_inve FROM wb_inve_mng wim LEFT JOIN pd_product_record ppr ON wim.sku = ppr.sku LEFT JOIN wb_merch_shop_inve wmsi ON wim.sku = wmsi.sku WHERE ppr.is_record = 1 AND ppr.is_valid = 0 AND wim.inve_status = 0 AND wim.is_valid = 0 AND wmsi.is_valid = 0 AND wim.merch_sn='"+weDtilMsg.get("merchSn")+"' limit "+weChatMapMsg.get("offset")+","+weChatMapMsg.get("limit")+"";
  251. //建立结果集
  252. ResultSet rs = stmt.executeQuery(sql);
  253. inventoryDataPushVos =convertList(rs);
  254. //关闭结果集
  255. rs.close();
  256. //关闭Statement对象
  257. stmt.close();
  258. //关闭数据库
  259. conn.close();
  260. }catch(Exception e){
  261. logger.error("查询oms库存数据出错");
  262. }
  263. return inventoryDataPushVos;
  264. }
  265. private static List<InventoryDataPushVo> convertList(ResultSet rs) throws SQLException {
  266. List<InventoryDataPushVo> list = new ArrayList();
  267. while (rs.next()) {
  268. InventoryDataPushVo inventoryDataPushVo = new InventoryDataPushVo();
  269. inventoryDataPushVo.setBarcode(rs.getString("prod_barcode"));
  270. inventoryDataPushVo.setProductName(rs.getString("prod_name"));
  271. inventoryDataPushVo.setShopSn(rs.getString("shop_sn"));
  272. inventoryDataPushVo.setShopInvent(rs.getInt("shop_inve"));
  273. inventoryDataPushVo.seteMatou(rs.getInt("valid_num"));
  274. list.add(inventoryDataPushVo);
  275. }
  276. return list;
  277. }
  278. }