From 626d711cb15896055c13fe344eb7fcc824589715 Mon Sep 17 00:00:00 2001 From: yujian <yujian@163.com> Date: 星期四, 19 十二月 2019 15:38:42 +0800 Subject: [PATCH] 帮助中心 --- fanli/src/main/java/com/yeshi/fanli/controller/client/v2/SearchControllerV2.java | 435 ++++++++++++++++++++++++++++++++++++++++++++++++----- 1 files changed, 388 insertions(+), 47 deletions(-) diff --git a/fanli/src/main/java/com/yeshi/fanli/controller/client/v2/SearchControllerV2.java b/fanli/src/main/java/com/yeshi/fanli/controller/client/v2/SearchControllerV2.java index 87ce6b5..77d1fa6 100644 --- a/fanli/src/main/java/com/yeshi/fanli/controller/client/v2/SearchControllerV2.java +++ b/fanli/src/main/java/com/yeshi/fanli/controller/client/v2/SearchControllerV2.java @@ -10,16 +10,21 @@ import java.util.regex.Pattern; import javax.annotation.Resource; +import javax.servlet.http.HttpSession; import org.springframework.core.task.TaskExecutor; import org.springframework.stereotype.Controller; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RequestMethod; +import org.yeshi.utils.HttpUtil; import org.yeshi.utils.JsonUtil; +import org.yeshi.utils.NumberUtil; import org.yeshi.utils.taobao.TbImgUtil; import com.google.gson.Gson; import com.google.gson.GsonBuilder; +import com.yeshi.fanli.dto.ConfigParamsDTO; +import com.yeshi.fanli.dto.douyin.DouYinGoods; import com.yeshi.fanli.dto.jd.JDFilter; import com.yeshi.fanli.dto.jd.JDSearchFilter; import com.yeshi.fanli.dto.jd.JDSearchResult; @@ -27,29 +32,39 @@ import com.yeshi.fanli.dto.pdd.PDDGoodsResult; import com.yeshi.fanli.dto.pdd.PDDSearchFilter; import com.yeshi.fanli.entity.accept.AcceptData; +import com.yeshi.fanli.entity.goods.CommonGoods; import com.yeshi.fanli.entity.jd.JDGoods; import com.yeshi.fanli.entity.taobao.SearchFilter; import com.yeshi.fanli.entity.taobao.TaoBaoGoodsBrief; import com.yeshi.fanli.entity.taobao.TaoBaoSearchResult; import com.yeshi.fanli.entity.taobao.dataoke.DaTaoKeDetail; import com.yeshi.fanli.exception.taobao.TaobaoGoodsDownException; +import com.yeshi.fanli.exception.user.TokenRecordException; import com.yeshi.fanli.log.LogHelper; +import com.yeshi.fanli.service.inter.brand.BrandInfoService; import com.yeshi.fanli.service.inter.config.BusinessSystemService; import com.yeshi.fanli.service.inter.config.ConfigService; import com.yeshi.fanli.service.inter.config.SuperHotSearchService; -import com.yeshi.fanli.service.inter.hongbao.HongBaoManageService; import com.yeshi.fanli.service.inter.lable.QualityGoodsService; import com.yeshi.fanli.service.inter.lable.TaoKeGoodsService; +import com.yeshi.fanli.service.inter.order.config.HongBaoManageService; import com.yeshi.fanli.service.inter.taobao.TaoBaoShopService; import com.yeshi.fanli.service.inter.taobao.TaoBaoUnionConfigService; import com.yeshi.fanli.service.inter.taobao.dataoke.DaTaoKeGoodsDetailService; import com.yeshi.fanli.service.inter.user.HistorySearchService; +import com.yeshi.fanli.service.inter.user.TokenRecordService; +import com.yeshi.fanli.service.inter.user.integral.IntegralGetService; import com.yeshi.fanli.tag.PageEntity; import com.yeshi.fanli.util.Constant; +import com.yeshi.fanli.util.DouYinUtil; import com.yeshi.fanli.util.StringUtil; import com.yeshi.fanli.util.ThreadUtil; import com.yeshi.fanli.util.Utils; +import com.yeshi.fanli.util.VersionUtil; +import com.yeshi.fanli.util.annotation.RequestSerializableByKey; +import com.yeshi.fanli.util.cache.IntegralGetCacheManager; import com.yeshi.fanli.util.cache.TaoBaoGoodsCacheUtil; +import com.yeshi.fanli.util.factory.CommonGoodsFactory; import com.yeshi.fanli.util.factory.goods.GoodsDetailVOFactory; import com.yeshi.fanli.util.jd.JDApiUtil; import com.yeshi.fanli.util.jd.JDUtil; @@ -58,8 +73,10 @@ import com.yeshi.fanli.util.taobao.SearchFilterUtil; import com.yeshi.fanli.util.taobao.TaoBaoUtil; import com.yeshi.fanli.util.taobao.TaoKeApiUtil; +import com.yeshi.fanli.vo.brand.BrandInfoVO; import com.yeshi.fanli.vo.brand.TaoBaoShopVO; import com.yeshi.fanli.vo.goods.GoodsDetailVO; +import com.yeshi.fanli.vo.msg.TokenVO; import net.sf.json.JSONArray; import net.sf.json.JSONObject; @@ -104,6 +121,20 @@ @Resource(name = "taskExecutor") private TaskExecutor executor; + @Resource + private TokenRecordService tokenRecordService; + + @Resource + private IntegralGetService integralGetService; + + @Resource + private IntegralGetCacheManager integralGetCacheManager; + + + @Resource + private BrandInfoService brandInfoService; + + /** * 绮樿创鏉夸俊鎭帹鑽� * @@ -113,17 +144,23 @@ * @param out */ @RequestMapping(value = "getRecommendInfo", method = RequestMethod.POST) - public void getRecommendInfo(AcceptData acceptData, String text, PrintWriter out) { + public void getRecommendInfo(AcceptData acceptData, String text, Long uid, PrintWriter out) { if (StringUtil.isNullOrEmpty(text)) { out.print(JsonUtil.loadFalseResult("鍊间负绌�")); return; } - //鍘婚櫎鍓嶅悗绌烘牸 - text=text.trim(); + // 鍘婚櫎鍓嶅悗绌烘牸 + text = text.trim(); - if (text.length() > 256) { - out.print(JsonUtil.loadFalseResult("鍊艰繃闀�")); + try { + TokenVO tokenVO = tokenRecordService.discernToken(text, uid, acceptData); + out.print(JsonUtil.loadTrueResult(tokenVO)); return; + } catch (TokenRecordException e) { + if (e.getCode() == 1001) { // 闇�瑕佺敤鎴风櫥褰� + out.print(JsonUtil.loadFalseResult(e.getCode(), e.getMsg())); + return; + } } TaoBaoGoodsBrief tb = null; @@ -132,8 +169,12 @@ Pattern p = Pattern.compile(URL_REGEX); Matcher matcher = p.matcher(text); if (!matcher.find()) {// 涓嶅寘鍚摼鎺� - String pattern = "^[A-Za-z0-9]+$"; - if (Pattern.matches(pattern, text)) { + if (text.length() > 256) { + out.print(JsonUtil.loadFalseResult("鍊艰繃闀�")); + return; + } + String pattern = "^[A-Za-z0-9-]+$"; + if (Pattern.matches(pattern, text.replace(" ", ""))) {// 鍒犻櫎绌烘牸 out.println(JsonUtil.loadFalseResult("涓嶆敮鎸佹帹鑽�")); return; } @@ -145,12 +186,14 @@ return; } - if (analysisTaoToken(text, out)) { + if (analysisTaoToken(acceptData, text, out)) { return; } - + if (!StringUtil.isNullOrEmpty(TaoBaoUtil.parseSystemTaoToken(text))) { + out.print(JsonUtil.loadFalseResult("涓嶆敮鎸佹帹鑽�")); + return; + } JSONObject root = new JSONObject(); - root.put("type", 2); JSONObject data = new JSONObject(); data.put("title", text); @@ -159,8 +202,17 @@ return; } + int type = 3; + CommonGoods commonGoods = null; text = matcher.group(); - if (text.contains("ju.taobao.com") || text.contains(".juhuasuan.com")) {// 鑱氬垝绠� + + if (text.startsWith("https://a.m.taobao.com/i"))// 娣樺疂璐﹀彿鏈櫥褰曠姸鎬� + { + text = text.substring("https://a.m.taobao.com/i".length(), text.indexOf(".htm")); + if (NumberUtil.isNumeric(text)) { + tb = TaoBaoUtil.isAlimama(text); + } + } else if (text.contains("ju.taobao.com") || text.contains(".juhuasuan.com")) {// 鑱氬垝绠� int index = text.indexOf("item_id"); if (index < 0) { out.println(JsonUtil.loadFalseResult("鏆傛湭鎵惧埌璇ュ晢鍝侊紝璇风◢鍚庡啀璇曪紒")); @@ -176,7 +228,8 @@ } tb = TaoBaoUtil.isAlimama(id); if (tb == null) { - tb = TaoBaoUtil.parsePhoneTmAndTb(id); + type = 4; + tb = getTaoBaoGoodsBriefFromGoodsId(id); } } else if (text.contains("http://zmnxbc.com")) { // 鎵嬫満绔ぉ鐚獳PP鍒嗕韩 tb = TaoBaoUtil.parsePhoneShareUrlByTM(text); @@ -187,38 +240,225 @@ id = map.get("id").replace("}", ""); tb = TaoBaoUtil.isAlimama(id); if (tb == null) { - tb = TaoBaoUtil.parsePhoneTmAndTb(id); + type = 4; + tb = getTaoBaoGoodsBriefFromGoodsId(id); } + } else if (text.contains("v.douyin.com")) { // 鎶栭煶 + analysisDouYin(acceptData, text, out); + return; } else { tb = TaoBaoUtil.parsePhoneShareUrlByTB(text); + + if (tb == null) { + String goodsId = TaoBaoUtil.getGoodsIdByPhoneShareUrl(text); + if (!StringUtil.isNullOrEmpty(goodsId)) { + tb = getTaoBaoGoodsBriefFromGoodsId(goodsId); + if (tb != null) + type = 4; + } + } + + if (tb == null)// 娣樺疂鏄┖鍊� + { + String jdId = JDUtil.getJDGoodsId(text); + + // 寰俊閾炬帴 + if (StringUtil.isNullOrEmpty(jdId)) { + jdId = JDUtil.getJDGoodsIdByWeiXin(text); + } + + // 棰嗗埜鐭繛鎺� + if (StringUtil.isNullOrEmpty(jdId) && text.contains("u.jd.com")) { + jdId = JDUtil.getJDGoodsIdByUJD(text); + } + + if (!StringUtil.isNullOrEmpty(jdId)) { + JDGoods goods = JDApiUtil.getGoodsDetail(Long.parseLong(jdId)); + if (goods != null) { + // 楂樼骇鎺ュ彛 -- 淇℃伅鏇村畬鏁� + JDGoods jdGoods = JDApiUtil.queryGoodsDetail(Long.parseLong(jdId)); + if (jdGoods != null) { + commonGoods = CommonGoodsFactory.create(jdGoods); + } else { + commonGoods = CommonGoodsFactory.create(goods); + } + } else { + type = 4; + goods = JDUtil.getSimpleGoodsInfo(jdId); + if (goods != null) { + commonGoods = new CommonGoods(); + commonGoods.setTitle(goods.getSkuName()); + commonGoods.setPicture(goods.getPicUrl()); + } + } + } else { + String pddId = PinDuoDuoUtil.getPDDGoodsId(text); + if (!StringUtil.isNullOrEmpty(pddId)) { + PDDGoodsDetail goods = PinDuoDuoApiUtil.getGoodsDetail(Long.parseLong(pddId)); + if (goods != null) { + commonGoods = CommonGoodsFactory.create(goods); + } else { + type = 4; + goods = PinDuoDuoUtil.getPDDGoodsInfo(pddId); + if (goods != null) { + commonGoods = new CommonGoods(); + commonGoods.setTitle(goods.getGoodsName()); + commonGoods.setPicture(goods.getGoodsThumbnailUrl()); + } + } + } + } + } } - if (tb == null) { + if (tb == null && commonGoods == null) { out.println(JsonUtil.loadFalseResult("鏆傛湭鎵惧埌璇ュ晢鍝侊紝璇风◢鍚庡啀璇曪紒")); return; } - JSONObject data = new JSONObject(); - JSONObject taoBaoGoodsJSON = new JSONObject(); - taoBaoGoodsJSON.put("title", tb.getTitle()); - taoBaoGoodsJSON.put("zkPrice", tb.getZkPrice()); - taoBaoGoodsJSON.put("id", tb.getAuctionId()); - taoBaoGoodsJSON.put("goodsType", Constant.SOURCE_TYPE_TAOBAO); - taoBaoGoodsJSON.put("url", "http://item.taobao.com/item.htm?id=" + tb.getAuctionId()); - data.put("goods", taoBaoGoodsJSON); - if (!StringUtil.isNullOrEmpty(tb.getPictUrl())) { - if (tb.getImgList() == null) - tb.setImgList(new ArrayList<>()); - tb.getImgList().add(0, TbImgUtil.getTBSize220Img(tb.getPictUrl())); + + if (type == 4) { + if (!VersionUtil.greaterThan_2_0_1(acceptData.getPlatform(), acceptData.getVersion())) { + out.println(JsonUtil.loadFalseResult("鏆傛湭鎵惧埌璇ュ晢鍝侊紝璇风◢鍚庡啀璇曪紒")); + return; + } + + JSONObject data = new JSONObject(); + if (tb != null) { + commonGoods = new CommonGoods(); + commonGoods.setTitle(tb.getTitle()); + commonGoods.setPicture(tb.getPictUrl()); + } + + if (StringUtil.isNullOrEmpty(commonGoods.getTitle()) + || StringUtil.isNullOrEmpty(commonGoods.getPicture())) { + out.println(JsonUtil.loadFalseResult("鏆傛湭鎵惧埌璇ュ晢鍝侊紝璇风◢鍚庡啀璇曪紒")); + return; + } + + JSONObject goodsJSON = new JSONObject(); + goodsJSON.put("title", commonGoods.getTitle()); + goodsJSON.put("pictUrl", commonGoods.getPicture()); + + data.put("type", type); + data.put("desc", "璇ュ晢鍝佹棤鎺ㄥ箍淇℃伅"); + data.put("goods", goodsJSON); + out.print(JsonUtil.loadTrueResult(data)); + return; } - data.put("imgs", tb.getImgList()); + + JSONObject data = new JSONObject(); + if (VersionUtil.greaterThan_1_6_5(acceptData.getPlatform(), acceptData.getVersion())) { + if (tb != null) { + TaoBaoGoodsBrief goodsBrief = null; + try { + goodsBrief = TaoKeApiUtil.searchGoodsDetail(tb.getAuctionId()); + } catch (TaobaoGoodsDownException e) { + e.printStackTrace(); + } + if (goodsBrief == null) { + out.println(JsonUtil.loadFalseResult("鏆傛湭鎵惧埌璇ュ晢鍝侊紝璇风◢鍚庡啀璇曪紒")); + return; + } + commonGoods = CommonGoodsFactory.create(goodsBrief); + } + + BigDecimal fanLiRate = hongBaoManageService.getFanLiRate(); + BigDecimal shareRate = hongBaoManageService.getShareRate(); + Gson gson = JsonUtil.getConvertBigDecimalToStringSubZeroBuilder(new GsonBuilder()) + .excludeFieldsWithoutExposeAnnotation().setDateFormat("yyyy-MM-dd").create(); + data.put("type", type); + data.put("goods", gson.toJson(GoodsDetailVOFactory.convertCommonGoods(commonGoods, + new ConfigParamsDTO(fanLiRate, shareRate, Constant.MAX_REWARD_RATE,hongBaoManageService.getVIPFanLiRate())))); + out.print(JsonUtil.loadTrueResult(data)); + return; + } + + if (tb != null) { + commonGoods = new CommonGoods(); + commonGoods.setPrice(tb.getZkPrice()); + commonGoods.setTitle(tb.getTitle()); + commonGoods.setGoodsId(tb.getAuctionId()); + commonGoods.setGoodsType(Constant.SOURCE_TYPE_TAOBAO); + commonGoods.setPicture(tb.getPictUrl()); + } + + JSONObject taoBaoGoodsJSON = new JSONObject(); + taoBaoGoodsJSON.put("title", commonGoods.getTitle()); + taoBaoGoodsJSON.put("zkPrice", commonGoods.getPrice() + ""); + taoBaoGoodsJSON.put("id", commonGoods.getGoodsId()); + taoBaoGoodsJSON.put("goodsType", commonGoods.getGoodsType()); + if (commonGoods.getGoodsType() == Constant.SOURCE_TYPE_TAOBAO) { + taoBaoGoodsJSON.put("url", "http://item.taobao.com/item.htm?id=" + commonGoods.getGoodsId()); + } else if (commonGoods.getGoodsType() == Constant.SOURCE_TYPE_JD) { + taoBaoGoodsJSON.put("url", String.format("https://item.jd.com/%s.html", commonGoods.getGoodsId() + "")); + } else if (commonGoods.getGoodsType() == Constant.SOURCE_TYPE_PDD) { + taoBaoGoodsJSON.put("url", "http://yangkeduo.com/goods.html?goods_id=" + commonGoods.getGoodsId()); + } + data.put("goods", taoBaoGoodsJSON); + List<String> picList = new ArrayList<>(); + picList.add(commonGoods.getPicture()); + data.put("imgs", picList); JSONObject root = new JSONObject(); root.put("type", 1); root.put("data", data); - out.print(JsonUtil.loadTrueResult(root)); } - private boolean analysisTaoToken(String text, PrintWriter out) { + private TaoBaoGoodsBrief getTaoBaoGoodsBriefFromGoodsId(String goodsId) { + TaoBaoGoodsBrief tb = TaoBaoUtil.getTmallGoodsInfo(goodsId); + if (tb == null && NumberUtil.isNumeric(goodsId)) {// 鏄暟瀛� + tb = TaoBaoUtil.getSimpleGoodsBrief(Long.parseLong(goodsId)); + if (tb != null) { + tb.setPictUrl(TbImgUtil.getTBSize220Img(tb.getPictUrl())); + } + } + return tb; + } + + /** + * 瑙f瀽鎶栭煶閾炬帴 + * + * @param acceptData + * @param text + * @param out + * @return + */ + private void analysisDouYin(AcceptData acceptData, String text, PrintWriter out) { + String location = HttpUtil.getLocation(text); + if (!StringUtil.isNullOrEmpty(location)) { + if (location.contains("taobao.com")) { // 娣樺疂鍟嗗搧 + String realUrl = TaoBaoUtil.getRealUrl(location); + if (!StringUtil.isNullOrEmpty(realUrl)) { + getRecommendInfo(acceptData, realUrl, null, out); + return; + } + } else if (location.contains("haohuo.jinritemai.com")) { // 鎶栭煶鍟嗗搧 + DouYinGoods goods = DouYinUtil.getGoodsInfo(location); + JSONObject goodsJSON = new JSONObject(); + goodsJSON.put("title", goods.getName()); + goodsJSON.put("pictUrl", goods.getImg()); + + JSONObject data = new JSONObject(); + data.put("type", 4); + data.put("desc", "璇ュ晢鍝佹棤鎺ㄥ箍淇℃伅"); + data.put("goods", goodsJSON); + out.print(JsonUtil.loadTrueResult(data)); + return; + } + } + out.println(JsonUtil.loadFalseResult("鏆傛湭鎵惧埌璇ュ晢鍝侊紝璇风◢鍚庡啀璇曪紒")); + return; + } + + /** + * 瑙f瀽娣樺彛浠� + * + * @param acceptData + * @param text + * @param out + * @return + */ + private boolean analysisTaoToken(AcceptData acceptData, String text, PrintWriter out) { String token = StringUtil.picUpTaoToken(text); if (!StringUtil.isNullOrEmpty(token)) { Long auctionId = TaoKeApiUtil.tokenConvertAuctionId(token); @@ -231,6 +471,32 @@ } if (tb != null) { + if (VersionUtil.greaterThan_1_6_5(acceptData.getPlatform(), acceptData.getVersion())) { + TaoBaoGoodsBrief goodsBrief = null; + try { + goodsBrief = TaoKeApiUtil.searchGoodsDetail(tb.getAuctionId()); + } catch (TaobaoGoodsDownException e) { + e.printStackTrace(); + } + + if (goodsBrief == null) { + out.println(JsonUtil.loadFalseResult("鏆傛湭鎵惧埌璇ュ晢鍝侊紝璇风◢鍚庡啀璇曪紒")); + return false; + } + + BigDecimal fanLiRate = hongBaoManageService.getFanLiRate(); + BigDecimal shareRate = hongBaoManageService.getShareRate(); + Gson gson = JsonUtil.getConvertBigDecimalToStringSubZeroBuilder(new GsonBuilder()) + .excludeFieldsWithoutExposeAnnotation().setDateFormat("yyyy-MM-dd").create(); + + JSONObject data = new JSONObject(); + data.put("type", 3); + data.put("goods", gson.toJson(GoodsDetailVOFactory.convertTaoBao(goodsBrief, + new ConfigParamsDTO(fanLiRate, shareRate, Constant.MAX_REWARD_RATE,hongBaoManageService.getVIPFanLiRate())))); + out.print(JsonUtil.loadTrueResult(data)); + return true; + } + JSONObject data = new JSONObject(); JSONObject taoBaoGoodsJSON = new JSONObject(); taoBaoGoodsJSON.put("title", tb.getTitle()); @@ -254,6 +520,25 @@ } } return false; + } + + /** + * 鍙d护棰嗗彇 + * + * @param acceptData + * @param kw + * @param goodsType + * @param out + */ + @RequestSerializableByKey(key = "'tokenReceive-'+#uid") + @RequestMapping(value = "tokenReceive", method = RequestMethod.POST) + public void tokenReceive(AcceptData acceptData, Long uid, String token, PrintWriter out) { + try { + String msg = tokenRecordService.receiveToken(token, uid, acceptData); + out.print(JsonUtil.loadTrueResult(msg)); + } catch (TokenRecordException e) { + out.print(JsonUtil.loadFalseResult(e.getCode(), e.getMsg())); + } } /** @@ -308,7 +593,8 @@ */ @RequestMapping(value = "searchGoods") public void searchGoods(AcceptData acceptData, Integer goodsType, String key, Integer page, String filter, - Integer order, PrintWriter out) { + Integer order, Long uid, HttpSession session, PrintWriter out) { + if (goodsType == null || goodsType < 1 || goodsType > 3) { out.print(JsonUtil.loadFalseResult(1, "璇蜂紶閫掓纭钩鍙板弬鏁�")); return; @@ -324,6 +610,24 @@ return; } final String searchkey = key.trim(); + + if (uid != null) { + if (page == 1) { + integralGetCacheManager.cacheSearchGoods(acceptData.getDevice(), System.currentTimeMillis()); + } else if (page > 1) { + Long lastTime = integralGetCacheManager.getLastSearchTime(acceptData.getDevice()); + if (lastTime != null && System.currentTimeMillis() - lastTime >= 15 * 1000L) {// 瓒呰繃15s娴忚 + integralGetCacheManager.clearSearchTime(acceptData.getDevice()); + ThreadUtil.run(new Runnable() { + @Override + public void run() { + // 澧炲姞閲戝竵 + integralGetService.addSearchResultScan(uid, key); + } + }); + } + } + } executor.execute(new Runnable() { @Override @@ -351,18 +655,18 @@ /*--------- 浜笢鍟嗗搧 -------*/ if (goodsType.intValue() == Constant.SOURCE_TYPE_JD) { - searchJDGoods(searchkey, page, filter, order, out); + searchJDGoods(acceptData, searchkey, page, filter, order, out); return; } /*-------- 鎷煎澶氬晢鍝� -------*/ if (goodsType.intValue() == Constant.SOURCE_TYPE_PDD) { - searchPDDGoods(searchkey, page, filter, order, out); + searchPDDGoods(acceptData, searchkey, page, filter, order, out); return; } /*-------- 娣樺疂鍟嗗搧 -------*/ - searchTaoBaoGoods(searchkey, page, filter, order, out); + searchTaoBaoGoods(acceptData, searchkey, page, filter, order, out); } /** @@ -376,7 +680,8 @@ * @param endprice * @return */ - private void searchTaoBaoGoods(String key, Integer page, String filter, Integer order, PrintWriter out) { + private void searchTaoBaoGoods(AcceptData acceptData, String key, Integer page, String filter, Integer order, + PrintWriter out) { SearchFilter sf = new SearchFilter(); sf.setKey(SearchFilterUtil.filterSearchContent(key)); sf.setPage(page); @@ -459,8 +764,10 @@ List<GoodsDetailVO> list = new ArrayList<GoodsDetailVO>(); BigDecimal fanLiRate = hongBaoManageService.getFanLiRate(); BigDecimal shareRate = hongBaoManageService.getShareRate(); + ConfigParamsDTO paramsDTO = new ConfigParamsDTO(fanLiRate, shareRate, Constant.MAX_REWARD_RATE,hongBaoManageService.getVIPFanLiRate()); + for (TaoBaoGoodsBrief goods : taoBaoGoodsBriefs) { - list.add(GoodsDetailVOFactory.convertTaoBao(goods, null, fanLiRate, shareRate)); + list.add(GoodsDetailVOFactory.convertTaoBao(goods, paramsDTO)); } Gson gson = JsonUtil.getConvertBigDecimalToStringSubZeroBuilder(new GsonBuilder()) @@ -470,14 +777,34 @@ data.put("result", gson.toJson(list)); data.put("count", result.getTaoBaoHead().getDocsfound()); - if (page == 1) { - // 绗竴椤佃繑鍥炲簵閾轰俊鎭� - List<TaoBaoShopVO> listShop = taoBaoShopService.getShopByKeyV2(key); - if (listShop != null && listShop.size() > 0 && listShop.get(0).getListGoodsVO() != null - && listShop.get(0).getListGoodsVO().size() > 2) { - data.put("shop", JsonUtil.getApiCommonGson().toJson(listShop.get(0))); + if (page == 1) { // 绗竴椤佃繑鍥炲簵閾轰俊鎭� + String platform = acceptData.getPlatform(); + String version = acceptData.getVersion(); + if (("ios".equalsIgnoreCase(platform) && VersionUtil.greaterThan_2_1(platform, version)) + || ("android".equalsIgnoreCase(platform) && VersionUtil.greaterThan_2_0_2(platform, version))) { + BrandInfoVO brandInfoVO = brandInfoService.listByAlikeName(key); + if (brandInfoVO != null) + data.put("shop", JsonUtil.getApiCommonGson().toJson(brandInfoVO)); + } else { + List<TaoBaoShopVO> listShop = taoBaoShopService.getShopByKeyV2(key); + if (listShop != null && listShop.size() > 0 && listShop.get(0).getListGoodsVO() != null + && listShop.get(0).getListGoodsVO().size() > 2) { + TaoBaoShopVO taoBaoShop = listShop.get(0); + if (("ios".equalsIgnoreCase(platform) && VersionUtil.greaterThan_2_0(platform, version)) + || ("android".equalsIgnoreCase(platform) && VersionUtil.greaterThan_2_0_1(platform, version))) { + BrandInfoVO brandInfoVO = new BrandInfoVO(); + brandInfoVO.setId(taoBaoShop.getId()); + brandInfoVO.setName(taoBaoShop.getShopName()); + brandInfoVO.setIcon(taoBaoShop.getShopIcon()); + brandInfoVO.setListGoods(taoBaoShop.getListGoodsVO()); + data.put("shop", JsonUtil.getApiCommonGson().toJson(brandInfoVO)); + } else { + data.put("shop", JsonUtil.getApiCommonGson().toJson(taoBaoShop)); + } + } } } + out.print(JsonUtil.loadTrueResult(data)); } @@ -492,9 +819,11 @@ * @param endprice * @return */ - private void searchJDGoods(String key, Integer page, String filter, Integer order, PrintWriter out) { + private void searchJDGoods(AcceptData acceptData, String key, Integer page, String filter, Integer order, + PrintWriter out) { JDSearchResult result = null; + boolean hasCoupon = false; String way = configService.get("jd_api_search_key"); if ("1".equals(way)) { JDFilter filterAPI = new JDFilter(); @@ -530,6 +859,7 @@ JSONObject jsonfilter = JSONObject.fromObject(filter); Boolean coupon = jsonfilter.optBoolean("coupon"); if (coupon != null && coupon) { + hasCoupon = true; filterAPI.setIsCoupon(1); // 鏈夊埜 } @@ -585,6 +915,7 @@ JSONObject jsonfilter = JSONObject.fromObject(filter); Boolean coupon = jsonfilter.optBoolean("coupon"); if (coupon != null && coupon) { + hasCoupon = true; jdfilter.setHasCoupon(1); // 鏈夊埜 } @@ -635,9 +966,17 @@ BigDecimal shareRate = hongBaoManageService.getShareRate(); Gson gson = JsonUtil.getConvertBigDecimalToStringSubZeroBuilder(new GsonBuilder()) .excludeFieldsWithoutExposeAnnotation().setDateFormat("yyyy-MM-dd").create(); + ConfigParamsDTO paramsDTO = new ConfigParamsDTO(fanLiRate, shareRate, Constant.MAX_REWARD_RATE,hongBaoManageService.getVIPFanLiRate()); + for (JDGoods goods : goodsList) { - GoodsDetailVO goodsDetailVO = GoodsDetailVOFactory.convertJDGoods(goods, fanLiRate, shareRate); - array.add(gson.toJson(goodsDetailVO)); + GoodsDetailVO goodsDetailVO = GoodsDetailVOFactory.convertJDGoods(goods, paramsDTO); + if (hasCoupon) { + if (goodsDetailVO.isHasCoupon()) { + array.add(gson.toJson(goodsDetailVO)); + } + } else { + array.add(gson.toJson(goodsDetailVO)); + } } } } @@ -658,7 +997,8 @@ * @param endprice * @return */ - private void searchPDDGoods(String key, Integer page, String filter, Integer order, PrintWriter out) { + private void searchPDDGoods(AcceptData acceptData, String key, Integer page, String filter, Integer order, + PrintWriter out) { PDDSearchFilter pddfilter = new PDDSearchFilter(); pddfilter.setKw(SearchFilterUtil.filterSearchContent(key)); pddfilter.setPage(page); @@ -710,9 +1050,10 @@ if (goodsList != null && goodsList.size() > 0) { BigDecimal fanLiRate = hongBaoManageService.getFanLiRate(); BigDecimal shareRate = hongBaoManageService.getShareRate(); + ConfigParamsDTO paramsDTO = new ConfigParamsDTO(fanLiRate, shareRate, Constant.MAX_REWARD_RATE,hongBaoManageService.getVIPFanLiRate()); for (PDDGoodsDetail goods : goodsList) { - GoodsDetailVO goodsDetailVO = GoodsDetailVOFactory.convertPDDGoods(goods, fanLiRate, shareRate); + GoodsDetailVO goodsDetailVO = GoodsDetailVOFactory.convertPDDGoods(goods, paramsDTO); array.add(gson.toJson(goodsDetailVO)); } } -- Gitblit v1.8.0