ApiPayService.java 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313
  1. package com.kmall.api.service;
  2. import com.kmall.api.contants.Dict;
  3. import com.kmall.api.dao.*;
  4. import com.kmall.api.entity.*;
  5. import com.kmall.api.service.pay.wxpay.WxPayPropertiesBuilder;
  6. import com.kmall.common.entity.FormIdsEntity;
  7. import com.kmall.common.service.FormIdsService;
  8. import com.kmall.common.utils.Constant;
  9. import com.kmall.common.utils.DateUtils;
  10. import com.kmall.common.utils.MapUtils;
  11. import com.kmall.common.utils.wechat.WechatRefundApiResult;
  12. import com.kmall.common.utils.wechat.WechatUtil;
  13. import io.swagger.models.auth.In;
  14. import org.apache.log4j.Logger;
  15. import org.springframework.beans.factory.annotation.Autowired;
  16. import org.springframework.stereotype.Service;
  17. import org.springframework.transaction.annotation.Transactional;
  18. import java.math.BigDecimal;
  19. import java.util.*;
  20. /**
  21. * 小程序form_id收集Service实现类
  22. *
  23. * @author Scott
  24. * @email
  25. * @date 2017-12-16 15:32:50
  26. */
  27. @Service
  28. public class ApiPayService {
  29. private static Logger logger = Logger.getLogger(ApiPayService.class);
  30. @Autowired
  31. private ApiOrderService orderService;
  32. @Autowired
  33. private FormIdsService formIdsService;
  34. @Autowired
  35. private ApiGoodsGroupOpenDetailService apiGoodsGroupOpenDetailService;
  36. @Autowired
  37. private ApiGoodsGroupOpenService apiGoodsGroupOpenService;
  38. @Autowired
  39. private PayerChildOrderRealService payerChildOrderRealService;
  40. @Autowired
  41. private ApiOrderExceptionRecordMapper mallOrderExceptionRecordMapper;
  42. @Autowired
  43. private ApiOrderProcessRecordMapper orderProcessRecordMapper;
  44. @Autowired
  45. private ApiOrderRefundMapper mallOrderRefundMapper;
  46. @Autowired
  47. private ApiUserCouponMapper apiUserCouponMapper;
  48. @Autowired
  49. private ApiOrderGoodsMapper apiOrderGoodsMapper;
  50. @Autowired
  51. private ApiProductStoreRelaMapper apiProductStoreRelaMapper;
  52. @Transactional
  53. public void payPrepay(Map<Object, Object> resultObj, Map<String, Object> resultUn, String nonceStr, List<OrderVo> orderVoList) {
  54. String prepay_id = MapUtils.getString("prepay_id", resultUn);
  55. // 先生成paySign 参考https://pay.weixin.qq.com/wiki/doc/api/wxa/wxa_api.php?chapter=7_7&index=5
  56. //resultObj.put("appId", ResourceUtil.getConfigByName("wx.appId"));
  57. resultObj.put("appId", WxPayPropertiesBuilder.instance().getAppId());
  58. resultObj.put("timeStamp", DateUtils.timeToStr(System.currentTimeMillis() / 1000, DateUtils.DATE_TIME_PATTERN));
  59. resultObj.put("nonceStr", nonceStr);
  60. resultObj.put("package", "prepay_id=" + prepay_id);
  61. resultObj.put("signType", "MD5");
  62. //String paySign = WechatUtil.arraySign(resultObj, ResourceUtil.getConfigByName("wx.paySignKey"));
  63. String paySign = WechatUtil.arraySign(resultObj, WxPayPropertiesBuilder.instance().getPaySignKey());
  64. resultObj.put("paySign", paySign);
  65. for (OrderVo orderInfo: orderVoList) {
  66. // 业务处理
  67. orderInfo.setPay_id(prepay_id);
  68. orderInfo.setPay_status(Integer.parseInt(Dict.payStatus.item_1.getItem())); // 付款中
  69. orderInfo.setOrder_status(Integer.parseInt(Dict.orderStatus.item_100.getItem()));
  70. orderService.update(orderInfo);
  71. Map map = new HashMap();
  72. map.put("orderSn", orderInfo.getOrder_sn());
  73. List<PayerChildOrderRealEntity> list = payerChildOrderRealService.queryList(map);
  74. PayerChildOrderRealEntity entity = new PayerChildOrderRealEntity();
  75. entity.setGoodsBizType(orderInfo.getOrderBizType());
  76. entity.setOrderSn(orderInfo.getOrder_sn());
  77. entity.setMerchSn(orderInfo.getMerchSn());
  78. entity.setMerchOrderSn(orderInfo.getMerchOrderSn());
  79. entity.setPayNo(orderInfo.getPay_id());
  80. entity.setPayPrice(orderInfo.getActual_price());
  81. entity.setCreateTime(new Date());
  82. entity.setModTime(new Date());
  83. entity.setUserId(Integer.parseInt(orderInfo.getUser_id() + ""));
  84. if(list.size() == 0) {
  85. payerChildOrderRealService.save(entity);//记录微信返回的支付单与子订单信息
  86. }else{
  87. for (PayerChildOrderRealEntity payerChildOrderRealEntity:list) {
  88. entity.setId(payerChildOrderRealEntity.getId());
  89. payerChildOrderRealService.update(entity);
  90. }
  91. }
  92. FormIdsEntity formIdsEntity = formIdsService.getFormIdsByMerchOrderSn(orderInfo.getMerchOrderSn());
  93. if(formIdsEntity== null){
  94. // 保存form_id
  95. formIdsService.save(orderInfo.getUser_id(), prepay_id, 1, orderInfo.getMerchOrderSn());
  96. }else{
  97. FormIdsEntity formIds = new FormIdsEntity();
  98. formIds.setMerchOrderSn(orderInfo.getMerchOrderSn());
  99. formIds.setFormId(prepay_id);
  100. formIds.setId(formIdsEntity.getId());
  101. formIds.setValidNum(formIdsEntity.getValidNum()+1);
  102. formIdsService.releaseFormIds(formIds);
  103. }
  104. }
  105. }
  106. @Transactional
  107. public void notify(String out_trade_no,String total_fee,String transaction_id,String time_end) {
  108. // 业务处理
  109. List<OrderVo> orderVoList = orderService.queryObjectByMerchOrderSn(out_trade_no);
  110. List<OrderProcessRecordEntity> processRecordEntityList = new ArrayList<>();
  111. Date timeEnd = DateUtils.convertStringToDate(time_end,DateUtils.DATE_TIME_PATTERN_YYYY_MM_DD_HH_MM_SS);
  112. if(orderVoList != null && orderVoList.size()>0) {
  113. for(OrderVo orderInfo:orderVoList) {
  114. //校验返回的订单金额是否与商户侧的订单金额一致
  115. String actualPrice = String.valueOf(orderInfo.getActual_price().multiply(Constant.ONE_HUNDRED));
  116. if(!total_fee.equalsIgnoreCase(actualPrice)){//不一致
  117. MallOrderExceptionRecord mallOrderExceptionRecord = new MallOrderExceptionRecord();
  118. mallOrderExceptionRecord.setUserId(Integer.parseInt(orderInfo.getUser_id()+""));
  119. mallOrderExceptionRecord.setOrderSn(orderInfo.getOrder_sn());
  120. mallOrderExceptionRecord.setExceptionStatus(Dict.exceptionStatus.item_04.getItem());
  121. mallOrderExceptionRecord.setExceptionContent("微信支付回调返回的订单金额与商户订单金额不一致");
  122. mallOrderExceptionRecord.setCreateTime(new Date());
  123. mallOrderExceptionRecordMapper.save(mallOrderExceptionRecord);//支付订单异常记录
  124. }
  125. if(Dict.orderStatus.item_100.getItem().equalsIgnoreCase(orderInfo.getOrder_status()+"")
  126. && Dict.payStatus.item_1.getItem().equalsIgnoreCase(orderInfo.getPay_status()+"")){
  127. OrderProcessRecordEntity processRecordEntity = orderProcessRecordMapper.queryObjectByOrderSn(orderInfo.getOrder_sn());
  128. if(processRecordEntity != null){
  129. OrderProcessRecordEntity entity = new OrderProcessRecordEntity();
  130. entity.setOrderSn(orderInfo.getOrder_sn());
  131. entity.setUserId(Integer.valueOf(orderInfo.getUser_id()+""));
  132. entity.setId(processRecordEntity.getId());
  133. entity.setPaySuccTime(timeEnd);//微信下单完成时间
  134. entity.setIsPaymentSend(Dict.isSend.item_1.getItem());
  135. processRecordEntityList.add(entity);
  136. }
  137. orderInfo.setPayTransactionId(transaction_id);
  138. orderInfo.setPay_status(Integer.parseInt(Dict.payStatus.item_2.getItem()));
  139. orderInfo.setPay_time(timeEnd);//微信下单完成时间
  140. if (orderInfo.getOrder_status() == Integer.parseInt(Dict.orderStatus.item_100.getItem())) {
  141. orderInfo.setOrder_status(Integer.parseInt(Dict.orderStatus.item_201.getItem()));
  142. }
  143. orderService.update(orderInfo);
  144. orderProcessRecordMapper.updateBatch(processRecordEntityList);//更新订单流转信息
  145. /*// 处理团购 todo 一期不实现团购
  146. if (null != orderInfo.getOrder_type() && orderInfo.getOrder_type().equals("2")) {
  147. GoodsGroupOpenDetailVo openDetailVo = apiGoodsGroupOpenDetailService.queryObject(orderInfo.getActivity_id());
  148. if (null != openDetailVo) {
  149. openDetailVo.setAttend_status(1);
  150. apiGoodsGroupOpenDetailService.update(openDetailVo);
  151. }
  152. GoodsGroupOpenVo openVo = apiGoodsGroupOpenService.queryObject(openDetailVo.getOpen_id());
  153. openVo.setAttend_num(openVo.getAttend_num() + 1);
  154. if (openVo.getMin_open_group() <= openVo.getAttend_num()) { // 一人拼团,直接结束
  155. openVo.setAttend_status(2);
  156. Map param = new HashMap();
  157. param.put("open_id", openDetailVo.getOpen_id());
  158. apiGoodsGroupOpenDetailService.updateComplete(param);
  159. } else {
  160. openVo.setAttend_status(1);
  161. }
  162. apiGoodsGroupOpenService.update(openVo);
  163. }*/
  164. // 微信支付成功通知
  165. orderService.notifyPaySuccess(orderInfo);
  166. /* // 打印机打印 todo 后台打印小票
  167. try {
  168. orderService.printMsg(orderInfo.getId());
  169. } catch (Exception e) {
  170. logger.error("打印机打印异常【" + e.getMessage() + "】");
  171. }*/
  172. }
  173. }
  174. }
  175. }
  176. /* *//**
  177. * 退款
  178. * @param
  179. *//*
  180. @Transactional
  181. public void refund(OrderVo orderInfo,WechatRefundApiResult result,String reason) {
  182. boolean needUpdateStock = true;
  183. if (orderInfo.getOrder_status() == Integer.parseInt(Dict.orderStatus.item_300.getItem())) {
  184. orderInfo.setOrder_status(Integer.parseInt(Dict.orderStatus.item_402.getItem()));
  185. } else if (orderInfo.getOrder_status() == Integer.parseInt(Dict.orderStatus.item_301.getItem())) {
  186. orderInfo.setOrder_status(Integer.parseInt(Dict.orderStatus.item_402.getItem()));
  187. } else if (orderInfo.getOrder_status() == Integer.parseInt(Dict.orderStatus.item_201.getItem())) {
  188. orderInfo.setOrder_status(Integer.parseInt(Dict.orderStatus.item_401.getItem()));
  189. } else {
  190. orderInfo.setOrder_status(Integer.parseInt(Dict.orderStatus.item_101.getItem()));
  191. }
  192. orderInfo.setPay_status(Integer.parseInt(Dict.payStatus.item_4.getItem()));
  193. // 判断是否有优惠券
  194. UserCouponVo couponVo = apiUserCouponMapper.queryByOrderId(orderInfo.getId());
  195. if (null != couponVo) {
  196. apiUserCouponMapper.cancelOrder(couponVo);
  197. }
  198. orderService.update(orderInfo);
  199. MallOrderRefund mallOrderRefund = mallOrderRefundMapper.queryObjectByOrderId(orderInfo.getId()+"");
  200. MallOrderRefund orderRefund = new MallOrderRefund();
  201. orderRefund.setRefundId(result.getRefund_id());
  202. orderRefund.setRefundType(Integer.parseInt(Dict.RefundType.item_1.getItem()));
  203. orderRefund.setOutRefundNo(result.getOut_refund_no());
  204. orderRefund.setRefundMoney(BigDecimal.valueOf(Long.valueOf(result.getRefund_fee())).divide(Constant.ONE_HUNDRED));
  205. orderRefund.setRefundStatus(Integer.parseInt(Dict.RefundStatus.item_2.getItem()));
  206. orderRefund.setModTime(new Date());
  207. if(mallOrderRefund !=null){
  208. orderRefund.setId(mallOrderRefund.getId());
  209. mallOrderRefundMapper.update(orderRefund);
  210. }else{
  211. orderRefund.setOrderId(Integer.parseInt(orderInfo.getId()+""));
  212. orderRefund.setUserId(Integer.parseInt(orderInfo.getUser_id()+""));
  213. orderRefund.setRefundReason(reason);
  214. orderRefund.setCreateTime(new Date());
  215. mallOrderRefundMapper.save(orderRefund);//退款记录
  216. }
  217. if (!needUpdateStock) {
  218. return;
  219. }
  220. // 更新库存
  221. Map<String, Object> map = new HashMap<String, Object>();
  222. map.put("order_id", orderInfo.getId());
  223. List<OrderGoodsVo> orderGoodsVoList = apiOrderGoodsMapper.queryList(map);
  224. for (OrderGoodsVo orderGoodsEntity : orderGoodsVoList) {
  225. ProductStoreRelaVo storeRelaEntity = apiProductStoreRelaMapper.queryByStoreIdProductId(Long.valueOf(orderInfo.getStore_id()), Long.valueOf(orderGoodsEntity.getProduct_id()));
  226. if (null == storeRelaEntity || null == storeRelaEntity.getSellVolume()) {
  227. storeRelaEntity.setSellVolume(0);
  228. }
  229. BigDecimal sellVolume = new BigDecimal(storeRelaEntity.getSellVolume()).subtract(new BigDecimal(orderGoodsEntity.getNumber()));//销售量
  230. if (sellVolume.compareTo(Constant.ZERO) < 0) {
  231. sellVolume = Constant.ZERO;
  232. }
  233. storeRelaEntity.setSellVolume(Integer.parseInt(String.valueOf(sellVolume)));
  234. if (null == storeRelaEntity.getStockNum()) {
  235. storeRelaEntity.setStockNum(0);
  236. }
  237. storeRelaEntity.setStockNum(storeRelaEntity.getStockNum() + orderGoodsEntity.getNumber());//库存数量
  238. apiProductStoreRelaMapper.update(storeRelaEntity);
  239. }
  240. }*/
  241. @Transactional
  242. public void refundNotify(WechatRefundApiResult refundApiResult) {
  243. String success_time = refundApiResult.getSuccess_time();
  244. String out_trade_no = refundApiResult.getOut_trade_no();//商户订单号
  245. // 业务处理
  246. List<OrderVo> orderVoList = orderService.queryOrderByMerchOrderSnAndRefundStatus(out_trade_no);
  247. Date successTime = DateUtils.strToDate(success_time);
  248. if(orderVoList != null && orderVoList.size()>0) {
  249. for(OrderVo orderInfo:orderVoList) {
  250. if(orderInfo.getOrder_status() == Integer.parseInt(Dict.orderStatus.item_201.getItem())
  251. || orderInfo.getOrder_status() == Integer.parseInt(Dict.orderStatus.item_401.getItem())){
  252. MallOrderRefund mallOrderRefund = mallOrderRefundMapper.queryObjectByOrderId(orderInfo.getId()+"");
  253. MallOrderRefund orderRefund = new MallOrderRefund();
  254. if(mallOrderRefund != null){
  255. orderRefund.setRefundTime(successTime);//退款成功时间
  256. orderRefund.setOutRefundNo(refundApiResult.getOut_refund_no());
  257. orderRefund.setRefundId(refundApiResult.getRefund_id());
  258. orderRefund.setRefundMoney(BigDecimal.valueOf(Long.valueOf(refundApiResult.getRefund_fee())).divide(Constant.ONE_HUNDRED));
  259. if (refundApiResult.getRefund_status().equalsIgnoreCase("SUCCESS")) {
  260. orderRefund.setRefundStatus(Integer.parseInt(Dict.RefundStatus.item_2.getItem()));
  261. orderRefund.setWechatRefundStatusDes("退款成功");
  262. } else if (refundApiResult.getRefund_status().equalsIgnoreCase("REFUNDCLOSE")) {
  263. orderRefund.setRefundStatus(Integer.parseInt(Dict.RefundStatus.item_4.getItem()));
  264. orderRefund.setWechatRefundStatusDes("退款关闭");
  265. } else if (refundApiResult.getRefund_status().equalsIgnoreCase("PROCESSING")) {
  266. orderRefund.setRefundStatus(Integer.parseInt(Dict.RefundStatus.item_5.getItem()));
  267. orderRefund.setWechatRefundStatusDes("退款处理中");
  268. } else if (refundApiResult.getRefund_status().equalsIgnoreCase("CHANGE")) {
  269. orderRefund.setRefundStatus(Integer.parseInt(Dict.RefundStatus.item_4.getItem()));
  270. orderRefund.setWechatRefundStatusDes("退款异常");
  271. }
  272. orderRefund.setRefundRecvAccout(refundApiResult.getRefund_recv_accout());
  273. orderRefund.setId(mallOrderRefund.getId());
  274. mallOrderRefundMapper.update(orderRefund);//更新订单退款信息
  275. OrderVo orderVo = new OrderVo();
  276. orderVo.setPay_status(Integer.parseInt(Dict.payStatus.item_4.getItem()));
  277. orderVo.setOrder_status(Integer.parseInt(Dict.orderStatus.item_401.getItem()));
  278. orderVo.setId(orderInfo.getId());
  279. orderService.update(orderVo);
  280. }
  281. }
  282. }
  283. }
  284. }
  285. }