【问题标题】:How to run curl in bash script and keep the result in a variable [duplicate]如何在bash脚本中运行curl并将结果保存在变量中[重复]
【发布时间】:2017-07-03 20:54:50
【问题描述】:

这应该很容易,但由于某种原因它不是:

尝试运行一个简单的curl 命令,获取它的输出,然后用它做一些事情。

cmd='curl -v -H "A: B" http://stackoverflow.com'
result=`$cmd | grep "A:"`
...

问题 - 标头“A: B”未发送。

curl 命令的执行似乎忽略了 header 参数,并运行 curl 两次 - 第二次以“B”作为主机(显然失败)。

有什么想法吗?

【问题讨论】:

  • 不确定您遇到的问题?您的预期输出是什么?
  • @elad-tabak 我建议您始终按照我的建议检查命令的结果,然后再将其存储在任何变量中。这将帮助您找到问题的确切位置

标签: bash curl


【解决方案1】:

您的问题是您在第一个命令上所做的只是将 cmd 设置为等于一个字符串。

尝试使用$(...) 执行实际命令,如下所示:

cmd=$(curl -v -H "A: B" http://stackoverflow.com)

此结果将是 curl 请求的实际输出。

这个问题已经回答了很多次了,比如Set variable to result of terminal command (Bash)

【讨论】:

    【解决方案2】:

    请记住,cURL 调试输出被重定向到 STDERR - 这样您就可以将输出通过管道传输到另一个程序,而不会破坏管道输入的信息。

    使用 --stderr - 标志将 STDERR 重定向到 STDOUT,如下所示:

    cmd="curl -s -v http://stackoverflow.com -H 'Test:1234' --stderr -"
    result=`$cmd | grep "Test:"`
    echo $result
    
    ./stackoverflow.sh 
    > 'Test:1234'
    

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 2011-03-09
      • 1970-01-01
      • 2020-05-25
      • 2020-05-24
      • 2018-08-10
      • 2021-06-12
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多