From 36be00e0f3cbe0d559c646fd2977e6e3a74aa6f9 Mon Sep 17 00:00:00 2001 From: KKSU <15274802129@163.com> Date: Mon, 30 Sep 2024 16:57:22 +0800 Subject: [PATCH] Merge branch 'bea' of http://120.27.238.55:7000/r/exchange into bea --- src/main/java/com/xcong/excoin/netty/logic/WebSocketLogic.java | 83 +++++++++++++++++++++++++++++++++++------ 1 files changed, 71 insertions(+), 12 deletions(-) diff --git a/src/main/java/com/xcong/excoin/netty/logic/WebSocketLogic.java b/src/main/java/com/xcong/excoin/netty/logic/WebSocketLogic.java index d1c9322..b2788cb 100644 --- a/src/main/java/com/xcong/excoin/netty/logic/WebSocketLogic.java +++ b/src/main/java/com/xcong/excoin/netty/logic/WebSocketLogic.java @@ -1,11 +1,22 @@ package com.xcong.excoin.netty.logic; +import cn.hutool.core.util.StrUtil; +import cn.hutool.crypto.asymmetric.KeyType; +import cn.hutool.crypto.asymmetric.RSA; import com.alibaba.fastjson.JSONObject; +import com.xcong.excoin.common.contants.AppContants; +import com.xcong.excoin.configurations.properties.SecurityProperties; +import com.xcong.excoin.modules.member.entity.MemberEntity; +import com.xcong.excoin.netty.bean.ChatRequest; import com.xcong.excoin.netty.bean.RequestBean; import com.xcong.excoin.netty.bean.ResponseBean; import com.xcong.excoin.netty.common.ChannelManager; import com.xcong.excoin.netty.common.NettyTools; +import com.xcong.excoin.rabbit.producer.ChatProducer; +import com.xcong.excoin.utils.RedisUtils; import io.netty.channel.Channel; +import lombok.extern.slf4j.Slf4j; +import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Component; @@ -14,28 +25,76 @@ * @email wangdoubleone@gmail.com * @date 2019-05-09 */ +@Slf4j @Component public class WebSocketLogic { + @Autowired + private RedisUtils redisUtils; + @Autowired + private ChatProducer chatProducer; + @Autowired + private SecurityProperties securityProperties; - public void webReqConnection(RequestBean requestBean) { + public void authCheck(RequestBean requestBean) { Channel channel = ChannelManager.findWebSocketChannel(requestBean.getChannelId()); - channel.writeAndFlush(NettyTools.webSocketBytes("this is ok")); - } + ResponseBean responseBean = new ResponseBean(); + responseBean.setType(requestBean.getType()); + responseBean.setStatus(1); - public void reqHomeSymbols(RequestBean requestBean) { - String params = requestBean.getParams(); - JSONObject jsonObject = JSONObject.parseObject(params); - String token = jsonObject.getString("token"); - String type = jsonObject.getString("type"); - ResponseBean responseBean = ResponseBean.ok(requestBean.getType(), null); + String token = requestBean.getData().toString(); + String redisKey = AppContants.APP_LOGIN_PREFIX + token; + String loginStr = redisUtils.getString(redisKey); + if (StrUtil.isBlank(loginStr)) { + ResponseBean res = ResponseBean.fail(); + res.setType(requestBean.getType()); + channel.writeAndFlush(NettyTools.webSocketBytes(JSONObject.toJSONString(res))); + return; + } - Channel channel = ChannelManager.findWebSocketChannel(requestBean.getChannelId()); + MemberEntity loginUser = JSONObject.parseObject(loginStr, MemberEntity.class); + Long memberId = loginUser.getId(); + channel.writeAndFlush(NettyTools.webSocketBytes(JSONObject.toJSONString(responseBean))); + ChannelManager.addWsChannel(channel, memberId); + String value = redisUtils.getString(AppContants.MSG_NOTICE + memberId); + if (StrUtil.isNotBlank(value)) { + responseBean.setType(3); + responseBean.setData(Integer.parseInt(value)); + channel.writeAndFlush(NettyTools.webSocketBytes(JSONObject.toJSONString(responseBean))); + + redisUtils.del(AppContants.MSG_NOTICE + memberId); + } } - public void defaultReq(RequestBean requestBean) { + public void sendMsg(RequestBean requestBean) { + String chatStr = requestBean.getData().toString(); + log.info("接收到的消息:{}", chatStr); + ChatRequest chat = JSONObject.parseObject(chatStr, ChatRequest.class); + Channel channel = ChannelManager.findWebSocketChannel(requestBean.getChannelId()); - channel.writeAndFlush("this is error type"); + ResponseBean res = ResponseBean.ok(chat); + chat.setTimestamp(System.currentTimeMillis()); + res.setType(2); + channel.writeAndFlush(NettyTools.webSocketJson(res)); + + // 判断是否在线 + Channel targetChannel = ChannelManager.findWsChannel(chat.getTargetId()); + if (targetChannel != null) { + chat.setIsSelf(2); + ResponseBean toRes = ResponseBean.ok(chat); + toRes.setType(2); + targetChannel.writeAndFlush(NettyTools.webSocketJson(toRes)); + } else { + // 在redis中保存用户未在线时,给该用户发送的消息条数 +// String key = AppContants.MSG_NOTICE + chat.getTargetId(); +// String value = redisUtils.getString(key); +// if (StrUtil.isEmpty(value)) { +// redisUtils.set(key , 1); +// } else { +// redisUtils.set(key, Integer.parseInt(value) + 1); +// } + } + chatProducer.sendMsgHistory(chat); } } -- Gitblit v1.9.1