C#自带的类库实现sha265会返回一个byte[] 数组
这个数组的长度是32,js的sha265是64,是把每个byte直接转换成了2个hex字符串。
C#中加密后是44位是因为把这个数组用base64编码成了字符串。
C#中也直接把byte转换成对应的hex字符串就和js中一样了。
另外,把str转换成byte[]数组的Encoding 如果不同,sha是不同的,一般js的都是utf8.
请参考
public static string SHA256(string str){
//如果str有中文,不同Encoding的sha是不同的!!
byte[] SHA256Data = Encoding.UTF8.GetBytes(str)
SHA256Managed Sha256 = new SHA256Managed()
byte[] by = Sha256.ComputeHash(SHA256Data)
return BitConverter.ToString(by).Replace("-", "").ToLower() //64
//return Convert.ToBase64String(by) //44
}
static void Main(string[] args)
{
string s = "hello world"
//sha265=b94d27b9934d3e08a52e52d7da7dabfac484efe37a5380ee9088f7ace2efcde9
string sha = SHA256(s)
Console.WriteLine("{0}\n{1} \nLength: {2}",s, sha, sha.Length)
}
= CryptoJS.HmacSHA256(stringSign, key)4.加密 //我这里是使用16进制的方法 具体API 可以打印CryptoJS.enc let hashInHex= CryptoJS.enc.Hex.stringify(hash)