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

JavaScript027

在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)

        }

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