r语言 - 如何正确使用 httr 进行 X-WSSE 身份验证



>我正在尝试连接到 emarsys 的 API。他们使用 X-WSSE 作为身份验证方法,我被困住了,需要弄清楚我做错了什么。我试图按照要求制作标题,但我不知道它在哪里出错了。我非常感谢您的评论!

install.packages("httr")
install.packages("digest")
library("httr") 
library("digest")
# prepare userdata
username     <- "customer001"
secretkey    <- "supersecretkey"
timestamp    <- format(as.POSIXlt(Sys.time(), "UTC"), "%Y-%m-%dT%H:%M:%SZ")
nonce        <- digest(random(8), length=16)
# passworddigest
pwd       <- paste0(nonce, timestamp, secretkey) 
pwd       <- digest::sha1(pwd, algo="sha1", serialize=FALSE)  
pwd       <- jsonlite::base64_enc(charToRaw(pwd)) 
URL_base     <- "https://api.emarsys.net/api/v2/"
URL_endpoint <- "contact/settings"
URL          <- paste0(URL_base,URL_endpoint)
# create header 
header <- c(paste0('UsernameToken ',
                   'Username="', username, '", ',
                   'PasswordDigest="', pwd,'", ',
                   'Nonce="', nonce, '", ',
                   'Created="', timestamp,'"'))
# name header
names(header) <- 'X-WSSE:'    
# make httr request   
response <- GET(URL, add_headers(.headers = header))
response

http-header 应该看起来像这样:

X-WSSE: 用户名令牌用户名="customer001", PasswordDigest="ZmI2ZmQ0MDIxYmQwNjcxNDkxY2RjNDNiMWExNjFkZA==", nonce="d36e3162829ed4c89851497a717f", created="2014-03-20T12:51:45Z"

但我不知道我在哪里可以找到,来自我的 httr 代码的请求看起来如何以及我做了什么不同。编辑: "digest::sha1(pwd, algo="sha1", serialize=FALSE)"必须digest(pwd, algo="sha1", serialize=FALSE).然后它起作用了。

这是一种评论,但我无法按照它需要的方式进行格式化以保持清晰,所以就在这里。所以学究们可以随意投反对票,如果这样感动的话:

首先,将 verbose() 参数添加到 GET() 调用,以查看您传递的内容是否是您认为应该传递的内容。我敢打赌,问题是您分配的'X-WSSEP:'值中的:。我还发现在add_headers()调用中使用命名参数要容易得多,所以也许可以尝试:

GET(
  url = URL,
  add_headers(`X-WSSE` = header),
  verbose()
)

看看这是否可以解决这个问题,或者至少让你走得更远。

另外:一旦您的问题得到解决并获得所需的访问权限,请考虑为 Emarsys API 制作一个 pkg。如果您之前没有制作过软件包,那么这可能是一种++gd学习体验,无论哪种方式,它都可能对其他人有所帮助。

相关内容

  • 没有找到相关文章

最新更新