在python
中,我通过以下方式使用requests
来调用API(不幸的是,无法共享API本身,因此很难重现):
import requests
url = url
headers = {'API-key': 'xxxxxxxxxxxxxxxx',
'Content-type': 'application/json',
'Accept': 'application/json'
}
r = requests.get(url, headers = headers, verify=False)
print(r.text)
在这里,我认为verify=False
会强制要求忽略SSL证书(如建议的here一样)。效果很好,但是我无法通过httr
通过以下方式进行复制:
library(httr)
url <- url
headers <- c('API-key' = 'xxxxxxxxxxxxxxxx',
'Content-type' = 'application/json',
'Accept' = 'application/json'
))
GET(url = url, add_headers(headers = headers)
现在,我相信verify=False
代码中的requests
是这里的关键,someone suggested认为,使用httr忽略SSL证书的方法是在请求之前使用set_config()
:
httr::set_config(httr::config(ssl_verifypeer=0L, ssl_verifyhost=0L))
GET(url = url, add_headers(headers = headers))
但是它不起作用。
$message
[1] "Unauthorized"
$http_status_code
[1] 401
httr::set_config(httr::config(ssl_verifypeer=0L, ssl_verifyhost=0L))
相当于verify=False
通话中的requests
吗?
答案 0 :(得分:1)
您显示的错误消息实际上是服务器的响应。 Is与SSL证书无关,因此您完全不需要禁用该检查。
问题在于add_headers
中的参数名称是.headers
而不是headers
。你只需要做
GET(url = url, add_headers(.headers = headers)