web-dev-qa-db-ja.com

ScalaでHTTPリクエストを行う

私は、ScalaでXMLを返すWebサービスに簡単なPOSTリクエストを発行しようとしています。

Dispatch がこのタスクに使用される標準ライブラリのようですが、ドキュメントが見つかりません。上でリンクしているメインサイトでは、約束と非同期プログラミングの実行方法について詳しく説明していますが、実際にはAPIについては説明していません。 periodic table -少し怖いように見えます-しかし、それはすでに何をすべきかを知っていて、不可解な構文のリマインダーのみを必要とする人々にとってのみ有用であるようです。

ScalazにはHTTPの機能があります のようにも見えますが、ドキュメントも見つかりません。

69
Andrea

私は次を使用します: 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"
116
kulikov

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)
6
schmmd

私はディスパッチを使用しています: 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

5
drexin

もう1つのオプションは、Typesafeのplay-wsです。これは、スタンドアロンライブラリとして分割されたPlay Framework WSライブラリです。

http://blog.devalias.net/post/89810672067/play-framework-seperated-ws-library

これを必ずしも最良の選択肢として提供するわけではありませんが、言及する価値はあります。

3
tksfz

Apache HttpComponents を使用しない理由 application FAQ は、さまざまなシナリオをカバーしています。

2
Brian Agnew

恥知らずなプラグを作成できる場合は、 Bee-Client というAPIがあります。これは、Scalaのラッパーです。

2
Rick-777

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)
  }
1
Sanjay Bharwani

私の 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")
1
Li Haoyi

これが私が取り組んでいたクラスです。 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"
    }
  }

}

0
Abdelrahman Aly