2016-02-08 18 views
5

connection.handleWithAsyncHandlerで動作するようにAkka httpウェブソケットを取得できません。ここに私のコードは、それをテストするために非同期ハンドラを持つWebsocket

import akka.actor.ActorSystem 
import akka.http.scaladsl.Http 
import akka.http.scaladsl.model.HttpMethods._ 
import akka.http.scaladsl.model._ 
import akka.http.scaladsl.model.ws.{Message, UpgradeToWebsocket} 
import akka.stream.ActorMaterializer 
import akka.stream.scaladsl.{Flow, Sink} 

import scala.concurrent.Future 

object Server extends App { 
    implicit val system = ActorSystem("server-system") 
    implicit val materializer = ActorMaterializer() 
    implicit val dispatcher = system.dispatcher 
    implicit val formats = net.liftweb.json.DefaultFormats 

    val serverSource = Http().bind(interface = "localhost", port = 9000) 

    val requestHandler: HttpRequest => Future[HttpResponse] = { 
     case request @ HttpRequest(GET, Uri.Path("/websocket"), _, _, _) => { 
      Future { 
       request.header[UpgradeToWebsocket] match { 
        case Some(upgrade) => { 
         upgrade.handleMessages(Flow[Message]) 
        } 
        case None => { 
         HttpResponse(StatusCodes.BadRequest) 
        } 
       } 
      } 
     } 
     case _: HttpRequest => { 
      Future.successful(HttpResponse(StatusCodes.BadRequest)) 
     } 
    } 

    val bindingFuture = serverSource.to(Sink.foreach { connection => 
     connection.handleWithAsyncHandler(requestHandler) 
    }).run() 
} 

と私のJSコードを(私はアッカのhttpの最新バージョンを使用しています)Scalaである:

コンソールで
<!doctype html> 
<html lang="en"> 
<head> 
    <meta charset="UTF-8"> 
    <title>Document</title> 
</head> 
<body> 
<script> 
    var ws = new WebSocket('ws://localhost:9000/websocket'); 

    ws.onopen = function() { 
     console.log('open'); 

     ws.send('test message'); 
    }; 

    ws.onmessage = function(msg) { 
     console.log(msg.data); 
    }; 

    ws.onclose = function() { 
     console.log('close'); 
    }; 
</script> 
</body> 
</html> 

私は

open 
close 
を取得します

WebSocket接続を開いた直後に閉じているのはなぜですか?

答えて

1

akka 2.4.2-RC2にアップデートすると、このトリックが実行されました。

関連する問題