• 微信二次开发SDK使用教程--手机朋友圈评论删除任务反馈通知服务端


    微信二次开发SDK使用教程--手机朋友圈评论删除任务反馈通知服务端

    case CircleCommentDeleteTaskResultNotice : {//朋友圈评论删除任务反馈
    log.debug("socket:msgtype=CircleCommentDeleteTaskResultNotice");
    circleCommentDeleteTaskResultNoticeHandler.handleMsg(ctx, msgVo);
    break;
    }

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

    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.AccountInfo;
    import com.jubotech.business.web.domain.WeChatAccountInfo;
    import com.jubotech.business.web.service.AccountService;
    import com.jubotech.business.web.service.WeChatAccountService;
    import com.jubotech.framework.netty.common.Constant;
    import com.jubotech.framework.netty.utils.MessageUtil;
    import com.jubotech.framework.netty.utils.NettyConnectionUtil;

    import Jubo.JuLiao.IM.Wx.Proto.CircleCommentDeleteTaskResultNotice.CircleCommentDeleteTaskResultNoticeMessage;
    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 CircleCommentDeleteTaskResultNoticeHandler{
    private final Logger log = LoggerFactory.getLogger(getClass());
    @Autowired
    private WeChatAccountService weChatAccountService;
    @Autowired
    private AccountService accountService;

    /**
     * 手机端朋友圈评论删除任务反馈
     * @author wechatno:tangjinjinwx
     * @param ctx
     * @param vo
     */
    
    public  void handleMsg(ChannelHandlerContext ctx, TransportMessage vo) {
        try {
        	CircleCommentDeleteTaskResultNoticeMessage req = vo.getContent().unpack(CircleCommentDeleteTaskResultNoticeMessage.class);
        	log.info(JsonFormat.printer().print(req));
    		// 把消息转发给pc端
    		// a、根据wechatId找到accountid
    		// b、通过accountid找到account
    		// c、通过account账号找到通道
    		WeChatAccountInfo account = weChatAccountService.findWeChatAccountInfoByWeChatId(req.getWeChatId());
    		if (null != account && null != account.getAccountid() && 1 != account.getIslogined()) {
    				AccountInfo accInfo = accountService.findAccountInfoByid(account.getAccountid());
    				if (null != accInfo) {
    					// 转发给pc端
    					ChannelHandlerContext chx = NettyConnectionUtil.getClientChannelHandlerContextByUserId(accInfo.getAccount());
    					if (null != chx) {
    						MessageUtil.sendJsonMsg(chx, EnumMsgType.CircleCommentDeleteTaskResultNotice, NettyConnectionUtil.getNettyId(chx),null, req);
    					}
    				}
    				// 告诉客户端消息已收到
    				MessageUtil.sendMsg(ctx, EnumMsgType.MsgReceivedAck, vo.getAccessToken(), vo.getId(), null);
    		} else {
    			// 对方不在线
    			MessageUtil.sendErrMsg(ctx, EnumErrorCode.TargetNotOnline, Constant.ERROR_MSG_NOTONLINE);
    		}
        } catch (Exception e) {
            e.printStackTrace();
            MessageUtil.sendErrMsg(ctx, EnumErrorCode.InvalidParam, Constant.ERROR_MSG_DECODFAIL);
        }
    }
    

    }

    项目地址:https://www.wuliaokankan.cn/url301/138.html
    接口参考:http://www.yunlauncher.com/Blog/articles/119.html

  • 相关阅读:
    Hadoop错误之namenode宕机的数据恢复
    Hadoop双namenode配置搭建(HA)
    Hadoop2之NameNode HA详解
    基于zookeeper的高可用Hadoop HA集群安装
    Spring Boot集成JPA的Column注解命名字段无效的问题
    Spring Boot使用Druid连接池基本配置
    Java设计模式六大原则之场景应用分析
    下半部和推后运行的工作
    SecureCRT连接linux,vim颜色显示问题
    Objective-C MacOS以管理员权限执行程序
  • 原文地址:https://www.cnblogs.com/wuliaokankan/p/10607906.html
Copyright © 2020-2023  润新知