Android之Mina频繁发送心跳包
16lz
2021-01-25
最近使用 Mina框架实现长连接时,发现客户端只发了一次心跳请求,服务器却不断的循环收到该请求。先来看看心跳包配置:
执行:connection.getFilterChain().addLast("heartbeat", getHeartBeat());
通过断点KeepAliveMessageFactoryImpl 类发现:
/** * 发送心跳包请求 */public class KeepAliveMessageFactoryImpl implements KeepAliveMessageFactory { private String heartRequest; private String heartResponse; public KeepAliveMessageFactoryImpl(String request, String response) { this.heartRequest = request; this.heartResponse = response; } /** * 检查是否是请求的心跳包信息 */ @Override public boolean isRequest(IoSession ioSession, Object o) { if (o.equals(heartRequest)) return true; return false; } /** * 用来判断接收到的消息是不是一个心跳回复包。 */ @Override public boolean isResponse(IoSession ioSession, Object o) { if (o.equals(heartResponse)) return true; return false; } /** * 获取一个回复的心跳包,并且发送出去 */ @Override public Object getRequest(IoSession ioSession) { Utils.print("预设发送心跳包--->" + heartRequest); return heartRequest; } /** * 获取一个心跳回复包。 */ @Override public Object getResponse(IoSession ioSession, Object o) { Utils.print("预设心跳包响应--->" + heartResponse); return heartResponse; }}
程序只回调一次 public Object getRequest(IoSession ioSession),然后不断回调
public Object getResponse(IoSession ioSession, Object o) 方法,服务器报错说收到很多次请求,一脸懵逼!
经过不懈努力调试,最后发现:
心跳包的请求和响应内容不能相同!把responseStr改为不同的内容就好了。
更多相关文章
- 万字长文带你了解最常用的开源 Squid 代理服务器
- Nginx系列教程(一)| 手把手教你在Linux环境下搭建Nginx服务
- Nginx系列教程(三)| 一文带你读懂Nginx的负载均衡
- android SharedPreferences初步
- AESUtil工具类
- 自定义布局-自定义RelativeLayout
- Android启动页用户相关政策弹框的实现
- Android(安卓)init进程--属性服务器
- [摘]Android移动开发