在C#中的sha256加密和js中的sha256加密 C#中加密后是44位,二js或一些在线加密网站是64位,改如何选择js和C#中加密结果相同的加密算法。

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} {1}  Length: {2}",s, sha, sha.Length);
        }
本人亲自使用!如有不明白可以加我Q:961823316
原文地址:https://www.cnblogs.com/Freedom0221/p/11455685.html