From 31e20ddb1eafa5bf64a0824629fb8c7a05450318 Mon Sep 17 00:00:00 2001 From: admin <weikou2014> Date: 星期五, 19 六月 2020 20:26:28 +0800 Subject: [PATCH] 商品系统完善 --- src/main/java/com/ks/tool/bkz/controller/ParseController.java | 112 +++++++++++++++++++++++++++++++++++++++++++++++--------- 1 files changed, 94 insertions(+), 18 deletions(-) diff --git a/src/main/java/com/ks/tool/bkz/controller/ParseController.java b/src/main/java/com/ks/tool/bkz/controller/ParseController.java index 163ce26..0535661 100644 --- a/src/main/java/com/ks/tool/bkz/controller/ParseController.java +++ b/src/main/java/com/ks/tool/bkz/controller/ParseController.java @@ -1,44 +1,78 @@ package com.ks.tool.bkz.controller; import com.alibaba.fastjson.JSONObject; -import com.ks.tool.bkz.util.FirstOrderSubDataUtil; -import com.ks.tool.bkz.util.UrlUtil; +import com.ks.tool.bkz.dto.FirstOrderSubParseResult; +import com.ks.tool.bkz.entity.FirstOrderSubInfo; +import com.ks.tool.bkz.entity.user.UserInfo; +import com.ks.tool.bkz.exception.TBCookieException; +import com.ks.tool.bkz.service.manager.RedisManager; +import com.ks.tool.bkz.service.sdlj.SDLJGoodsService; +import com.ks.tool.bkz.service.user.UserService; +import com.ks.tool.bkz.util.*; import org.springframework.stereotype.Controller; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.ResponseBody; +import javax.annotation.Resource; +import javax.servlet.http.HttpServletRequest; +import java.io.PrintWriter; +import java.io.UnsupportedEncodingException; +import java.net.URLDecoder; +import java.net.URLEncoder; import java.util.Map; @Controller -@RequestMapping("parse") +@RequestMapping("sdlj/parse") public class ParseController { + @Resource + private RedisManager redisManager; - String cookie = null; + @Resource + private SDLJGoodsService sdljGoodsService; + + @Resource + private UserService userService; + + private String getCookieKey(String tbUid) { + return "tbcookie-" + tbUid; + } @RequestMapping("getRequestUrl") @ResponseBody - public String getRequestUrl(String baseUrl) { + public String getRequestUrl(String baseUrl, String tbUid) { String host = UrlUtil.getHost(baseUrl); Map<String, String> params = UrlUtil.getParamsMap(baseUrl); params.put("t", System.currentTimeMillis() + ""); + + String cookie = redisManager.get(getCookieKey(tbUid)); String token = FirstOrderSubDataUtil.getTokenFromCookie(cookie); String data = params.get("data"); + try { + data = URLDecoder.decode(data, "UTF-8"); + } catch (UnsupportedEncodingException e) { + e.printStackTrace(); + } JSONObject dataJSON = JSONObject.parseObject(data); String paramsStr = dataJSON.getString("params"); dataJSON = JSONObject.parseObject(paramsStr); int pageNo = dataJSON.getInteger("pageNo"); - dataJSON.put("pageNo", pageNo + 1); - JSONObject paramsJSON = new JSONObject(); - paramsJSON.put("params", dataJSON.toJSONString()); - data = paramsJSON.toJSONString(); - String sign = FirstOrderSubDataUtil.getSign(token, params.get("t"), params.get("appKey"), data); - params.put("data", data); - params.put("sign", sign); - String requestUrl = UrlUtil.getRequestUrl(host, params); - - - return requestUrl; + if (pageNo < 30) { + dataJSON.put("pageNo", pageNo + 1); + JSONObject paramsJSON = new JSONObject(); + paramsJSON.put("params", dataJSON.toJSONString()); + data = paramsJSON.toJSONString(); + String sign = FirstOrderSubDataUtil.getSign(token, params.get("t"), params.get("appKey"), data); + params.put("data", data); + params.put("sign", sign); + String requestUrl = UrlUtil.getRequestUrl(host, params); + JSONObject root = new JSONObject(); + root.put("url", requestUrl); + System.out.println(requestUrl); + return JsonUtil.loadTrueResult(root); + } else { + return JsonUtil.loadFalseResult(1, ""); + } } @@ -49,9 +83,51 @@ * @return */ @RequestMapping("uploadCookies") + @ResponseBody public String uploadCookie(String cookies) { - this.cookie = cookies; - return ""; + String tbUid = TBCookieUtil.getTBUid(cookies); + if (!StringUtil.isNullOrEmpty(tbUid)) { + redisManager.save(getCookieKey(tbUid), cookies, 60 * 60); + } + return JsonUtil.loadTrueResult(""); + } + + @RequestMapping("getLoginUrl") + public void getLoginUrl(PrintWriter out) { + JSONObject data = new JSONObject(); + data.put("loginUrl", String.format("http://login.taobao.com/member/login.jhtml?style=mini&newMini2=true&redirectURL=%s&full_redirect=true&disableQuickLogin=true", URLEncoder.encode("https://m.tb.cn/h.VN61jro?sm=9ed9c4"))); + out.print(JsonUtil.loadTrueResult(data)); + } + + + @RequestMapping("getCookie") + @ResponseBody + public String getCookie() { + return redisManager.get("cookie"); + } + + @RequestMapping("uploadContent") + @ResponseBody + public String uploadContent(String content, String tbUid, HttpServletRequest request) { + String token = request.getHeader("token"); + String account = UserUtil.getAccountFromToken(token); + UserInfo user = userService.selectByAccount(account); + try { + FirstOrderSubParseResult result = FirstOrderSubDataUtil.parseOrderSubData(content); + if (result != null && result.isHasNextPage()) { + if (result.getGoodsList() != null) + for (FirstOrderSubInfo info : result.getGoodsList()) { + sdljGoodsService.addSDLJGoods(info,user.getId(),tbUid ); + System.out.println(info.getId() + "-" + info.getTitle()); + } + System.out.println("----------------------------"); + return JsonUtil.loadTrueResult(""); + } else { + return JsonUtil.loadFalseResult(1, "鏃犳洿澶氭暟鎹�"); + } + } catch (TBCookieException e) { + return JsonUtil.loadFalseResult(1001, "娣樺疂鎺堟潈鍑洪敊"); + } } -- Gitblit v1.8.0