引用:小帅哥 发表于 2025-07-03 09:07 肯定能触发,我的意思其实是担心,你是不是对代码的调用理解不太对,导致了问题。因为通常搞web系统习惯了,一时比较难以理解长连接这种东西,它不是像http一样拉起就能用,它有一整套客户端的连接建立和维持才能通信。 所以,你最好尽量多贴代码,越多越好,至少能让我明白你是怎么干的,我才能理解你有没有搞对。 另外,你如果是在spring boot工程里集成,你可以参考这些帖子,对照一下是否用法没搞对,尤其是这篇:《SpringBoot集成开源IM框架MobileIMSDK,实现即时通讯IM聊天功能》 |
引用:JackJiang 发表于 2025-07-02 18:26 您提供的demo会监听到谁谁谁上线了,引入到自己的项目中这个上线日志就没触发监听? |
引用:小帅哥 发表于 2025-07-02 17:40 你的代码看起来我有点费解 你用MobileIMSDK的情况下,没有理由需要去直接操作Channel对象,你服务端如果需向某个人发送消息,直接调用LocalSendHelper即可 另一个,你一定要注意把长连接跟你的http短连接分开理解,长连接是有状态的,对它的消息推送一定是要借助sdk层提供的LocalSendHelper即可这样的公开接口才能实现 |
引用:JackJiang 发表于 2025-07-02 17:28 * **/ @RequestMapping(value = "/sendMessage",method = RequestMethod.POST) public synchronized JSONObject sendMessage(@RequestParam("image") MultipartFile[] image,@RequestParam("files") MultipartFile[] files, HttpServletRequest request) throws Exception { //转换json对象 ImModel imModel= JSON.parseObject(request.getParameter("imModel"), ImModel.class); JSONObject jsonObject = new JSONObject(); Channel fromChannel= (Channel) ServerEventListenerImpl.map.get(imModel.getFromUserId()); Channel channel= null;这是我们自己写的业务处理接口,就会触发@Overridepublic void onUserLogout(String userId, Object obj, Channel session) { map.put(userId,null); //保存客户信息到redis中 logger.debug("【DEBUG_回调通知OnUserLogoutAction_CallBack】用户:"+userId+" 离线了!"); } |
引用:小帅哥 发表于 2025-07-02 17:23 “非Im的接口”,具体指的是什么样的接口?你可以给点实际的代码或例子,让你理解你在干什么,不然我猜不出到底发生了啥,因为你说的,跟我理解,好像不在一个频道 |
引用:小帅哥 发表于 2025-07-02 17:18 具体你是怎么做的,你可以贴一贴具体的实现代码,我看看是否有什么问题 |
引用:小帅哥 发表于 2025-07-02 17:18 说的更明白一点,就是客户端调用服务端非Im的接口,都会触发onUserLogout监听 |
引用:JackJiang 发表于 2025-07-02 17:12 在Java后端demo的消息发送接口外面,包了一层,然后就出现调用自己写的接口,监听立马反馈对方离线 |
引用:小帅哥 发表于 2025-07-02 17:06 我有点没看明白。 你现在是在运行原版的MobileIMSDK鸿蒙NEXT客户端Demo+MobileIMSDK原版的服务端Demo出现了贴子里的情况,还是客户端有什么改动或者是有做什么修改? |
引用:JackJiang 发表于 2025-07-02 15:47 |
引用:小帅哥 发表于 2025-07-02 15:14 截图或拍个操作视频,把你这个启动、运行、连接过程演示给我看看,我帮你分析分析 |
引用:JackJiang 发表于 2025-07-02 15:03 您这边提供的鸿蒙demo |
引用:小帅哥 发表于 2025-07-02 14:54 你用的是什么客户端? |
|
INFO - [11:47:58.450][IMCORE-ws]客户端{uid:null}/127.0.0.1:51497的会话已超时失效,很可能是对方非正常通出或网络故障,即将以会话异常的方式执行关闭流程 ... | (MBWebsocketClientInboundHandler^exceptionCaught:59) DEBUG - [11:47:58.451][IMCORE-websocket]此客户端的Channel抛出了exceptionCaught,原因是:null,可以提前close掉了哦! | (ServerCoreHandler^exceptionCaught:154) io.netty.handler.timeout.ReadTimeoutException: null,用的是官方demo,能正常启动,访问时报这个错误 |
|
INFO - [11:47:58.450][IMCORE-ws]客户端{uid:null}/127.0.0.1:51497的会话已超时失效,很可能是对方非正常通出或网络故障,即将以会话异常的方式执行关闭流程 ... | (MBWebsocketClientInboundHandler^exceptionCaught:59) DEBUG - [11:47:58.451][IMCORE-websocket]此客户端的Channel抛出了exceptionCaught,原因是:null,可以提前close掉了哦! | (ServerCoreHandler^exceptionCaught:154) io.netty.handler.timeout.ReadTimeoutException: null,请问怎么解决 |