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