public abstract class WebSocketClient extends AbstractWebSocket implements Runnable, WebSocket
connect(), then receive events like onMessage(String) via the overloaded methods and to send(String) data to the server.WebSocket.READYSTATE, WebSocket.Role| Modifier and Type | Field and Description |
|---|---|
protected URI |
uri
The URI this channel is supposed to connect to.
|
DEFAULT_PORT, DEFAULT_WSS_PORT| Constructor and Description |
|---|
WebSocketClient(URI serverUri)
Constructs a WebSocketClient instance and sets it to the connect to the
specified URI.
|
WebSocketClient(URI serverUri,
Draft protocolDraft)
Constructs a WebSocketClient instance and sets it to the connect to the
specified URI.
|
WebSocketClient(URI serverUri,
Draft protocolDraft,
Map<String,String> httpHeaders,
int connectTimeout)
Constructs a WebSocketClient instance and sets it to the connect to the
specified URI.
|
| Modifier and Type | Method and Description |
|---|---|
void |
close()
Initiates the websocket close handshake.
|
void |
close(int code)
sends the closing handshake.
|
void |
close(int code,
String message)
sends the closing handshake.
|
void |
closeBlocking()
Same as
close but blocks until the websocket closed or failed to do so. |
void |
closeConnection(int code,
String message)
This will close the connection immediately without a proper close handshake.
|
void |
connect()
Initiates the websocket connection.
|
boolean |
connectBlocking()
Same as
connect but blocks until the websocket connected or failed to do so. |
protected Collection<WebSocket> |
connections()
Getter to get all the currently available connections
|
WebSocket |
getConnection()
Getter for the engine
|
Draft |
getDraft()
Returns the protocol version this channel uses.
|
InetSocketAddress |
getLocalSocketAddress()
Returns the address of the endpoint this socket is bound to.
|
InetSocketAddress |
getLocalSocketAddress(WebSocket conn) |
WebSocket.READYSTATE |
getReadyState()
This represents the state of the connection.
|
InetSocketAddress |
getRemoteSocketAddress()
Returns the address of the endpoint this socket is connected to, or
null if it is unconnected. |
InetSocketAddress |
getRemoteSocketAddress(WebSocket conn) |
String |
getResourceDescriptor()
Returns the HTTP Request-URI as defined by http://tools.ietf.org/html/rfc2616#section-5.1.2
If the opening handshake has not yet happened it will return null. |
Socket |
getSocket()
Returns the socket to allow Hostname Verification
|
URI |
getURI()
Returns the URI that this WebSocketClient is connected to.
|
boolean |
hasBufferedData()
Checks if the websocket has buffered data
|
boolean |
isClosed()
Is the websocket in the state CLOSED
|
boolean |
isClosing()
Is the websocket in the state CLOSING
|
boolean |
isConnecting()
Is the websocket in the state CONNECTING
|
boolean |
isFlushAndClose()
Returns true when no further frames may be submitted
This happens before the socket connection is closed. |
boolean |
isOpen()
Is the websocket in the state OPEN
|
abstract void |
onClose(int code,
String reason,
boolean remote) |
void |
onCloseInitiated(int code,
String reason)
Send when this peer sends a close handshake
|
void |
onClosing(int code,
String reason,
boolean remote)
Called as soon as no further frames are accepted
|
abstract void |
onError(Exception ex) |
void |
onFragment(Framedata frame)
Deprecated.
|
void |
onMessage(ByteBuffer bytes) |
abstract void |
onMessage(String message) |
abstract void |
onOpen(ServerHandshake handshakedata) |
void |
onWebsocketClose(WebSocket conn,
int code,
String reason,
boolean remote)
Calls subclass' implementation of onClose.
|
void |
onWebsocketCloseInitiated(WebSocket conn,
int code,
String reason)
send when this peer sends a close handshake
|
void |
onWebsocketClosing(WebSocket conn,
int code,
String reason,
boolean remote)
Called as soon as no further frames are accepted
|
void |
onWebsocketError(WebSocket conn,
Exception ex)
Calls subclass' implementation of onIOError.
|
void |
onWebsocketMessage(WebSocket conn,
ByteBuffer blob)
Called when an entire binary frame has been received.
|
void |
onWebsocketMessage(WebSocket conn,
String message)
Calls subclass' implementation of onMessage.
|
void |
onWebsocketMessageFragment(WebSocket conn,
Framedata frame)
This default implementation does not do anything.
|
void |
onWebsocketOpen(WebSocket conn,
Handshakedata handshake)
Calls subclass' implementation of onOpen.
|
void |
onWriteDemand(WebSocket conn)
This method is used to inform the selector thread that there is data queued to be written to the socket.
|
void |
run() |
void |
send(byte[] data)
Sends binary data to the connected webSocket server.
|
void |
send(ByteBuffer bytes)
Send Binary data (plain bytes) to the other end.
|
void |
send(String text)
Sends text to the connected websocket server.
|
void |
sendFragmentedFrame(Framedata.Opcode op,
ByteBuffer buffer,
boolean fin)
Allows to send continuous/fragmented frames conveniently.
|
void |
sendFrame(Collection<Framedata> frames)
Send a collection of frames to the other end
|
void |
sendFrame(Framedata framedata)
Send a frame to the other end
|
void |
sendPing()
Send a ping to the other end
|
void |
setProxy(Proxy proxy) |
void |
setSocket(Socket socket)
Accepts bound and unbound sockets.
|
getConnectionLostTimeout, isReuseAddr, isTcpNoDelay, setConnectionLostTimeout, setReuseAddr, setTcpNoDelay, startConnectionLostTimer, stopConnectionLostTimergetFlashPolicy, onWebsocketHandshakeReceivedAsClient, onWebsocketHandshakeReceivedAsServer, onWebsocketHandshakeSentAsClient, onWebsocketPing, onWebsocketPongprotected URI uri
public WebSocketClient(URI serverUri)
serverUri - the server URI to connect topublic WebSocketClient(URI serverUri, Draft protocolDraft)
serverUri - the server URI to connect toprotocolDraft - The draft which should be used for this connectionpublic WebSocketClient(URI serverUri, Draft protocolDraft, Map<String,String> httpHeaders, int connectTimeout)
serverUri - the server URI to connect toprotocolDraft - The draft which should be used for this connectionhttpHeaders - Additional HTTP-HeadersconnectTimeout - The Timeout for the connectionpublic URI getURI()
public Draft getDraft()
public Socket getSocket()
public void connect()
public boolean connectBlocking()
throws InterruptedException
connect but blocks until the websocket connected or failed to do so.InterruptedException - Thrown when the threads get interruptedpublic void close()
closeBlockingpublic void closeBlocking()
throws InterruptedException
close but blocks until the websocket closed or failed to do so.InterruptedException - Thrown when the threads get interruptedpublic void send(String text) throws NotYetConnectedException
send in interface WebSockettext - The string which will be transmitted.NotYetConnectedException - websocket is not yet connectedpublic void send(byte[] data)
throws NotYetConnectedException
send in interface WebSocketdata - The byte-Array of data to send to the WebSocket server.NotYetConnectedException - websocket is not yet connectedprotected Collection<WebSocket> connections()
AbstractWebSocketconnections in class AbstractWebSocketpublic void sendPing()
throws NotYetConnectedException
WebSocketsendPing in interface WebSocketNotYetConnectedException - websocket is not yet connectedpublic WebSocket.READYSTATE getReadyState()
getReadyState in interface WebSocketpublic final void onWebsocketMessage(WebSocket conn, String message)
onWebsocketMessage in interface WebSocketListenerconn - The WebSocket instance this event is occurring on.message - The UTF-8 decoded message that was received.public final void onWebsocketMessage(WebSocket conn, ByteBuffer blob)
WebSocketListeneronWebsocketMessage in interface WebSocketListenerconn - The WebSocket instance this event is occurring on.blob - The binary message that was received.public void onWebsocketMessageFragment(WebSocket conn, Framedata frame)
WebSocketAdapteronWebsocketMessageFragment in interface WebSocketListeneronWebsocketMessageFragment in class WebSocketAdapterconn - The WebSocket instance this event is occurring on.frame - The fragmented frameWebSocketListener.onWebsocketMessageFragment(WebSocket, Framedata)public final void onWebsocketOpen(WebSocket conn, Handshakedata handshake)
onWebsocketOpen in interface WebSocketListenerconn - The WebSocket instance this event is occuring on.handshake - The handshake of the websocket instancepublic final void onWebsocketClose(WebSocket conn, int code, String reason, boolean remote)
onWebsocketClose in interface WebSocketListenerconn - The WebSocket instance this event is occuring on.code - The codes can be looked up here: CloseFramereason - Additional information stringremote - Returns whether or not the closing of the connection was initiated by the remote host.public final void onWebsocketError(WebSocket conn, Exception ex)
onWebsocketError in interface WebSocketListenerconn - The WebSocket instance this event is occuring on.ex - The exception that occurred. public final void onWriteDemand(WebSocket conn)
WebSocketListeneronWriteDemand in interface WebSocketListenerconn - The WebSocket instance this event is occuring on.public void onWebsocketCloseInitiated(WebSocket conn, int code, String reason)
WebSocketListeneronWebsocketCloseInitiated in interface WebSocketListenerconn - The WebSocket instance this event is occuring on.code - The codes can be looked up here: CloseFramereason - Additional information stringpublic void onWebsocketClosing(WebSocket conn, int code, String reason, boolean remote)
WebSocketListeneronWebsocketClosing in interface WebSocketListenerconn - The WebSocket instance this event is occuring on.code - The codes can be looked up here: CloseFramereason - Additional information stringremote - Returns whether or not the closing of the connection was initiated by the remote host.public void onCloseInitiated(int code,
String reason)
code - The codes can be looked up here: CloseFramereason - Additional information stringpublic void onClosing(int code,
String reason,
boolean remote)
code - The codes can be looked up here: CloseFramereason - Additional information stringremote - Returns whether or not the closing of the connection was initiated by the remote host.public WebSocket getConnection()
public InetSocketAddress getLocalSocketAddress(WebSocket conn)
getLocalSocketAddress in interface WebSocketListenerconn - The WebSocket instance this event is occuring on.WebSocket.getLocalSocketAddress()public InetSocketAddress getRemoteSocketAddress(WebSocket conn)
getRemoteSocketAddress in interface WebSocketListenerconn - The WebSocket instance this event is occuring on.null if it is unconnected.WebSocket.getRemoteSocketAddress()public abstract void onOpen(ServerHandshake handshakedata)
public abstract void onMessage(String message)
public abstract void onClose(int code,
String reason,
boolean remote)
public abstract void onError(Exception ex)
public void onMessage(ByteBuffer bytes)
@Deprecated public void onFragment(Framedata frame)
public void setProxy(Proxy proxy)
public void setSocket(Socket socket)
connect.
If the given socket is not yet bound it will be bound to the uri specified in the constructor.socket - The socket which should be used for the connectionpublic void sendFragmentedFrame(Framedata.Opcode op, ByteBuffer buffer, boolean fin)
WebSocketsendFragmentedFrame in interface WebSocketop - This is only important for the first frame in the sequence. Opcode.TEXT, Opcode.BINARY are allowed.buffer - The buffer which contains the payload. It may have no bytes remaining.fin - true means the current frame is the last in the sequence.public boolean isOpen()
WebSocketpublic boolean isFlushAndClose()
WebSocketisFlushAndClose in interface WebSocketpublic boolean isClosed()
WebSocketpublic boolean isClosing()
WebSocketpublic boolean isConnecting()
WebSocketisConnecting in interface WebSocketpublic boolean hasBufferedData()
WebSockethasBufferedData in interface WebSocketpublic void close(int code)
WebSocketpublic void close(int code,
String message)
WebSocketpublic void closeConnection(int code,
String message)
WebSocketcloseConnection in interface WebSocketcode - the closing codemessage - the closing messagepublic void send(ByteBuffer bytes) throws IllegalArgumentException, NotYetConnectedException
WebSocketsend in interface WebSocketbytes - the binary data to sendIllegalArgumentException - the data is nullNotYetConnectedException - websocket is not yet connectedpublic void sendFrame(Framedata framedata)
WebSocketpublic void sendFrame(Collection<Framedata> frames)
WebSocketpublic InetSocketAddress getLocalSocketAddress()
WebSocketgetLocalSocketAddress in interface WebSocketpublic InetSocketAddress getRemoteSocketAddress()
WebSocketnull if it is unconnected.getRemoteSocketAddress in interface WebSocketpublic String getResourceDescriptor()
WebSocketgetResourceDescriptor in interface WebSocketCopyright © 2017. All rights reserved.