mirror of
https://gitee.com/fudiwei/DotNetCore.SKIT.FlurlHttpClient.Wechat.git
synced 2025-07-15 14:04:32 +08:00
75 lines
4.5 KiB
C#
75 lines
4.5 KiB
C#
using System;
|
||
using System.Text;
|
||
using Xunit;
|
||
|
||
namespace SKIT.FlurlHttpClient.Wechat.Api.UnitTests
|
||
{
|
||
using SKIT.FlurlHttpClient.Primitives;
|
||
|
||
public class TestCase_ToolsAESUtilityTests
|
||
{
|
||
[Fact(DisplayName = "测试用例:AES-CBC 解密")]
|
||
public void TestAESCBCDecryption()
|
||
{
|
||
string iv = "KEWv/gyiIwAfHvjrLeaX6w==";
|
||
string key = "YZJqKnNFi0KAiKUc0ggC2g==";
|
||
string cipherText = "Gu2PVnxVWl+jK4F8c0liGxfkB5Bj3m5HRvwgEIk1Yb+36RZ3Bg7YmUnud/ooiHz0PQroipsH7GCjlGwUeT04NwmrFaP1y3dRYPLpS43ed9QZWcFIFo+8vTs3Zco6S98DUvaNEAs8duhz/BzfBOZaIHMziRqEtPFI0ZDzCgJluBirJ6Wl3UkygZ5/QLo3KA53qGdip7K48Rq8XbCwuidTCw==";
|
||
|
||
string expectedPlainData = "{\"phoneNumber\":\"186****5613\",\"purePhoneNumber\":\"186****5613\",\"countryCode\":\"86\",\"watermark\":{\"timestamp\":1634545675,\"appid\":\"wxc****17e87e0e0a7\"}}";
|
||
string actualPlainData = Utilities.AESUtility.DecryptWithCBC(encodingKey: new EncodedString(key, EncodingKinds.Base64), encodingIV: new EncodedString(iv, EncodingKinds.Base64), encodingCipher: new EncodedString(cipherText, EncodingKinds.Base64))!;
|
||
|
||
Assert.Equal(expectedPlainData, actualPlainData, ignoreCase: true);
|
||
}
|
||
|
||
[Fact(DisplayName = "测试用例:AES-GCM 加密")]
|
||
public void TestAESGCMEncrypt()
|
||
{
|
||
string key = "b302fd4719dd26523d555e6fe392b91a";
|
||
string nonce = "b302fd4719dd";
|
||
string aad = "26523d555e6fe392b91a";
|
||
string plainText = "Awesome SKIT.FlurlHttpClient.Wechat.Api!";
|
||
|
||
string actualPlain = Utilities.AESUtility.EncryptWithGCM(encodingKey: new EncodedString(key, EncodingKinds.Literal), encodingNonce: new EncodedString(nonce, EncodingKinds.Literal), encodingAssociatedData: new EncodedString(aad, EncodingKinds.Literal), plainData: plainText)!;
|
||
string expectedPlain = "bUGHWv7V1+rMtfIx4pIhD95i3J72AK+K1I0vsxBNWAUq8JLjUJ1iSY79kdqp2LCDe4IuOpPxXC0=";
|
||
|
||
Assert.Equal(expectedPlain, actualPlain);
|
||
}
|
||
|
||
[Fact(DisplayName = "测试用例:AES-GCM 解密")]
|
||
public void TestAESGCMDecrypt()
|
||
{
|
||
string key = "b302fd4719dd26523d555e6fe392b91a";
|
||
string nonce = "b302fd4719dd";
|
||
string aad = "26523d555e6fe392b91a";
|
||
string cipherText = "bUGHWv7V1+rMtfIx4pIhD95i3J72AK+K1I0vsxBNWAUq8JLjUJ1iSY79kdqp2LCDe4IuOpPxXC0=";
|
||
|
||
string actualPlain = Utilities.AESUtility.DecryptWithGCM(encodingKey: new EncodedString(key, EncodingKinds.Literal), encodingNonce: new EncodedString(nonce, EncodingKinds.Literal), encodingAssociatedData: new EncodedString(aad, EncodingKinds.Literal), encodingCipher: new EncodedString(cipherText, EncodingKinds.Base64))!;
|
||
string expectedPlain = "Awesome SKIT.FlurlHttpClient.Wechat.Api!";
|
||
|
||
Assert.Equal(expectedPlain, actualPlain);
|
||
|
||
// 以下是根据微信官方文档提供的示例数据的测试用例
|
||
{
|
||
string wxsampleKey = "otUpngOjU+nVQaWJIC3D/yMLV17RKaP6t4Ot9tbnzLY=";
|
||
string wxsampleNonce = "r2WDQt56rEAmMuoR";
|
||
string wxsampleAad = "https://api.weixin.qq.com/wxa/getuserriskrank|wxba6223c06417af7b|1635927956|fa05fe1e5bcc79b81ad5ad4b58acf787";
|
||
string wxsampleData = "HExs66Ik3el+iM4IpeQ7SMEN934FRLFYOd3EmeaIrpP4EPTHckoco6O+PaoRZRa3lqaPRZT7r52f7LUok6gLxc6cdR8C4vpIIfh4xfLC4L7FNy9GbuMK1hcoi8b7gkWJcwZMkuCFNEDmqn3T49oWzAQOrY4LZnnnykv6oUJotdAsnKvmoJkLK7hRh7M2B1d2UnTnRuoIyarXc5Iojwoghx4BOvnV";
|
||
string wxsampleTag = "z2BFD8QctKXTuBlhICGOjQ==";
|
||
|
||
byte[] keyBytes = Convert.FromBase64String(wxsampleKey);
|
||
byte[] nonceBytes = Convert.FromBase64String(wxsampleNonce);
|
||
byte[] aadBytes = Encoding.UTF8.GetBytes(wxsampleAad);
|
||
byte[] encdataBytes = Convert.FromBase64String(wxsampleData);
|
||
byte[] authtagBytes = Convert.FromBase64String(wxsampleTag);
|
||
byte[] cipherBytes = new byte[encdataBytes.Length + authtagBytes.Length];
|
||
Buffer.BlockCopy(encdataBytes, 0, cipherBytes, 0, encdataBytes.Length);
|
||
Buffer.BlockCopy(authtagBytes, 0, cipherBytes, encdataBytes.Length, authtagBytes.Length);
|
||
|
||
byte[] plainBytes = Utilities.AESUtility.DecryptWithGCM(keyBytes, nonceBytes, aadBytes, cipherBytes);
|
||
string plainData = Encoding.UTF8.GetString(plainBytes).Trim();
|
||
Assert.True(plainData.StartsWith("{") && plainData.EndsWith("}"));
|
||
}
|
||
}
|
||
}
|
||
}
|