yujian
2019-03-14 4aadf484e193995c23ee1d5bb1971a497d2f9a0d
fanli/src/main/java/com/yeshi/fanli/controller/client/SearchController.java
@@ -10,10 +10,6 @@
import javax.annotation.Resource;
import net.sf.ehcache.Element;
import net.sf.json.JSONArray;
import net.sf.json.JSONObject;
import org.springframework.cache.annotation.Cacheable;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
@@ -29,7 +25,7 @@
import com.yeshi.fanli.entity.bus.search.HistorySearch;
import com.yeshi.fanli.entity.bus.search.HotSearch;
import com.yeshi.fanli.entity.bus.su.search.SuperHotSearch;
import com.yeshi.fanli.entity.system.System;
import com.yeshi.fanli.entity.system.BusinessSystem;
import com.yeshi.fanli.entity.taobao.PidUser;
import com.yeshi.fanli.entity.taobao.SearchFilter;
import com.yeshi.fanli.entity.taobao.TaoBaoGoodsBrief;
@@ -38,9 +34,9 @@
import com.yeshi.fanli.entity.taobao.TaoBaoSearchNav;
import com.yeshi.fanli.entity.taobao.TaoBaoSearchResult;
import com.yeshi.fanli.entity.taobao.TaoBaoUnionConfig;
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.config.SystemService;
import com.yeshi.fanli.service.inter.goods.HonestService;
import com.yeshi.fanli.service.inter.hongbao.HongBaoManageService;
import com.yeshi.fanli.service.inter.lable.QualityGoodsService;
import com.yeshi.fanli.service.inter.lable.TaoKeGoodsService;
@@ -52,12 +48,19 @@
import com.yeshi.fanli.util.taobao.SearchFilterUtil;
import com.yeshi.fanli.util.taobao.TaoBaoUtil;
import net.sf.ehcache.Element;
import net.sf.json.JSONArray;
import net.sf.json.JSONObject;
@Controller
@RequestMapping("api/v1/search")
public class SearchController {
   @Resource
   private SystemService systemService;
   private BusinessSystemService businessSystemService;
   @Resource
   private ConfigService configService;
   @Resource
   private SuperHotSearchService superHotSearchSerivce;
@@ -69,21 +72,17 @@
   private HongBaoManageService manageService;
   @Resource
   private HonestService honestService;
   @Resource
   private TaoBaoUnionConfigService taoBaoUnionConfigService;
   @Resource
   private TaoKeGoodsService taoKeGoodsService;
   @Resource
   private QualityGoodsService qualityGoodsService;
   @RequestMapping(value = "gethotsearch", method = RequestMethod.POST)
   public void getHotSearch(AcceptData acceptData, PrintWriter out) {
      System system = systemService.getSystemCache(acceptData.getPlatform(), acceptData.getPackages());
      BusinessSystem system = businessSystemService.getBusinessSystemCache(acceptData.getPlatform(), acceptData.getPackages());
      if (system == null) {
         out.print(JsonUtil.loadFalseResult("系统不存在"));
         return;
@@ -110,7 +109,7 @@
   @RequestMapping("specialSearch")
   public void specialSearch(AcceptData acceptData, long hid, int page, PrintWriter out) {
      Honest honest = honestService.getOne(hid);
      Honest honest = null;
      if (honest == null) {
         out.print(JsonUtil.loadFalseResult(""));
         return;
@@ -137,11 +136,9 @@
      data.put("nav", gson.toJson(navList));
      List<TaoBaoGoodsBriefExtra> re = new ArrayList<TaoBaoGoodsBriefExtra>();
      List<TaoBaoGoodsBrief> taoBaoGoodsBriefs = result.getTaoBaoGoodsBriefs();
      Map<String, String> map = manageService.convertMap();
      String proportion = map.get("hongbao_goods_proportion");
      String fcRate = map.get("hongbao_fc_ratio");
      BigDecimal proportion = manageService.getFanLiRate();
      for (TaoBaoGoodsBrief bf : taoBaoGoodsBriefs) {
         re.add(TaoBaoUtil.getTaoBaoGoodsBriefExtra(bf, proportion, fcRate, ""));
         re.add(TaoBaoUtil.getTaoBaoGoodsBriefExtra(bf, proportion.toString(), ""));
      }
      Gson gson2 = JsonUtil.getApiCommonGson();
      data.put("result", gson2.toJson(re));
@@ -163,7 +160,7 @@
         String endprice, String fastFilter, PrintWriter out) {
      String bid = getHistorySearchBid(acceptData);
      historySearchService.addHistorySearch(kw, bid);
      System system = systemService.getSystemCache(acceptData.getPlatform(), acceptData.getPackages());
      BusinessSystem system = businessSystemService.getBusinessSystemCache(acceptData.getPlatform(), acceptData.getPackages());
      if (system == null) {
         out.print(JsonUtil.loadFalseResult("系统不存在"));
         return;
@@ -289,7 +286,7 @@
            } else if ("fahuodi".equalsIgnoreCase(ty)) {
               int id = array.optJSONObject(i).optInt("id");
               sf.setProvinceId(id);
            }else if ("materialId".equalsIgnoreCase(ty)) {
            } else if ("materialId".equalsIgnoreCase(ty)) {
               int id = array.optJSONObject(i).optInt("id");
               sf.setProvinceId(id);
            }
@@ -312,9 +309,7 @@
      int fq = sf.getQuan();
      int fh = sf.getHongbao();
      boolean ft = sf.isTmall();
      Map<String, String> map = manageService.convertMap();
      String proportion = map.get("hongbao_goods_proportion");
      String fcRate = map.get("hongbao_fc_ratio");
      BigDecimal proportion = manageService.getFanLiRate();
      if (fq == 0 && fh == 0 && !ft) {
         if (result != null && result.getTaoBaoGoodsBriefs() != null)
            for (TaoBaoGoodsBrief bf : result.getTaoBaoGoodsBriefs()) {
@@ -323,10 +318,10 @@
                  double sales = count;
                  String salesCountMidea = String.format("%.1f", sales / 10000);
                  bf.setSalesCount(salesCountMidea + "万");
                  re.add(TaoBaoUtil.getTaoBaoGoodsBriefExtra(bf, proportion, fcRate, ""));
                  re.add(TaoBaoUtil.getTaoBaoGoodsBriefExtra(bf, proportion.toString(), ""));
               } else {
                  bf.setSalesCount(count + "");
                  re.add(TaoBaoUtil.getTaoBaoGoodsBriefExtra(bf, proportion, fcRate, ""));
                  re.add(TaoBaoUtil.getTaoBaoGoodsBriefExtra(bf, proportion.toString(), ""));
               }
            }
      } else {
@@ -338,13 +333,13 @@
                  double sales = count;
                  String salesCountMidea = String.format("%.1f", sales / 10000);
                  taoBaoGoodsBrief.setSalesCount(salesCountMidea + "万");
                  taoBaoGoodsBriefExtra = TaoBaoUtil.getTaoBaoGoodsBriefExtra(taoBaoGoodsBrief, proportion,
                        fcRate, "");
                  taoBaoGoodsBriefExtra = TaoBaoUtil.getTaoBaoGoodsBriefExtra(taoBaoGoodsBrief,
                        proportion.toString(), "");
                  re.add(taoBaoGoodsBriefExtra);
               } else {
                  taoBaoGoodsBrief.setSalesCount(count + "");
                  taoBaoGoodsBriefExtra = TaoBaoUtil.getTaoBaoGoodsBriefExtra(taoBaoGoodsBrief, proportion,
                        fcRate, "");
                  taoBaoGoodsBriefExtra = TaoBaoUtil.getTaoBaoGoodsBriefExtra(taoBaoGoodsBrief,
                        proportion.toString(), "");
                  re.add(taoBaoGoodsBriefExtra);
               }
            }
@@ -406,14 +401,16 @@
      return StringUtil.Md5(sb.toString());
   }
   /**
    * 搜索-新版
    *
    * @param acceptData
    * @param kw
    * @param page
    * @param filter
    * @param order  销量由高到低:1 、 价格从高到低:2 、 价格从低到高:3 、 推广量高到低:4(综合默认)、返利比高到低:5 、返利比低到高:6  、推荐20
    * @param order
    *            销量由高到低:1 、 价格从高到低:2 、 价格从低到高:3 、 推广量高到低:4(综合默认)、返利比高到低:5
    *            、返利比低到高:6 、推荐20
    * @param startprice
    * @param endprice
    * @param fastFilter
@@ -421,13 +418,13 @@
    */
   @RequestMapping(value = "searchgoods")
   public void searchgoods(AcceptData acceptData, String kw, int page, String filter, String order, String startprice,
         String endprice, String fastFilter, PrintWriter out) {
         String endprice, Double startTkRate, Double endTkRate, String fastFilter, PrintWriter out) {
      String bid = getHistorySearchBid(acceptData);
      historySearchService.addHistorySearch(kw, bid);
      System system = systemService.getSystemCache(acceptData.getPlatform(), acceptData.getPackages());
      BusinessSystem system = businessSystemService.getBusinessSystemCache(acceptData.getPlatform(), acceptData.getPackages());
      if (system == null) {
         out.print(JsonUtil.loadFalseResult("系统不存在"));
         return;
@@ -437,7 +434,7 @@
         out.print(JsonUtil.loadFalseResult("无法搜索链接"));
         return;
      }
      if (!StringUtil.isNullOrEmpty(fastFilter)) {
         if (!StringUtil.isNullOrEmpty(filter)) {
            JSONArray filterArray = JSONArray.fromObject(filter);
@@ -448,8 +445,7 @@
            filter = fastFilter;
         }
      }
      // 是否是推荐
      boolean recommend = false;
      if (!StringUtil.isNullOrEmpty(fastFilter)) {
@@ -457,14 +453,13 @@
         JSONArray array = JSONArray.fromObject(filter);
         for (int i = 0; i < array.size(); i++) {
            String ty = array.optJSONObject(i).optString("type");
            if ("recommend".equalsIgnoreCase(ty)) {
               recommend = true;
            }
         }
      }
      JSONObject data = null;
      if (!recommend) {
         // 淘宝接口请求
@@ -473,25 +468,27 @@
         // 推荐:精选库
         data = searchQualityGoods(kw, page, filter, order, startprice, endprice);
      }
      // 获取推荐词
      List<String> listRecommendWords = new ArrayList<String>();
      if (page == 0 && StringUtil.isNullOrEmpty(order) && "4".equalsIgnoreCase(order)) {
      // 综合 查询第一页时获取候选词
      if (page == 0) {
         listRecommendWords = TaoBaoUtil.getSuguestSearch(kw);
         if (listRecommendWords == null || listRecommendWords.size() == 0) {
            listRecommendWords = new ArrayList<String>();
         }
         }
      }
      Gson gson = new GsonBuilder().create();
      data.put("words", gson.toJson(listRecommendWords));
      if (data != null)
         data.put("words", gson.toJson(listRecommendWords));
      out.print(JsonUtil.loadTrueResult(data));
   }
   /**
    * 执行搜索-新版
    *
    * @param kw
    * @param page
    * @param filter
@@ -500,7 +497,8 @@
    * @param endprice
    * @return
    */
   private JSONObject searchGoods(String kw, int page, String filter, String order, String startprice, String endprice) {
   private JSONObject searchGoods(String kw, int page, String filter, String order, String startprice,
         String endprice) {
      page = page + 1;
      SearchFilter sf = new SearchFilter();
@@ -599,13 +597,24 @@
            } else if ("fahuodi".equalsIgnoreCase(ty)) {
               int id = array.optJSONObject(i).optInt("id");
               sf.setProvinceId(id);
            }else if ("materialId".equalsIgnoreCase(ty)) {
            } else if ("materialId".equalsIgnoreCase(ty)) {
               int id = array.optJSONObject(i).optInt("id");
               sf.setProvinceId(id);
            } else if ("tkRate1".equalsIgnoreCase(ty)) {
               setSearchTkRate(0, sf);
            } else if ("tkRate2".equalsIgnoreCase(ty)) {
               setSearchTkRate(1, sf);
            } else if ("tkRate3".equalsIgnoreCase(ty)) {
               setSearchTkRate(2, sf);
            } else if ("tkRate4".equalsIgnoreCase(ty)) {
               setSearchTkRate(3, sf);
            } else if ("tkRate5".equalsIgnoreCase(ty)) {
               setSearchTkRate(4, sf);
            }
         }
         sf.setParams(params);
      }
      TaoBaoSearchResult result = TaoBaoUtil.search(sf);
      if (result == null) {
         return null;
@@ -623,8 +632,7 @@
      int fh = sf.getHongbao();
      boolean ft = sf.isTmall();
      Map<String, String> map = manageService.convertMap();
      String proportion = map.get("hongbao_goods_proportion");
      String fcRate = map.get("hongbao_fc_ratio");
      BigDecimal proportion = manageService.getFanLiRate();
      if (fq == 0 && fh == 0 && !ft) {
         if (result != null && result.getTaoBaoGoodsBriefs() != null)
            for (TaoBaoGoodsBrief bf : result.getTaoBaoGoodsBriefs()) {
@@ -633,10 +641,10 @@
                  double sales = count;
                  String salesCountMidea = String.format("%.1f", sales / 10000);
                  bf.setSalesCount(salesCountMidea + "万");
                  re.add(TaoBaoUtil.getTaoBaoGoodsBriefExtra(bf, proportion, fcRate, ""));
                  re.add(TaoBaoUtil.getTaoBaoGoodsBriefExtra(bf, proportion.toString(), ""));
               } else {
                  bf.setSalesCount(count + "");
                  re.add(TaoBaoUtil.getTaoBaoGoodsBriefExtra(bf, proportion, fcRate, ""));
                  re.add(TaoBaoUtil.getTaoBaoGoodsBriefExtra(bf, proportion.toString(), ""));
               }
            }
      } else {
@@ -648,13 +656,13 @@
                  double sales = count;
                  String salesCountMidea = String.format("%.1f", sales / 10000);
                  taoBaoGoodsBrief.setSalesCount(salesCountMidea + "万");
                  taoBaoGoodsBriefExtra = TaoBaoUtil.getTaoBaoGoodsBriefExtra(taoBaoGoodsBrief, proportion,
                        fcRate, "");
                  taoBaoGoodsBriefExtra = TaoBaoUtil.getTaoBaoGoodsBriefExtra(taoBaoGoodsBrief,
                        proportion.toString(), "");
                  re.add(taoBaoGoodsBriefExtra);
               } else {
                  taoBaoGoodsBrief.setSalesCount(count + "");
                  taoBaoGoodsBriefExtra = TaoBaoUtil.getTaoBaoGoodsBriefExtra(taoBaoGoodsBrief, proportion,
                        fcRate, "");
                  taoBaoGoodsBriefExtra = TaoBaoUtil.getTaoBaoGoodsBriefExtra(taoBaoGoodsBrief,
                        proportion.toString(), "");
                  re.add(taoBaoGoodsBriefExtra);
               }
            }
@@ -665,11 +673,10 @@
      data.put("count", result.getTaoBaoHead().getDocsfound());
      return data;
   }
   /**
    * 执行搜索精选库
    *
    * @param kw
    * @param page
    * @param filter
@@ -678,77 +685,155 @@
    * @param endprice
    * @return
    */
   private JSONObject searchQualityGoods(String key, int page, String filter, String order, String startprice, String endprice) {
   private JSONObject searchQualityGoods(String key, int page, String filter, String order, String startprice,
         String endprice) {
      Integer hasQuan = null;
      Integer userType = null;
      Double start_Price = null;
      Double end_Price= null;
      Double end_Price = null;
      Integer sort = null;
      Double startTkRate = null;
      Double endTkRate = null;
      int provinceId = -100;
      // 起始价格
      if (!com.yeshi.fanli.util.StringUtil.isNullOrEmpty(startprice)) {
         start_Price = Double.parseDouble(startprice);
      }
      // 结束价格
      if (!com.yeshi.fanli.util.StringUtil.isNullOrEmpty(endprice)) {
         end_Price =  Double.parseDouble(endprice);
         end_Price = Double.parseDouble(endprice);
      }
      // 排序
      // 排序
      if (!com.yeshi.fanli.util.StringUtil.isNullOrEmpty(order)) {
         if (Integer.parseInt(order) == 4) {
            sort = 20; // 综合时:采用默认权重排序
         } else {
            sort =Integer.parseInt(order);
            sort = Integer.parseInt(order);
         }
      }
      /* 其他筛选条件 */
      /* 其他筛选条件 */
      if (!com.yeshi.fanli.util.StringUtil.isNullOrEmpty(filter)) {
         // 查询淘宝天猫
         JSONArray array = JSONArray.fromObject(filter);
         for (int i = 0; i < array.size(); i++) {
            String ty = array.optJSONObject(i).optString("type");
            if ("userType".equalsIgnoreCase(ty)) {
               userType = 1; // 天猫
            } else if ("quantype".equalsIgnoreCase(ty)) {
               hasQuan = 1; // 有券
            } else if ("hongbaotype".equalsIgnoreCase(ty)) {
            } else if ("fahuodi".equalsIgnoreCase(ty)) {
               provinceId = array.optJSONObject(i).optInt("id");
            } else if ("tkRate1".equalsIgnoreCase(ty)) {
               // 获取对应参数
               String value = configService.get("tkRate_range");
               if (!StringUtil.isNullOrEmpty(value)) {
                  JSONArray tkRatearray = JSONArray.fromObject(value);
                  if (tkRatearray != null) {
                     String start = tkRatearray.optJSONObject(0).optString("start");
                     if (!StringUtil.isNullOrEmpty(start)) {
                        startTkRate = Double.parseDouble(start);
                     }
                     String end = tkRatearray.optJSONObject(0).optString("end");
                     if (!StringUtil.isNullOrEmpty(end)) {
                        endTkRate = Double.parseDouble(end);
                     }
                  }
               }
            } else if ("tkRate2".equalsIgnoreCase(ty)) {
               // 获取对应参数
               String value = configService.get("tkRate_range");
               if (!StringUtil.isNullOrEmpty(value)) {
                  JSONArray tkRatearray = JSONArray.fromObject(value);
                  if (tkRatearray != null) {
                     String start = tkRatearray.optJSONObject(1).optString("start");
                     if (!StringUtil.isNullOrEmpty(start)) {
                        startTkRate = Double.parseDouble(start);
                     }
                     String end = tkRatearray.optJSONObject(1).optString("end");
                     if (!StringUtil.isNullOrEmpty(end)) {
                        endTkRate = Double.parseDouble(end);
                     }
                  }
               }
            } else if ("tkRate3".equalsIgnoreCase(ty)) {
               // 获取对应参数
               String value = configService.get("tkRate_range");
               if (!StringUtil.isNullOrEmpty(value)) {
                  JSONArray tkRatearray = JSONArray.fromObject(value);
                  if (tkRatearray != null) {
                     String start = tkRatearray.optJSONObject(2).optString("start");
                     if (!StringUtil.isNullOrEmpty(start)) {
                        startTkRate = Double.parseDouble(start);
                     }
                     String end = tkRatearray.optJSONObject(2).optString("end");
                     if (!StringUtil.isNullOrEmpty(end)) {
                        endTkRate = Double.parseDouble(end);
                     }
                  }
               }
            } else if ("tkRate4".equalsIgnoreCase(ty)) {
               // 获取对应参数
               String value = configService.get("tkRate_range");
               if (!StringUtil.isNullOrEmpty(value)) {
                  JSONArray tkRatearray = JSONArray.fromObject(value);
                  if (tkRatearray != null) {
                     String start = tkRatearray.optJSONObject(3).optString("start");
                     if (!StringUtil.isNullOrEmpty(start)) {
                        startTkRate = Double.parseDouble(start);
                     }
                     String end = tkRatearray.optJSONObject(3).optString("end");
                     if (!StringUtil.isNullOrEmpty(end)) {
                        endTkRate = Double.parseDouble(end);
                     }
                  }
               }
            } else if ("tkRate5".equalsIgnoreCase(ty)) {
               // 获取对应参数
               String value = configService.get("tkRate_range");
               if (!StringUtil.isNullOrEmpty(value)) {
                  JSONArray tkRatearray = JSONArray.fromObject(value);
                  if (tkRatearray != null) {
                     String start = tkRatearray.optJSONObject(4).optString("start");
                     if (!StringUtil.isNullOrEmpty(start)) {
                        startTkRate = Double.parseDouble(start);
                     }
                     String end = tkRatearray.optJSONObject(4).optString("end");
                     if (!StringUtil.isNullOrEmpty(end)) {
                        endTkRate = Double.parseDouble(end);
                     }
                  }
               }
            }
         }
      }
      int pageSize = Constant.PAGE_SIZE;
      List<QualityFactory> listQuery = qualityGoodsService.listRecommendBykey(page * pageSize,
            pageSize, key, hasQuan, userType, start_Price, end_Price, sort);
      List<QualityFactory> listQuery = qualityGoodsService.listRecommendBykey(page * pageSize, pageSize, key, hasQuan,
            userType, start_Price, end_Price, startTkRate, endTkRate, sort);
      List<TaoBaoGoodsBriefExtra> listExtra = new ArrayList<TaoBaoGoodsBriefExtra>();
      Map<String, String> map = manageService.convertMap();
      String proportion = map.get("hongbao_goods_proportion");
      String fcRate = map.get("hongbao_fc_ratio");
      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;
@@ -757,30 +842,29 @@
            } 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, fcRate, null));
            listExtra.add(TaoBaoUtil.getTaoBaoGoodsBriefExtra(taoBaoGoodsBrief, proportion.toString(), null));
         }
      }
      long count = qualityGoodsService.countRecommendBykey(key, hasQuan, userType, start_Price, end_Price);
      long count = qualityGoodsService.countRecommendBykey(key, hasQuan, userType, start_Price, end_Price,
            startTkRate, endTkRate);
      // 设置发货地址
      TaoBaoSearchNav nav = new TaoBaoSearchNav();
      nav.setName("发货地");
      nav.setName("发货地选择");
      nav.setFlag("address");
      nav.setId(11110);
      nav.setType("fahuodi");
      List<TaoBaoSearchNav> navList = new ArrayList<>();
      List<TaoBaoSearchNav> childNavList = new ArrayList<>();
      List<TaoBaoProvince> provinceList = TaoBaoUtil.getTaoBaoProvinceList();
      for (TaoBaoProvince province : provinceList) {
@@ -795,17 +879,49 @@
      nav.setSubIds(childNavList);
      navList.add(nav);
      Gson gson = new GsonBuilder().create();
      Gson gson2 = JsonUtil.getConvertBigDecimalToStringSubZeroBuilder(new GsonBuilder())
            .excludeFieldsWithoutExposeAnnotation().create();
      JSONObject data = new JSONObject();
      data.put("nav", gson.toJson(navList));
      data.put("result", gson2.toJson(listExtra));
      data.put("count", count);
      return data;
   }
   /**
    * 设置查询佣金比例范围
    *
    * @param i
    * @param sf
    */
   public void setSearchTkRate(int i, SearchFilter sf) {
      // 获取对应参数
      String value = configService.get("tkRate_range");
      if (!StringUtil.isNullOrEmpty(value)) {
         JSONArray tkRatearray = JSONArray.fromObject(value);
         if (tkRatearray != null) {
            String start = tkRatearray.optJSONObject(i).optString("start");
            if (!StringUtil.isNullOrEmpty(start)) {
               int tkRate = (int) (Float.parseFloat(start) * 100);
               sf.setStartTkRate(tkRate);
            }
            String end = tkRatearray.optJSONObject(i).optString("end");
            if (!StringUtil.isNullOrEmpty(end)) {
               int tkRate = (int) (Float.parseFloat(end) * 100);
               sf.setEndTkRate(tkRate);
            }
         }
      }
   }
}