记得上下班打卡 | git大法好,push需谨慎

Commit f04dff16 authored by jiangxiulong's avatar jiangxiulong

同步数据异常处理

parent b568f5f5
...@@ -6,6 +6,7 @@ import io.swagger.annotations.Api; ...@@ -6,6 +6,7 @@ import io.swagger.annotations.Api;
import io.swagger.annotations.ApiImplicitParam; import io.swagger.annotations.ApiImplicitParam;
import io.swagger.annotations.ApiImplicitParams; import io.swagger.annotations.ApiImplicitParams;
import io.swagger.annotations.ApiOperation; import io.swagger.annotations.ApiOperation;
import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Autowired; import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.util.LinkedMultiValueMap; import org.springframework.util.LinkedMultiValueMap;
import org.springframework.util.MultiValueMap; import org.springframework.util.MultiValueMap;
...@@ -19,6 +20,7 @@ import java.io.*; ...@@ -19,6 +20,7 @@ import java.io.*;
@Api(tags = "同步微信用户数据") @Api(tags = "同步微信用户数据")
@RestController @RestController
@RequestMapping("/wechatSync") @RequestMapping("/wechatSync")
@Slf4j
public class SweetWechatSyncDataController { public class SweetWechatSyncDataController {
@Autowired @Autowired
...@@ -35,8 +37,7 @@ public class SweetWechatSyncDataController { ...@@ -35,8 +37,7 @@ public class SweetWechatSyncDataController {
BufferedReader bufferedReader = new BufferedReader(read); BufferedReader bufferedReader = new BufferedReader(read);
String mobile = null; String mobile = null;
while ((mobile = bufferedReader.readLine()) != null) { while ((mobile = bufferedReader.readLine()) != null) {
System.out.println(mobile); log.info("regMobilen:mobile:[{}]", mobile);
try { try {
MultiValueMap<String, String> params = new LinkedMultiValueMap(); MultiValueMap<String, String> params = new LinkedMultiValueMap();
params.add("mobile", mobile); params.add("mobile", mobile);
...@@ -46,7 +47,7 @@ public class SweetWechatSyncDataController { ...@@ -46,7 +47,7 @@ public class SweetWechatSyncDataController {
String url = ""; String url = "";
HttpUtil.post(url, params); HttpUtil.post(url, params);
} catch (Exception e) { } catch (Exception e) {
e.printStackTrace(); log.info("regMobileException:mobile:[{}]", mobile);
} }
} }
...@@ -62,7 +63,7 @@ public class SweetWechatSyncDataController { ...@@ -62,7 +63,7 @@ public class SweetWechatSyncDataController {
try { try {
sweetWechatMpService.userInfo(); sweetWechatMpService.userInfo();
} catch (Exception e) { } catch (Exception e) {
e.printStackTrace(); log.error("getUsers", e);
} }
} }
...@@ -75,7 +76,7 @@ public class SweetWechatSyncDataController { ...@@ -75,7 +76,7 @@ public class SweetWechatSyncDataController {
try { try {
sweetWechatMpService.getUser(openId); sweetWechatMpService.getUser(openId);
} catch (Exception e) { } catch (Exception e) {
e.printStackTrace(); log.error("getUser", e);
} }
} }
......
...@@ -47,42 +47,49 @@ public class SweetWechatMpService { ...@@ -47,42 +47,49 @@ public class SweetWechatMpService {
log.info("nextOpenid:[{}] ", nextOpenid); log.info("nextOpenid:[{}] ", nextOpenid);
for (String openId : openids) { for (String openId : openids) {
WxMpUser wxMpUser = wxMpService.getUserService().userInfo(openId); try {
log.info("openId:[{}],wxMpUsers:[{}]", openId, wxMpUser); WxMpUser wxMpUser = wxMpService.getUserService().userInfo(openId);
if (!wxMpUser.getSubscribe()) {
SweetWechatUser userInfo = redisDataUtils.getSweetWechatUser(wxMpUser.getUnionId()); log.info("getSubscribeFalse:openId:[{}]", openId);
if (null == userInfo) { continue;
SweetWechatUser sweetWechatUser = SweetWechatUser.getNew(); }
sweetWechatUser.setOpenId(wxMpUser.getOpenId()); SweetWechatUser userInfo = redisDataUtils.getSweetWechatUser(wxMpUser.getUnionId());
sweetWechatUser.setUnionId(wxMpUser.getUnionId()); if (null == userInfo) {
sweetWechatUser.setNickname(wxMpUser.getNickname()); SweetWechatUser sweetWechatUser = SweetWechatUser.getNew();
sweetWechatUser.setSexDesc(wxMpUser.getSexDesc()); sweetWechatUser.setOpenId(wxMpUser.getOpenId());
sweetWechatUser.setSex(wxMpUser.getSex()); sweetWechatUser.setUnionId(wxMpUser.getUnionId());
sweetWechatUser.setHeadImgUrl(wxMpUser.getHeadImgUrl()); sweetWechatUser.setNickname(wxMpUser.getNickname());
sweetWechatUser.setLanguage(wxMpUser.getLanguage()); sweetWechatUser.setSexDesc(wxMpUser.getSexDesc());
sweetWechatUser.setCountry(wxMpUser.getCountry()); sweetWechatUser.setSex(wxMpUser.getSex());
sweetWechatUser.setProvince(wxMpUser.getProvince()); sweetWechatUser.setHeadImgUrl(wxMpUser.getHeadImgUrl());
sweetWechatUser.setCity(wxMpUser.getCity()); sweetWechatUser.setLanguage(wxMpUser.getLanguage());
sweetWechatUser.setSubscribeTime(DateUtil.ofEpochMilli(wxMpUser.getSubscribeTime())); sweetWechatUser.setCountry(wxMpUser.getCountry());
sweetWechatUser.setSubscribeScene(wxMpUser.getSubscribeScene()); sweetWechatUser.setProvince(wxMpUser.getProvince());
sweetWechatUser.setUserId(IDGenerator.nextSnowId()); sweetWechatUser.setCity(wxMpUser.getCity());
LinkedList<String> sqls = CollectionUtil.linkedListString(); sweetWechatUser.setSubscribeTime(DateUtil.ofEpochMilli(wxMpUser.getSubscribeTime()));
LinkedList<Object[]> sqlsDataA = CollectionUtil.linkedListObjectArr(); sweetWechatUser.setSubscribeScene(wxMpUser.getSubscribeScene());
sqls.add(SqlMapping.get("sweet_user.insert")); sweetWechatUser.setUserId(IDGenerator.nextSnowId());
sqlsDataA.add(new Object[]{ LinkedList<String> sqls = CollectionUtil.linkedListString();
sweetWechatUser.getUserId(), sweetWechatUser.getOpenId(), sweetWechatUser.getUnionId(), sweetWechatUser.getNickname(), LinkedList<Object[]> sqlsDataA = CollectionUtil.linkedListObjectArr();
sweetWechatUser.getSexDesc(), sweetWechatUser.getSex(), sweetWechatUser.getHeadImgUrl(), sweetWechatUser.getLanguage(), sqls.add(SqlMapping.get("sweet_user.insert"));
sweetWechatUser.getCountry(), sweetWechatUser.getProvince(), sweetWechatUser.getCity(), sqlsDataA.add(new Object[]{
sweetWechatUser.getSubscribeTime(), sweetWechatUser.getSubscribeScene() sweetWechatUser.getUserId(), sweetWechatUser.getOpenId(), sweetWechatUser.getUnionId(), sweetWechatUser.getNickname(),
}); sweetWechatUser.getSexDesc(), sweetWechatUser.getSex(), sweetWechatUser.getHeadImgUrl(), sweetWechatUser.getLanguage(),
queueUtils.sendMsgByRedis(MQConst.SweetQueue.SWEET_USER_INSERT_DRAW.getKey(), sweetWechatUser.getCountry(), sweetWechatUser.getProvince(), sweetWechatUser.getCity(),
SqlMapping.gets(sqls, sqlsDataA)); sweetWechatUser.getSubscribeTime(), sweetWechatUser.getSubscribeScene()
// 入缓存 });
redisDataUtils.setSweetWechatUser(sweetWechatUser); queueUtils.sendMsgByRedis(MQConst.SweetQueue.SWEET_USER_INSERT_DRAW.getKey(),
SqlMapping.gets(sqls, sqlsDataA));
// 入缓存
redisDataUtils.setSweetWechatUser(sweetWechatUser);
}
} catch (Exception e) {
log.info("forException:openId:[{}]", openId);
} }
} }
log.info("nextOpenidSuccess:[{}] ", nextOpenid);
} while (!nextOpenid.isEmpty()); } while (!nextOpenid.isEmpty());
log.info("同步微信用户完成");
} }
public void getUser(String openId) throws WxErrorException { public void getUser(String openId) throws WxErrorException {
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment