You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
|
|
|
|
using Org.BouncyCastle.Crypto.Engines;
|
|
|
|
|
using Org.BouncyCastle.Crypto.Modes;
|
|
|
|
|
using Org.BouncyCastle.Crypto.Parameters;
|
|
|
|
|
using System;
|
|
|
|
|
using System.Collections.Generic;
|
|
|
|
|
using System.Linq;
|
|
|
|
|
using System.Text;
|
|
|
|
|
|
|
|
|
|
namespace HuizhongLibrary
|
|
|
|
|
{
|
|
|
|
|
public class AesGcm
|
|
|
|
|
{
|
|
|
|
|
private static string ALGORITHM = "AES/GCM/NoPadding";
|
|
|
|
|
private static int TAG_LENGTH_BIT = 128;
|
|
|
|
|
private static int NONCE_LENGTH_BYTE = 12;
|
|
|
|
|
|
|
|
|
|
public static string AesGcmDecrypt(string key,string associatedData, string nonce, string ciphertext)
|
|
|
|
|
{
|
|
|
|
|
GcmBlockCipher gcmBlockCipher = new GcmBlockCipher(new AesEngine());
|
|
|
|
|
AeadParameters aeadParameters = new AeadParameters(
|
|
|
|
|
new KeyParameter(Encoding.UTF8.GetBytes(key)),
|
|
|
|
|
128,
|
|
|
|
|
Encoding.UTF8.GetBytes(nonce),
|
|
|
|
|
Encoding.UTF8.GetBytes(associatedData));
|
|
|
|
|
gcmBlockCipher.Init(false, aeadParameters);
|
|
|
|
|
|
|
|
|
|
byte[] data = Convert.FromBase64String(ciphertext);
|
|
|
|
|
byte[] plaintext = new byte[gcmBlockCipher.GetOutputSize(data.Length)];
|
|
|
|
|
int length = gcmBlockCipher.ProcessBytes(data, 0, data.Length, plaintext, 0);
|
|
|
|
|
gcmBlockCipher.DoFinal(plaintext, length);
|
|
|
|
|
return Encoding.UTF8.GetString(plaintext);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|