From 468042c516adb6da5684a2d9f95a5d1e130553dc Mon Sep 17 00:00:00 2001
From: java110 <928255095@qq.com>
Date: 星期四, 26 八月 2021 15:36:55 +0800
Subject: [PATCH] Merge branch 'master' of http://git.homecommunity.cn/supervip/MicroCommunity

---
 service-front/src/main/java/com/java110/front/smo/login/impl/OwnerAppLoginSMOImpl.java |   71 +++++++++++++++++++++++++++--------
 1 files changed, 55 insertions(+), 16 deletions(-)

diff --git a/service-front/src/main/java/com/java110/front/smo/login/impl/OwnerAppLoginSMOImpl.java b/service-front/src/main/java/com/java110/front/smo/login/impl/OwnerAppLoginSMOImpl.java
old mode 100644
new mode 100755
index 60946a2..2b78c9a
--- a/service-front/src/main/java/com/java110/front/smo/login/impl/OwnerAppLoginSMOImpl.java
+++ b/service-front/src/main/java/com/java110/front/smo/login/impl/OwnerAppLoginSMOImpl.java
@@ -16,6 +16,7 @@
 import com.java110.utils.constant.*;
 import com.java110.utils.exception.SMOException;
 import com.java110.utils.util.Assert;
+import com.java110.utils.util.Base64Convert;
 import com.java110.utils.util.BeanConvertUtil;
 import com.java110.utils.util.StringUtil;
 import com.java110.vo.ResultVo;
@@ -67,11 +68,17 @@
         ResponseEntity<String> responseEntity;
 
         JSONObject loginInfo = JSONObject.parseObject(pd.getReqData());
+        boolean loginByPhone = false;
+        if (paramIn.containsKey("loginByPhone")) {
+            loginByPhone = paramIn.getBoolean("loginByPhone");
+        }
 
         loginInfo.put("passwd", AuthenticationFactory.passwdMd5(loginInfo.getString("password")));
         UserDto userDto = new UserDto();
         userDto.setUserName(loginInfo.getString("username"));
         userDto.setPassword(loginInfo.getString("password"));
+        userDto.setLoginByPhone(loginByPhone);
+        userDto.setLevelCd("02");
         userDto = super.postForApi(pd, userDto, ServiceCodeConstant.SERVICE_CODE_USER_LOGIN, UserDto.class);
 
         if (userDto == null) {
@@ -206,6 +213,19 @@
 
         //鑾峰彇 openId
         String openId = paramObj.getString("openid");
+        String userinfo_url = WechatConstant.APP_GET_USER_INFO_URL
+                .replace("ACCESS_TOKEN", paramObj.getString("access_token"))
+                .replace("OPENID", openId);
+
+        ResponseEntity<String> userinfo_paramOut = outRestTemplate.getForEntity(userinfo_url, String.class);
+        logger.debug("璋冪敤寰俊鎹㈠幓openId ", userinfo_paramOut);
+        if (userinfo_paramOut.getStatusCode() != HttpStatus.OK) {
+            return ResultVo.redirectPage("/");
+        }
+        JSONObject userinfo_paramObj = JSONObject.parseObject(userinfo_paramOut.getBody());
+
+        //澶勭悊鏄电О鏈夌壒娈婄鍙峰鑷� 鍏ュ簱澶辫触闂
+        userinfo_paramObj.put("nickname", Base64Convert.byteToBase64(userinfo_paramObj.getString("nickname").getBytes()));
 
         int loginFlag = paramIn.getInteger("loginFlag");
 
@@ -214,10 +234,12 @@
             //灏唎penId鏀惧埌redis 缂撳瓨锛岀粰鍓嶆涓嬪彂涓存椂绁ㄦ嵁
             String code = UUID.randomUUID().toString();
             CommonCache.setValue(code, openId, expireTime);
-            if(errorUrl.indexOf("?")> 0){
-                errorUrl +=("&code=" + code);
-            }else{
-                errorUrl +=("?code=" + code);
+            CommonCache.setValue(code + "-nickname", userinfo_paramObj.getString("nickname"), expireTime);
+            CommonCache.setValue(code + "-headimgurl", userinfo_paramObj.getString("headimgurl"), expireTime);
+            if (errorUrl.indexOf("?") > 0) {
+                errorUrl += ("&code=" + code);
+            } else {
+                errorUrl += ("?code=" + code);
             }
             return ResultVo.redirectPage(errorUrl);
         }
@@ -234,12 +256,14 @@
             //灏唎penId鏀惧埌redis 缂撳瓨锛岀粰鍓嶆涓嬪彂涓存椂绁ㄦ嵁
             String code = UUID.randomUUID().toString();
             CommonCache.setValue(code, openId, expireTime);
-            if(errorUrl.indexOf("?")> 0){
-                errorUrl +=("&code=" + code);
-            }else{
-                errorUrl +=("?code=" + code);
+            CommonCache.setValue(code + "-nickname", userinfo_paramObj.getString("nickname"), expireTime);
+            CommonCache.setValue(code + "-headimgurl", userinfo_paramObj.getString("headimgurl"), expireTime);
+            if (errorUrl.indexOf("?") > 0) {
+                errorUrl += ("&code=" + code);
+            } else {
+                errorUrl += ("?code=" + code);
             }
-            return ResultVo.redirectPage(errorUrl );
+            return ResultVo.redirectPage(errorUrl);
         }
 
         // String accessToken = paramObj.getString("access_token");//鏆傛椂涓嶇敤
@@ -261,14 +285,24 @@
         if (StringUtil.isEmpty(tmpUserDto.getKey())) {
             String code = UUID.randomUUID().toString();
             CommonCache.setValue(code, openId, expireTime);
-            if(errorUrl.indexOf("?")> 0){
-                errorUrl +=("&code=" + code);
-            }else{
-                errorUrl +=("?code=" + code);
+            CommonCache.setValue(code + "-nickname", userinfo_paramObj.getString("nickname"), expireTime);
+            CommonCache.setValue(code + "-headimgurl", userinfo_paramObj.getString("headimgurl"), expireTime);
+            if (errorUrl.indexOf("?") > 0) {
+                errorUrl += ("&code=" + code);
+            } else {
+                errorUrl += ("?code=" + code);
             }
             return ResultVo.redirectPage(errorUrl);
         }
-        redirectUrl = redirectUrl + (redirectUrl.indexOf("?") > 0 ? "&key=" + tmpUserDto.getKey() : "?key=" + tmpUserDto.getKey());
+        //濡傛灉鍙傛暟涓湁key 鐩存帴鐢ㄦ柊鐨勮鐩�
+        Map tempRedirectParam = super.urlToMap(redirectUrl);
+        tempRedirectParam.put("key", tmpUserDto.getKey());
+        if (redirectUrl.indexOf("?") > -1) {
+            redirectUrl = redirectUrl.substring(0, redirectUrl.indexOf("?")) + super.mapToUrlParam(tempRedirectParam);
+        } else {
+            redirectUrl = redirectUrl + super.mapToUrlParam(tempRedirectParam);
+        }
+        //redirectUrl = redirectUrl + (redirectUrl.indexOf("?") > 0 ? "&key=" + tmpUserDto.getKey() : "?key=" + tmpUserDto.getKey());
         return ResultVo.redirectPage(redirectUrl);
 
     }
@@ -321,7 +355,7 @@
 
             openUrl = WechatConstant.OPEN_AUTH
                     .replace("APPID", smallWeChatDto.getAppId())
-                    .replace("SCOPE", "snsapi_base")
+                    .replace("SCOPE", "snsapi_userinfo")
                     .replace(
                             "REDIRECT_URL",
                             URLEncoder
@@ -365,6 +399,8 @@
         String code = paramIn.getString("code");
 
         String openId = CommonCache.getValue(code);
+        String nickname = CommonCache.getValue(code + "-nickname");
+        String headimgurl = CommonCache.getValue(code + "-headimgurl");
 
         if (StringUtil.isEmpty(openId)) {
             responseEntity = new ResponseEntity<>("椤甸潰澶辨晥锛岃鍒锋柊鍚庨噸璇�", HttpStatus.UNAUTHORIZED);
@@ -381,6 +417,9 @@
         JSONObject userOwnerInfo = new JSONObject();
         OwnerAppUserDto ownerAppUserDto = new OwnerAppUserDto();
         ownerAppUserDto.setOpenId(openId);
+        // ownerAppUserDto.setNickName(StringUtil.encodeEmoji(nickname));
+        ownerAppUserDto.setNickName(nickname);
+        ownerAppUserDto.setHeadImgUrl(headimgurl);
         ownerAppUserDto.setAppType(OwnerAppUserDto.APP_TYPE_WECHAT);
         if (curOwnerApp != null) {
             ownerAppUserDto.setAppUserId(curOwnerApp.getAppUserId());
@@ -522,5 +561,5 @@
     public void setRestTemplate(RestTemplate restTemplate) {
         this.restTemplate = restTemplate;
     }
-
+    
 }

--
Gitblit v1.8.0