From 0c78c7aaeaa5a427bc8a5c5faf3cd6bbb589c2da Mon Sep 17 00:00:00 2001 From: yujian <yujian@123.com> Date: 星期二, 08 十月 2019 12:08:38 +0800 Subject: [PATCH] map 改造 --- fanli/src/main/java/com/yeshi/fanli/util/jd/JDUtil.java | 139 ++++++++++++++++++++++++++++++++++++++++++++++ 1 files changed, 138 insertions(+), 1 deletions(-) diff --git a/fanli/src/main/java/com/yeshi/fanli/util/jd/JDUtil.java b/fanli/src/main/java/com/yeshi/fanli/util/jd/JDUtil.java index 9ec8560..87870ae 100644 --- a/fanli/src/main/java/com/yeshi/fanli/util/jd/JDUtil.java +++ b/fanli/src/main/java/com/yeshi/fanli/util/jd/JDUtil.java @@ -26,6 +26,7 @@ import org.yeshi.utils.BigDecimalUtil; import org.yeshi.utils.HttpUtil; +import com.yeshi.fanli.dto.GoodsClassDTO; import com.yeshi.fanli.dto.jd.JDCommissionInfo; import com.yeshi.fanli.dto.jd.JDCouponInfo; import com.yeshi.fanli.dto.jd.JDPingouInfo; @@ -33,7 +34,6 @@ import com.yeshi.fanli.dto.jd.JDSearchResult; import com.yeshi.fanli.dto.jd.JDShopInfo; import com.yeshi.fanli.entity.jd.JDGoods; -import com.yeshi.fanli.entity.taobao.TaoBaoGoodsBrief; import com.yeshi.fanli.tag.PageEntity; import com.yeshi.fanli.util.MoneyBigDecimalUtil; import com.yeshi.fanli.util.StringUtil; @@ -390,6 +390,57 @@ return BigDecimalUtil.getWithNoZera(MoneyBigDecimalUtil.mul(money, new BigDecimal("0.9"))); } + + /** + * 鍟嗗搧浣i噾璁$畻 + * + * @param goods + * @param rate + * @return + */ + public static BigDecimal getGoodsFanLiMoneyPlus(JDGoods goods, BigDecimal rate) { + BigDecimal money = new BigDecimal(0); + BigDecimal commissionPlus = goods.getCommissionPlus(); + if (commissionPlus == null) { + return money; + } + + + + BigDecimal price = null; + JDPingouInfo pinGouInfo = goods.getPinGouInfo(); + if (pinGouInfo == null) { + price = goods.getPrice(); + } else { + price = pinGouInfo.getPingouPrice(); + } + + JDCouponInfo couponInfo = goods.getCouponInfo(); + if (couponInfo == null) { + money = MoneyBigDecimalUtil.mul(MoneyBigDecimalUtil + .mul(MoneyBigDecimalUtil.mul(price, commissionPlus), new BigDecimal("0.01")), + MoneyBigDecimalUtil.div(rate, new BigDecimal(100))); + } else { + BigDecimal quota = couponInfo.getQuota(); + BigDecimal discount = couponInfo.getDiscount(); + if (quota.compareTo(price) <= 0 && price.compareTo(discount) > 0) { + + BigDecimal finalPrice = price.subtract(discount); + money = MoneyBigDecimalUtil.mul(MoneyBigDecimalUtil.mul( + MoneyBigDecimalUtil.mul(finalPrice, commissionPlus), + new BigDecimal("0.01")), MoneyBigDecimalUtil.div(rate, new BigDecimal(100))); + + } else {// 涓嶈兘鐢ㄥ埜 + money = MoneyBigDecimalUtil.mul( + MoneyBigDecimalUtil.mul(MoneyBigDecimalUtil.mul(price,commissionPlus), + new BigDecimal("0.01")), + MoneyBigDecimalUtil.div(rate, new BigDecimal(100))); + } + } + // 杩斿埄姣斾緥涓哄師鏉ョ殑90% + return BigDecimalUtil.getWithNoZera(MoneyBigDecimalUtil.mul(money, new BigDecimal("0.9"))); + } + /** * 璁$畻鍟嗗搧鍒稿悗浠凤紝娌℃湁鍒稿垯杩斿洖鍘熶环 * @@ -628,5 +679,91 @@ } return jdGoods; } + + + /** + * 鑾峰彇绫荤洰 + * @param level 绛夌骇 + * @param parentId 涓婄骇id + * @return + */ + public static List<GoodsClassDTO> getCategoryList(int level, int parentId) { + try { + // 璇锋眰鍦板潃 + String requestUrl = "https://union.jd.com/api/help/getCategoryList?level=%s&parentId=%s"; + // 鎵ц璇锋眰 + String result = HttpUtil.get(String.format(requestUrl, level, parentId)); + if (!StringUtil.isNullOrEmpty(result)) { + JSONObject json = JSONObject.fromObject(result); + JSONArray jsonArray = json.getJSONArray("data"); + if (jsonArray != null && jsonArray.size() > 0) { + List<GoodsClassDTO> list = new ArrayList<GoodsClassDTO>(); + for (int i=0;i <jsonArray.size() ;i ++ ) { + Object object = jsonArray.get(i); + if (object == null) + continue; + JSONObject jsonClass = JSONObject.fromObject(object); + + GoodsClassDTO goodsClass = new GoodsClassDTO(); + goodsClass.setId(jsonClass.optString("id")); + goodsClass.setName(jsonClass.optString("categoryName")); + list.add(goodsClass); + } + return list; + } + } + } catch (Exception e) { + e.printStackTrace(); + } + return null; + } + + /** + * 鑾峰彇绫荤洰 + * @param level 绛夌骇 + * @param parentId 涓婄骇id + * @return + */ + public static List<GoodsClassDTO> getCategoryCommiPlus(int level, int parentId) { + try { + // 璇锋眰鍦板潃 + String requestUrl = "https://union.jd.com/api/help/getCategoryCommiPlus?level=%s&parentId=%s"; + // 鎵ц璇锋眰 + String result = HttpUtil.get(String.format(requestUrl, level, parentId)); + + if (!StringUtil.isNullOrEmpty(result)) { + JSONObject json = JSONObject.fromObject(result); + JSONArray jsonArray = json.getJSONArray("data"); + if (jsonArray != null && jsonArray.size() > 0) { + List<GoodsClassDTO> list = new ArrayList<GoodsClassDTO>(); + for (int i=0;i <jsonArray.size() ;i ++ ) { + Object object = jsonArray.get(i); + if (object == null) + continue; + JSONObject jsonClass = JSONObject.fromObject(object); + + GoodsClassDTO goodsClass = new GoodsClassDTO(); + goodsClass.setId(jsonClass.optString("id")); + goodsClass.setName(jsonClass.optString("name")); + + String selfMobileComm = jsonClass.optString("selfMobileComm"); + if (!StringUtil.isNullOrEmpty(selfMobileComm)) + goodsClass.setSelfComm(new BigDecimal(selfMobileComm)); + + String popMobileComm = jsonClass.optString("popMobileComm"); + if (!StringUtil.isNullOrEmpty(popMobileComm)) + goodsClass.setPopComm(new BigDecimal(popMobileComm)); + + list.add(goodsClass); + } + return list; + } + } + } catch (Exception e) { + e.printStackTrace(); + } + return null; + } + } -- Gitblit v1.8.0