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)
}
不安全。因为会公开私钥,因此sha256公钥放js中是不安全的,SHA(Secure Hash Algorithm),中文名为安全散列算法,是美国国家安全局(NSA)设计,美国国家标准与技术研究院(NIST)发布的一系列密码散列函数,包括 SHA-1.SHA-224.SHA-256.SHA-384 和 SHA-512 等变体。