Java Websocket 開発ガイド: クライアントとサーバー間のリアルタイム通信を実装する方法、具体的なコード例が必要です
Web アプリケーションの継続的な開発では、時間的なコミュニケーションはプロジェクトの重要な部分になっています。従来の HTTP プロトコルでは、クライアントがサーバーにリクエストを送信し、レスポンスを受信して初めてデータを取得できるため、クライアントは最新のデータを取得するためにサーバーを継続的にポーリングすることになり、パフォーマンスと効率の問題が発生します。 。 WebSocket はこれらの問題を解決するために生まれました。
WebSocket は HTML5 の新しいプロトコルです。双方向通信を提供し、クライアントのポーリング作業を軽減します。クライアントは、サーバーからの応答を待たずに、サーバーにメッセージを直接送信できます。これにより、リアルタイム アプリケーションの開発がより簡単かつ効率的になります。
Java は Web アプリケーション開発で広く使用されている言語であり、Websocket を簡単に実装する方法も提供します。 Java で Websocket を使用する方法は次のとおりです。
最初のステップは、Java の WebSocket API をインポートすることです。これは、Maven 中央リポジトリから行うか、Java EE 7 フレームワークの javax.websocket パッケージの API を使用して行うことができます。
次は、Java EE 7 の javax.websocket パッケージの API を使用して Websocket を実装する例です。
- ServerEndpoint アノテーション クラスの作成
Use @WebSocket アノテーションは、このクラスがこのセッションを WebSocket エンドポイントとして使用できることを Java サーバーに伝えるクラスを作成し、このアドレスを WebSocket エンドポイントと照合するための URI を提供します。
import javax.websocket.*; import javax.websocket.server.ServerEndpoint; @ServerEndpoint(value = "/websocket") public class WebSocketExample { @OnOpen public void onOpen(){ System.out.println("Connection opened"); } @OnClose public void onClose(){ System.out.println("Connection closed"); } @OnMessage public void onMessage(String message){ System.out.println("Message received: " + message); } }
WebSocketExample クラスを WebSocket プログラムへの入り口として使用します。上記の例では、Endpoint クラスで @ServerEndpoint アノテーションを使用して、クラスを指定された URI にマップしました。
@OnOpen、@OnMessage、および @OnClose アノテーションはイベントベースであり、WebSocket 接続が開かれ、メッセージが受信され、接続が閉じられるときに呼び出されるメソッドを指定するために使用されます。
取得されたメッセージ文字列は、onMessage コールバック メソッドに直接渡されます。これで、WebSocket サーバー側でエンドポイントが定義されました。
- クライアントの作成例
public class WebSocketClientExample extends Endpoint { public static CountDownLatch latch; @Override public void onOpen(final Session session, EndpointConfig config) { System.out.println("Connected"); try { session.getBasicRemote().sendText("Hello"); } catch (IOException ex) { } } @Override public void onError(final Session session, Throwable t) { t.printStackTrace(); } }
WebSocket クライアントは、WebSocket API の一部である javax.websocket.Endpoint を基本クラスとして使用できます。
CountDownLatch を使用して、クライアントがサーバーに接続されているかどうかを判断します。
onOpen() コールバック メソッドで、サーバーに接続し、メッセージを送信しました。
注: この例では、メッセージは session.getBasicRemote().sendText(“Hello”); メソッドを使用して送信されます。 WebSocket API には、メッセージを送信するための別のメソッド、つまり session.getAsyncRemote().sendText("Hello"); があります。違いは、getBasicRemote() メソッドがブロッキングであるのに対し、getAsyncRemote() メソッドはノンブロッキングであることです。 。 の。メッセージを非同期に送信したい場合は、getAsyncRemote() を使用できます。
- テスト クラスを作成してアプリケーションを実行する
サーバーとクライアントにサービスを提供し、接続が正常に確立されることを確認するテスト クラスを構築します。アプリケーションを起動し、実行中のアプリケーションが WebSocket サーバーと対話できるようにする必要があります。すべてが正常であれば、開発ツールのコンソールにいくつかのメッセージが表示されるはずです。
import javax.websocket.*; import java.net.URI; import java.util.concurrent.CountDownLatch; public class AppRunner { public static void main(String[] args) throws Exception { WebSocketContainer container = ContainerProvider.getWebSocketContainer(); CountDownLatch latch = new CountDownLatch(1); container.connectToServer(new WebSocketExample(), new URI("ws://localhost:8080/websocket")); latch.await(); } }
このテスト コードは、WebSocket クライアントを起動し、localhost:8080 の WebSocket サーバーへの接続を試行します。 CountDownLatch オブジェクトを使用して、いくつかの追加情報とともに接続の成功を待ちます。
テストを実行するときは、Web ブラウザーで http://localhost:8080/websocket と入力し、JavaScript コンソールを開いてメッセージを表示し、JavaScript WebSocket オブジェクトを通じて WebSocket クライアントにメッセージを送信します。
概要:
リアルタイム通信に WebSocket を使用すると、従来の HTTP 定期ポーリングを使用するよりもはるかに効率的です。 Java 言語では、WebSocket API を使用して WebSocket を実装できます。この記事では、WebSocket サーバーとクライアントの Java サンプル プログラムと具体的なコードの実装例を紹介します。
以上がJava Websocket 開発ガイド: クライアントとサーバー間のリアルタイム通信を実現する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

この記事では、Javaプロジェクト管理、自動化の構築、依存関係の解像度にMavenとGradleを使用して、アプローチと最適化戦略を比較して説明します。

この記事では、MavenやGradleなどのツールを使用して、適切なバージョン化と依存関係管理を使用して、カスタムJavaライブラリ(JARファイル)の作成と使用について説明します。

この記事では、カフェインとグアバキャッシュを使用してJavaでマルチレベルキャッシュを実装してアプリケーションのパフォーマンスを向上させています。セットアップ、統合、パフォーマンスの利点をカバーし、構成と立ち退きポリシー管理Best Pra

この記事では、キャッシュや怠zyなロードなどの高度な機能を備えたオブジェクトリレーショナルマッピングにJPAを使用することについて説明します。潜在的な落とし穴を強調しながら、パフォーマンスを最適化するためのセットアップ、エンティティマッピング、およびベストプラクティスをカバーしています。[159文字]

Javaのクラスロードには、ブートストラップ、拡張機能、およびアプリケーションクラスローダーを備えた階層システムを使用して、クラスの読み込み、リンク、および初期化が含まれます。親の委任モデルは、コアクラスが最初にロードされ、カスタムクラスのLOAに影響を与えることを保証します


ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

AtomエディタMac版ダウンロード
最も人気のあるオープンソースエディター

ZendStudio 13.5.1 Mac
強力な PHP 統合開発環境

SublimeText3 中国語版
中国語版、とても使いやすい

WebStorm Mac版
便利なJavaScript開発ツール

VSCode Windows 64 ビットのダウンロード
Microsoft によって発売された無料で強力な IDE エディター
