之前公司使用的即时消息方案是Androidpn,近来改成了WEBSOCKET,较之Androidpn来讲,websocket更加轻量级,但是仅仅封装了连接的协议,没有注册,登录,心跳,所以需要这些协议的需要自己扩展.上代码:
//Android客户端
public class CustWebSocketClient extends WebSocketClient {
//自己搞的监听
private OnStateChangeListener stateChangeListener;
private Context context;
//实例化
public CustWebSocketClient (Context context, URI serverURI,
OnStateChangeListener stateChangeListener) {
super(serverURI);
this.context = context;
this.stateChangeListener = stateChangeListener;
}
//关闭
@Override
public void onClose(int arg0, String arg1, boolean arg2) {
if (null != stateChangeListener) {
stateChangeListener.onClose(arg0, arg1, arg2);
}
}
//异常
@Override
public void onError(Exception arg0) {
NLog.i(TAG, "onError");
if (null != stateChangeListener) {
stateChangeListener.onError(arg0);
}
}
//收到消息
@Override
public void onMessage(String message) {
if (null != stateChangeListener) {
stateChangeListener.onMessage(message);
}
}
//连接建立
@Override
public void onOpen(ServerHandshake arg0) {
if (null != stateChangeListener) {
stateChangeListener.onOpen(arg0);
}
}
}
服务器端,网上都是用html5来搞好的,我看不懂,也不想用,就改成了servlet
public class ChatWebSocketServlet extends WebSocketServlet {
private static final long serialVersionUID = 1L;
private static Map<String, ChatMessageInbound> connects = new HashMap<String, ChatMessageInbound>();;
private static final String GUEST_PREFIX = "Guest";
private final AtomicInteger connectionIds = new AtomicInteger(0);
private static final AtomicInteger connectionIds = new AtomicInteger(0);
@Override
protected StreamInbound createWebSocketInbound(String subProtocol,
HttpServletRequest request) {
//return new ChatMessageInbound(connectionIds.incrementAndGet());
return new ChatMessageInbound(connectionIds.incrementAndGet(), this);//创建一个连接
}
}
<****************************************************************>
public class ChatMessageInbound extends MessageInbound {
private String nickname;
private static final String UNKNOWN_AUTH = "unauth_client";
public ChatMessageInbound(int id, WebSocketListener listener) {
this.nickname = UNKNOWN_AUTH + id;
}
@Override
protected void onOpen(WsOutbound outbound) {
NLog.i(ChatMessageInbound.class, "onOpen");
connects.put(connect.getNickname(), this);
}
@Override
protected void onClose(int status) {
connects.remove(this);
}
@Override
protected void onBinaryMessage(ByteBuffer message) throws IOException {
NLog.i(ChatMessageInbound.class, "ChatMessageInbound.onBinaryMessage ");
throw new UnsupportedOperationException("Binary message not supported.");
}
@Override
protected void onTextMessage(CharBuffer message) throws IOException {
NLog.i(ChatMessageInbound.class, "ChatMessageInbound.onTextMessage ");
}
public synchronized boolean sendMessage(String message, boolean isSaved) {
boolean isSend = false;
CharBuffer buffer = CharBuffer.wrap(message);
try {
getWsOutbound().writeTextMessage(buffer);
} catch (IOException e) {
}
return isSend;
}
}