0

Play Framework バージョン 2.1 で websocket 通信が機能しないようです。

ボタンを押すだけでメッセージを送受信するだけの簡単なテストを作成しました。そのためのすべてのコードは以下のとおりです。しかし、ボタン以外は何も表示されません。

誰かがこの問題を見たことがありますか、それとも以下のコードで何が間違っているのか教えてもらえますか?

Chrome の最新バージョンを使用しています。

これが私の簡単なセットアップです。

Application.java 内

public static Result index() {
    return ok(index.render());
}

public static WebSocket<String> sockHandler() {
    return new WebSocket<String>() {
        // called when the websocket is established
        public void onReady(WebSocket.In<String> in,
                WebSocket.Out<String> out) {
            // register a callback for processing instream events
            in.onMessage(new Callback<String>() {
                public void invoke(String event) {
                    System.out.println(event);
                }
            });

            // write out a greeting
            out.write("I'm contacting you regarding your recent websocket.");
        }
    };
}

ルートファイルで GET / controllers.Application.index()

# Map static resources from the /public folder to the /assets URL path
GET     /assets/*file               controllers.Assets.at(path="/public", file)
GET     /greeter                    controllers.Application.sockHandler()

Index.Scala.html 内

@main(null) {

<div class="greeting"></div>
<button class="send">Send</button>

<script type="text/javascript" charset="utf-8">

    $(function() {
        var WS = window['MozWebSocket'] ? MozWebSocket : WebSocket
        var sock = new WS("@routes.Application.sockHandler()")

        sock.onmessage = function(event) {
            $('.greeting').append(event.data)
        }

        $('button.send').click(function() {
            sock.send("I'm sending a message now.")
        });            
    })

</script>

}

Main.scala.html 内

@(title: String)(content: Html)
<!DOCTYPE html>
<html>
<head>
    <title>@title</title>
    <link rel="stylesheet" media="screen" href="@routes.Assets.at("stylesheets/main.css")">
    <link rel="shortcut icon" type="image/png" href="@routes.Assets.at("images/favicon.png")">
    <script src="@routes.Assets.at("javascripts/jquery-1.7.1.min.js")" type="text/javascript"></script>
</head>
<body>
    @content
</body>

4

2 に答える 2

3

Route のwebSocketURL()メソッドを使用して、WebSocket のコンストラクターに渡すことができる URL を取得できます。Play の websocket-chat サンプル コードの例を次に示します。

$(function() {            
  var WS = window['MozWebSocket'] ? MozWebSocket : WebSocket
  var chatSocket = new WS("@routes.Application.chat(username).webSocketURL()")

  var sendMessage = function() {
    chatSocket.send(JSON.stringify(
      {text: $("#talk").val()}
    ))
    $("#talk").val('')
  }

  // ...

したがって、コードでは次のようなものを使用できます

var sock = new WS("@routes.Application.sockHandler().webSocketURL()");

個人的には、補間されたコードと JS を混在させるのは好きではありません。クライアントで実行されるコードは、サーバーではなく、クライアントの状態のみに関係する必要があると思うからです (スクリプトを外部にリファクタリングすることは言うまでもありません)ファイルが不可能)、私はこのようなことをする傾向があります:

<div class="container app-container" 
     data-ws-uri="@routes.Application.WSUri.webSocketURL()">
.......
</div>

次に、JSで次のようなことができます

var sock = new WS(document.querySelector(".app-container").dataset.wsUri);
// ....
于 2013-03-25T00:40:50.493 に答える
3

問題は

var sock = new WS("@routes.Application.sockHandler()")

プロトコルと完全な URL をws://localhost:9000/greeterの形式で指定する必要があります。

この質問を確認して、javascript で実行してください:ページ URI に関連する WebSocket URI を構築する方法は?

于 2013-03-22T14:40:02.147 に答える