admin
2020-04-13 dd5b15229cb15459fa7c31ccea77dac28cbfafbd
fanli/src/main/java/com/yeshi/fanli/job/order/jd/UpdateJDOrderJob.java
@@ -12,8 +12,13 @@
import com.yeshi.fanli.dto.jd.JDOrderResult;
import com.yeshi.fanli.entity.jd.JDOrder;
import com.yeshi.fanli.exception.jd.JDOrderException;
import com.yeshi.fanli.service.inter.jd.JDOrderService;
import com.yeshi.fanli.log.LogHelper;
import com.yeshi.fanli.service.inter.order.jd.JDOrderService;
import com.yeshi.fanli.util.Constant;
import com.yeshi.fanli.util.RedisKeyEnum;
import com.yeshi.fanli.util.RedisManager;
import com.yeshi.fanli.util.StringUtil;
import com.yeshi.fanli.util.TimeUtil;
import com.yeshi.fanli.util.cmq.JDOrderCMQManager;
import com.yeshi.fanli.util.jd.JDApiUtil;
@@ -34,18 +39,28 @@
    */
   public void saveJDOrders(List<JDOrder> jdOrderList) {
      for (JDOrder order : jdOrderList) {
         if (order.getValidCode() == 15)// 过滤掉代付款状态
         LogHelper.orderInfo("京东订单:" + order.getOrderId() + "-" + order.getValidCode());
         if (order.getValidCode() == 15)// 过滤掉待付款
            continue;
         // 防止多个商品拆单问题,爬取
         if (order.getOrderItemList().size() > 1
               && order.getOrderTime() > System.currentTimeMillis() - 1000 * 60 * 3L) {
            continue;
         }
         try {
            jdOrderService.addJDOrder(order);
            /**
             * 做频率限制
             */
            String key = "jd-order-" + order.getOrderId();
            String key = RedisKeyEnum.getRedisKey(RedisKeyEnum.JDOrder, order.getOrderId() + "");
            String result = redisManager.getCommonString(key);
            JDOrderCMQManager.getInstance().addJDOrder(order.getOrderId() + "");
            redisManager.cacheCommonString(key, "1", 60 * 60 * 2);// 2小时内不再更新
            // 判断
            if (StringUtil.isNullOrEmpty(result)) {
               JDOrderCMQManager.getInstance().addJDOrder(order.getOrderId() + "");
               redisManager.cacheCommonString(key, "1", 60 * 60 * 2);// 2小时内不再更新
            }
         } catch (JDOrderException e) {
            e.printStackTrace();
         }
@@ -57,15 +72,16 @@
    */
   @Scheduled(cron = "0 0/1 * * * ? ")
   public void updateSoonOrder() {
      // if (!Constant.IS_TASK)
      // return;
      if (!Constant.IS_TASK)
         return;
      LogHelper.job("开始爬取京东订单");
      long now = System.currentTimeMillis();
      JDOrderResult result = JDApiUtil.getOrderList(1, 200, new Date(now), JDApiUtil.ORDER_TYPE_CREATETIME);
      if (result != null && result.getOrderList() != null)
         saveJDOrders(result.getOrderList());
      // 查询上个小时的
      result = JDApiUtil.getOrderList(1, 200, new Date(now - 1000 * 60 * 60 * 24L), JDApiUtil.ORDER_TYPE_CREATETIME);
      result = JDApiUtil.getOrderList(1, 200, new Date(now - 1000 * 60 * 60L), JDApiUtil.ORDER_TYPE_CREATETIME);
      if (result != null && result.getOrderList() != null)
         saveJDOrders(result.getOrderList());
   }
@@ -75,8 +91,8 @@
    */
   @Scheduled(cron = "0 0/10 * * * ? ")
   public void updateUpdateOrder() {
      // if (!Constant.IS_TASK)
      // return;
      if (!Constant.IS_TASK)
         return;
      List<JDOrder> jdOrderList = new ArrayList<>();
      int pageSize = 200;
      int page = 1;
@@ -92,4 +108,60 @@
      saveJDOrders(jdOrderList);
   }
   /**
    * 更新一个小时的订单
    *
    * @param date
    */
   private List<JDOrder> getHourOrder(Date date) {
      List<JDOrder> jdOrderList = new ArrayList<>();
      int pageSize = 200;
      int page = 1;
      JDOrderResult result = JDApiUtil.getOrderList(page++, pageSize, date, JDApiUtil.ORDER_TYPE_UPDATETIME);
      if (result != null) {
         jdOrderList.addAll(result.getOrderList());
         while (result != null && result.isHasMore()) {
            result = JDApiUtil.getOrderList(page++, pageSize, date, JDApiUtil.ORDER_TYPE_UPDATETIME);
            if (result != null)
               jdOrderList.addAll(result.getOrderList());
         }
      }
      return jdOrderList;
   }
   /**
    * 更新一天的数据
    *
    * @param date
    */
   public void updateDayOrder(Date date) {
      Date now = new Date();
      List<JDOrder> orderList = new ArrayList<>();
      Date startTime = new Date(
            TimeUtil.convertToTimeTemp(TimeUtil.getGernalTime(date.getTime(), "yyyy-MM-dd"), "yyyy-MM-dd"));
      // 一个小时为一个步长
      for (int i = 0; i < 24; i++) {
         Date da = new Date(startTime.getTime() + 1000 * 60 * 60L * i);
         if (da.getTime() > now.getTime())
            break;
         List<JDOrder> tempOrderList = getHourOrder(da);
         if (tempOrderList != null && tempOrderList.size() > 0)
            orderList.addAll(tempOrderList);
      }
      saveJDOrders(orderList);
   }
   /**
    * 更新最近3天的订单(每天早上凌晨0点过10分,早上8点过10分)
    */
   @Scheduled(cron = "0 10 0,8 * * ? ")
   public void updateLatest3DayOrder() {
      if (!Constant.IS_TASK)
         return;
      Date now = new Date();
      for (int i = 1; i < 4; i++) {
         updateDayOrder(new Date(now.getTime() - 1000 * 60 * 60 * 24L * i));
      }
   }
}