客户端用法:反序列化

为能将事件流反序列化为 Source[ServerSentEvent, NotUsed],需要引入 EventStreamUnmarshalling 定义的 FromEntityUnmarshaller[Source[ServerSentEvent, NotUsed]] 到当前作用域:

import akka.http.scaladsl.unmarshalling.sse.EventStreamUnmarshalling._

Http()
  .singleRequest(Get("http://localhost:8000/events"))
  .flatMap(Unmarshal(_).to[Source[ServerSentEvent, NotUsed]])
  .foreach(_.runForeach(println))

若要可靠的持久订阅事件流,则可以使用 Alpakka 提供 EventSource 连接器,其会用上次连接的最后一个事件的 ID 自动重连。

Copyright © satansk.com 2017 all right reserved,powered by Gitbook该文件修订时间: 2018-01-23 13:16:49

results matching ""

    No results matching ""