对接java接口时使用到des加解密,这里记录下
1.加密数据传递时需要UrlEncode下,防止‘+’自动编译成‘ ’空格
2.java默认的模式是ECB,需要指定一下。
/// <summary>
/// 获取Des加密
/// </summary>
/// <param name="str"></param>
/// <returns></returns>
public string GetDescEncry(string str)
{
byte[] keyBytes = Encoding.UTF8.GetBytes(_MchPriKey.Substring(0, 8));//key.Substring(0, 8)
byte[] inputByteArray = Encoding.UTF8.GetBytes(str);
DESCryptoServiceProvider provider = new DESCryptoServiceProvider();
provider.KeySize = 64;
provider.Mode = CipherMode.ECB;
provider.Key = keyBytes;
MemoryStream mStream = new MemoryStream();
CryptoStream cStream = new CryptoStream(mStream, provider.CreateEncryptor(), CryptoStreamMode.Write);
cStream.Write(inputByteArray, 0, inputByteArray.Length);
cStream.FlushFinalBlock();
return Convert.ToBase64String(mStream.ToArray());
}
/// <summary>
/// Des解密
/// </summary>
/// <param name="str"></param>
/// <returns></returns>
public string GetDesDecrypt(string str)
{
byte[] rgbKey = Encoding.UTF8.GetBytes(_MchPriKey.Substring(0, 8));
byte[] rgbIV = Encoding.UTF8.GetBytes(_MchPriKey);//发现长度并不影响解密
byte[] inputByteArray = Convert.FromBase64String(str);
DESCryptoServiceProvider dCSP = new DESCryptoServiceProvider();
dCSP.Mode = CipherMode.ECB;
MemoryStream mStream = new MemoryStream();
CryptoStream cStream = new CryptoStream(mStream, dCSP.CreateDecryptor(rgbKey, rgbIV), CryptoStreamMode.Write);
cStream.Write(inputByteArray, 0, inputByteArray.Length);
cStream.FlushFinalBlock();
return Encoding.UTF8.GetString(mStream.ToArray());
}