2016-07-28 3 views

답변

1

이 예제에 언급 된 get/getAs 메서드는 fetch 메서드의 편리한 래퍼입니다. https://github.com/http4s/http4s/blob/a4b52b042338ab35d89d260e0bcb39ccec1f1947/client/src/main/scala/org/http4s/client/Client.scala#L116

Request 생성자를 사용하고 method으로 Method.POST을 전달하십시오. 이 도움이

fetch(Request(Method.POST, uri)) 
+0

나는 똑같은 것을 발견했습니다. Request의 어떤 구현을 사용하는지, 데이터를 추가하기 위해 바디를 어떻게 수정할 수 있는지 찾아야 할 수도 있습니다. – sascha10000

-3
import org.http4s.circe._ 
import org.http4s.dsl._ 
import io.circe.generic.auto._  

case class Name(name: String) 

    implicit val nameDecoder: EntityDecoder[Name] = jsonOf[Name] 

    def routes: PartialFunction[Request, Task[Response]] = { 
    case req @ POST -> Root/"hello" => 
    req.decode[Name] { name => 
    Ok(s"Hello, ${name.name}") 
    } 

희망.

+0

이 서버 측 코드가 아닌가요? 위의 코드에서 POST 요청을 수락하고 요청에서 Name 객체를 읽은 다음 Hello 이름으로 응답을 생성합니다. 하지만 내 질문은 클라이언트 쪽입니다. –

1

https4s 버전 : 0.14.11

어려운 부분은 후 본체를 설정하는 방법입니다. 코드에 들어가면 type EntityBody = Process[Task, ByteVector]을 찾을 수 있습니다. 하지만 그게 뭐야? 그러나 스 카즈 급강하를 할 준비가되지 않았다면 withBody을 사용하십시오.

object Client extends App { 
    val client = PooledHttp1Client() 
    val httpize = Uri.uri("http://httpize.herokuapp.com") 

    def post() = { 
    val req = Request(method = Method.POST, uri = httpize/"post").withBody("hello") 
    val task = client.expect[String](req) 
    val x = task.unsafePerformSync 
    println(x) 
    } 

    post() 
    client.shutdownNow() 
} 

P. http4s 클라이언트에 대한 유용한 게시물 (중국어를 건너 뛰고 스칼라 코드 읽기) : http://sadhen.com/blog/2016/11/27/http4s-client-intro.html

관련 문제