当前位置: 移动技术网 > IT编程>开发语言>c# > md5加密串的不同方式

md5加密串的不同方式

2020年07月08日  | 移动技术网IT编程  | 我要评论

使用c#语言进行开发的时候,我们经常会用到md5加密串,md5进行加密的时候有不同的加密方式,可以选择不同的编码方式。下面来比较下。

当我们进行接口访问调用的时候,一般第三方的接口会有安全机制和校验方式,已保证调用的合法性。比如第三方的接口会要求你发送的参数进行拼接后,md5加密字符串进行发送给对方,对方获取到发送过来的参数后,会同样进行参数md5加密,与你的加密串比对是否相同,否则返回错误信息。

一种加密方式gb2312方式,代码参考如下:


/// MD5加密
        /// </summary>
        /// <param name="str">加密字符</param>
        /// <param name="code">加密位数16/32</param>
        /// <returns></returns>
        public static string md5(string str, int bit)
        {
            MD5CryptoServiceProvider md5Hasher = new MD5CryptoServiceProvider();
            byte[] hashedDataBytes;
            hashedDataBytes = md5Hasher.ComputeHash(Encoding.GetEncoding("gb2312").GetBytes(str));
            StringBuilder tmp = new StringBuilder();
            foreach (byte i in hashedDataBytes)
            {
                tmp.Append(i.ToString("x2"));
            }
            if (bit == 16)
                return tmp.ToString().Substring(8, 16);
            else
            if (bit == 32) return tmp.ToString();//默认情况
            else return string.Empty;
        }
另外一种是utf-8方式的编码,代码参考



/// <summary>
        /// utf8格式的加密
        /// </summary>
        /// <param name="str"></param>
        /// <param name="bit"></param>
        /// <returns></returns>
        public static string md5UTF8(string str, int bit)
        {
            MD5CryptoServiceProvider md5Hasher = new MD5CryptoServiceProvider(); 
            byte[] hashedDataBytes = md5Hasher.ComputeHash(UnicodeEncoding.UTF8.GetBytes(str));
            var tmp = System.BitConverter.ToString(hashedDataBytes).Replace("-", "");
            if (bit == 16)
                return tmp.ToString().Substring(8, 16);
            else
            if (bit == 32) return tmp.ToString();//默认情况
            else return string.Empty;
        }


以上就是两种不同的加密处理方式,你可能不清楚对方的加密方式,此时可能就会要去更换不同的加密方式。

在开发过程中可能会帮到你,解决你实际问题。

来源:移动技术网,分享请保留出处。

如对本文有疑问, 点击进行留言回复!!

相关文章:

验证码:
移动技术网