我正在尝试在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
是否适合该任务?
答案 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的略微修改。