如何从Twitter中读取响应数据Streaming API - POST状态/过滤器? 我建立了连接,并收到200个状态代码,但我不知道如何阅读推文。我只是想在他们来的时候发布推文。Playframework和Twitter Streaming API
ws.url(url)
.sign(OAuthCalculator(consumerKey, requestToken))
.withMethod("POST")
.stream()
.map { response =>
if(response.headers.status == 200)
println(response.body)
}
编辑:我发现这个解决方案
ws.url(url)
.sign(OAuthCalculator(consumerKey, requestToken))
.withMethod("POST")
.stream()
.map { response =>
if(response.headers.status == 200){
response.body
.scan("")((acc, curr) => if (acc.contains("\r\n")) curr.utf8String else acc + curr.utf8String)
.filter(_.contains("\r\n"))
.map(json => Try(parse(json).extract[Tweet]))
.runForeach {
case Success(tweet) =>
println("-----")
println(tweet.text)
case Failure(e) =>
println("-----")
println(e.getStackTrace)
}
}
}
感谢您的解释 – mkovacek
以后可以关闭连接吗?我打算有多个跟踪不同单词的请求,我希望在未来某个时间关闭特定连接? – mkovacek
查看Akka文档中的[Dynamic Stream Handling](http://doc.akka.io/docs/akka/2.4.8/scala/stream/stream-dynamic.html)。一个想法是:创建一个共享kill开关,然后用'source.via(killSwitch.flow)'将其添加到流中。在killswitch上运行'shutdown()'应该关闭连接。 – Mikesname