2

我在使用 Google Sheet 中的脚本调用 Binance cryptoexchange API 时遇到问题。

我已经使用示例https://www.binance.com/restapipub.html#user-content-signed-endpoint-security中的数据检查了我的签名处理, 并且我得到了相同的签名。

我已经用另一个集线器(coinigy.com)检查了我的 API 密钥和秘密,密钥工作正常。

但是我自己执行脚本时仍然出现 401 错误...

币安支持没有回答。

有人可以帮忙吗?

function BinanceTest(key,secret) {
/*var randnumber=Math.random()*500;
Utilities.sleep(randnumber);*/
var baseURL = "https://api.binance.com";
var completeURL = baseURL + "/api/v3/account";
var timestamp=new Date().getTime();
var payload = "timestamp="+timestamp;
var signature = Utilities.computeHmacSha256Signature(payload, secret);
signature = signature.map(function(byte) {
  return ('0' + (byte & 0xFF).toString(16)).slice(-2);
}).join('');
completeURL=completeURL+"?"+payload+"&signature="+signature;
var params = {
  'method': 'get',
  'headers': {'X-MBX-APIKEY': key},
  'contentType': 'application/x-www-form-urlencoded',
  'muteHttpExceptions': true
};  
var response = fetchJSON(completeURL,params);
var servertime=fetchJSON("https://api.binance.com/api/v1/time").serverTime;
return [servertime,timestamp,payload,signature,JSON.stringify(params),completeURL,response];

};


function fetchJSON (url) {
  var randnumber=Math.random()*3000;
  Utilities.sleep(randnumber);
  try {
    var json = UrlFetchApp.fetch(url,{muteHttpExceptions: true })
    } catch (exception) {
      Logger.log(url+": "+exception)
      return 'exception'
    } 
  if ('undefined' == typeof(json))
    return 'Error retrieving JSON data'
  
  if (json.getResponseCode() != 200)
    return json.getResponseCode()
    
  json = json.getContentText()
  if (json.length<=0)
    return 'JSON data was invalid'

  try {
    json = JSON.parse(json)
  } catch (exception) {
    Logger.log(url+" "+exception)
    return "err2"
  }
  if ('undefined' == typeof(json) || json == null)
    // return 'err'
  return 'Quote data was malformed JSON data'

  return json
}

4

1 回答 1

1

我认为您的脚本几乎是正确的。但错误的原因是fetchJSON()fetchJSON()只接收url. 但是var response = fetchJSON(completeURL,params);发送completeURLparams。这样,fetchJSON()不接收params并发生错误。那么这个改装怎么样呢?

从 :

var response = fetchJSON(completeURL,params);

到 :

var response = UrlFetchApp.fetch(completeURL, params);

笔记 :

  • 如果此修改不起作用,请从 中删除'contentType': 'application/x-www-form-urlencoded',params然后重试。

我无法确认这些修改是否有效。所以如果这不起作用,你能告诉我错误信息吗?我想修改。

编辑 :

请尝试以下示例脚本,并告诉我响应。如果返回“当前账户信息”的响应,则说明脚本有效。

  1. 将以下脚本复制并粘贴到您的脚本编辑器中。
  2. 请在示例脚本中输入您的密钥和密码。
  3. 在脚本编辑器上,运行 -> 运行函数 -> 示例
  4. 脚本完成后,通过 View -> Logs 检索响应

样本 :

function sample() {
  var key = "### your key ###";
  var secret = "### your secret ###";

  var baseURL = "https://api.binance.com";
  var completeURL = baseURL + "/api/v3/account";
  var timestamp=new Date().getTime();
  var payload = "timestamp="+timestamp;
  var signature = Utilities.computeHmacSha256Signature(payload, secret);
  signature = signature.map(function(byte) {
    return ('0' + (byte & 0xFF).toString(16)).slice(-2);
  }).join('');
  completeURL=completeURL+"?"+payload+"&signature="+signature;
  var params = {
    'method': 'get',
    'headers': {'X-MBX-APIKEY': key},
    'muteHttpExceptions': true
  };  
  var response = UrlFetchApp.fetch(completeURL, params);
  Logger.log(response.getContentText())
}
于 2018-01-13T00:03:56.127 回答