我需要一个成熟的HTTP客户端库,它是scala惯用的,简洁的用法,简单的语义.我查看了Apache HTTP和Scala Dispatch以及许多新的库,这些库承诺提供惯用的Scala包装.Apache HTTP客户端肯定需要冗长,而Dispatch很容易混淆.
什么是适合Scala使用的HTTP客户端?
Ric*_*tze 29
我最近开始使用Dispatch,有点神秘(很棒的一般介绍,严重缺乏详细的场景/基于用例的文档).Dispatch 0.9.1是Ning的Async Http Client的Scala包装器; 要完全理解发生了什么,需要将自己引入该库.在实践中,我唯一需要关注的是RequestBuilder - 其他一切都很好地融入了我对HTTP的理解.
我给0.9发布了一个坚定的大拇指(到目前为止!)非常简单地完成工作......一旦你超越了最初的学习曲线.
Dispatch的Http"builder"是不可变的,似乎在线程环境中运行良好.虽然我在文档中找不到任何说明它是线程安全的东西; 一般阅读来源表明它是.
请注意,RequestBuilder是可变的,因此不是线程安全的.
以下是一些我发现有用的其他链接:
我找不到0.9.*版本的ScalaDoc链接,所以我浏览0.9.*版本的源代码 ;
ScalaDoc为0.8版本 ; 一个基本上不同的野兽(今天)大于0.9.
运营商的"周期性"表也与0.8相关.
较早的0.8"发送 - 经典"文档帮助我理解了他们如何使用网址构建器,并提供了一些关于如何将事物捆绑在一起的提示,这些提示结果为0.9.
imp*_*def 27
不再维护 Dispatch和其他一些库.目前唯一认真的是喷雾客户端和Play!WS.
spray-client的语法有点神秘.play-ws很容易使用:
(build.sbt)
libraryDependencies += "com.typesafe.play" %% "play-ws" % "2.4.3"
Run Code Online (Sandbox Code Playgroud)
(基本用法)
val wsClient = NingWSClient()
wsClient
.url("http://wwww.something.com")
.get()
.map { wsResponse =>
// read the response
}
Run Code Online (Sandbox Code Playgroud)
Mar*_*Tye 21
这里的聚会有点晚了,但我对喷雾客户印象深刻.
它有一个很好的DSL用于构建请求,支持同步和异步执行,以及各种(非)编组类型(JSON,XML,表单).它也和Akka很好地配合.
Ric*_*777 10
在与Apache客户端有过一些不愉快的经历后,我开始编写自己的.内置的HttpURLConnection被广泛认为是有缺陷的.但那不是我的体验.事实上,反过来一直如此,Apache客户端有一个有问题的线程模型.从Java6(或5?)开始,HttpURLConnection提供了高效的HTTP1.1连接,内置了keep-alive等基本功能,并且可以毫不费力地处理并发使用.
因此,为了弥补HttpURLConnection提供的不方便的API,我开始在Scala中编写一个新的API,作为一个开源项目.它只是HttpURLConnection的包装器,但与HttpURLConnection不同,它的目的是易于使用.与Apache客户端不同,它应该很容易适应现有项目.与Dispatch不同,它应该很容易学习.
它被称为蜜蜂客户端
我为无耻的插头道歉.:)
sttp是我们一直在等待的Scala HTTP库!
它有一个流畅的DSL用于形成和执行请求(来自其README的代码示例):
val request = sttp
.cookie("session", "*!@#!@!$")
.body(file) // of type java.io.File
.put(uri"http://httpbin.org/put")
.auth.basic("me", "1234")
.header("Custom-Header", "Custom-Value")
.response(asByteArray)
Run Code Online (Sandbox Code Playgroud)
它支持通过可插拔后端的同步,异步和流媒体调用,包括Akka-HTTP(以前的Spray)和古老的AsyncHttpClient(Netty):
implicit val sttpHandler = AsyncHttpClientFutureHandler()
val futureFirstResponse: Future[Response[String]] = request.send()
Run Code Online (Sandbox Code Playgroud)
它支持scala.concurrent.Future,scalaz.concurrent.Task,monix.eval.Task,和cats.effect.IO-所有主要斯卡拉IO单子库.
此外,它还有一些额外的技巧:
它具有请求和响应的案例类表示(尽管它没有像例如强类型标题那样):https : //github.com/softwaremill/sttp/blob/master/core/src/main/scala /com/softwaremill/sttp/RequestT.scala https://github.com/softwaremill/sttp/blob/master/core/src/main/scala/com/softwaremill/sttp/Response.scala
它提供了一个URI字符串插补器:
val test = "chrab?szcz majowy"
val testUri: Uri = uri"http://httpbin.org/get?bug=$test"
import com.softwaremill.sttp.circe._
val response: Either[io.circe.Error, Response] =
sttp
.post(uri"...")
.body(requestPayload)
.response(asJson[Response])
.send()
最后,它由软件工厂的可靠人员维护,并且有很好的文档.
小智 5
除了Dispatch之外没有多少.scalaz试图建立一个功能强大的http客户端.但它已经过时了一段时间scalaz7分支中没有它的版本.另外,在playframework中有一个非常有用的ning async-http-client 包装器.你可以在那里打电话:
WS.url("http://example.com/feed").get()
WS.url("http://example.com/item").post("content")
Run Code Online (Sandbox Code Playgroud)
如果您不使用游戏,可以使用此API作为灵感!在您的项目中,不喜欢Dispatch API.
| 归档时间: |
|
| 查看次数: |
38198 次 |
| 最近记录: |