From feee16c2fe842ef452823d3f8ed95a39ad191ee6 Mon Sep 17 00:00:00 2001
From: 喻健 <喻健@Admin>
Date: 星期一, 10 十二月 2018 16:11:20 +0800
Subject: [PATCH] 分享记录来源查询

---
 fanli/src/main/java/com/yeshi/fanli/controller/client/UserAccountController.java |  106 ++++++++++++++++++++++++++++++++++++++++++++++++-----
 1 files changed, 96 insertions(+), 10 deletions(-)

diff --git a/fanli/src/main/java/com/yeshi/fanli/controller/client/UserAccountController.java b/fanli/src/main/java/com/yeshi/fanli/controller/client/UserAccountController.java
index d12d4ae..52f1e99 100644
--- a/fanli/src/main/java/com/yeshi/fanli/controller/client/UserAccountController.java
+++ b/fanli/src/main/java/com/yeshi/fanli/controller/client/UserAccountController.java
@@ -9,6 +9,7 @@
 
 import org.springframework.stereotype.Controller;
 import org.springframework.web.bind.annotation.RequestMapping;
+import org.yeshi.utils.JsonUtil;
 
 import com.alipay.api.AlipayApiException;
 import com.yeshi.fanli.entity.accept.AcceptData;
@@ -29,7 +30,6 @@
 import com.yeshi.fanli.service.inter.config.ConfigService;
 import com.yeshi.fanli.service.inter.config.InviteGetMoneyService;
 import com.yeshi.fanli.service.inter.config.SystemService;
-import com.yeshi.fanli.service.inter.goods.CollectionGoodsService;
 import com.yeshi.fanli.service.inter.hongbao.HongBaoManageService;
 import com.yeshi.fanli.service.inter.hongbao.HongBaoMessageService;
 import com.yeshi.fanli.service.inter.hongbao.HongBaoService;
@@ -49,13 +49,11 @@
 import com.yeshi.fanli.service.inter.user.TBPidService;
 import com.yeshi.fanli.service.inter.user.UserAccountService;
 import com.yeshi.fanli.service.inter.user.UserInfoService;
-import com.yeshi.fanli.service.inter.user.WxDownService;
 import com.yeshi.fanli.util.GsonUtil;
 import com.yeshi.fanli.util.RedisManager;
 import com.yeshi.fanli.util.StringUtil;
 import com.yeshi.fanli.util.account.UserUtil;
 import com.yeshi.fanli.util.wx.WXLoginUtil;
-import org.yeshi.utils.JsonUtil;
 
 import net.sf.json.JSONObject;
 
@@ -118,12 +116,7 @@
 	private AccountMessageService accountMessageService;
 
 	@Resource
-	private CollectionGoodsService collectionGoodsService;
-	@Resource
 	private HongBaoManageService hongBaoManageService;
-
-	@Resource
-	private WxDownService wxDownService;
 
 	@Resource
 	private UserAccountService userAccountService;
@@ -161,7 +154,7 @@
 	 */
 	@RequestMapping(value = "login")
 	public void login(AcceptData acceptData, String code, String vcode, String phone, boolean wxinstall,
-			String tbOpenid, String tbNickName, String tbPortrait, int loginType, Boolean first, HttpSession session,
+			String tbOpenid, String tbNickName, String tbPortrait, int loginType, Boolean first, HttpSession session,HttpServletRequest request,
 			PrintWriter out) {
 		System system = systemService.getSystemCache(acceptData.getPlatform(), acceptData.getPackages());
 		if (system == null) {
@@ -185,7 +178,7 @@
 		tbUserInfo.setTbName(tbNickName);
 		tbUserInfo.setTbPic(tbPortrait);
 		try {
-			LoginResult result = userAccountService.login(session, first, system.getAppid(), code, phone, tbUserInfo,
+			LoginResult result = userAccountService.login(request, first, system.getAppid(), code, phone, tbUserInfo,
 					wxinstall, loginType);
 			if (result == null)
 				LogHelper.error("login-result涓虹┖鍊�");
@@ -723,6 +716,99 @@
 			redisManager.removeCommonString(key);
 		}
 	}
+	
+	
+	
+	@RequestMapping(value = "bindalipaywithverifynew")
+	public void bindAlipayWithVerifyNew(AcceptData acceptData, Long uid, String name, String account, PrintWriter out) {
+
+		System system = systemService.getSystemCache(acceptData.getPlatform(), acceptData.getPackages());
+		if (system == null) {
+			out.print(JsonUtil.loadFalseResult("绯荤粺涓嶅瓨鍦�"));
+			return;
+		}
+
+		if (uid == null || uid == 0) {
+			out.print(JsonUtil.loadFalseResult(1, "璇蜂笂浼犵敤鎴稩D"));
+			return;
+		}
+
+		if (StringUtil.isNullOrEmpty(name)) {
+			out.print(JsonUtil.loadFalseResult(1, "璇蜂笂浼犳敮浠樺疂瀹炲悕鍚嶇О"));
+			return;
+		}
+
+		if (StringUtil.isNullOrEmpty(account)) {
+			out.print(JsonUtil.loadFalseResult(1, "璇蜂笂浼犳敮浠樺疂璐﹀彿"));
+			return;
+		}
+
+		UserInfo user = userInfoService.getUserById(uid);
+
+		boolean bind = redisManager.isBindAlipayAccountSMSStateValid(user.getPhone());
+		if (!bind) {
+			out.print(JsonUtil.loadFalseResult(90002, "鎵嬫満楠岃瘉瓒呮椂"));
+			return;
+		}
+
+		String key = "bindalipay-" + uid;
+
+		if (!StringUtil.isNullOrEmpty(redisManager.getCommonString(key))) {
+			out.print(JsonUtil.loadFalseResult(1001, "鏈嶅姟鍣ㄧ箒蹇欙紝璇风◢鍚庨噸璇�"));
+			return;
+		}
+		redisManager.cacheCommonString(key, "1", 120);
+		// 鍙互灞曠ず缁欑敤鎴风湅鐨勯敊璇爜
+		String[] ALIPAY_CODES = new String[] { "SYSTEM_ERROR", "PERMIT_CHECK_PERM_LIMITED", "PERM_AML_NOT_REALNAME_REV",
+				"PERM_AML_NOT_REALNAME_REV", "PAYEE_USER_INFO_ERROR", "PAYEE_ACC_OCUPIED",
+				"PERMIT_CHECK_PERM_IDENTITY_THEFT", "PERMIT_NON_BANK_LIMIT_PAYEE", "EXCEED_LIMIT_UNRN_DM_AMOUNT" };
+		try {
+			BindingAccount bindingAccount = bindingAccountService.changeAlipayBindingWithVerify(uid, name, account);
+			out.print(JsonUtil.loadTrue(0, JsonUtil.getGson().toJson(bindingAccount), "绯荤粺宸叉垚鍔熻浆璐�0.1鍏冨埌鎻愮幇璐﹀彿涓紝鎻愮幇璐﹀彿楠岃瘉閫氳繃锛屾伃鍠滀綘锛佸彲浠ユ彁鐜颁簡銆�"));
+		} catch (AlipayTransferException e1) {
+			if (e1.getSubCode().equalsIgnoreCase("PAYEE_NOT_EXIST")) {
+				String msg = "绯荤粺鏈兘鎴愬姛杞处0.1鍏冿紝鎻愮幇璐﹀彿淇℃伅鏈夎锛岃鏍稿鍚庨噸鏂板~鍐欍��";
+				out.print(JsonUtil.loadFalseResult(1, msg));
+			} else {
+				for (String st : ALIPAY_CODES) {
+					if (st.equalsIgnoreCase(e1.getSubCode())) {
+						out.print(JsonUtil.loadFalseResult(2, e1.getMsg()));
+						return;
+					}
+				}
+				out.print(JsonUtil.loadFalseResult(3, "鏀粯瀹濇帴鍙e嚭閿欙紝楠岃瘉澶辫触锛岃鑱旂郴瀹㈡湇銆�"));
+				return;
+			}
+
+		} catch (AlipayApiException e2) {
+			out.print(JsonUtil.loadFalseResult(4, e2.getErrMsg()));
+			return;
+		} catch (AlipayAccountException e3) {
+			// 璐︽埛鏃犱綑棰�
+			if (e3.getCode() == AlipayAccountException.CODE_NO_MONEY) {
+				out.print(JsonUtil.loadFalseResult(5, "浣犵殑璐︽埛鐩墠娌℃湁浣欓锛屾棤闇�缁戝畾鎻愮幇璐﹀彿銆�"));
+				return;
+				// 鎻愮幇娆℃暟闄愬埗
+			} else if (e3.getCode() == AlipayAccountException.CODE_TIMES_LIMIT) {
+				out.print(JsonUtil.loadFalseResult(6, "姣忔湀浠呭彲淇敼1娆℃彁鐜拌处鍙凤紝璇蜂笅鏈堝啀璇曞惂銆�"));
+				return;
+			} else {
+				out.print(JsonUtil.loadFalseResult(7, e3.getMsg()));
+				return;
+			}
+
+		} catch (Exception e) {
+			try {
+				LogHelper.errorDetailInfo(e);
+			} catch (Exception e1) {
+				e1.printStackTrace();
+			}
+			out.print(JsonUtil.loadFalseResult(8, "鏈嶅姟鍣ㄥ唴閮ㄩ敊璇紝楠岃瘉澶辫触锛岃鑱旂郴瀹㈡湇銆�"));
+		} finally {
+			redisManager.removeCommonString(key);
+		}
+	}
+	
 
 	/**
 	 * 鑾峰彇鐢ㄦ埛璧勯噾璇︽儏

--
Gitblit v1.8.0