-1
avoir du mal à obtenir C# et Javascript pour générer le même HMAC:HMAC C# et 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));
}
Produit: 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);
Produit: mFZyyKT03OOThRnt/9dG/0x + jRde3jCMvI6Rd0eKhEE =
Où est-il apiKey dans le code C#? Est-ce sharedKey? SercretKeyBytes est une chaîne, char [] ou byte []? Je soupçonne secrtetKeyBytes d'être converti en une chaîne qui est la cause du problème. – jdweng
Désolé, oui, son sharedKey. Non, secretKeyBytes est définitivement encore un octet dans l'objet HMCSHA256. –
Pouvez-vous ajouter cela comme réponse? Ils clé était une chaîne dans le javascript. –