이 콘텐츠는 선택한 언어로 제공되지 않습니다.
Chapter 15. Creating WebSocket Applications
The WebSocket protocol provides two-way communication between web clients and servers. Communications between clients and the server are event-based, allowing for faster processing and smaller bandwidth compared with polling-based methods. WebSocket is available for use in web applications using a JavaScript API and by client WebSocket endpoints using the Java Websocket API.
A connection is first established between client and server as an HTTP connection. The client then requests a WebSocket connection using the Upgrade
header. All communications are then full-duplex over the same TCP/IP connection, with minimal data overhead. Because each message does not include unnecessary HTTP header content, Websocket communications require smaller bandwidth. The result is a low latency communications path suited to applications, which require real-time responsiveness.
The JBoss EAP WebSocket implementation provides full dependency injection support for server endpoints, however, it does not provide CDI services for client endpoints.
A WebSocket application requires the following components and configuration changes:
- A Java client or a WebSocket enabled HTML client. You can verify HTML client browser support at this location: http://caniuse.com/#feat=websockets
- A WebSocket server endpoint class.
- Project dependencies configured to declare a dependency on the WebSocket API.
Create the WebSocket Application
The code examples that follow are taken from the websocket-hello
quickstart that ships with JBoss EAP. It is a simple example of a WebSocket application that opens a connection, sends a message, and closes a connection. It does not implement any other functions or include any error handling, which would be required for a real world application.
Create the JavaScript HTML client.
The following is an example of a WebSocket client. It contains these JavaScript functions:
-
connect()
: This function creates the WebSocket connection passing the WebSocket URI. The resource location matches the resource defined in the server endpoint class. This function also intercepts and handles the WebSocketonopen
,onmessage
,onerror
, andonclose
. -
sendMessage()
: This function gets the name entered in the form, creates a message, and sends it using a WebSocket.send() command. -
disconnect()
: This function issues the WebSocket.close() command. -
displayMessage()
: This function sets the display message on the page to the value returned by the WebSocket endpoint method. displayStatus()
: This function displays the WebSocket connection status.Example: Application
index.html
CodeCopy to Clipboard Copied! Toggle word wrap Toggle overflow
-
Create the WebSocket server endpoint.
You can create a WebSocket server endpoint using either of the following methods.
-
Programmatic Endpoint
: The endpoint extends the Endpoint class. -
Annotated Endpoint
: The endpoint class uses annotations to interact with the WebSocket events. It is simpler to code than the programmatic endpoint.
The code example below uses the annotated endpoint approach and handles the following events.
-
The
@ServerEndpoint
annotation identifies this class as a WebSocket server endpoint and specifies the path. -
The
@OnOpen
annotation is triggered when the WebSocket connection is opened. -
The
@OnMessage
annotation is triggered when a message is received. The
@OnClose
annotation is triggered when the WebSocket connection is closed.Example: WebSocket Endpoint Code
Copy to Clipboard Copied! Toggle word wrap Toggle overflow
-
Declare the WebSocket API dependency in your project POM file.
If you use Maven, you add the following dependency to the project
pom.xml
file.Example: Maven Dependency
Copy to Clipboard Copied! Toggle word wrap Toggle overflow
The quickstarts that ship with JBoss EAP include additional WebSocket client and endpoint code examples.