spring boot netty 即时通讯系统之客户端与服务端聊天(八)

通过客户端发送信息给服务端进行消息的推送,推荐从前面的章节开始看。

ChatReqHandler.java

import com.fyrt.fyrtim.util.*;
import io.netty.channel.ChannelHandlerContext;
import io.netty.channel.ChannelInboundHandlerAdapter;
import lombok.extern.slf4j.Slf4j;

import java.util.HashSet;
import java.util.Scanner;

@Slf4j
public class ChatReqHandler extends ChannelInboundHandlerAdapter {


    @Override
    public void channelRead(ChannelHandlerContext ctx, Object msg) throws Exception {
        NettyMessage nettyMessage = (NettyMessage) JsonUtil.parseNettyMessage(msg);
        System.out.println("数据接收到了");
        User user = nettyMessage.getUser();
        if (user != null) {
            System.out.println(user.getUserId() + ":" + nettyMessage.getMsg());
        } else {
            System.out.println(nettyMessage.getMsg());

        }

    }


    @Override
    public void channelActive(ChannelHandlerContext ctx) throws Exception {
        System.out.println("IM系统准备就绪,请发送消息: ");
        new Thread(() -> {
            while (true) {
                //读取用户在命令行输入的各种数据类型 Terminal控制台输入数据
                Scanner sc = new Scanner(System.in);
                //此扫描器执行当前行,并返回跳过的输入信息
                String line = sc.nextLine();
                HashSet<String> set = new HashSet<>();
                set.add("闪电侠");
                NettyMessage nettyMessage = new NettyMessage(TransportType.STRING.getValue(), line, set, ctx.channel(), UserChannelUtil.user());
                String body = JsonUtil.objectToJson(nettyMessage);
                //发送数据并刷新
                ctx.writeAndFlush(body);
            }
        }).start();
    }

    @Override
    public void exceptionCaught(ChannelHandlerContext ctx, Throwable cause) throws Exception {
        cause.printStackTrace();
        ctx.close();
    }
}

 

 

ChatRespHandler.java

import com.fyrt.fyrtim.util.*;
import io.netty.channel.Channel;
import io.netty.channel.ChannelHandlerContext;
import io.netty.channel.ChannelInboundHandlerAdapter;

import java.util.Iterator;
import java.util.Set;

public class ChatRespHandler extends ChannelInboundHandlerAdapter {

    @Override
    public void channelRead(ChannelHandlerContext ctx, Object msg) throws Exception {
        NettyMessage nettyMessage = (NettyMessage) JsonUtil.parseNettyMessage(msg);
        //用户组
        Set<String> userIds = nettyMessage.getOtherUsers();
        if (userIds.size() > 0) {
            userIds.forEach(userId -> {
                  //判断当前用户是否登录,当前channel中是否存在用户信息
                if (UserChannelUtil.userIdChannelMap.get(userId) == null) {
                    System.out.println("用户不在线");
                } else {
                    Channel channel = UserChannelUtil.getChannel(userId);
                    //获取用户通道
                    User user = UserChannelUtil.getUser(channel);
                    //发送到指定的用户通道
                    channel.writeAndFlush(JsonUtil.objectToJson(new NettyMessage(TransportType.STRING.getValue(), nettyMessage.getMsg(), user)));

                }
            });
        } else {
            ctx.writeAndFlush(JsonUtil.objectToJson(new NettyMessage(TransportType.STRING.getValue(), nettyMessage.getMsg(), ctx.channel())));
        }
    }


    @Override
    public void exceptionCaught(ChannelHandlerContext ctx, Throwable cause) throws Exception {
        cause.printStackTrace();
        ctx.close();
    }


}

实现效果:

 

代码已上传至github:https://github.com/beibeirenzhe/netty-im/tree/master/fyrtim

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值