1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
|
package org.eclipse.jetty.websocket.server.ab;
import java.io.IOException;
import org.eclipse.jetty.util.FutureCallback;
import org.eclipse.jetty.util.log.Log;
import org.eclipse.jetty.util.log.Logger;
import org.eclipse.jetty.websocket.annotations.OnWebSocketConnect;
import org.eclipse.jetty.websocket.annotations.OnWebSocketMessage;
import org.eclipse.jetty.websocket.annotations.WebSocket;
import org.eclipse.jetty.websocket.api.WebSocketConnection;
/**
* Simple Echo WebSocket, using async writes of echo
*/
@WebSocket
public class ABSocket
{
private static Logger LOG = Log.getLogger(ABSocket.class);
private WebSocketConnection conn;
private String abbreviate(String message)
{
if (message.length() > 80)
{
return '"' + message.substring(0,80) + "\"...";
}
return '"' + message + '"';
}
@OnWebSocketMessage
public void onBinary(byte buf[], int offset, int len)
{
LOG.debug("onBinary(byte[{}],{},{})",buf.length,offset,len);
// echo the message back.
try
{
this.conn.write(null,new FutureCallback<Void>(),buf,offset,len);
}
catch (IOException e)
{
e.printStackTrace(System.err);
}
}
@OnWebSocketConnect
public void onOpen(WebSocketConnection conn)
{
this.conn = conn;
}
@OnWebSocketMessage
public void onText(String message)
{
if (LOG.isDebugEnabled())
{
if (message == null)
{
LOG.debug("onText() msg=null");
}
else
{
LOG.debug("onText() size={}, msg={}",message.length(),abbreviate(message));
}
}
// echo the message back.
try
{
this.conn.write(null,new FutureCallback<Void>(),message);
}
catch (IOException e)
{
e.printStackTrace(System.err);
}
}
}
|