-1
Probleme mit C# und Javascript immer die gleiche HMAC zu generieren:HMAC C# und JavaScript
C#:
string data = String.Format("{0}{1}{2}{3}{4}{5}", APPId, requestHttpMethod, requestUri, requestTimeStamp, nonce, requestContentBase64String);
var secretKeyBytes = Convert.FromBase64String(sharedKey);
byte[] signature = Encoding.UTF8.GetBytes(data);
using (HMACSHA256 hmac = new HMACSHA256(secretKeyBytes))
{
byte[] signatureBytes = hmac.ComputeHash(signature);
return (incomingBase64Signature.Equals(Convert.ToBase64String(signatureBytes), StringComparison.Ordinal));
}
Produziert: apZUyGrS23BcEd2q5guGS4uQWVvcCvaDXIjCrLn/Hp4 =
Javascript:
var signatureRawData = "".concat(appId, requestHttpMethod, requestUri, requestTimeStamp, nonce, requestContentBase64String);
var hash = CryptoJS.HmacSHA256(signatureRawData, apiKey);
var hashInBase64 = CryptoJS.enc.Base64.stringify(hash);
Erzeugt: mFZyyKT03OOThRnt/9dG/0x + jRde3jCMvI6Rd0eKhEE =
Wo ist er apiKey in der C# -Code? Ist es sharedKey? Ist sercretKeyBytes eine Zeichenfolge, char [] oder byte []? Ich vermute, dass secrtetKeyBytes in eine Zeichenfolge konvertiert wird, die die Ursache des Problems ist. – jdweng
Sorry, ja, es sharedKey. Nein, secretKeyBytes ist definitiv immer noch Bytes im HMCSHA256-Objekt. –
Können Sie das als Antwort hinzufügen? Der Schlüssel war eine Zeichenfolge im Javascript. –