新聞中心
這篇文章將簡要演示如何利用Java Websocket API的編程式版本開發(fā)并部署(服務(wù)器與客戶端)websocket端點。

站在用戶的角度思考問題,與客戶深入溝通,找到溫泉網(wǎng)站設(shè)計與溫泉網(wǎng)站推廣的解決方案,憑借多年的經(jīng)驗,讓設(shè)計與互聯(lián)網(wǎng)技術(shù)結(jié)合,創(chuàng)造個性化、用戶體驗好的作品,建站類型包括:成都做網(wǎng)站、成都網(wǎng)站建設(shè)、企業(yè)官網(wǎng)、英文網(wǎng)站、手機端網(wǎng)站、網(wǎng)站推廣、域名注冊、虛擬空間、企業(yè)郵箱。業(yè)務(wù)覆蓋溫泉地區(qū)。
第一步——擴展javax.websocket.Endpoint類
- public class ProgrammaticEchoEnpoint extends Endpoint {
- @Override
- public void onOpen(Session session, EndpointConfig config) {
- System.out.println("Peer " + session.getId() + " connected");
- session.addMessageHandler(new MessageHandler.Whole
() { - @Override
- public void onMessage(String message) {
- try {
- session.getBasicRemote().sendText("Got message from " + session.getId() + "\n" + message);
- } catch (IOException ex) {
- }
- }
- });
- }
- @Override
- public void onClose(Session session, CloseReason closeReason) {
- System.out.println("Peer " + session.getId() + " disconnected due to " + closeReason.getReasonPhrase());
- }
- @Override
- public void onError(Session session, Throwable error) {
- System.out.println("Error communicating with peer " + session.getId() + ". Detail: "+ error.getMessage());
- }
- }
接下來我們還要編寫客戶端端點(使用同樣的API組合):
- public class ProgrammaticEchoClient extends Endpoint {
- @Override
- public void onOpen(Session session, EndpointConfig config) {
- System.out.println("Connected to server");
- }
- //a message handler and other life cycle implementations have been skipped on purpose...
- }
第二步——實現(xiàn)ServerApplicationConfig接口
該接口屬于javax.websocket.server包的組成部分,且能夠通過覆寫以實現(xiàn)端點部署中的定制化邏輯(適用于注釋以及編程式端點)。
- public class CustomServerAppConfigProvider implements ServerApplicationConfig {
- @Override
- public Set
getEndpointConfigs(Set > endpointClasses) { - Set
result = new HashSet<>(); - for (Class epClass : endpointClasses) {
- //need to ignore Client endpoint class
- if (epClass.equals(ProgrammaticChatEndpoint.class)) {
- ServerEndpointConfig sec = ServerEndpointConfig.Builder.create(epClass, "/letschat").build();
- result.add(sec);
- }
- }
- return result;
- }
- @Override
- public Set
> getAnnotatedEndpointClasses(Set > scanned) { - return Collections.emptySet();
- }
- }
怎樣處理Client端點?
如果有必要,大家也可以創(chuàng)建自己的ClientEndpointConfig實例,并利用它對指向websocket服務(wù)器端點的連接進行初始化。
- WebSocketContainer webSocketContainer = ContainerProvider.getWebSocketContainer();
- ClientEndpointConfig config = ClientEndpointConfig.Builder.create().decoders(StockTickDecoder.class).build();
- Session session = webSocketContainer.connectToServer(StockTickerClient().class, config,
- new URI("ws://hotstocks.com/ticker"));
注意事項:
- 客戶端以及服務(wù)器端的config對象只能為等同于(編程式)對象的@ServerEndpoint以及@ClientEndpoint注釋元素(例如值、編碼器、解碼器以及配置器等等)。
- 各獨立builder類(ServerEndpointConfig.Builder與ClientEndpointConfig.Builder)用于分別創(chuàng)建服務(wù)器與客戶端配置實例。
- ServerEndpointConfig實例的創(chuàng)建屬于mandatory,因為服務(wù)器端點無法在不配合URI的前提下進行部署。不過這種情況在客戶端端點方面不會出現(xiàn)——因為其全部作用就是接入現(xiàn)有服務(wù)器端點。
- 端點config(服務(wù)器&客戶端)擁有configurator概念,其可通過對應(yīng)builder方法進行創(chuàng)建與設(shè)置。
- 接下來我們還將發(fā)布更多與Websocket相關(guān)的指導(dǎo)性文章,各位敬請期待。
當(dāng)前題目:JavaEE7當(dāng)中的編程式Websocket端點
當(dāng)前路徑:http://www.dlmjj.cn/article/djoojgd.html


咨詢
建站咨詢
