RestSharp BitStamp身份验证失败

时间:2014-02-06 19:30:07

标签: c# api restsharp bitcoin

我无法从BitStamp API接收任何数据。 我在这做错了什么?我的内容构成了错误的响应结果:

{"error": "Missing key, signature and nonce parameters"}

        public ActionResult Index()
        {
            const string BaseUrl = "https://www.bitstamp.net/api/balance/";
            var client = new RestClient();
            var request = new RestRequest();

            client.BaseUrl = BaseUrl;
            AddApiAuthentication(request);
            var response = client.Execute(request);
            var foo = response.Content;
            //{"error": "Missing key, signature and nonce parameters"}
            return View();
        }

        public void AddApiAuthentication(RestRequest restRequest)
        {
            var nonce = DateTime.Now.Ticks;
            var signature = GetSignature(nonce, apiKey, apiSecret, clientId);

            restRequest.AddParameter("key", apiKey);
            restRequest.AddParameter("signature", signature);
            restRequest.AddParameter("nonce", nonce);

        }

        private string GetSignature(long nonce, string key, string secret, string clientId)
        {
            string msg = string.Format("{0}{1}{2}", nonce, clientId, key);
            return ByteArrayToString(SignHMACSHA256(secret, StrinToByteArray(msg))).ToUpper();
        }

        public static byte[] SignHMACSHA256(String key, byte[] data)
        {
            HMACSHA256 hashMaker = new HMACSHA256(Encoding.ASCII.GetBytes(key));
            return hashMaker.ComputeHash(data);
        }

        public static byte[] StrinToByteArray(string str)
        {
            return System.Text.Encoding.ASCII.GetBytes(str);
        }

        public static string ByteArrayToString(byte[] hash)
        {
            return BitConverter.ToString(hash).Replace("-", "").ToLower();
        }

API身份验证似乎适用于this post中的用户。 我是否以正确的方式执行请求?

1 个答案:

答案 0 :(得分:4)

对于我们的新应用程序,我们使用以下代码:

public class BitstampAuthenticatedRequest : RestRequest
{
    #region Data
    private readonly string _clientId = "xxxxx"; // Numbers

    private readonly string _apiKey = "xxxxx"; // Random numbers and letters
    private readonly string _apiSecret = "xxxx"; // Random numbers and letters

    private long Nonce = DateTime.Now.Ticks;

    #endregion

    #region Constructor

    public BitstampAuthenticatedRequest(string resource, Method method)
    : base(resource, method)
    {
        this.AddParameter("key", _apiKey);            
        this.AddParameter("nonce", Nonce);
        this.AddParameter("signature", CreateSignature());
    }

    #endregion

    #region Methods

    private string CreateSignature()
    {
        string msg = string.Format("{0}{1}{2}", Nonce,
            _clientId,
            _apiKey);

        return ByteArrayToString(SignHMACSHA256(_apiSecret, StringToByteArray(msg))).ToUpper();
    }

    private static byte[] SignHMACSHA256(String key, byte[] data)
    {
        HMACSHA256 hashMaker = new HMACSHA256(Encoding.ASCII.GetBytes(key));
        return hashMaker.ComputeHash(data);
    }

    private static byte[] StringToByteArray(string str)
    {
        return System.Text.Encoding.ASCII.GetBytes(str);
    }

    private static string ByteArrayToString(byte[] hash)
    {
        return BitConverter.ToString(hash).Replace("-", "").ToLower();
    }

    #endregion
}

并称之为:

        // Decide which url to use
        var baseUrl = "https://www.bitstamp.net/api/balance/";

        // Create the authenticated request
        RestRequest request = new BitstampAuthenticatedRequest(baseUrl, Method.POST);

        // Get the response
        var response = new RestClient().Execute(request);

Justed在控制台应用程序中再次测试了代码并确实正常工作。如果您需要进一步的帮助,请发表评论。