如何在不等待响应的情况下发送GET请求

时间:2019-03-29 15:10:06

标签: r curl get httr

我正在尝试在ShinyApp内运行GET请求,但是我不想等待响应,因为这将花费很长时间来处理,并且我并不需要在ShinyApp内真正需要响应,尽管状态代码会很好,但不是必须的。

或者也许有一个函数可以发送异步请求?像将整个GET包装在一个Future / Promise中一样?

当前,我的ShinyApp中有这个watchEvent:

  observeEvent(input$import, {
    httr::GET(url = "https://someurl/that/takes/a/long/time")
  })

curl_fetch_multi软件包中的curl是否适合该任务?

1 个答案:

答案 0 :(得分:2)

这是一种以会话内非阻塞方式(观察者未返回任何内容)异步运行GET的方法:

library(shiny)
library(future)
library(promises)
library(future.callr)
library(httr)

plan(callr)

queryGoogle <- function(queryString) {
  myResponse <- httr::GET("http://google.com/", path = "search", query = list(q = queryString))
  return(myResponse)
}

ui <- fluidPage(
  br(),
  textOutput("time_output"),
  br(),
  textInput(inputId="query_input", label = NULL, value = "", placeholder = "Search google..."),
  actionButton("import", "Query"),
  hr(),
  textOutput("query_output")
)

server <- function(input, output, session) {
  futureData <- reactiveValues(response = NULL)

  observeEvent(input$import, {
    myFuture <- future({
      queryGoogle(isolate(input$query_input))
    })

    then(
      myFuture,
      onFulfilled = function(value) {
        futureData$response <- value
      },
      onRejected = NULL
    )
    return(NULL)
  })

  output$query_output <- renderPrint({
    req(futureData$response)
  })

  time <- reactive({
    invalidateLater(500, session)
    Sys.time()
  })

  output$time_output <- renderText({ paste("Something running in parallel:", time()) })
}

shinyApp(ui, server)

这是对我的回答here的略微修改。