使用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;
}
以上就是两种不同的加密处理方式,你可能不清楚对方的加密方式,此时可能就会要去更换不同的加密方式。
在开发过程中可能会帮到你,解决你实际问题。
来源:,分享请保留出处。
达?矢抾哆拉?