私は、ScalaでXMLを返すWebサービスに簡単なPOSTリクエストを発行しようとしています。
Dispatch がこのタスクに使用される標準ライブラリのようですが、ドキュメントが見つかりません。上でリンクしているメインサイトでは、約束と非同期プログラミングの実行方法について詳しく説明していますが、実際にはAPIについては説明していません。 periodic table -少し怖いように見えます-しかし、それはすでに何をすべきかを知っていて、不可解な構文のリマインダーのみを必要とする人々にとってのみ有用であるようです。
ScalazにはHTTPの機能があります のようにも見えますが、ドキュメントも見つかりません。
私は次を使用します: https://github.com/scalaj/scalaj-http 。
簡単なGETリクエストを次に示します。
import scalaj.http.Http
Http("http://foo.com/search").param("q", "monkeys").asString
およびPOSTの例:
val result = Http("http://example.com/url").postData("""{"id":"12","json":"data"}""")
.header("Content-Type", "application/json")
.header("Charset", "UTF-8")
.option(HttpOptions.readTimeout(10000)).asString
Scalaj HTTPはSBTを介して利用できます。
libraryDependencies += "org.scalaj" % "scalaj-http_2.11" % "2.3.0"
spray-client を使用できます。ドキュメントが不足しています(詳細については掘り下げる必要がありました クエリパラメータを使用してGETリクエストを行う方法 )が、すでにスプレーを使用している場合は素晴らしいオプションです。そして、ドキュメントはディスパッチよりも優れています。
AI2 over dispatch で使用しています。これは、演算子のシンボリック性が低く、すでにスプレー/アクターを使用しているためです。
import spray.client.pipelining._
val url = "http://youruri.com/yo"
val pipeline: HttpRequest => Future[HttpResponse] = sendReceive
// Post with header and parameters
val responseFuture1: Future[String] = pipeline(Post(Uri(url) withParams ("param" -> paramValue), yourPostData) map (_.entity.asString)
// Post with header
val responseFuture2: Future[String] = pipeline(Post(url, yourPostData)) map (_.entity.asString)
私はディスパッチを使用しています: http://dispatch.databinder.net/Dispatch.html
彼らは、私が本当に気に入っている完全に新しいAPIを備えた新しいバージョン(0.9.0)をリリースしました。そしてそれは非同期です。
プロジェクトページの例:
import dispatch._
val svc = url("http://api.hostip.info/country.php")
val country = Http(svc OK as.String)
for (c <- country)
println(c)
編集:これはあなたを助けるかもしれません https://github.com/dispatch/reboot/blob/master/core/src/main/scala/requests.scala
もう1つのオプションは、Typesafeのplay-wsです。これは、スタンドアロンライブラリとして分割されたPlay Framework WSライブラリです。
http://blog.devalias.net/post/89810672067/play-framework-seperated-ws-library
これを必ずしも最良の選択肢として提供するわけではありませんが、言及する価値はあります。
Apache HttpComponents を使用しない理由 application FAQ は、さまざまなシナリオをカバーしています。
恥知らずなプラグを作成できる場合は、 Bee-Client というAPIがあります。これは、Scalaのラッパーです。
1つのエンドポイントをテストするために(統合テストで)同じことをしなければなりませんでした。以下は、ScalaのGETリクエストからレスポンスを取得するコードです。 jsonからオブジェクトへの変換のために、scala.io.Sourceを使用してエンドポイントから読み取り、ObjectMapperを使用しています。
private def buildStockMasterUrl(url:String, stockStatus:Option[String]) = {
stockStatus match {
case Some(stockStatus) => s"$url?stockStatus=${stockStatus}"
case _ => url
}
}
private def fetchBooksMasterData(stockStatus:Option[String]): util.ArrayList[BooksMasterData] = {
val url: String = buildBooksMasterUrl("http://localhost:8090/books/rest/catalogue/booksMasterData",stockStatus)
val booksMasterJson : String = scala.io.Source.fromURL(url).mkString
val mapper = new ObjectMapper()
apper.readValue(booksMasterJson,classOf[util.ArrayList[BooksMasterData]])
}
case class BooksMasterData(id:String,description: String,category: String)
そして、ここに私の同じテスト方法があります
test("validate booksMasterData resource") {
val booksMasterData = fetchBooksMasterData(Option(null))
booksMasterData.size should be (740)
}
私の Requests-Scala ライブラリを使用:
// Mill
ivy"com.lihaoyi::requests:0.1.8"
// SBT
"com.lihaoyi" %% "requests" % "0.1.8"
これは次のように簡単です
val r = requests.get("https://api.github.com/users/lihaoyi")
r.statusCode
// 200
r.headers("content-type")
// Buffer("application/json; charset=utf-8")
r.text
// {"login":"lihaoyi","id":934140,"node_id":"MDQ6VXNlcjkzNDE0MA==",...
val r = requests.post("http://httpbin.org/post", data = Map("key" -> "value"))
val r = requests.put("http://httpbin.org/put", data = Map("key" -> "value"))
val r = requests.delete("http://httpbin.org/delete")
val r = requests.head("http://httpbin.org/head")
val r = requests.options("http://httpbin.org/get")
これが私が取り組んでいたクラスです。 GETおよびPOSTリクエスト。パラメータなしのGET-POSTパラメータ付き)状態。
build.sbtファイルに次の依存関係のみが必要です。
libraryDependencies += "org.scalaj" %% "scalaj-http" % "2.3.0"
ドキュメントは次の場所にあります: https://github.com/scalaj/scalaj-http#post-raw-arraybyte-or-string-data-and-get-response-code
import scala.collection.mutable.ArrayBuffer
import scalaj.http.{Http, HttpResponse}
object HttpRequestHandler {
val userName: String = "admin"
val password: String = "admin"
def sendHttpGetRequest(request: String): String = {
println(" Send Http Get Request (Start) ")
try {
val httpResponse: HttpResponse[String] = Http(request).auth(userName,password)
.asString
val response = if (httpResponse.code == 200) httpResponse.body
else{
println("Bad HTTP response: code = "+httpResponse.code )
return "ERROR"
}
println(" Send Http Get Request (End) ")
return response
} catch {
case e: Exception => println("Error in sending Get request: "+e.getMessage)
return "ERROR"
}
}
def arrayBufferToJson(params:ArrayBuffer[(String,String)]): String ={
var jsonString = "{"
var count: Int = 0
for(param <- params){
jsonString+="\""+param._1+"\":\""+param._2+"\""+ ( if(count!=params.length-1) "," else "")
count+=1
}
jsonString+="}"
return jsonString
}
def sendHttpPostRequest(request: String,params: ArrayBuffer[(String,String)]): String = {
println(" Send Http Post Request (Start) ")
try {
val postData : String = arrayBufferToJson(params)
println("Parameters: "+postData)
val httpResponse: HttpResponse[String] = Http(request).auth(userName,password)
.header("X-Requested-By","sdc")
.header("Content-Type", "application/json;charset=UTF-8")
.header("X-Stream" , "true")
.header("Accept", "application/json")
.postData(postData.getBytes)
.asString
val response = if (httpResponse.code == 200) httpResponse.body
else{
println("Bad HTTP response: code = "+httpResponse.code )
"ERROR"
}
println(" Send Http Post Request (End) ")
return response
} catch {
case e: Exception => println("Error in sending Post request: " + e.getMessage)
return "ERROR"
}
}
}