最近使用 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改为不同的内容就好了。

 

 

 

更多相关文章

  1. 万字长文带你了解最常用的开源 Squid 代理服务器
  2. Nginx系列教程(一)| 手把手教你在Linux环境下搭建Nginx服务
  3. Nginx系列教程(三)| 一文带你读懂Nginx的负载均衡
  4. android SharedPreferences初步
  5. AESUtil工具类
  6. 自定义布局-自定义RelativeLayout
  7. Android启动页用户相关政策弹框的实现
  8. Android(安卓)init进程--属性服务器
  9. [摘]Android移动开发

随机推荐

  1. Android 获取WIFI MAC地址的方法
  2. 2011.07.06(2)——— android apiDemos 之
  3. Android-TextView多行本文滚动轻松实现
  4. button selector 样式
  5. Android studio图片ERROR: 9-patch image
  6. android手机中图片的拖拉及浏览功能
  7. RelativeLayout
  8. Android Wi-Fi 设置带宽代码流程
  9. inputtype
  10. Android中Dialog对话框