From ab35ac8b769b2d9816dffb33a64f2c6f7bd5dd6e Mon Sep 17 00:00:00 2001 From: admin <weikou2014> Date: 星期四, 05 九月 2024 17:05:55 +0800 Subject: [PATCH] 风行网页版爬虫 --- src/main/java/com/yeshi/buwan/controller/parser/UserParser.java | 146 ++++++++++++++++++++++++++++++++++++++++-------- 1 files changed, 122 insertions(+), 24 deletions(-) diff --git a/src/main/java/com/yeshi/buwan/controller/parser/UserParser.java b/src/main/java/com/yeshi/buwan/controller/parser/UserParser.java index 1586f95..54151b5 100644 --- a/src/main/java/com/yeshi/buwan/controller/parser/UserParser.java +++ b/src/main/java/com/yeshi/buwan/controller/parser/UserParser.java @@ -1,6 +1,7 @@ package com.yeshi.buwan.controller.parser; import com.google.gson.Gson; +import com.google.gson.GsonBuilder; import com.google.gson.reflect.TypeToken; import com.yeshi.buwan.domain.Collection; import com.yeshi.buwan.domain.*; @@ -15,6 +16,7 @@ import com.yeshi.buwan.dto.search.SolrShortVideoSearchFilter; import com.yeshi.buwan.dto.search.SolrVideoSearchFilter; import com.yeshi.buwan.dto.user.LoginInfoDto; +import com.yeshi.buwan.dto.user.QQUserInfo; import com.yeshi.buwan.exception.SMSException; import com.yeshi.buwan.exception.user.LoginUserException; import com.yeshi.buwan.exception.user.RegisterUserException; @@ -32,9 +34,11 @@ import com.yeshi.buwan.util.factory.vo.UserInfoVOFactory; import com.yeshi.buwan.util.log.LoggerUtil; import com.yeshi.buwan.util.log.UserActiveLogFactory; +import com.yeshi.buwan.util.login.QQLoginUtil; import com.yeshi.buwan.util.video.VideoCategoryConstant; import com.yeshi.buwan.util.video.VideoConstant; import com.yeshi.buwan.util.video.VideoUtil; +import com.yeshi.buwan.util.wx.MyWXLoginUtil; import com.yeshi.buwan.videos.pptv.PPTVUtil; import com.yeshi.buwan.vo.AcceptData; import com.yeshi.buwan.vo.video.VideoListResultVO; @@ -43,6 +47,7 @@ import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.stereotype.Controller; +import org.yeshi.utils.entity.wx.WeiXinUser; import org.yeshi.utils.exception.MailSendException; import org.yeshi.utils.mail.EmailApiUtil; import org.yeshi.utils.mail.EmailInfo; @@ -104,6 +109,9 @@ @Resource private SMSService smsService; + + @Resource + DetailSystemConfigService detailSystemConfigService; public void getUid(AcceptData acceptData, HttpServletRequest request, PrintWriter out) { DetailSystem detailSystem = systemService.getDetailSystemByPackage(acceptData.getPackageName()); @@ -1146,7 +1154,7 @@ return; } - if (!StringUtil.isNullOrEmpty(account) && !account.trim().endsWith("@qq.com")) { + if (!StringUtil.isNullOrEmpty(account) && !account.trim().endsWith("@qq.com") && !acceptData.getPackage().equalsIgnoreCase("com.yeshi.buwanshequ.ios")) { out.print(JsonUtil.loadFalseJson("鍙敮鎸丵Q閭娉ㄥ唽")); return; } @@ -1188,7 +1196,7 @@ out.print(JsonUtil.loadFalseJson("璇蜂笂浼燛mail")); return; } - if (!StringUtil.isNullOrEmpty(account) && !account.trim().endsWith("@qq.com")) { + if (!StringUtil.isNullOrEmpty(account) && !account.trim().endsWith("@qq.com") && !acceptData.getPackage().equalsIgnoreCase("com.yeshi.buwanshequ.ios")) { out.print(JsonUtil.loadFalseJson("鍙敮鎸丵Q閭娉ㄥ唽")); return; } @@ -1265,33 +1273,121 @@ * @param out */ public void login(AcceptData acceptData, HttpServletRequest request, PrintWriter out) { - String account = request.getParameter("Email");// 閭 - String pwd = request.getParameter("Pwd");// 瀵嗙爜 - if (StringUtil.isNullOrEmpty(account)) { - out.print(JsonUtil.loadFalseJson("璇蜂笂浼燛mail")); - return; + String loginType = request.getParameter("LoginType"); + int logintTypeInt = LoginUser.LOGIN_TYPE_EMAIL; + if (!StringUtil.isNullOrEmpty(loginType)) { + logintTypeInt = Integer.parseInt(loginType); } - - if (StringUtil.isNullOrEmpty(pwd)) { - out.print(JsonUtil.loadFalseJson("璇蜂笂浼燩wd")); - return; - } - - // DetailSystem ds = - // systemService.getDetailSystemByPackage(packageName); - // 娉ㄥ唽 --鐢ㄦ埛鍚�,鏄电О,瀵嗙爜 - LoginInfoDto loginInfoDto = new LoginInfoDto(); - loginInfoDto.setLoginType(LoginUser.LOGIN_TYPE_EMAIL); loginInfoDto.setSystemId(acceptData.getDetailSystem().getSystem().getId()); - loginInfoDto.setEmail(account); - loginInfoDto.setPwd(StringUtil.Md5(pwd)); loginInfoDto.setIpInfo(IPUtil.getRemotIP(request) + ":" + request.getRemotePort()); + switch (logintTypeInt) { + case LoginUser.LOGIN_TYPE_EMAIL: { + String account = request.getParameter("Email");// 閭 + String pwd = request.getParameter("Pwd");// 瀵嗙爜 + if (StringUtil.isNullOrEmpty(account)) { + out.print(JsonUtil.loadFalseJson("璇蜂笂浼燛mail")); + return; + } + + if (StringUtil.isNullOrEmpty(pwd)) { + out.print(JsonUtil.loadFalseJson("璇蜂笂浼燩wd")); + return; + } + loginInfoDto.setLoginType(LoginUser.LOGIN_TYPE_EMAIL); + loginInfoDto.setSystemId(acceptData.getDetailSystem().getSystem().getId()); + loginInfoDto.setEmail(account); + loginInfoDto.setPwd(StringUtil.Md5(pwd)); + } + break; + case LoginUser.LOGIN_TYPE_PHONE: { + String account = request.getParameter("Phone");// 閭 + String pwd = request.getParameter("Pwd");// 瀵嗙爜 + if (StringUtil.isNullOrEmpty(account)) { + out.print(JsonUtil.loadFalseJson("璇蜂笂浼犵數璇濆彿鐮�")); + return; + } + + if (StringUtil.isNullOrEmpty(pwd)) { + out.print(JsonUtil.loadFalseJson("璇蜂笂浼犲瘑鐮�")); + return; + } + loginInfoDto.setLoginType(LoginUser.LOGIN_TYPE_PHONE); + loginInfoDto.setPhone(account); + loginInfoDto.setPwd(StringUtil.Md5(pwd)); + + } + break; + case LoginUser.LOGIN_TYPE_QQ: { + String accessToken = request.getParameter("AccessToken"); + String openId = request.getParameter("OpenId"); + if (StringUtil.isNullOrEmpty(accessToken) || StringUtil.isNullOrEmpty(openId)) { + out.print(JsonUtil.loadFalseJson("璇蜂笂浼燪Q鎺堟潈淇℃伅")); + return; + } + + String qqAppId = detailSystemConfigService.getConfigValueByKey("qq_app_id", acceptData.getDetailSystem().getId(), acceptData.getVersion()); + if (StringUtil.isNullOrEmpty(qqAppId)) { + out.print(JsonUtil.loadFalseJson("QQ APPID鑾峰彇鍑洪敊")); + return; + } + QQLoginUtil.QQUserInfoEntity userEntity = QQLoginUtil.getUserInfo(qqAppId.trim(), accessToken, openId); + if (userEntity == null) { + out.print(JsonUtil.loadFalseJson("QQ鐢ㄦ埛淇℃伅瑙f瀽鍑洪敊")); + return; + } + + QQUserInfo userInfo = new QQUserInfo(); + userInfo.setSex(userEntity.getGender()); + userInfo.setPortrait(userEntity.getFigureurl()); + userInfo.setOpenId(openId); + userInfo.setName(userEntity.getNickname()); + loginInfoDto.setLoginType(LoginUser.LOGIN_TYPE_QQ); + loginInfoDto.setQqUserInfo(userInfo); + } + break; + case LoginUser.LOGIN_TYPE_WX: { + String code = request.getParameter("Code"); + if (StringUtil.isNullOrEmpty(code)) { + out.print(JsonUtil.loadFalseJson("璇蜂笂浼犲井淇℃巿鏉冪爜")); + return; + } + + WeiXinUser weiXinUser = MyWXLoginUtil.getUserInfo(code, MyWXLoginUtil.WEIXIN_APPID, MyWXLoginUtil.WEIXIN_SECRET); + if (weiXinUser == null) { + out.print(JsonUtil.loadFalseJson("鑾峰彇鎺堟潈淇℃伅澶辫触,璇风◢鍚庡啀璇�")); + return; + } + loginInfoDto.setLoginType(LoginUser.LOGIN_TYPE_WX); + loginInfoDto.setWeiXinUser(weiXinUser); + } + break; + default: + out.print(JsonUtil.loadFalseJson("鐧诲綍鏂瑰紡閿欒")); + return; + } + try { LoginUser user = userService.login(loginInfoDto); out.print(JsonUtil.loadTrueJson(StringUtil.outPutResultJson(user))); } catch (LoginUserException e) { - out.print(JsonUtil.loadFalseJson(e.getMessage())); + if ((logintTypeInt == LoginUser.LOGIN_TYPE_WX || logintTypeInt == LoginUser.LOGIN_TYPE_QQ) && e.getCode() == LoginUserException.CODE_NO_USER) { + //娉ㄥ唽 + try { + LoginUser lu = userService.register(loginInfoDto); + if (lu != null) { + JSONObject object = new JSONObject(); + object.put("user", new GsonBuilder().excludeFieldsWithoutExposeAnnotation().create().toJson(lu)); + out.print(JsonUtil.loadTrueJson(object.toString())); + } else { + out.print(JsonUtil.loadFalseJson("鐧诲綍澶辫触")); + } + } catch (RegisterUserException e1) { + out.print(JsonUtil.loadFalseJson("鐧诲綍澶辫触")); + } + } else { + out.print(JsonUtil.loadFalseJson(e.getMessage())); + } } } @@ -1381,7 +1477,7 @@ user.setPortrait(potrait); if (!StringUtil.isNullOrEmpty(sex)) user.setSex(sex); - if (!StringUtil.isNullOrEmpty(acceptData.getSign())) + if (!StringUtil.isNullOrEmpty(personalSign)) user.setSign(personalSign); if (!StringUtil.isNullOrEmpty(birthDay)) user.setBirthday(birthDay); @@ -1426,6 +1522,8 @@ * @param out */ public void setPwd(AcceptData acceptData, HttpServletRequest request, PrintWriter out) { + + String email = request.getParameter("Email");// 涓�х鍚� String pwd = request.getParameter("Pwd");// 瀵嗙爜 String verifyCode = request.getParameter("VerifyCode");// 楠岃瘉鐮� @@ -1451,7 +1549,7 @@ } // 娉ㄥ唽 --鐢ㄦ埛鍚�,鏄电О,瀵嗙爜 - LoginUser user = userService.getLoginUserByOpenId(email); + LoginUser user = userService.getValidLoginUserByEmail(email, acceptData.getDetailSystem().getSystem().getId()); if (user == null) { out.print(JsonUtil.loadFalseJson("璇ョ敤鎴蜂笉瀛樺湪")); } else { @@ -1495,7 +1593,7 @@ public static String savePortrait(String base64, HttpSession session) { if (StringUtil.isNullOrEmpty(base64)) return ""; - base64 = base64.replace("\r\n",""); + base64 = base64.replace("\r\n", ""); String fileName = "portrait_" + System.currentTimeMillis() + ".jpg"; // 瀹氫箟涓婁紶璺緞 -- Gitblit v1.8.0