Bitstamp - nowe uwierzytelnienie w C # - podpis

Nowe uwierzytelnianie sygnalizatora bitowego mówi:

Podpis jest wiadomością zakodowaną w HMAC-SHA256 zawierającą: nonce, identyfikator klienta i klucz API. Kod HMAC-SHA256 musi zostać wygenerowany przy użyciu tajnego klucza wygenerowanego przy użyciu klucza API. Ten kod musi zostać przekonwertowany na jego szesnastkową reprezentację (64 duże litery). Przykład (Python): message = nonce + id_klienta + api_key signature = hmac.new (API_SECRET, msg = wiadomość, digestmod = hashlib.sha256) .hexdigest (). górny()

Źródło:połączyć

Mam następujący kod, aby dodać nowy podpis (i inne parametry):

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)
    {
        byte[] bytes = new byte[str.Length * sizeof(char)];
        System.Buffer.BlockCopy(str.ToCharArray(), 0, bytes, 0, bytes.Length);
        return bytes;
    }

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

I wtedy pojawia się ten błąd:

{"error": "Invalid signature"}

Ktoś wpadł na pomysł, jaki może być problem? Sprawdziłem moje parametry 100 razy i nie są one błędne. Może ktoś otrzymał działający fragment kodu (w języku C #) dla nowego uwierzytelnienia?

AKTUALIZACJA

Abhinav miał rację, metoda StringToByteArray była błędna (nie tylko literówka: P) działający kod to:

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

questionAnswers(1)

yourAnswerToTheQuestion