在this answer on stack之后,我能够从我的个人币别帐户正确提取所有订单或交易数据。
function connect() {
var ss = SpreadsheetApp.getActiveSpreadsheet();
var sheet = ss.getSheets()[0];
var key = '****';
var secret = '****';
var curTime = Number(new Date().getTime()).toFixed(0);
var symbol = "TRXETH";
var limit = 13;
var string = "symbol="+symbol+"&limit=12×tamp=" + curTime;
var sKey = Utilities.computeHmacSha256Signature(string, secret);
sKey = sKey.map(function(e) {
var v = (e < 0 ? e + 256 : e).toString(16);
return v.length == 1 ? "0" + v : v;
}).join("");
var params = {
'method': 'get',
'headers': {'X-MBX-APIKEY': key},
'muteHttpExceptions': true
};
var url = "https://api.binance.com/api/v3/myTrades?" + string + "&signature=" + sKey;
var data = UrlFetchApp.fetch(url, params);
var data = JSON.parse(data.getContentText());
它工作得很好,但是由于我还需要提取还要存储和提取数据,所以我认为我已经制作了一个新的专用脚本。
而且它不起作用:
function deposit() {
var ss = SpreadsheetApp.getActiveSpreadsheet();
var sheet = ss.getSheets()[0];
var key = '****';
var secret = '****';
var curTime = Number(new Date().getTime()).toFixed(0);
var string = "/wapi/v3/withdrawHistory.html?timestamp=" + curTime;
var sKey = Utilities.computeHmacSha256Signature(string, secret);
sKey = sKey.map(function(e) {
var v = (e < 0 ? e + 256 : e).toString(16);
return v.length == 1 ? "0" + v : v;
}).join("");
var params = {
'method': 'get',
'headers': {'X-MBX-APIKEY': key},
'muteHttpExceptions': true,
//'signature': sKey
};
var url = "https://api.binance.com" + string + "&signature=" + sKey;
var data = UrlFetchApp.fetch(url, params);
var data = JSON.parse(data.getContentText());
现在github上有几张票可以解决这个问题,但是似乎没有一个适合我的情况:有人可以告诉我我的代码有什么问题吗?谢谢
答案 0 :(得分:2)
从您的脚本和回复中我可以理解如上。如果我的理解是正确的,那么下面的修改如何?
var string = "/wapi/v3/withdrawHistory.html?timestamp=" + curTime;
至:
var string = "timestamp=" + curTime;
和
从:var url = "https://api.binance.com" + string + "&signature=" + sKey;
至:
var url = "https://api.binance.com/wapi/v3/withdrawHistory.html?" + string + "&signature=" + sKey;