mirror of
https://gitee.com/fudiwei/DotNetCore.SKIT.FlurlHttpClient.Wechat.git
synced 2025-12-29 18:04:42 +08:00
feat(tenpayv3): 新增微工卡投保相关接口
This commit is contained in:
@@ -0,0 +1,11 @@
|
||||
{
|
||||
"insurance_company_name": "平安",
|
||||
"insurance_company_order_no": "5fds5345dfd",
|
||||
"insure_effect_time": "2018-06-08T10:34:56+08:00",
|
||||
"insure_invalid_time": "2018-06-08T10:34:56+08:00",
|
||||
"insure_state": "INSURE_SUCCESS",
|
||||
"openid": "11111111",
|
||||
"sp_mchid": "1900000109",
|
||||
"sub_mchid": "1900000109",
|
||||
"wesure_order_no": "5fds5345dfd"
|
||||
}
|
||||
@@ -0,0 +1,8 @@
|
||||
{
|
||||
"authenticate_type": "NORMAL",
|
||||
"id_card_number": "7FzH5XksJG3a8HLLsaaUV6K54y1OnPMY5",
|
||||
"sp_mchid": "1900000109",
|
||||
"sub_mchid": "1900000109",
|
||||
"token": "abcdefghijklmn",
|
||||
"user_name": "LP7bT4hQXUsOZCEvK2YrSiqFsnP0oRMfeoLN0vBg"
|
||||
}
|
||||
@@ -0,0 +1,6 @@
|
||||
{
|
||||
"authenticate_success_time": "2015-05-20T13:29:35+08:00",
|
||||
"fail_reason": "SP_MCH_NO_PERMISSION",
|
||||
"openid": "11111111",
|
||||
"result": "SUCCESS"
|
||||
}
|
||||
@@ -1336,6 +1336,62 @@ namespace SKIT.FlurlHttpClient.Wechat.TenpayV3.UnitTests
|
||||
}
|
||||
}
|
||||
|
||||
[Fact(DisplayName = "测试用例:加密请求中的敏感数据([POST] /payroll-card/wesure/token-validations)")]
|
||||
public async Task TestEncryptRequestSensitiveProperty_GetPayrollCardWesureTokenValidationRequest()
|
||||
{
|
||||
static Models.GetPayrollCardWesureTokenValidationRequest GenerateMockRequestModel()
|
||||
{
|
||||
return new Models.GetPayrollCardWesureTokenValidationRequest()
|
||||
{
|
||||
UserName = MOCK_PLAIN_STR,
|
||||
IdCardNumber = MOCK_PLAIN_STR
|
||||
};
|
||||
}
|
||||
|
||||
static void AssertMockRequestModel(Models.GetPayrollCardWesureTokenValidationRequest request, Func<string, string> decryptor)
|
||||
{
|
||||
Assert.NotEqual(MOCK_PLAIN_STR, request.UserName!);
|
||||
Assert.NotEqual(MOCK_PLAIN_STR, request.IdCardNumber!);
|
||||
Assert.Equal(MOCK_PLAIN_STR, decryptor.Invoke(request.UserName!));
|
||||
Assert.Equal(MOCK_PLAIN_STR, decryptor.Invoke(request.IdCardNumber!));
|
||||
Assert.Equal(MOCK_CERT_SN, request.WechatpayCertificateSerialNumber!, ignoreCase: true);
|
||||
}
|
||||
|
||||
if (!string.IsNullOrEmpty(TestConfigs.WechatMerchantRSACertificatePrivateKey))
|
||||
{
|
||||
using (var client = CreateMockClientUseRSA(autoEncrypt: false))
|
||||
{
|
||||
var request = GenerateMockRequestModel();
|
||||
client.EncryptRequestSensitiveProperty(request);
|
||||
AssertMockRequestModel(request, (cipher) => Utilities.RSAUtility.DecryptWithECB(RSA_PEM_PRIVATE_KEY, (EncodedString)cipher)!);
|
||||
}
|
||||
|
||||
using (var client = CreateMockClientUseRSA(autoEncrypt: true))
|
||||
{
|
||||
var request = GenerateMockRequestModel();
|
||||
await client.ExecuteGetPayrollCardWesureTokenValidationAsync(request);
|
||||
AssertMockRequestModel(request, (cipher) => Utilities.RSAUtility.DecryptWithECB(RSA_PEM_PRIVATE_KEY, (EncodedString)cipher)!);
|
||||
}
|
||||
}
|
||||
|
||||
if (!string.IsNullOrEmpty(TestConfigs.WechatMerchantSM2CertificatePrivateKey))
|
||||
{
|
||||
using (var client = CreateMockClientUseSM2(autoEncrypt: false))
|
||||
{
|
||||
var request = GenerateMockRequestModel();
|
||||
client.EncryptRequestSensitiveProperty(request);
|
||||
AssertMockRequestModel(request, (cipher) => Utilities.SM2Utility.Decrypt(SM2_PEM_PRIVATE_KEY, (EncodedString)cipher)!);
|
||||
}
|
||||
|
||||
using (var client = CreateMockClientUseSM2(autoEncrypt: true))
|
||||
{
|
||||
var request = GenerateMockRequestModel();
|
||||
await client.ExecuteGetPayrollCardWesureTokenValidationAsync(request);
|
||||
AssertMockRequestModel(request, (cipher) => Utilities.SM2Utility.Decrypt(SM2_PEM_PRIVATE_KEY, (EncodedString)cipher)!);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
[Fact(DisplayName = "测试用例:加密请求中的敏感数据([POST] /profitsharing/orders)")]
|
||||
public async Task TestEncryptRequestSensitiveProperty_CreateProfitSharingOrderRequest()
|
||||
{
|
||||
|
||||
Reference in New Issue
Block a user