2016-11-16 4 views
0

Я пытаюсь перенести приложение C# в узел. Приложение имеет эту функцию # C для генерации SHA256C# HMAC Sha256 эквивалент в узле

public static string CreateSHA256Signature(string targetText) 
     { 
      string _secureSecret = "E49756B4C8FAB4E48222A3E7F3B97CC3"; 
      byte[] convertedHash = new byte[_secureSecret.Length/2]; 
      for (int i = 0; i < _secureSecret.Length/2; i++) 
      { 
       convertedHash[i] = (byte)Int32.Parse(_secureSecret.Substring(i * 2, 2), System.Globalization.NumberStyles.HexNumber); 
      } 


      string hexHash = ""; 
      using (HMACSHA256 hasher = new HMACSHA256(convertedHash)) 
      { 
       byte[] hashValue = hasher.ComputeHash(Encoding.UTF8.GetBytes(targetText)); 
       foreach (byte b in hashValue) 
       { 
        hexHash += b.ToString("X2"); 
       } 
      } 
      return hexHash; 
     } 
    Response.Write(CreateSHA256Signature("TEST STRING")); 
    // returns 55A891E416F480D5BE52B7985557B24A1028E4DAB79B64D0C5088F948EB3F52E 

Я пытался использовать узел крипто следующим образом:

console.log(crypto.createHmac('sha256', 'E49756B4C8FAB4E48222A3E7F3B97CC3').update('TEST STRING', 'utf-8').digest('hex')) 
// returns bc0a28c3f60d323404bca7dfc4261d1280ce46e887dc991beb2c5bf5e7ec6100 

Как я могу получить тот же результат, C# в узле?

ответ

2

Ваш ключ отличается от версии C#. Попробуйте преобразовать шестнадцатеричную строку в необработанные байты. Таким образом, crypto знает, чтобы взять байты вместо фактической строки.

Например:

var crypto = require('crypto'); 

var key = Buffer.from('E49756B4C8FAB4E48222A3E7F3B97CC3', 'hex'); 
console.log(crypto.createHmac('sha256', key).update('TEST STRING').digest('hex'))