From ff34faee79dfdbb2a72839b97b1e748551549b08 Mon Sep 17 00:00:00 2001
From: yj <Administrator@192>
Date: 星期五, 06 三月 2020 10:21:02 +0800
Subject: [PATCH] 发圈
---
fanli/src/main/java/com/yeshi/fanli/controller/web/WebSearchController.java | 370 ++++++++++++++++++----------------------------------
1 files changed, 126 insertions(+), 244 deletions(-)
diff --git a/fanli/src/main/java/com/yeshi/fanli/controller/web/WebSearchController.java b/fanli/src/main/java/com/yeshi/fanli/controller/web/WebSearchController.java
index a975921..d402333 100644
--- a/fanli/src/main/java/com/yeshi/fanli/controller/web/WebSearchController.java
+++ b/fanli/src/main/java/com/yeshi/fanli/controller/web/WebSearchController.java
@@ -10,16 +10,16 @@
import javax.annotation.Resource;
-import net.sf.json.JSONArray;
-import net.sf.json.JSONObject;
-
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
+import org.yeshi.utils.JsonUtil;
+import org.yeshi.utils.taobao.TbImgUtil;
import com.google.gson.Gson;
import com.google.gson.GsonBuilder;
import com.yeshi.fanli.entity.accept.AcceptData;
+import com.yeshi.fanli.entity.bus.lable.QualityFactory;
import com.yeshi.fanli.entity.bus.search.HotSearch;
import com.yeshi.fanli.entity.bus.su.search.SuperHotSearch;
import com.yeshi.fanli.entity.system.CustomerContent;
@@ -28,13 +28,17 @@
import com.yeshi.fanli.entity.taobao.TaoBaoGoodsBriefExtra;
import com.yeshi.fanli.entity.taobao.TaoBaoSearchNav;
import com.yeshi.fanli.entity.taobao.TaoBaoSearchResult;
+import com.yeshi.fanli.service.inter.config.CustomerContentService;
import com.yeshi.fanli.service.inter.config.SuperHotSearchService;
import com.yeshi.fanli.service.inter.config.SystemClientParamsService;
-import com.yeshi.fanli.service.inter.hongbao.HongBaoManageService;
+import com.yeshi.fanli.service.inter.lable.QualityGoodsService;
+import com.yeshi.fanli.service.inter.order.config.HongBaoManageService;
import com.yeshi.fanli.service.inter.user.HistorySearchService;
import com.yeshi.fanli.util.StringUtil;
import com.yeshi.fanli.util.taobao.TaoBaoUtil;
-import org.yeshi.utils.JsonUtil;
+
+import net.sf.json.JSONArray;
+import net.sf.json.JSONObject;
@Controller
@RequestMapping("api/web/v1/webSearch")
@@ -55,266 +59,144 @@
@Resource
private SuperHotSearchService superHotSearchSerivce;
- // 浼樻儬鍒�
- /*
- * public final static int quanType = 1;
- *
- * public final static int baoyou = 2;
- *
- * public final static int TMALL = 3;
- */
+ @Resource
+ private CustomerContentService customerContentService;
- /**
- *
- * 鏂规硶璇存槑: 鍏抽敭瀛楁彁绀哄缓璁悳绱�
- *
- * @author mawurui createTime 2018骞�4鏈�25鏃� 涓嬪崍3:04:52
- * @param acceptData
- * @param kw
- * @param out
- */
- @RequestMapping(value = "suggestsearch", method = RequestMethod.GET)
- public void getSugguestSearch(String callback, AcceptData acceptData, String kw, PrintWriter out) {
- List<String> list = TaoBaoUtil.getSuguestSearch(kw);
- if (list != null && list.size() > 0) {
- JSONArray array = new JSONArray();
- int num = 0;
- for (String st : list) {
- array.add(st);
- num = num + 1;
- if (num >= 5) {
- break;
- }
- }
- out.print(JsonUtil.loadJSONP(callback, JsonUtil.loadTrueResult(array)));
- } else {
- out.print(JsonUtil.loadJSONP(callback, JsonUtil.loadTrueResult("")));
- }
- return;
- }
+ @Resource
+ private QualityGoodsService qualityGoodsService;
- /**
- *
- * 鏂规硶璇存槑: 鎼滅储
- *
- * @author mawurui createTime 2018骞�5鏈�3鏃� 涓婂崍9:53:54
- * @param acceptData
- * @param kw
- * @param page
- * @param filter
- * @param order
- * @param startprice
- * @param endprice
- * @param fastFilter
- * @param out
- */
- @RequestMapping(value = "search", method = RequestMethod.GET)
- public void search(String callback, AcceptData acceptData, String kw, int page, String filter, String order,
- String startprice, String endprice, String fastFilter, PrintWriter out) {
+ @RequestMapping(value = "searchGoods", method = RequestMethod.GET)
+ public void searchGoods(String callback, AcceptData acceptData, String kw, int page, int pagesize, String filters,
+ String rate, String order, String startprice, String endprice, PrintWriter out) {
/*
* System system = webControllerUtil.getSystem(acceptData); if(system ==
* null){
* out.print(JsonUtil.loadFalseResult(WebControllerUtil.NOSYSTEM));
* return; }
*/
- if (!StringUtil.isNullOrEmpty(fastFilter)) {
- if (!StringUtil.isNullOrEmpty(filter)) {
- JSONArray filterArray = JSONArray.fromObject(filter);
- JSONArray fastFilterArray = JSONArray.fromObject(fastFilter);
- filterArray.addAll(fastFilterArray);
- filter = filterArray.toString();
- } else {
- filter = fastFilter;
- }
- }
- JSONObject data = search(kw, page, filter, order, startprice, endprice);
- out.print(JsonUtil.loadJSONP(callback, JsonUtil.loadTrueResult(data)));
- }
-
- private JSONObject search(String kw, int page, String filter, String order, String startprice, String endprice) {
+ if (pagesize > 100)
+ return;
SearchFilter sf = new SearchFilter();
- sf.setKey(kw);
sf.setPage(page);
- sf.setSort(0);
-
- if (!com.yeshi.fanli.util.StringUtil.isNullOrEmpty(startprice)) {
- sf.setStartPrice(new BigDecimal(startprice));
- }
-
- if (!com.yeshi.fanli.util.StringUtil.isNullOrEmpty(endprice)) {
- sf.setEndPrice(new BigDecimal(endprice));
- }
-
- if (!com.yeshi.fanli.util.StringUtil.isNullOrEmpty(order)) {
- if (Integer.parseInt(order) == 0) { // 閿�閲�
- sf.setSort(TaoBaoUtil.SORT_SALE_HIGH_TO_LOW);
- } else if (Integer.parseInt(order) == 3) {
- sf.setSort(TaoBaoUtil.SORT_PRICE_HIGH_TO_LOW);
- } else if (Integer.parseInt(order) == 2) {
- sf.setSort(TaoBaoUtil.SORT_PRICE_LOW_TO_HIGH);
- } else if (Integer.parseInt(order) == 1) {
-
- }
- }
- /*
- * else{ //榛樿閿�閲忎粠楂樺埌浣庢帓搴� sf.setSort(TaoBaoUtil.SORT_SALE_HIGH_TO_LOW); }
- */
-
- if (!com.yeshi.fanli.util.StringUtil.isNullOrEmpty(filter)) {
- // 鏌ヨ娣樺疂澶╃尗
-
- if (Integer.parseInt(filter) == 1) {
- filter = "[{\"type\": \"quantype\"}]";
- } else if (Integer.parseInt(filter) == 2) {
- filter = "[{\"type\": \"baoyou\"}]";
- } else if (Integer.parseInt(filter) == 3) {
- filter = "[{\"type\": \"userType\"}]";
- } else {
- filter = "[]";
- }
- JSONArray array = JSONArray.fromObject(filter);
- Set<String> params = new HashSet<String>();
+ sf.setPageSize(pagesize);
+ sf.setKey(StringUtil.isNullOrEmpty(kw) ? "" : kw);
+ boolean recommend = false;
+ if (!StringUtil.isNullOrEmpty(filters)) {
+ JSONArray array = JSONArray.fromObject(filters);
for (int i = 0; i < array.size(); i++) {
- String ty = array.optJSONObject(i).optString("type");
- if ("shoptype".equalsIgnoreCase(ty)) {
- if (array.optJSONObject(i).optInt("id") == 21) {
- sf.setTmFlagship(false); // 涓嶇瓫锟�?
- } else {
- sf.setTmFlagship(true);
- sf.setTmall(true);
- sf.setShopTag("b2c");
- }
- } else if ("category".equalsIgnoreCase(ty)) {
- sf.setCateIds(array.optJSONObject(i).optString("id"));
- } else if ("userType".equalsIgnoreCase(ty)) {
- // if(array.optJSONObject(i).optInt("id") == 51)
- sf.setTmall(true);
- // else
- // sf.setTmall(false);
- } else if ("baoyou".equalsIgnoreCase(ty)) {
- // if(array.optJSONObject(i).optInt("id") == 61)
- sf.setBaoYou(true);
- // else
- // sf.setBaoYou(false);
- } else if ("quantype".equalsIgnoreCase(ty)) {
- // if (array.optJSONObject(i).optInt("id") == 31){
+ String type = array.optJSONObject(i).optString("type");
+ if ("quantype".equalsIgnoreCase(type)) {
sf.setQuan(1);
- if (sf.isTmFlagship()) {
- sf.setShopTag(sf.getShopTag() + ",dpyhq");
- } else {
- sf.setShopTag("dpyhq");
- }
- // }
- // else
- // sf.setQuan(2);
- } else if ("hongbaotype".equalsIgnoreCase(ty)) {
- if (array.optJSONObject(i).optInt("id") == 41)// 鏈夌孩锟�?
- sf.setHongbao(1);
- else// 鏃犵孩锟�?
- sf.setHongbao(2);
- } else if ("property".equalsIgnoreCase(ty)) {
- String pid = (String) array.optJSONObject(i).opt("pid");
- String id = (String) array.optJSONObject(i).opt("id");
- boolean flag = false;
- String str = null;
- for (String string : params) {
- flag = string.contains(pid + ":");
- if (flag) {
- str = string;
- break;
- }
- }
- if (flag) {
- params.add(str + "," + id);
- params.remove(str);
- } else {
- params.add(pid + ":" + id);
- }
+ } else if ("baoyou".equalsIgnoreCase(type)) {
+ sf.setBaoYou(true);
+ } else if ("usertype".equalsIgnoreCase(type)) {
+ sf.setTmall(true);
+ } else if ("recommend".equalsIgnoreCase(type)) {
+ //
+ recommend = true;
}
}
- sf.setParams(params);
}
- TaoBaoSearchResult result = TaoBaoUtil.search(sf);
- List<TaoBaoSearchNav> navList = TaoBaoUtil.getBaseNav();
- if (result.getNavList() != null)
- navList.addAll(result.getNavList());
- Gson gson = new GsonBuilder().create();
- JSONObject data = new JSONObject();
- data.put("nav", gson.toJson(navList));
- List<TaoBaoGoodsBriefExtra> re = new ArrayList<TaoBaoGoodsBriefExtra>();
- List<TaoBaoGoodsBrief> taoBaoGoodsBriefs = result.getTaoBaoGoodsBriefs();
- int fq = sf.getQuan();
- int fh = sf.getHongbao();
- boolean ft = sf.isTmall();
- Map<String, String> map = manageService.convertMap();
- BigDecimal proportion = manageService.getFanLiRate();
- if (fq == 0 && fh == 0 && !ft) {
- for (TaoBaoGoodsBrief bf : result.getTaoBaoGoodsBriefs()) {
- re.add(TaoBaoUtil.getTaoBaoGoodsBriefExtra(bf, proportion.toString(), ""));
+
+ if (!StringUtil.isNullOrEmpty(startprice))
+ sf.setStartPrice(new BigDecimal(startprice));
+ if (!StringUtil.isNullOrEmpty(endprice))
+ sf.setEndPrice(new BigDecimal(endprice));
+
+ if (!StringUtil.isNullOrEmpty(rate))
+ try {
+ sf.setStartTkRate(Integer.parseInt(rate));
+ } catch (Exception e) {
}
+ if (!StringUtil.isNullOrEmpty(order))
+ if (Integer.parseInt(order) == 0)
+ sf.setSort(TaoBaoUtil.SORT_SALE_HIGH_TO_LOW);
+ else if (Integer.parseInt(order) == 2)
+ sf.setSort(TaoBaoUtil.SORT_PRICE_LOW_TO_HIGH);
+ else if (Integer.parseInt(order) == 3)
+ sf.setSort(TaoBaoUtil.SORT_PRICE_HIGH_TO_LOW);
+ else if (Integer.parseInt(order) == 4)
+ sf.setSort(TaoBaoUtil.SORT_TKRATE_HIGH_TO_LOW);
+ if (StringUtil.isNullOrEmpty(kw))
+ recommend = true;
+
+ List<TaoBaoGoodsBriefExtra> listExtra = new ArrayList<TaoBaoGoodsBriefExtra>();
+
+ long count = 0;
+ if (recommend) {
+
+ List<QualityFactory> listQuery = qualityGoodsService.listRecommendBykey((page - 1) * pagesize, pagesize, kw,
+ sf.getQuan() == 1 ? 1 : 0, sf.isTmall() ? 1 : 0,
+ StringUtil.isNullOrEmpty(startprice) ? null : Double.parseDouble(startprice),
+ StringUtil.isNullOrEmpty(endprice) ? null : Double.parseDouble(endprice),
+ StringUtil.isNullOrEmpty(rate) ? null : Double.parseDouble(rate), null, 1);
+
+ BigDecimal proportion = manageService.getFanLiRate();
+ /* 閬嶅巻鍒楄〃鏁版嵁 */
+ if (listQuery != null && listQuery.size() > 0) {
+ for (QualityFactory selectionGoods : listQuery) {
+
+ TaoBaoGoodsBrief taoBaoGoodsBrief = selectionGoods.getTaoBaoGoodsBrief();
+
+ if (taoBaoGoodsBrief == null) {
+ continue;
+ }
+
+ int biz30day = taoBaoGoodsBrief.getBiz30day();
+ if (biz30day >= 10000) {
+ double sales = biz30day;
+ String salesCountMidea = String.format("%.1f", sales / 10000);
+ taoBaoGoodsBrief.setSalesCount(salesCountMidea + "涓�");
+ } else {
+ taoBaoGoodsBrief.setSalesCount(biz30day + "");
+ }
+
+ // 鏀瑰彉鍥剧墖灏哄
+ String pictUrl = taoBaoGoodsBrief.getPictUrl();
+ if (!StringUtil.isNullOrEmpty(pictUrl) && !pictUrl.contains("320x320")) {
+ taoBaoGoodsBrief.setPictUrl(TbImgUtil.getTBSize320Img(pictUrl));
+ }
+
+ listExtra.add(TaoBaoUtil.getTaoBaoGoodsBriefExtra(taoBaoGoodsBrief, proportion.toString(), null));
+ }
+ }
+ count = qualityGoodsService.countRecommendBykey(kw, sf.getQuan() == 1 ? 1 : 0, sf.isTmall() ? 1 : 0,
+ StringUtil.isNullOrEmpty(startprice) ? null : Double.parseDouble(startprice),
+ StringUtil.isNullOrEmpty(endprice) ? null : Double.parseDouble(endprice),
+ StringUtil.isNullOrEmpty(rate) ? null : Double.parseDouble(rate), null);
+
} else {
- TaoBaoGoodsBriefExtra taoBaoGoodsBriefExtra;
- for (TaoBaoGoodsBrief taoBaoGoodsBrief : taoBaoGoodsBriefs) {
- taoBaoGoodsBriefExtra = TaoBaoUtil.getTaoBaoGoodsBriefExtra(taoBaoGoodsBrief, proportion.toString(), "");
- re.add(taoBaoGoodsBriefExtra);
+ TaoBaoSearchResult result = TaoBaoUtil.search(sf);
+ if (result != null) {
+ List<TaoBaoGoodsBrief> taoBaoGoodsBriefs = result.getTaoBaoGoodsBriefs();
+ int fq = sf.getQuan();
+ int fh = sf.getHongbao();
+ boolean ft = sf.isTmall();
+ BigDecimal proportion = manageService.getFanLiRate();
+ if (fq == 0 && fh == 0 && !ft) {
+ if (taoBaoGoodsBriefs != null)
+ for (TaoBaoGoodsBrief bf : taoBaoGoodsBriefs) {
+ listExtra.add(TaoBaoUtil.getTaoBaoGoodsBriefExtra(bf, proportion.toString(), ""));
+ }
+ } else {
+ TaoBaoGoodsBriefExtra taoBaoGoodsBriefExtra;
+ if (taoBaoGoodsBriefs != null)
+ for (TaoBaoGoodsBrief taoBaoGoodsBrief : taoBaoGoodsBriefs) {
+ taoBaoGoodsBriefExtra = TaoBaoUtil.getTaoBaoGoodsBriefExtra(taoBaoGoodsBrief,
+ proportion.toString(), "");
+ listExtra.add(taoBaoGoodsBriefExtra);
+ }
+ }
+ count = result.getTaoBaoHead().getDocsfound();
}
+
}
+ JSONObject data = new JSONObject();
Gson gson2 = new GsonBuilder().excludeFieldsWithoutExposeAnnotation().create();
- data.put("result", gson2.toJson(re));
- data.put("count", result.getTaoBaoHead().getDocsfound());
- return data;
- }
-
- /**
- *
- * 鏂规硶璇存槑: 鑱旂郴瀹㈡湇鎺ュ彛
- *
- * @author mawurui createTime 2018骞�4鏈�10鏃� 涓婂崍9:02:41
- */
- @RequestMapping(value = "contactCustomer", method = RequestMethod.GET)
- public void contactCustomerService(PrintWriter out) {
- String title = "鑱旂郴瀹㈡湇";
- List<CustomerContent> contentList = systemClientParamsService.contactCustomerService(title);
- JSONObject data = new JSONObject();
- data.put("contentList", JsonUtil.getSimpleGsonWithDate().toJson(contentList));
- out.print(JsonUtil.loadTrueResult(data));
- }
-
- /**
- *
- * 鏂规硶璇存槑: 鐑棬鎼滅储
- *
- * @author mawurui createTime 2018骞�5鏈�11鏃� 涓嬪崍4:32:46
- * @param acceptData
- * @param out
- */
- @RequestMapping(value = "getHotSearch", method = RequestMethod.GET)
- public void getHotSearch(AcceptData acceptData, String callback, PrintWriter out) {
- /*
- * System system = xcxMiniControllerUtil.getSystem(acceptData); if
- * (system == null) {
- * out.print(JsonUtil.loadFalseResult(XcxMiniControllerUtil.NOSYSTEM));
- * return; }
- */
- List<SuperHotSearch> superHotSearchList = superHotSearchSerivce.getSuperHotSearchBySystemId(4); // 杩斿埄鍒竌pp
- if (superHotSearchList == null || superHotSearchList.size() == 0) {
- out.print(JsonUtil.loadFalseResult(WebControllerUtil.NODATA));
- return;
- }
- List<HotSearch> hotSearchList = new ArrayList<HotSearch>();
- for (SuperHotSearch superHotSearch : superHotSearchList) {
- HotSearch hotSearch = superHotSearch.getHotSearch();
- hotSearchList.add(hotSearch);
- }
-
- JSONObject data = new JSONObject();
- data.put("count", hotSearchList.size());
- data.put("hotSearchList", hotSearchList);
-
- String result = JsonUtil.loadJSONP(callback, JsonUtil.loadTrueResult(data));
- out.print(result);
- return;
+ data.put("result", gson2.toJson(listExtra));
+ data.put("count", count);
+ out.print(JsonUtil.loadJSONP(callback, JsonUtil.loadTrueResult(data)));
}
}
--
Gitblit v1.8.0