首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Scala读取连续http流

Scala读取连续http流
EN

Stack Overflow用户
提问于 2015-10-13 15:36:04
回答 1查看 881关注 0票数 3

如何连接和读取scala中的连续(块) http流?例如,如果我用python/瓶编写了一个简单的服务:

代码语言:javascript
复制
from gevent import monkey; monkey.patch_all()

import gevent
from bottle import route, run

@route('/stream')
def stream():
    while True:
        yield 'blah\n'
        gevent.sleep(1)

run(host='0.0.0.0', port=8100, server='gevent')

我计划使用akka-stream来处理数据,我只需要一种检索它的方法。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2015-10-13 16:56:37

这应该能行。基本上,您只需对一个uri进行一个请求,就会产生一个分块的响应。响应实体包含一个dataBytes流。如果出现分块响应,这将是块流。对于非块响应(HttpEntity.Strict),这将是一个只有一个块的流。

显然,您也可以显式地匹配该实体,以查看它是否为HttpEntity.Chunked,但通常您也希望保留处理非块响应的能力。

在实际应用程序中,您不会使用runForeach来执行副作用,而是使用dataBytes流进行一些处理。

代码语言:javascript
复制
import akka.actor.ActorSystem
import akka.http.scaladsl.Http
import akka.http.scaladsl.model.{Uri, HttpRequest}
import akka.stream.ActorMaterializer

object ChunkTestClient extends App {

  implicit val system = ActorSystem("test")
  import system.dispatcher

  implicit val materializer = ActorMaterializer()
  val source = Uri("https://jigsaw.w3.org/HTTP/ChunkedScript")
  val finished = Http().singleRequest(HttpRequest(uri = source)).flatMap { response =>
    response.entity.dataBytes.runForeach { chunk =>
      println(chunk.utf8String)
    }
  }
}
票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/33106851

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档