朋友说想搭个聊天服务器。经过多方研究,发现网上有一款开源软件J-IM,是搭建在国产通讯工具t-io上的,作者经过J-IM封装,已经变成了成熟产品谭聊,基础的东西作者也进行了开源。本着学习和研究的目的,本人还是想研究一下该项目。方便集成在项目中使用。
J-IM经过DEMO测试,确实减少了不少工作量。不过在搭建过程中,还是花了不少功夫。该工具是纯JAVA写的,为了测试方便,本人使用了另一个用JAVAFX写的通讯工具开源代码进行了集成。集成过程总体来说挺顺利,但在返回离线消息时候出现了问题。经研究,使用J-IM返回离线消息,需要做如下几个操作:
一.服务端
1.开启redis
config/jim.properties中,将jim.store = off 改为jim.store = on
2.启用RedisMessageHelper
imServerConfig.setMessageHelper(new RedisMessageHelper());
3.服务端开启时,启用MessageReqHandler
MessageReqHandler msgReqHandler = CommandManager.getCommand(Command.COMMAND_GET_MESSAGE_REQ, MessageReqHandler.class);
msgReqHandler.setSingleProcessor(new DefaultAsyncChatMessageProcessor());
在调试过程中,发现在取离线消息时,始终取不了,经排查问题解决如下:
因为 RedisMessageHelper 这个类里面getFriendsOfflineMessage(String userId)方法里面,List<String> messages = RedisCacheManager.getCache(GROUP).sortSetGetAll(userKey);没取到数据,正确的要改成List<String> messages = RedisCacheManager.getCache(PUSH).sortSetGetAll(userKey); 就是要把GROUP改成PUSH。
二、客户端
1.连接服务器
开源代码中有,就不再贴出来了。
2.连接上服务器之后,执行如下代码,即可返回消息:
MessageReqBody mrb=new MessageReqBody();
mrb.setCmd(19);
mrb.setType(0);
mrb.setUserId(to);
TcpPacket chatTcpPacket = new TcpPacket(Command.COMMAND_GET_MESSAGE_REQ,JSONObject.toJSON(mrb).toString().getBytes());
JimClientAPI.send(imClientChannelContext, chatTcpPacket);
以上是本人做J-IM开发测试遇到的坑,给后来人做参考。