- 相關推薦
如何開發(fā)部署websocket端點
下面YJBYS小編為大家整理了關于如何利用Java Websocket API的編程式版本開發(fā)并部署(服務器與客戶端)websocket端點的文章,希望對你有所幫助。
第一步——擴展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...
}
第二步——實現ServerApplicationConfig接口
該接口屬于javax.websocket.server包的組成部分,且能夠通過覆寫以實現端點部署中的定制化邏輯(適用于注釋以及編程式端點)。
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服務器端點的連接進行初始化。
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"));
注意事項:
客戶端以及服務器端的config對象只能為等同于(編程式)對象的@ServerEndpoint以及@ClientEndpoint注釋元素(例如值、編碼器、解碼器以及配置器等等)。
各獨立builder類(ServerEndpointConfig.Builder與ClientEndpointConfig.Builder)用于分別創(chuàng)建服務器與客戶端配置實例。
ServerEndpointConfig實例的創(chuàng)建屬于mandatory,因為服務器端點無法在不配合URI的前提下進行部署。不過這種情況在客戶端端點方面不會出現——因為其全部作用就是接入現有服務器端點。
端點config(服務器&客戶端)擁有configurator概念,其可通過對應builder方法進行創(chuàng)建與設置。
【如何開發(fā)部署websocket端點】相關文章:
如何開發(fā)幼兒的右腦09-06
如何面試Web前端開發(fā)06-21
如何開發(fā)企業(yè)高層客戶10-01
如何開發(fā)中層管理者09-17
如何開發(fā)中層領導力07-14
如何開發(fā)和維護老客戶07-24
如何開發(fā)一個SEO友好的網站05-31
如何開發(fā)0到1歲寶寶學說話的潛力07-09
靈活調整戰(zhàn)略部署06-27