-1
我想知道如何在C#中正確加密,Laravel(PHP)可以用它的加密解密?如何在與Laravel的加密兼容的C#中進行加密?
這是我的C#加密:
private static readonly Encoding encoding = Encoding.UTF8;
public static void Main(string[] args)
{
string key = "ysWZKXsnB1aS38Qzj5cza01wd3wT1234";
string text = "Here is some data to encrypt!";
string encrypted = encrypt(text, key);
// Display the original data and the encrypted data.
Console.WriteLine("Original: {0}", text);
Console.WriteLine("Key: {0}", key);
Console.WriteLine("Encrypted: {0}", encrypted);
}
private static string encrypt(string plainText, string key)
{
RijndaelManaged aes = new RijndaelManaged();
aes.KeySize = 256;
aes.BlockSize = 128;
aes.Padding = PaddingMode.PKCS7;
aes.Mode = CipherMode.CBC;
aes.Key = encoding.GetBytes(key);
aes.GenerateIV();
ICryptoTransform AESEncrypt = aes.CreateEncryptor(aes.Key, aes.IV);
byte[] buffer = Encoding.ASCII.GetBytes(phpSerialize(plainText));
String encryptedText = Convert.ToBase64String(Encoding.Default.GetBytes(Encoding.Default.GetString(AESEncrypt.TransformFinalBlock(buffer, 0, buffer.Length))));
String mac = "";
mac = BitConverter.ToString(hmacSHA256(Convert.ToBase64String(aes.IV) + encryptedText, key)).Replace("-", "").ToLower();
var keyValues = new Dictionary<string, object>
{
{ "iv", Convert.ToBase64String(aes.IV) },
{ "value", encryptedText },
{ "mac", mac },
};
JavaScriptSerializer serializer = new JavaScriptSerializer();
return Convert.ToBase64String(Encoding.ASCII.GetBytes(serializer.Serialize(keyValues)));
}
代碼成功加密,BU Laravel返回 「無法解密數據。」當試圖在這裏解密代碼輸出時。
[如何解密AES-256-CBC加密字符串](https://stackoverflow.com/questions/20297973/how-to-decrypt-an-aes-256-cbc-encrypted-string) –
這個問題和答案對你來說足夠嗎?因爲在Laravel文檔中指定它使用該加密。 –
共享鏈接用於解密來自Laravel的加密字符串。我想知道的是如何以適當的方式通過C#加密,以便Laravel也可以解密它。 – doncadavona