在试图使用R中的HTTR包和GET()函数时,我面临着一个挑战:
pg2 = GET("http://httpbin.org/basic-auth/user/passwd", authenticate("user","passwd"))我得到了以下错误:
Error in function (type, msg, asError = TRUE) :
SSL certificate problem, verify that the CA cert is OK. Details:
error:14090086:SSL routines:SSL3_GET_SERVER_CERTIFICATE:certificate verify failed我在网上搜索,发现我需要使用以下命令行更新.Rprofile文件:
options(RCurlOptions = list(verbose = FALSE, capath = system.file("CurlSSL", "cacert.pem", package = "RCurl"), ssl.verifypeer = FALSE))但是它仍然不起作用,我一直收到同样的错误信息。
同样,当我尝试下面的代码时
> HEAD("https://www.google.com", verbose())您可以看到它仍然在cacert.pm文件中查找CA。
发布于 2015-02-22 17:37:51
我花了大约五个小时玩卷发和RCurl。我能让它发挥作用。你想要的选项是cainfo,而不是capath。Capath告诉RCurl在哪里查找证书文件。Cainfo指定一个文件。
这对我适用于RCurl。
library(RCurl)
cer_file <- "/home/user/curltest/cacert.pem"
server_url <- "some_server"
getURL(server_url, cainfo=cer_file)现在的问题是如何让httr理解这个设置。文档讨论了默认的ca_cert,但没有解释如何使用不同的证书。在我的例子中,我连接到一个不会在默认证书中的intranet站点。答案在于config.R。Httr允许我们像下面所做的那样设置RCurl配置选项。
cer_file <- "/home/me/curltest/cacert.pem"
GET(login_url, config=list(cainfo=cer_file))如果您正在连接互联网,您可能只需要更新HTTR附带的默认仙人掌。自述文件向您展示了如何做到这一点。这样,您就不需要在每个调用中指定证书。
setwd("path to httr package")
GET("https://raw.githubusercontent.com/bagder/ca-bundle/e9175fec5d0c4d42de24ed6d84a06d504d5e5a09/ca-bundle.crt",
write_disk("inst/cacert.pem", overwrite = TRUE))https://stackoverflow.com/questions/28557831
复制相似问题