LoginSignup
1
3

More than 3 years have passed since last update.

JavaとjavascriptでWebSocketを試してみよう!

Posted at

Javaとjavascriptを使用します(jQuery使用)

1.Javaでサーバーサイドを記述します。
内容の説明はコード内のコメントを読んでいただくと、だいたい分かるかと思います。

WebSocketServer.java
package main.java;

import java.io.IOException;
import java.util.HashMap;
import java.util.Map;

import javax.websocket.CloseReason;
import javax.websocket.EndpointConfig;
import javax.websocket.OnClose;
import javax.websocket.OnError;
import javax.websocket.OnMessage;
import javax.websocket.OnOpen;
import javax.websocket.Session;
import javax.websocket.server.ServerEndpoint;

//これをつけるとWebSocketServer
//URLはワイルドカード可能
@ServerEndpoint("/WebSocketServer")
public class WebSocketServer {

    //Session(通信)を保存しておくためのMap
    private static Map<String, Session> session = new HashMap<>();

    //自分のIDを保存しておく変数
     String myId = "";

     //自分の名前を保存しておく変数
     String myName = "";

    /**
     * 接続時に呼ばれるメソッド
     */
    @OnOpen
    public void onOpen(final Session client, final EndpointConfig config) {
        /* セッション確立時の処理 */
        String log = client.getId() + " Was connected.";
        System.out.println(log);

    }

    /**
     * エラー時に呼ばれるメソッド
     */
    @OnError
    public void onError(final Session client, final Throwable error) {
        /* エラー発生時の処理 */
        String log = client.getId() + " was error. [" + error.getMessage() + "]";
        System.out.println(log);
    }

    /**
     * 切断時に呼ばれるメソッド
     */
    @OnClose
    public void onClose(final Session client, final CloseReason reason) throws IOException {
        /* セッション解放時の処理 */
        String log = client.getId() + " was closed by " + reason.getCloseCode() + "[" + reason.getCloseCode().getCode()
                + "]";
        System.out.println(log);
    }

    /**
     * メッセージが呼ばれた時に呼ばれるメソッド
     */
    @OnMessage
    public void onMessage(final String text, final Session client) throws IOException {
        /* メッセージ受信時の処理 */
        System.out.println("WebSocket受信:" + text);

        //メッセージの内容は、改行区切りで操作、idが記述されているものとする
        String[] t = text.split("\n");
        String event = t[0];
        String id = t[1];

        System.out.println("EVENT:" + event);
        System.out.println("ID:" + id);
        switch (event) {

        case "login":
            //HashMapにSessionを保存しておく
            session.put(id, client);
            //変数にIDを保存する。
            myId = id;

            //名前の切り出し
            int strSize = id.length();
            int cutLength = 4;
            int nameCut = strSize - cutLength;
            //変数に名前だけを保存
            myName = id.substring(0,nameCut);
            System.out.println("切り出した名前:" + myName);

            //idで保存したセッションに文字列を送信
            Session mySession = session.get(id);
            mySession.getBasicRemote().sendText("Welcom to " + myName + " !!");
            System.out.println("login:" + id);
            break;

        case "commit":
            //ブロードキャスト
            for (Session s : session.values()) {
                s.getBasicRemote().sendText(myName + ": " + t[1]);
            }
            System.out.println("commit:" + t[1]);
            break;

        case "close":
            //セッション一覧から削除
            System.out.println("削除するID:" + myId);
            //保存したセッションを削除
            session.remove(myId);
            System.out.println("close:セッション削除");
            break;
        }
    }
}

2.クライアント側のjavascriptを記述します。
こちらもコメントを読み取っていただくと幸いです。

script.js
$(function() {
    var url = 'ws://' + window.location.host + '/SampleServer/WebSocketServer';
    var ws = null;
    var inputId;
    console.log('ロケーション:' + window.location.host);

        //4桁のランダムな数を生成するための変数
        var min = 1000;
        var max = 9999;

        //名前に添付してID化するためのソルトコード
        var saltCode;

    //initButtonを押すとここが走るよ
      $('#login').on("click",function() {
        if (ws == null) {
            inputId = $('#box1').find('input').val();
             //IDがが空なら登録させない
             if(inputId != "") {
            //Websocketを初期化
             ws = new WebSocket(url);
            //イベントハンドラの登録
             ws.onopen = onOpen;
             ws.onmessage = onMessage;
             ws.onclose = onClose;
             ws.onerror = onError;
             console.log("ID:" + inputId);
            } else {
                alert("ID名を入力してください!!");
            }
        }

      });

    //WebSocket open
    function onOpen(event) {
       $("#log").prepend("&lt;onopen&gt; " + "<br/>");
        console.log("WebSocket接続確立");
                //4桁のランダムな整数を生成
                saltCode = Math.floor(Math.random() * (max + 1 - min)) + min;
                //明示的に文字列へのキャスト
                String(saltCode);
                //ソルトコードをくっつけてID作成
                inputId = inputId + saltCode;
                console.log('ソルトコード付きID:' + inputId);
       ws.send("login\n" + inputId);
    };

    //WebSocket message
    function onMessage(receive) {
       $("#log").prepend(receive.data + "<br/><br/>");
        console.log("レスポンスメッセージ:" + receive.data);
    };

    //WebSocket error
    function onError() {
        $("#log").prepend("&lt;onerror&gt; " + "<br/>");
        console.log("エラー処理");
        alert("error");
    };

    //WebSocket close
    function onClose() {
        $("#log").prepend("&lt;onclose&gt; " + "<br/>");
        ws.send("close\ndelete")
        ws = null;
        console.log("WebSocket切断");
    };


    //windowが閉じられた(例:ブラウザを閉じた)時のイベントを設定
    $(window).on("beforeunload",function() {
        ws.onclose(); //WebSocket close
    });

    //WebSocketを使ってメッセージをサーバに送信
   $('#send').on('click',function() {
       var sendMessage = $('#message').val();
       console.log("メッセージ:" + sendMessage);
       if(sendMessage != "") {
       ws.send("commit\n" + sendMessage);
           $('#message').val("");
       } else {
           console.log("空なので送信しません");
       }
   });
});

3.簡単なhtmlを用意します。

index.html
<!DOCTYPE html>

<html>
<head>
    <title>WebSocket Server Sample</title>
    <meta charset="utf-8"/>
    <script src="js/lib/jquery-3.4.1.min.js"></script>


    </head>
<body>
    <div id="box1">
    <input type="text" id="id" placeholder="inputID" />
    <button id="login">login</button>
        </div>
    <br/>
    <div id="box2">
    <input type="text" id="message" placeholder="inputMessage" />
        <button id="send">send</button>
        </div>
    <br/>
    <div id="log"></div>
    <script src="js/script.js"></script>
    </body>
</html>

このように動作するかと思います。

スクリーンショット 2020-04-19 12.48.35.png

別のユーザーでログインしてメセージを送信します。

スクリーンショット 2020-04-19 12.52.09.png

メッセージが送られてきます。!!

スクリーンショット 2020-04-19 12.54.07.png

ちゃんとメッセージが読めます。

このようにwebSocketを使用すると簡単なチャットのシステムを作成することができました。
データベースと連携させたりシステムを作り込んでいくと面白いものがつくれそうですね。
以上が簡単なwebsocket実装でした。

最後まで読んでくれてありがとうございます。

1
3
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
1
3