From 04f09e52ffd4681bdfd85e51acd3da0d1280c3d3 Mon Sep 17 00:00:00 2001 From: admin <weikou2014> Date: 星期六, 16 四月 2022 16:07:10 +0800 Subject: [PATCH] bug修复 --- src/main/java/com/yeshi/buwan/controller/parser/UserParser.java | 135 +++++++++++++++++++++++++++++++++++++++++--- 1 files changed, 125 insertions(+), 10 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 9598bf3..9181699 100644 --- a/src/main/java/com/yeshi/buwan/controller/parser/UserParser.java +++ b/src/main/java/com/yeshi/buwan/controller/parser/UserParser.java @@ -2,8 +2,8 @@ import com.google.gson.Gson; import com.google.gson.reflect.TypeToken; -import com.yeshi.buwan.domain.*; import com.yeshi.buwan.domain.Collection; +import com.yeshi.buwan.domain.*; import com.yeshi.buwan.domain.solr.SolrAlbumVideo; import com.yeshi.buwan.domain.solr.SolrShortVideo; import com.yeshi.buwan.domain.system.DetailSystem; @@ -15,10 +15,11 @@ 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.exception.SMSException; import com.yeshi.buwan.exception.user.LoginUserException; import com.yeshi.buwan.exception.user.RegisterUserException; -import com.yeshi.buwan.videos.pptv.PPTVUtil; import com.yeshi.buwan.service.imp.*; +import com.yeshi.buwan.service.inter.SMSService; import com.yeshi.buwan.service.inter.juhe.InternetSearchVideoService; import com.yeshi.buwan.service.inter.system.SystemConfigService; import com.yeshi.buwan.service.manager.search.SolrAlbumVideoDataManager; @@ -27,7 +28,6 @@ import com.yeshi.buwan.util.*; import com.yeshi.buwan.util.JuHe.VideoResourceUtil; import com.yeshi.buwan.util.annotation.RequireUid; -import com.yeshi.buwan.util.email.MailSenderUtil; import com.yeshi.buwan.util.factory.VideoInfoFactory; import com.yeshi.buwan.util.factory.vo.UserInfoVOFactory; import com.yeshi.buwan.util.log.LoggerUtil; @@ -35,6 +35,7 @@ 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.videos.pptv.PPTVUtil; import com.yeshi.buwan.vo.AcceptData; import com.yeshi.buwan.vo.video.VideoListResultVO; import net.sf.json.JSONArray; @@ -42,6 +43,9 @@ import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.stereotype.Controller; +import org.yeshi.utils.exception.MailSendException; +import org.yeshi.utils.mail.EmailApiUtil; +import org.yeshi.utils.mail.EmailInfo; import redis.clients.jedis.Jedis; import javax.annotation.Resource; @@ -56,6 +60,8 @@ public class UserParser { Logger searchKeyLogger = LoggerFactory.getLogger("searchKey"); + + Logger logger = LoggerFactory.getLogger(UserParser.class); @Resource @@ -95,6 +101,9 @@ @Resource private RedisManager redisManager; + + @Resource + private SMSService smsService; public void getUid(AcceptData acceptData, HttpServletRequest request, PrintWriter out) { DetailSystem detailSystem = systemService.getDetailSystemByPackage(acceptData.getPackageName()); @@ -721,7 +730,7 @@ //鏂扮増鐑棬鎼滅储 public void getHotSearchNew(AcceptData acceptData, HttpServletRequest request, PrintWriter out) { - DetailSystemConfig config = configService.getConfigByKey("hot_search", acceptData.getDetailSystem(), acceptData.getVersion()); + DetailSystemConfig config = configService.getConfigByKey("hot_search", acceptData.getDetailSystem(), acceptData.getVersion()); if (config == null) { out.print(JsonUtil.loadFalseJson("鏃犲唴瀹�")); return; @@ -864,7 +873,11 @@ VideoInfo vf = new VideoInfo(); vf.setId(videoId); Collection c = new Collection(); - c.setUser(new UserInfo(acceptData.getUid())); + if (!StringUtil.isNullOrEmpty(acceptData.getUid())) { + c.setUser(new UserInfo(acceptData.getUid())); + } else { + c.setUser(new UserInfo("1")); + } if (!StringUtil.isNullOrEmpty(loginUid)) { c.setLoginUser(new LoginUser(loginUid)); } @@ -1155,7 +1168,7 @@ } final String code = StringUtil.getVerifyCode(); - request.getSession().setAttribute(account, code); + // new Thread(new Runnable() { // public void run() { // for (int i = 0; i < 3; i++) { @@ -1168,13 +1181,56 @@ content = title; } - boolean isS = MailSenderUtil.sendEmail(account, "ysyz17784739772@126.com", "weikou2014", title, - content); + System.out.println(content); + + EmailInfo emailInfo = new EmailInfo(); + emailInfo.setToEmail(account); + emailInfo.setTitle(title); + emailInfo.setFromEmail("app_yzm_zc@163.com"); + emailInfo.setFormEmailPwd("KZKSRTEMDWEQRAQR"); + emailInfo.setContent(content); + emailInfo.setApp("褰辫"); + try { + EmailApiUtil.sendEmail(emailInfo); + request.getSession().setAttribute(account, code); + out.print(JsonUtil.loadTrueJson("楠岃瘉鐮佸彂閫佹垚鍔�")); + } catch (MailSendException e) { + e.printStackTrace(); + out.print(JsonUtil.loadFalseJson("楠岃瘉鐮佸彂閫佸け璐�")); + } // } // }).start(); - out.print(JsonUtil.loadTrueJson("楠岃瘉鐮佸彂閫佹垚鍔�")); } + + + public void sendSMSCode(AcceptData acceptData, HttpServletRequest request, PrintWriter out) { + String phone = request.getParameter("phone"); + + if (StringUtil.isNullOrEmpty(phone)) { + out.print(JsonUtil.loadFalseJson("鐢佃瘽鍙风爜涓嶈兘涓虹┖")); + return; + } + + if (!StringUtil.isMobile(phone)) { + out.print(JsonUtil.loadFalseJson("鐢佃瘽鍙风爜鏍煎紡涓嶆纭�")); + return; + } + + try { + smsService.sendLoginVCode(phone, 6, acceptData.getDetailSystem().getId(), acceptData.getVersion()); + } catch (SMSException e) { + e.printStackTrace(); + out.print(JsonUtil.loadFalseJson(e.getMessage())); + return; + } catch (Exception e) { + logger.error("鐭俊鍙戦�佸嚭閿�", e); + out.print(JsonUtil.loadFalseJson("鐭俊鍙戦�佸嚭閿欙紝璇风◢鍚庡啀璇�")); + return; + } + out.print(JsonUtil.loadTrueJson("")); + } + /** * 鐧诲綍 @@ -1204,11 +1260,70 @@ loginInfoDto.setSystemId(acceptData.getDetailSystem().getSystem().getId()); loginInfoDto.setEmail(account); loginInfoDto.setPwd(StringUtil.Md5(pwd)); + loginInfoDto.setIpInfo(IPUtil.getRemotIP(request) + ":" + request.getRemotePort()); try { LoginUser user = userService.login(loginInfoDto); out.print(JsonUtil.loadTrueJson(StringUtil.outPutResultJson(user))); } catch (LoginUserException e) { out.print(JsonUtil.loadFalseJson(e.getMessage())); + } + } + + + /** + * 鐧诲綍 + * + * @param request + * @param out + */ + public void phoneLogin(AcceptData acceptData, HttpServletRequest request, PrintWriter out) { + String account = request.getParameter("phone");// 閭 + String vcode = request.getParameter("code");// 瀵嗙爜 + if (StringUtil.isNullOrEmpty(account)) { + out.print(JsonUtil.loadFalseJson("璇蜂笂浼犳墜鏈哄彿")); + return; + } + + if (StringUtil.isNullOrEmpty(vcode)) { + out.print(JsonUtil.loadFalseJson("璇蜂笂浼犻獙璇佺爜")); + return; + } + + if (!smsService.verifyLoginVCode(account, vcode, acceptData.getDetailSystem().getId(), acceptData.getVersion())) { + out.print(JsonUtil.loadFalseJson("楠岃瘉鐮侀敊璇�")); + return; + } + + LoginInfoDto loginInfoDto = new LoginInfoDto(); + loginInfoDto.setLoginType(LoginUser.LOGIN_TYPE_PHONE); + loginInfoDto.setSystemId(acceptData.getDetailSystem().getSystem().getId()); + loginInfoDto.setPhone(account); + loginInfoDto.setSmsCode(vcode); + loginInfoDto.setIpInfo(IPUtil.getRemotIP(request) + ":" + request.getRemotePort()); + try { + LoginUser user = userService.login(loginInfoDto); + out.print(JsonUtil.loadTrueJson(StringUtil.outPutResultJson(user))); + } catch (LoginUserException e) { + //鐢ㄦ埛涓嶅瓨鍦� + if (e.getCode() == LoginUserException.CODE_NO_USER) { + //娉ㄥ唽鐢ㄦ埛 + try { + userService.register(loginInfoDto); + //娉ㄥ唽鎴愬姛锛屽紑濮嬬櫥褰� + try { + LoginUser user = userService.login(loginInfoDto); + out.print(JsonUtil.loadTrueJson(StringUtil.outPutResultJson(user))); + } catch (LoginUserException e2) { + out.print(JsonUtil.loadFalseJson("鐧诲綍鍑洪敊锛岃绋嶅悗鍐嶈瘯")); + } + + } catch (RegisterUserException e1) { + e1.printStackTrace(); + out.print(JsonUtil.loadFalseJson("鐧诲綍鍑洪敊锛岃绋嶅悗鍐嶈瘯")); + } + } else { + out.print(JsonUtil.loadFalseJson(e.getMessage())); + } } } @@ -1360,7 +1475,7 @@ String path = session.getServletContext().getRealPath("upload") + "/" + fileName; if (!new File(session.getServletContext().getRealPath("upload") + "/").exists()) new File(session.getServletContext().getRealPath("upload") + "/").mkdirs(); - boolean isS = StringUtil.generateImageFromBase64(base64, path); + boolean isS = StringUtil.generateImageFromBase64(base64.replace("\n",""), path); if (!isS) return ""; -- Gitblit v1.8.0