微信客服系统开发SDK使用教程-客户端退出通知

微信客服系统开发SDK使用教程-客户端退出通知

case "AccountLogoutNotice": {// 客户端退出通知
log.debug("websocket:msgtype=AccountLogoutNotice。。。。。");
accountLogoutNoticeWebsocketHandler.handleMsg(ctx, vo,contentJsonStr);
break;
}

package com.jubotech.framework.netty.handler.websocket;

import java.util.List;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;

import com.google.protobuf.util.JsonFormat;
import com.jubotech.business.web.domain.WeChatAccountInfo;
import com.jubotech.business.web.service.WeChatAccountService;
import com.jubotech.framework.netty.common.Constant;
import com.jubotech.framework.netty.utils.MessageUtil;

import Jubo.JuLiao.IM.Wx.Proto.AccountLogoutNotice.AccountLogoutNoticeMessage;
import Jubo.JuLiao.IM.Wx.Proto.TransportMessageOuterClass.EnumErrorCode;
import Jubo.JuLiao.IM.Wx.Proto.TransportMessageOuterClass.EnumMsgType;
import Jubo.JuLiao.IM.Wx.Proto.TransportMessageOuterClass.TransportMessage;
import io.netty.channel.ChannelHandlerContext;

@Service
public class AccountLogoutNoticeWebsocketHandler{
private final Logger log = LoggerFactory.getLogger(getClass());
@Autowired
private WeChatAccountService weChatAccountService;

/** 
 * pc客户端退出通知
 * @author wechatno:tangjinjinwx
 * @param ctx
 * @param vo
 */
public  void handleMsg(ChannelHandlerContext ctx ,TransportMessage vo, String contentJsonStr) {
    try {
        log.info(contentJsonStr);
        AccountLogoutNoticeMessage.Builder bd = AccountLogoutNoticeMessage.newBuilder();
        JsonFormat.parser().merge(contentJsonStr, bd);
        AccountLogoutNoticeMessage req = bd.build();
        //AccountLogoutNoticeMessage req = vo.getContent().unpack(AccountLogoutNoticeMessage.class);
        //1、校验用户信息
        if(null != req){
            Integer id = (int) req.getUnionId();
            List<WeChatAccountInfo> list =  weChatAccountService.findWeChatAccountInfo(null, id);
            if(null != list && list.size()>0){
                for(int i=0;i<list.size();i++){
                    WeChatAccountInfo info = list.get(i);
                    if(null != info.getIslogined() && null != info.getAccountid() && 0 == info.getIslogined() && info.getAccountid() == id){
                        info.setIslogined(1);//状态改成未登录
                        //info.setAccountid(null);//账号置空
                        weChatAccountService.updateLogined(info);
                    }
                }   
            }
        } 
        //3、告诉客户端消息已收到
        MessageUtil.sendJsonMsg(ctx, EnumMsgType.MsgReceivedAck, vo.getAccessToken(), vo.getId(), null);

    } catch (Exception e) {
        e.printStackTrace();
        MessageUtil.sendJsonErrMsg(ctx, EnumErrorCode.InvalidParam, Constant.ERROR_MSG_DECODFAIL);
    }
}

}

项目地址:https://github.com/wuliaokankan/WeChat.CRM.SDK
接口参考:http://www.yunlauncher.com/Blog/articles/119.html

猜你喜欢

转载自www.cnblogs.com/wuliaokankan/p/10681796.html