在C#中的sha256加密和js中的sha256加密

JavaScript023

在C#中的sha256加密和js中的sha256加密,第1张

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)