public static class AesSecret
{
#region 秘鑰對
private const string saltString = "Wolfy@home";
private const string pWDString = "home@Wolfy";
#endregion
#region 加/解密算法
/// <summary>
/// 解密
/// </summary>
/// <param name="sSource">需要解密的內容</param>
/// <returns></returns>
public static byte[] DecryptString(string strSource)
{
byte[] encryptBytes = Convert.FromBase64String(strSource);
byte[] salt = Encoding.UTF8.GetBytes(saltString);
//提供高級加密標準 (AES) 對稱算法的托管實現。
AesManaged aes = new AesManaged();
//通過使用基于 System.Security.Cryptography.HMACSHA1 的偽隨機數生成器,實現基于密碼的密鑰派生功能 (PBKDF2)。
Rfc2898DeriveBytes rfc = new Rfc2898DeriveBytes(pWDString, salt);
// 獲取或設置加密操作的塊大?。ㄒ晕粸閱挝唬? aes.BlockSize = aes.LegalBlockSizes[0].MaxSize;
//獲取或設置用于對稱算法的密鑰大?。ㄒ晕粸閱挝唬?。
aes.KeySize = aes.LegalKeySizes[0].MaxSize;
//獲取或設置用于對稱算法的密鑰。
aes.Key = rfc.GetBytes(aes.KeySize / 8);
//獲取或設置用于對稱算法的初始化向量 (IV)。
aes.IV = rfc.GetBytes(aes.BlockSize / 8);
// 用當前的 Key 屬性和初始化向量 IV 創建對稱解密器對象
System.Security.Cryptography.ICryptoTransform decryptTransform = aes.CreateDecryptor();
// 解密后的輸出流
MemoryStream decryptStream = new MemoryStream();
// 將解密后的目標流(decryptStream)與解密轉換(decryptTransform)相連接
CryptoStream decryptor = new CryptoStream(
decryptStream, decryptTransform, CryptoStreamMode.Write);
// 將一個字節序列寫入當前 CryptoStream (完成解密的過程)
decryptor.Write(encryptBytes, 0, encryptBytes.Length);
decryptor.Close();
// 將解密后所得到的流轉換為字符串
return decryptStream.ToArray();
}
/// <summary>
/// 加密
/// </summary>
/// <param name="sSource">需要加密的內容</param>
/// <returns></returns>
public static byte[] EncryptString(string strSource)
{
byte[] data = UTF8Encoding.UTF8.GetBytes(strSource);
byte[] salt = UTF8Encoding.UTF8.GetBytes(saltString);
// AesManaged - 高級加密標準(AES) 對稱算法的管理類
AesManaged aes = new AesManaged();
// Rfc2898DeriveBytes - 通過使用基于 HMACSHA1 的偽隨機數生成器,實現基于密碼的密鑰派生功能 (PBKDF2 - 一種基于密碼的密鑰派生函數)
// 通過 密碼 和 salt 派生密鑰
Rfc2898DeriveBytes rfc = new Rfc2898DeriveBytes(pWDString, salt);
/*
* AesManaged.BlockSize - 加密操作的塊大?。▎挝唬篵it)
* AesManaged.LegalBlockSizes - 對稱算法支持的塊大?。▎挝唬篵it)
* AesManaged.KeySize - 對稱算法的密鑰大小(單位:bit)
* AesManaged.LegalKeySizes - 對稱算法支持的密鑰大?。▎挝唬篵it)
* AesManaged.Key - 對稱算法的密鑰
* AesManaged.IV - 對稱算法的密鑰大小
* Rfc2898DeriveBytes.GetBytes(int 需要生成的偽隨機密鑰字節數) - 生成密鑰
*/
aes.BlockSize = aes.LegalBlockSizes[0].MaxSize;
aes.KeySize = aes.LegalKeySizes[0].MaxSize;
aes.Key = rfc.GetBytes(aes.KeySize / 8);
aes.IV = rfc.GetBytes(aes.BlockSize / 8);
// 用當前的 Key 屬性和初始化向量 IV 創建對稱加密器對象
ICryptoTransform encryptTransform = aes.CreateEncryptor();
// 加密后的輸出流
MemoryStream encryptStream = new MemoryStream();
// 將加密后的目標流(encryptStream)與加密轉換(encryptTransform)相連接
CryptoStream encryptor = new CryptoStream
(encryptStream, encryptTransform, CryptoStreamMode.Write);
// 將一個字節序列寫入當前 CryptoStream (完成加密的過程)
encryptor.Write(data, 0, data.Length);
encryptor.Close();
return encryptStream.ToArray();
}
#endregion
}
我想把這個翻譯成java版,水平不夠希望大神幫忙一下,這里我萬分感謝!
添加回答
舉報
0/150
提交
取消