From 3824cbcaec6e6c67418d5280a53e9c2fedeef6f9 Mon Sep 17 00:00:00 2001 From: admin <weikou2014> Date: 星期四, 11 七月 2019 16:34:13 +0800 Subject: [PATCH] 订单bug,分享爆款自购修改 --- fanli/src/main/java/com/yeshi/fanli/job/UpdateOrderJob.java | 201 ++++++++++++++++++++++++++++++-------------------- 1 files changed, 120 insertions(+), 81 deletions(-) diff --git a/fanli/src/main/java/com/yeshi/fanli/job/UpdateOrderJob.java b/fanli/src/main/java/com/yeshi/fanli/job/UpdateOrderJob.java index 495afa7..15e72e0 100644 --- a/fanli/src/main/java/com/yeshi/fanli/job/UpdateOrderJob.java +++ b/fanli/src/main/java/com/yeshi/fanli/job/UpdateOrderJob.java @@ -1,6 +1,7 @@ package com.yeshi.fanli.job; import java.util.ArrayList; +import java.util.Calendar; import java.util.Date; import java.util.Iterator; import java.util.List; @@ -11,21 +12,17 @@ import org.springframework.scheduling.annotation.Scheduled; import org.springframework.stereotype.Component; +import com.yeshi.fanli.entity.bus.user.LostOrder; import com.yeshi.fanli.entity.bus.user.Order; import com.yeshi.fanli.entity.taobao.PidUser; import com.yeshi.fanli.entity.taobao.TaoBaoOrder; import com.yeshi.fanli.entity.taobao.TaoBaoUnionConfig; import com.yeshi.fanli.entity.taobao.TaoBaoWeiQuanOrder; -import com.yeshi.fanli.exception.TaoBaoOrderException; import com.yeshi.fanli.log.LogHelper; import com.yeshi.fanli.service.inter.common.DataMonitorService; -import com.yeshi.fanli.service.inter.hongbao.HongBaoService; -import com.yeshi.fanli.service.inter.hongbao.ThreeSaleGiftService; import com.yeshi.fanli.service.inter.order.LostOrderService; -import com.yeshi.fanli.service.inter.order.OrderItemServcie; import com.yeshi.fanli.service.inter.order.OrderProcessService; import com.yeshi.fanli.service.inter.order.OrderService; -import com.yeshi.fanli.service.inter.order.PidOrderService; import com.yeshi.fanli.service.inter.taobao.TaoBaoOrderService; import com.yeshi.fanli.service.inter.taobao.TaoBaoUnionConfigService; import com.yeshi.fanli.service.inter.taobao.TaoBaoWeiQuanOrderService; @@ -33,6 +30,7 @@ import com.yeshi.fanli.util.Constant; import com.yeshi.fanli.util.RedisManager; import com.yeshi.fanli.util.StringUtil; +import com.yeshi.fanli.util.TaoBaoConstant; import com.yeshi.fanli.util.TimeUtil; import com.yeshi.fanli.util.taobao.TaoBaoOrderUtil; import com.yeshi.fanli.util.taobao.TaoKeOrderApiUtil; @@ -44,18 +42,6 @@ public UpdateOrderJob() { System.out.println("鍒濆鍖�:UpdateOrderJob"); } - - @Resource - private OrderItemServcie orderItemServcie; - - @Resource - private ThreeSaleGiftService threeSaleGiftService; - - @Resource - private HongBaoService hongBaoService; - - @Resource - private PidOrderService pidOrderService; @Resource private OrderProcessService orderProcessService; @@ -95,19 +81,20 @@ int page = 1; String startTimeStr = TimeUtil.getGernalTime(startTime, "yyyy-MM-dd HH:mm:ss"); List<TaoBaoOrder> orderList = TaoKeOrderApiUtil.getTaoBaoAllOrder(startTimeStr, span, page, - Constant.TAOBAO_AUTH_APPKEY, Constant.TAOBAO_AUTH_APPSECRET); + TaoBaoConstant.TAOBAO_AUTH_APPKEY, TaoBaoConstant.TAOBAO_AUTH_APPSECRET); while (orderList.size() == 100 * page) { page++; List<TaoBaoOrder> tempOrderList = TaoKeOrderApiUtil.getTaoBaoAllOrder(startTimeStr, span, page, - Constant.TAOBAO_AUTH_APPKEY, Constant.TAOBAO_AUTH_APPSECRET); + TaoBaoConstant.TAOBAO_AUTH_APPKEY, TaoBaoConstant.TAOBAO_AUTH_APPSECRET); if (tempOrderList != null && tempOrderList.size() > 0) orderList.addAll(tempOrderList); } return orderList; } - + /** * 鑾峰彇绗笁鏂规櫘閫氳鍗� + * * @param startTime * @param span * @return @@ -116,11 +103,11 @@ int page = 1; String startTimeStr = TimeUtil.getGernalTime(startTime, "yyyy-MM-dd HH:mm:ss"); List<TaoBaoOrder> orderList = TaoKeOrderApiUtil.getTaoBaoThirdAllOrder(startTimeStr, span, page, - Constant.TAOBAO_AUTH_APPKEY, Constant.TAOBAO_AUTH_APPSECRET); + TaoBaoConstant.TAOBAO_AUTH_APPKEY, TaoBaoConstant.TAOBAO_AUTH_APPSECRET); while (orderList.size() == 100 * page) { page++; List<TaoBaoOrder> tempOrderList = TaoKeOrderApiUtil.getTaoBaoThirdAllOrder(startTimeStr, span, page, - Constant.TAOBAO_AUTH_APPKEY, Constant.TAOBAO_AUTH_APPSECRET); + TaoBaoConstant.TAOBAO_AUTH_APPKEY, TaoBaoConstant.TAOBAO_AUTH_APPSECRET); if (tempOrderList != null && tempOrderList.size() > 0) orderList.addAll(tempOrderList); } @@ -129,13 +116,14 @@ /** * 鑾峰彇鏌愪釜鍖洪棿娈电殑璁㈠崟 + * * @param startTime * @param endTime * @return */ public static List<TaoBaoOrder> getCommonOrder(long startTime, long endTime) { List<TaoBaoOrder> orderList = new ArrayList<>(); - long span =(endTime - startTime)%1000==0? (endTime - startTime)/1000:(endTime - startTime)/1000+1; + long span = (endTime - startTime) % 1000 == 0 ? (endTime - startTime) / 1000 : (endTime - startTime) / 1000 + 1; int count = (int) (span / 1200); if (span % 1200 != 0) count++; @@ -153,17 +141,17 @@ } return orderList; } - - + /** * 鐖彇涓夋柟璁㈠崟 + * * @param startTime * @param endTime * @return */ public static List<TaoBaoOrder> getThirdCommonOrder(long startTime, long endTime) { List<TaoBaoOrder> orderList = new ArrayList<>(); - long span =(endTime - startTime)%1000==0? (endTime - startTime)/1000:(endTime - startTime)/1000+1; + long span = (endTime - startTime) % 1000 == 0 ? (endTime - startTime) / 1000 : (endTime - startTime) / 1000 + 1; int count = (int) (span / 1200); if (span % 1200 != 0) count++; @@ -200,36 +188,38 @@ } public void updateOrder(long startTime, long endTime) { -// 鑰佺増鏈鐞嗘柟寮� - List<TaoBaoUnionConfig> configList = taoBaoUnionConfigService.getConfigByTypeCache(PidUser.TYPE_FANLI_ANDROID); - List<TaoBaoOrder> orderList = new ArrayList<>(); - try { - orderList = TaoBaoOrderUtil.getOrderList(startTime, endTime, configList.get(0)); - } catch (TaoBaoOrderException e2) { - try { - LogHelper.errorDetailInfo(e2); - } catch (Exception e) { - e.printStackTrace(); - } - } - List<TaoBaoOrder> thirdOrderList = new ArrayList<>(); - try { - thirdOrderList = TaoBaoOrderUtil.getThirdServiceOrderList(startTime, endTime, configList.get(0)); - } catch (TaoBaoOrderException e2) { - try { - LogHelper.errorDetailInfo(e2); - } catch (Exception e) { - e.printStackTrace(); - } - } - if (thirdOrderList != null && thirdOrderList.size() > 0) - orderList.addAll(thirdOrderList); -//鏂扮増鏈鐞嗘柟寮� -// List<TaoBaoOrder> orderList= getCommonOrder(startTime, endTime); -// List<TaoBaoOrder> tempOrderList2=getThirdCommonOrder(startTime, endTime); -// if(tempOrderList2!=null&&tempOrderList2.size()>0) -// orderList.addAll(tempOrderList2); - + // 鑰佺増鏈鐞嗘柟寮� + // List<TaoBaoUnionConfig> configList = + // taoBaoUnionConfigService.getConfigByTypeCache(PidUser.TYPE_FANLI_ANDROID); + // List<TaoBaoOrder> orderList = new ArrayList<>(); + // try { + // orderList = TaoBaoOrderUtil.getOrderList(startTime, endTime, + // configList.get(0)); + // } catch (TaoBaoOrderException e2) { + // try { + // LogHelper.errorDetailInfo(e2); + // } catch (Exception e) { + // e.printStackTrace(); + // } + // } + // List<TaoBaoOrder> thirdOrderList = new ArrayList<>(); + // try { + // thirdOrderList = TaoBaoOrderUtil.getThirdServiceOrderList(startTime, + // endTime, configList.get(0)); + // } catch (TaoBaoOrderException e2) { + // try { + // LogHelper.errorDetailInfo(e2); + // } catch (Exception e) { + // e.printStackTrace(); + // } + // } + // if (thirdOrderList != null && thirdOrderList.size() > 0) + // orderList.addAll(thirdOrderList); + // 鏂扮増鏈鐞嗘柟寮� + List<TaoBaoOrder> orderList = getCommonOrder(startTime, endTime); + List<TaoBaoOrder> tempOrderList2 = getThirdCommonOrder(startTime, endTime); + if (tempOrderList2 != null && tempOrderList2.size() > 0) + orderList.addAll(tempOrderList2); LogHelper.orderInfo("姝e湪鎵ц璁㈠崟鐖彇缁撴潫锛屽叡鏈夎鍗�:" + orderList.size()); addOrder(orderList); @@ -276,7 +266,7 @@ return orderList; } - private void addOrder(List<TaoBaoOrder> orderList) { + public void addOrder(List<TaoBaoOrder> orderList) { if (orderList != null) for (int i = 0; i < orderList.size(); i++) { @@ -303,11 +293,8 @@ try { taoBaoOrderService.addTaoBaoOrderList(orderList); } catch (Exception e) { - try { - LogHelper.errorDetailInfo(e); - } catch (Exception e1) { - e1.printStackTrace(); - } + LogHelper.errorDetailInfo(e); + } try { @@ -339,20 +326,16 @@ } } } catch (Exception e) { - try { - LogHelper.errorDetailInfo(e); - } catch (Exception e1) { - e1.printStackTrace(); - } + LogHelper.errorDetailInfo(e); } } // 姣�15鍒嗛挓鐖彇涓�娆� -// @Scheduled(cron = "0 0/15 * * * ? ") + @Scheduled(cron = "0 0/15 * * * ? ") public void doJob1() { -// if (!Constant.IS_TASK) -// return; - long currentTime = System.currentTimeMillis(); + if (!Constant.IS_TASK) + return; + long currentTime = System.currentTimeMillis() - 1000 * 60; String h = TimeUtil.getGernalTime(currentTime, "HH"); String m = TimeUtil.getGernalTime(currentTime, "mm"); int mm = Integer.parseInt(h) * 60 + Integer.parseInt(m); @@ -371,8 +354,9 @@ public void doJob6() { if (!Constant.IS_TASK) return; - long endTime=System.currentTimeMillis(); - updateOrder(endTime-1000*60*20L, endTime); + long endTime = System.currentTimeMillis() - 1000 * 60; + ; + updateOrder(endTime - 1000 * 60 * 20L, endTime); } // 杩斿埄 @@ -409,18 +393,73 @@ orderProcessService.weiQuanOrder(orderList); } - // 澶勭悊鍒嗕韩鍟嗗搧鎵�浜х敓鐨勮鍗�(鍚庣画鐗堟湰搴熼櫎) - // @Scheduled(cron = "0 0/2 * * * ? ") - // public void doPidOrder() { - // if (!Constant.IS_TASK) - // return; - // pidOrderService.doPidOrder(); - // } - // 姣�6涓皬鏃舵墽琛屼竴娆� @Scheduled(cron = "0 0 0/6 * * ? ") public void doLostOrder() { + if (!Constant.IS_TASK) + return; lostOrderService.processFail(); } + // 姣�2鍒嗛挓鎵ц涓�娆� + @Scheduled(cron = "0 0/2 * * * ? ") + public void addLostOrder() { + if (!Constant.IS_TASK) + return; + LogHelper.test("澶勭悊涓㈠け璁㈠崟"); + List<LostOrder> list = lostOrderService.listByStateAndResultCode(LostOrder.STATE_PASS, + LostOrder.RESULT_CODE_VERFING, 1, 50); + if (list != null) + for (LostOrder lo : list) { + List<TaoBaoOrder> taoBaoOrderList = taoBaoOrderService.getTaoBaoOrderByOrderId(lo.getOrderId()); + // 娓呴櫎棰戠巼闄愬埗 + if (taoBaoOrderList != null && taoBaoOrderList.size() > 0) { + String key = "addorderqueue-" + lo.getOrderId(); + redisManager.removeCommonString(key); + addOrder(taoBaoOrderList); + LogHelper.test("鑷姩澶勭悊娣樺疂璁㈠崟:" + lo.getOrderId()); + } + } + } + + /** + * 澶勭悊娣樺疂缁撶畻璁㈠崟,30fen鎵ц涓�娆� + */ + @Scheduled(cron = "30 0 0/1 * * ? ") + public void doSettleOrders() { + if (!Constant.IS_TASK) + return; + // 澶勭悊3-15澶╁墠鐨勮鍗曪紝姣忓ぉ璺戜竴娆� + Calendar ca = Calendar.getInstance(); + int hour = ca.get(Calendar.HOUR_OF_DAY); + + long startTime = TimeUtil.convertToTimeTemp( + TimeUtil.getGernalTime(ca.getTimeInMillis() - 1000 * 60 * 60 * 24 * 3L, "yyyy-MM-dd"), "yyyy-MM-dd") + - hour * (1000 * 60 * 60 * 12L); + long endTime = startTime + 1000 * 60 * 60 * 12L; + List<TaoBaoOrder> orderList = TaoKeOrderApiUtil.getTaoBaoSettleOrders(startTime, endTime, false); + List<TaoBaoOrder> tempOrderList = TaoKeOrderApiUtil.getTaoBaoSettleOrders(startTime, endTime, true); + if (tempOrderList != null && tempOrderList.size() > 0) + orderList.addAll(tempOrderList); + addOrder(orderList); + } + + /** + * 13鍒嗛挓鏇存柊鏈�杩�13鍒嗛挓鐨勭粨绠楁暟鎹� + */ + @Scheduled(cron = "0 0/13 * * * ? ") + public void doSettleOrdersToday() { + if (!Constant.IS_TASK) + return; + // 澶勭悊3-15澶╁墠鐨勮鍗曪紝姣忓ぉ璺戜竴娆� + Calendar ca = Calendar.getInstance(); + long startTime = ca.getTimeInMillis() - 1000 * 60 * 5L - 1000 * 60 * 13L; + long endTime = startTime + 1000 * 60 * 13L; + List<TaoBaoOrder> orderList = TaoKeOrderApiUtil.getTaoBaoSettleOrders(startTime, endTime, false); + List<TaoBaoOrder> tempOrderList = TaoKeOrderApiUtil.getTaoBaoSettleOrders(startTime, endTime, true); + if (tempOrderList != null && tempOrderList.size() > 0) + orderList.addAll(tempOrderList); + addOrder(orderList); + } + } -- Gitblit v1.8.0