From f537abe9f3646c739beaf15076246a2f71a347e9 Mon Sep 17 00:00:00 2001
From: admin <weikou2014>
Date: 星期四, 20 二月 2025 16:57:55 +0800
Subject: [PATCH] IOS广告增加区域屏蔽

---
 src/main/java/com/yeshi/buwan/controller/parser/UserParser.java |  546 ++++++++++++++++++++++++++++++++++++++++++++---------
 1 files changed, 447 insertions(+), 99 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 c683f1a..b2f17e6 100644
--- a/src/main/java/com/yeshi/buwan/controller/parser/UserParser.java
+++ b/src/main/java/com/yeshi/buwan/controller/parser/UserParser.java
@@ -1,36 +1,46 @@
 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.*;
 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;
 import com.yeshi.buwan.domain.system.DetailSystemConfig;
 import com.yeshi.buwan.domain.user.LoginUser;
 import com.yeshi.buwan.domain.video.InternetSearchVideo;
 import com.yeshi.buwan.dto.log.BaseLog;
 import com.yeshi.buwan.dto.search.SolrResultDTO;
+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;
-import com.yeshi.buwan.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.SolrAlbumVideoDataManager;
-import com.yeshi.buwan.service.manager.SolrInternetSearchVideoDataManager;
+import com.yeshi.buwan.service.manager.IPManager;
+import com.yeshi.buwan.service.manager.search.SolrAlbumVideoDataManager;
+import com.yeshi.buwan.service.manager.search.SolrInternetSearchVideoDataManager;
+import com.yeshi.buwan.service.manager.search.SolrShortVideoDataManager;
 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;
 import com.yeshi.buwan.util.log.UserActiveLogFactory;
-import com.yeshi.buwan.util.rank.IqiyiRankUtil;
+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;
 import net.sf.json.JSONArray;
@@ -38,18 +48,29 @@
 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;
+import redis.clients.jedis.Jedis;
 
 import javax.annotation.Resource;
 import javax.servlet.http.HttpServletRequest;
 import javax.servlet.http.HttpSession;
 import java.io.File;
-import java.io.IOException;
 import java.io.PrintWriter;
 import java.lang.reflect.Type;
 import java.util.*;
 
 @Controller
 public class UserParser {
+
+    Logger searchKeyLogger = LoggerFactory.getLogger("searchKey");
+
+    Logger logger = LoggerFactory.getLogger(UserParser.class);
+
+    Logger deviceGeoLogger = LoggerFactory.getLogger("deviceGeo");
+
 
     @Resource
     private SystemService systemService;
@@ -77,10 +98,26 @@
     private SolrAlbumVideoDataManager solrDataManager;
     @Resource
     private SolrInternetSearchVideoDataManager solrInternetSearchVideoDataManager;
+
+    @Resource
+    private SolrShortVideoDataManager solrShortVideoDataManager;
+
     @Resource
     private ConfigParser configParser;
     @Resource
     private SystemConfigService systemConfigService;
+
+    @Resource
+    private RedisManager redisManager;
+
+    @Resource
+    private SMSService smsService;
+
+    @Resource
+    DetailSystemConfigService detailSystemConfigService;
+
+    @Resource
+    private IPManager ipManager;
 
     public void getUid(AcceptData acceptData, HttpServletRequest request, PrintWriter out) {
         DetailSystem detailSystem = systemService.getDetailSystemByPackage(acceptData.getPackageName());
@@ -91,7 +128,7 @@
             out.print(JsonUtil.loadFalseJson("鑾峰彇uid澶辫触"));
             return;
         } else {
-            Map<String, String> map = configService.getConfigAsMap(detailSystem, acceptData.getVersion());
+            Map<String, String> map = configService.getConfigAsMap(acceptData.getChildDetailSystem(), acceptData.getVersion());
             ShareContent share = shareService.getShareContent(detailSystem.getId());
             JSONObject object = new JSONObject();
             object.put("Uid", uid);
@@ -101,7 +138,7 @@
             object.put("ZiXun", map.get("zixun_url"));
             if (acceptData.getPlatform().equalsIgnoreCase("ios") && !"涓浗".equalsIgnoreCase(userInfo.getCountry()))// 姝e湪瀹℃牳鐨勭増鏈�
                 object.put("CommentUrl", "");
-            else
+            else if (share != null)
                 object.put("CommentUrl", share.getShareUrl());
             object.put("IOSSlotID", "");
 
@@ -167,12 +204,10 @@
             // 骞垮憡绫诲瀷
             object.put("adType", map.get("ad_type"));
 
-            int fullVideoVersion = Integer.parseInt(map.get("video_detail_full_video_version"));
-            String fullVideoVersionChannels = map.get("video_detail_full_video_version_channel");
-            JSONObject json = JSONObject.fromObject(fullVideoVersionChannels);
-            if (json.optInt(acceptData.getChannel().toLowerCase(), 0) > 0) {
-                fullVideoVersion = json.optInt(acceptData.getChannel().toLowerCase(), 0);
-            }
+//            String fullVideoVersionChannels = map.get("video_detail_full_video_version_channel");
+//            JSONObject json = JSONObject.fromObject(fullVideoVersionChannels);
+//            if (json.optInt(acceptData.getChannel().toLowerCase(), 0) > 0) {
+//            }
 
 
             ConfigParser.ADConfig adConfig = configParser.getAdShowType("ad_video_detail_full_video", acceptData.getChannel(), acceptData.getVersion(), map);
@@ -318,7 +353,7 @@
             object.put("data", array);
             out.print(JsonUtil.loadTrueJson(object.toString()));
         } else {
-            List<Long> resourceList = videoResouceUtil.getAvailableResourceIds(detailSystem, acceptData.getVersion());
+            List<Long> resourceList = videoResouceUtil.getAvailableResourceIds(detailSystem, acceptData.getVersion(), acceptData.getChannel());
             String cacheMD5 = "0";
             if (resourceList != null && resourceList.size() > 0)
                 for (Long l : resourceList)
@@ -405,6 +440,30 @@
             return;
         }
 
+        final String id = StringUtil.Md5(String.format("%s#%s#%s#%s", acceptData.getDetailSystem().getId(), acceptData.getDevice(), key, type));
+        ThreadUtil.run(new Runnable() {
+            @Override
+            public void run() {
+                String redisKey = "search-" + id;
+                Jedis jedis = redisManager.getJedis();
+                try {
+                    //閲嶅璇锋眰杩囨护
+                    if (jedis.setnx(redisKey, "1") <= 0) {
+                        return;
+                    }
+                    jedis.expire(redisKey, 120);
+                    JSONObject searchData = new JSONObject();
+                    searchData.put("key", key);
+                    searchData.put("type", type);
+                    searchData.put("detailSystemId", acceptData.getDetailSystem().getId());
+                    searchData.put("device", acceptData.getDevice());
+                    searchData.put("createTime", System.currentTimeMillis());
+                    searchKeyLogger.info(new Gson().toJson(searchData));
+                } finally {
+                    jedis.close();
+                }
+            }
+        });
         LoggerUtil.getUserActiveLogger().info(UserActiveLogFactory.createSearch(new BaseLog(acceptData, ""), key, type));
 
         int pageIndex = StringUtil.getPage(page);
@@ -412,7 +471,7 @@
             pageIndex = 1;
         }
 
-        List<Long> resourceList = videoResouceUtil.getAvailableResourceIds(acceptData.getDetailSystem(), acceptData.getVersion());
+        List<Long> resourceList = videoResouceUtil.getAvailableResourceIds(acceptData.getDetailSystem(), acceptData.getVersion(), acceptData.getChannel());
 
 
         String cacheMD5 = "0";
@@ -502,11 +561,13 @@
                 }
             }
 
-
-            vt = new VideoType();
-            vt.setId(Constant.SEARCH_RESULT_TYPE_HIGH_DEFINITION);
-            vt.setName("楂樻竻");
-            typeList.add(vt);
+            //闊╁墽涓嶈繑鍥為珮娓�
+            if (!acceptData.getDetailSystem().getId().equalsIgnoreCase("48")) {
+                vt = new VideoType();
+                vt.setId(Constant.SEARCH_RESULT_TYPE_HIGH_DEFINITION);
+                vt.setName("楂樻竻");
+                typeList.add(vt);
+            }
 
 
             JSONArray array1 = new JSONArray();
@@ -536,7 +597,7 @@
             int rootType = internetSearchVideo.getRootType();
             SolrVideoSearchFilter filter = new SolrVideoSearchFilter();
             filter.setVideoType(rootType);
-            filter.setResourceIds(new String[]{PPTVUtil.RESOURCE_ID + ""});
+            filter.setResourceIds(Arrays.asList(new String[]{PPTVUtil.RESOURCE_ID + ""}));
             filter.setSortKey("watchcount");
             SolrResultDTO dto = solrDataManager.find(filter, 1, 20);
             List<SolrAlbumVideo> solrAlbumVideoList = new ArrayList<>();
@@ -581,18 +642,53 @@
 
     }
 
+
+    private void guessLikeForShortVideo(AcceptData acceptData, String videoId, PrintWriter out) {
+        SolrShortVideo solrShortVideo = solrShortVideoDataManager.findOne(videoId);
+        SolrShortVideoSearchFilter filter = new SolrShortVideoSearchFilter();
+        filter.setRootVideoType(solrShortVideo.getRootVideoType());
+        if (solrShortVideo.getArea() != null) {
+            filter.setAreas(Arrays.asList(solrShortVideo.getArea().split(",")));
+        }
+
+        SolrResultDTO dto = solrShortVideoDataManager.find(filter, 1, 10);
+
+
+        JSONObject object = new JSONObject();
+        object.put("count", dto.getVideoList().size() + "");
+        JSONArray array = new JSONArray();
+
+        for (int i = 0; i < dto.getVideoList().size(); i++) {
+            SolrShortVideo temp = (SolrShortVideo) dto.getVideoList().get(i);
+            if (temp.getId().equalsIgnoreCase(videoId))
+                continue;
+            array.add(StringUtil.outPutResultJson(VideoInfoFactory.create(temp)));
+        }
+        if (array.size() % 2 != 0) {
+            array.remove(array.size() - 1);
+        }
+
+        object.put("data", array);
+        out.print(JsonUtil.loadTrueJson(object.toString()));
+    }
+
     // 鐚滀綘鍠滄
     public void guessLike(AcceptData acceptData, HttpServletRequest request, PrintWriter out) {
 
         String videoId = request.getParameter("VideoId");
-        if (!NumberUtil.isNumeric(videoId)) {
-            guessLikeForInternetSearch(acceptData, videoId, out);
-            return;
+        int fromtype = VideoUtil.getVideoFromType(videoId);
+        switch (fromtype) {
+            case HomeVideo.FROM_TYPE_INTERNET:
+                guessLikeForInternetSearch(acceptData, videoId, out);
+                return;
+            case HomeVideo.FROM_TYPE_SHORT:
+                guessLikeForShortVideo(acceptData, videoId, out);
+                return;
         }
 
         DetailSystem ds = systemService.getDetailSystemByPackage(acceptData.getPackageName());
 
-        List<Long> resourceList = videoResouceUtil.getAvailableResourceIds(acceptData.getDetailSystem(), acceptData.getVersion());
+        List<Long> resourceList = videoResouceUtil.getAvailableResourceIds(acceptData.getDetailSystem(), acceptData.getVersion(), acceptData.getChannel());
         List<VideoInfo> list1 = StringUtil.isNullOrEmpty(videoId)
                 ? recommendService.guessLikeList(ds.getId(), 4, resourceList, CacheUtil.getMD5Long(resourceList))
                 : recommendService.guessLikeList(ds.getId(), 4, videoId, resourceList,
@@ -713,6 +809,32 @@
                         break;
                 }
             }
+            if (map.get(0) == null) {
+                //濡傛灉娌℃湁鐑悳姒滃氨濉厖鎵�鏈夋鍗曠殑鍓嶅嚑涓暟鎹�
+                List<String> list = new ArrayList<>();
+                Type type = new TypeToken<List<String>>() {
+                }.getType();
+
+                for (int i = 1; i < 5; i++) {
+                    if (map.get(i) != null) {
+                        JSONObject json = map.get(i);
+                        String key = json.keySet().iterator().next() + "";
+                        JSONArray array = json.optJSONArray(key);
+                        List<String> keys = new Gson().fromJson(array.toString(), type);
+                        if (keys.size() > 3) {
+                            list.addAll(keys.subList(0, 3));
+                        } else {
+                            list.addAll(keys);
+                        }
+                    }
+                }
+                if (list.size() > 10) {
+                    list = list.subList(0, 10);
+                }
+                JSONObject data = new JSONObject();
+                data.put("鐑悳姒�", list);
+                map.put(0, data);
+            }
         }
 
         JSONObject data = new JSONObject();
@@ -733,7 +855,18 @@
     public void getUserInfo(AcceptData acceptData, HttpServletRequest request, PrintWriter out) {
         UserData data = userService.getUserData(acceptData.getUid());
         out.print(JsonUtil.loadTrueJson(StringUtil.outPutResultJson(data)));
-
+        // 璁板綍鏃ュ織
+        try {
+//            if(!"appstore".equalsIgnoreCase(acceptData.getChannel())) {
+                String ip = IPUtil.getRemotIP(request);
+                IPUtil.IPInfo ipInfo = ipManager.getIPInfo(ip);
+                if (ipInfo != null) {
+                    deviceGeoLogger.info("鐢ㄦ埛淇℃伅(uid-{})-IP褰掑睘鍦� IP-{},鐗堟湰-{}, 娓犻亾-{}锛岀渷-{}锛� 甯�-{}",acceptData.getUid(), ip, acceptData.getVersion(), acceptData.getChannel(), ipInfo.getProvince(), ipInfo.getCity());
+                }
+//            }
+        } catch (Exception e) {
+            e.printStackTrace();
+        }
     }
 
     @RequireUid
@@ -791,7 +924,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));
                 }
@@ -878,6 +1015,35 @@
 
     }
 
+
+    private void getRelativeVideosForShortVideo(AcceptData acceptData, String videoId, PrintWriter out) {
+        SolrShortVideo solrShortVideo = solrShortVideoDataManager.findOne(videoId);
+        SolrShortVideoSearchFilter filter = new SolrShortVideoSearchFilter();
+        filter.setKey(solrShortVideo.getName());
+        filter.setFuzzy(true);
+
+        SolrResultDTO dto = solrShortVideoDataManager.find(filter, 1, 10);
+
+
+        JSONObject object = new JSONObject();
+        object.put("count", dto.getVideoList().size() + "");
+        JSONArray array = new JSONArray();
+
+        for (int i = 0; i < dto.getVideoList().size(); i++) {
+            SolrShortVideo temp = (SolrShortVideo) dto.getVideoList().get(i);
+            if (temp.getId().equalsIgnoreCase(videoId))
+                continue;
+            array.add(StringUtil.outPutResultJson(VideoInfoFactory.create(temp)));
+        }
+        if (array.size() % 2 != 0) {
+            array.remove(array.size() - 1);
+        }
+
+        object.put("data", array);
+        out.print(JsonUtil.loadTrueJson(object.toString()));
+    }
+
+
     /**
      * 鐩稿叧瑙嗛
      *
@@ -891,12 +1057,17 @@
             return;
         }
 
-        if (!NumberUtil.isNumeric(videoId)) {
-            getRelativeVideosForInternetSearch(acceptData, videoId, out);
-            return;
+        int fromtype = VideoUtil.getVideoFromType(videoId);
+        switch (fromtype) {
+            case HomeVideo.FROM_TYPE_INTERNET:
+                getRelativeVideosForInternetSearch(acceptData, videoId, out);
+                return;
+            case HomeVideo.FROM_TYPE_SHORT:
+                getRelativeVideosForShortVideo(acceptData, videoId, out);
+                return;
         }
 
-        List<Long> resourceList = videoResouceUtil.getAvailableResourceIds(acceptData.getDetailSystem(), acceptData.getVersion());
+        List<Long> resourceList = videoResouceUtil.getAvailableResourceIds(acceptData.getDetailSystem(), acceptData.getVersion(), acceptData.getChannel());
 
         DetailSystem ds = systemService.getDetailSystemByPackage(acceptData.getPackageName());
         List<VideoInfo> list = recommendService.getRelativeVideoList(ds.getId(), 4, videoId, resourceList,
@@ -935,7 +1106,7 @@
             return;
         }
 
-        List<Long> resourceList = videoResouceUtil.getAvailableResourceIds(acceptData.getDetailSystem(), acceptData.getVersion());
+        List<Long> resourceList = videoResouceUtil.getAvailableResourceIds(acceptData.getDetailSystem(), acceptData.getVersion(), acceptData.getChannel());
 
         DetailSystem ds = systemService.getDetailSystemByPackage(acceptData.getPackageName());
         List<VideoInfo> list1 = recommendService.peopleSee(ds.getId(), 4, videoId, resourceList,
@@ -1000,13 +1171,13 @@
             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;
         }
 
         int port = request.getRemotePort();
-        String ip = getIp(request);
+        String ip = IPUtil.getRemotIP(request);
 
         if (StringUtil.isNullOrEmpty(nickName))
             nickName = "鏃犲悕姘�";
@@ -1042,23 +1213,75 @@
             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;
         }
 
         final String code = StringUtil.getVerifyCode();
-        request.getSession().setAttribute(account, code);
+
         // new Thread(new Runnable() {
         // public void run() {
         // for (int i = 0; i < 3; i++) {
-        boolean isS = MailSenderUtil.sendEmail(account, "ysyz17784739772@126.com", "weikou2014", "甯冧父绀惧尯娉ㄥ唽楠岃瘉鐮�:" + code,
-                "甯冧父绀惧尯娉ㄥ唽楠岃瘉鐮�:" + code);
+        DetailSystem detailSystem = systemService.getDetailSystemByPackage(acceptData.getPackageName());
+        String title = "甯冧父绀惧尯娉ㄥ唽楠岃瘉鐮�:" + code;
+        String content = "甯冧父绀惧尯娉ㄥ唽楠岃瘉鐮�:" + code;
+        if (!detailSystem.getAppName().contains("甯冧父")) {
+            String name = detailSystem.getAppName();
+            title = name + "楠岃瘉鐮�:" + code;
+            content = title;
+        }
+
+        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(""));
+    }
+
 
     /**
      * 鐧诲綍
@@ -1067,32 +1290,179 @@
      * @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()));
+            }
+        }
+    }
+
+
+    /**
+     * 鐧诲綍
+     *
+     * @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()));
+            }
         }
     }
 
@@ -1124,7 +1494,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);
@@ -1151,6 +1521,12 @@
 
         // 娉ㄥ唽 --鐢ㄦ埛鍚�,鏄电О,瀵嗙爜
         LoginUser user = userService.getLoginUser(loginUid);
+        if (user.getState() != null && user.getState() == LoginUser.STATE_UNREGISTER) {
+            out.print(JsonUtil.loadFalseJson("璐︽埛宸叉敞閿�"));
+            return;
+        }
+        //闅愯棌user涓殑email
+        user.setEmail(UserInfoVOFactory.getHiddenEmail(user.getEmail()));
         if (user.getPortrait() != null && !user.getPortrait().startsWith("http"))
             user.setPortrait("http://" + Constant.WEBSITE + "/BuWan" + user.getPortrait());
         out.print(JsonUtil.loadTrueJson(StringUtil.outPutResultJson(user)));
@@ -1163,6 +1539,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");// 楠岃瘉鐮�
@@ -1188,7 +1566,7 @@
         }
 
         // 娉ㄥ唽 --鐢ㄦ埛鍚�,鏄电О,瀵嗙爜
-        LoginUser user = userService.getLoginUserByOpenId(email);
+        LoginUser user = userService.getValidLoginUserByEmail(email, acceptData.getDetailSystem().getSystem().getId());
         if (user == null) {
             out.print(JsonUtil.loadFalseJson("璇ョ敤鎴蜂笉瀛樺湪"));
         } else {
@@ -1232,13 +1610,14 @@
     public static String savePortrait(String base64, HttpSession session) {
         if (StringUtil.isNullOrEmpty(base64))
             return "";
+        base64 = base64.replace("\r\n", "");
 
         String fileName = "portrait_" + System.currentTimeMillis() + ".jpg";
         // 瀹氫箟涓婁紶璺緞
         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 "";
 
@@ -1253,43 +1632,12 @@
     }
 
     public void getIPInfo(AcceptData acceptData, HttpServletRequest request, PrintWriter out) {
-
-        String ip = request.getHeader("x-forwarded-for");
-        if (ip == null || ip.length() == 0 || "unknown".equalsIgnoreCase(ip)) {
-            ip = request.getHeader("Proxy-Client-IP");
-        }
-        if (ip == null || ip.length() == 0 || "unknown".equalsIgnoreCase(ip)) {
-            ip = request.getHeader("WL-Proxy-Client-IP");
+        String ip = IPUtil.getRemotIP(request);
+        try {
+            out.print(ip + "-----" + new Gson().toJson(IPUtil.getLocalIPInfo(request.getRemoteAddr())));
+        } catch (Exception e) {
+            e.printStackTrace();
         }
 
-        if (ip == null || ip.length() == 0 || "unknown".equalsIgnoreCase(ip)) {
-            ip = request.getHeader("X-Real-IP");
-        }
-
-        if (ip == null || ip.length() == 0 || "unknown".equalsIgnoreCase(ip)) {
-            ip = request.getRemoteAddr();
-        }
-        out.print(ip + "-----" + IPUtil.getIPContry(request.getRemoteAddr()));
-
-    }
-
-    public static String getIp(HttpServletRequest request) {
-        String ip = request.getHeader("x-forwarded-for");
-        if (ip == null || ip.length() == 0 || "unknown".equalsIgnoreCase(ip)) {
-            ip = request.getHeader("Proxy-Client-IP");
-        }
-        if (ip == null || ip.length() == 0 || "unknown".equalsIgnoreCase(ip)) {
-            ip = request.getHeader("WL-Proxy-Client-IP");
-        }
-        if (ip == null || ip.length() == 0 || "unknown".equalsIgnoreCase(ip)) {
-            ip = request.getHeader("HTTP_CLIENT_IP");
-        }
-        if (ip == null || ip.length() == 0 || "unknown".equalsIgnoreCase(ip)) {
-            ip = request.getHeader("HTTP_X_FORWARDED_FOR");
-        }
-        if (ip == null || ip.length() == 0 || "unknown".equalsIgnoreCase(ip)) {
-            ip = request.getRemoteAddr();
-        }
-        return ip;
     }
 }

--
Gitblit v1.8.0