gpt4 book ai didi

对 Coinbase Exchange 私有(private) API 的 PHP 身份验证

转载 作者:可可西里 更新时间:2023-10-31 23:30:35 25 4
gpt4 key购买 nike

我正在尝试通过 Coinbase Exchange 私有(private) API 的身份验证以获取余额和下/取消订单。下面是我尝试使用的代码的演示版本。我已按照文档进行操作,但我不断收到以下错误:

{"message":"invalid signature"}

有人可以告诉我我做错了什么吗? :)

编辑:我根据 Sašo 的回答修改了下面的代码,所以它现在可以工作了。

<?php
$key = "";
$secret = "";
$passphrase = "";

$time = time();
$url = "https://api.gdax.com/accounts";

$data = $time."GET"."/accounts";
echo $data . "<br/>";

$sign = base64_encode(hash_hmac("sha256", $data, base64_decode($secret), true));
echo $sign . "<br/>";

$headers = array(
'CB-ACCESS-KEY: '.$key,
'CB-ACCESS-SIGN: '.$sign,
'CB-ACCESS-TIMESTAMP: '.$time,
'CB-ACCESS-PASSPHRASE: '.$passphrase,
'Content-Type: application/json'
);

var_dump($headers);

echo $url;

static $ch = null;

if (is_null($ch)) {
$ch = curl_init($url);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_USERAGENT, 'Mozilla/5.0 (Windows NT 6.1) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/41.0.2228.0 Safari/537.36');
curl_setopt($ch, CURLOPT_URL, $url);
curl_setopt($ch, CURLOPT_HTTPHEADER, $headers);
curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, FALSE);

$res = curl_exec($ch);
echo $res;
}

最佳答案

在执行 hash_hmac 时,您缺少 raw_output 的真实参数

http://php.net/manual/en/function.hash-hmac.php

raw_output:设置为 TRUE 时,输出原始二进制数据。 FALSE 输出小写的十六进制数。

关于对 Coinbase Exchange 私有(private) API 的 PHP 身份验证,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28206685/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com