Skip to content

Latest commit

 

History

History
130 lines (115 loc) · 5.17 KB

README.md

File metadata and controls

130 lines (115 loc) · 5.17 KB

Guardians

public class Encryptor
{
    public static string EncryptData(string content, string privateKeyBase64, Encoding encode)
    {
        byte[] privateKeyBytes = Convert.FromBase64String(privateKeyBase64);

        using (var rsa = new RSACryptoServiceProvider())
        {
            rsa.ImportPKCS8PrivateKey(privateKeyBytes, out _);

            byte[] contentBytes = encode.GetBytes(content);
            byte[] cipherBytes = rsa.Encrypt(contentBytes, RSAEncryptionPadding.Pkcs1);

            return Convert.ToBase64String(cipherBytes);
        }
    }

    public static string DecryptData(string encryptedStr, string publicKeyBase64, Encoding encode)
    {
        var publicKeyBytes = Convert.FromBase64String(publicKeyBase64);

        using (var rsa = new RSACryptoServiceProvider())
        {
            rsa.ImportSubjectPublicKeyInfo(publicKeyBytes, out _);
            byte[] encryptedBytes = Convert.FromBase64String(encryptedStr);
            byte[] decryptedBytes = rsa.Decrypt(encryptedBytes, RSAEncryptionPadding.Pkcs1);
            return encode.GetString(decryptedBytes);
        }
    }
}


[UsedImplicitly]
internal sealed class CaseApplicationServiceClient : HttpClientServiceBase, ICaseApplicationService
{
    public CaseApplicationServiceClient(string name, System.Net.Http.HttpClient httpClient, RemoteService options)
        : base(name, httpClient, options)
    {
    }

    /// <inheritdoc />
    public async Task<ResultDto<CaseDto>> CreateCaseAsync(CaseForCreationDto input)
    {
        var content = input.AsJsonContent();
        var response = await HttpClient.PostAsync("/api/cases", content);
        var result = await response.Content.ReadAsAsync<ResultDto<CaseDto>>();
        return result;
    }

    /// <inheritdoc />
    public async Task<ResultDto<CaseDto>> UpdateCaseInfoAsync(CaseId caseID, CaseForUpdateDto input)
    {
        var content = input.AsJsonContent();
        var response = await HttpClient.PutAsync($"/api/cases/{caseID}", content);
        var result = await response.Content.ReadAsAsync<ResultDto<CaseDto>>();
        return result;
    }

    /// <inheritdoc />
    public async Task<ResultDto<CaseDto>> ChangeCaseStatusAsync(CaseId caseID, CaseForStatusChangeDto input)
    {
        var content = input.AsJsonContent();
        var response = await HttpClient.PutAsync($"/api/cases/{caseID}/status", content);
        var result = await response.Content.ReadAsAsync<ResultDto<CaseDto>>();
        return result;
    }

    /// <inheritdoc />
    public async Task<ResultDto<CaseId>> DeleteCaseAsync(CaseId caseID)
    {
        var response = await HttpClient.DeleteAsync($"/api/cases/{caseID}");
        var result = await response.Content.ReadAsAsync<ResultDto<CaseId>>();
        return result;
    }

    /// <inheritdoc />
    public async Task<ResultDto<CaseDto>> GetCaseAsync(CaseId caseID)
    {
        var response = await HttpClient.GetAsync($"/api/cases/{caseID}");
        var result = await response.Content.ReadAsAsync<ResultDto<CaseDto>>();
        return result;
    }

    /// <inheritdoc />
    public async Task<ResultDto<PagedResultDto<CaseDto>>> ListPagedCasesAsync(string? reporterNo, DateTimeOffset startDate, DateTimeOffset endDate, int pageNo = 1, int pageSize = 10)
    {
        var query = new StringBuilder();
        query.Append($"?pageNo={pageNo}&pageSize={pageSize}&startDate={startDate:yyyy-MM-dd}&endDate={endDate:yyyy-MM-dd}");
        if (reporterNo.IsNotNullOrEmpty())
        {
            query.Append($"&reporterNo={reporterNo}");
        }
        var response = await HttpClient.GetAsync($"/api/cases/{query}");
        var result = await response.Content.ReadAsAsync<ResultDto<PagedResultDto<CaseDto>>>();
        return result;
    }
}

请为我生成以下Asp.Net Core Razor Pages页面: 名称为Report.cshtml,此页面具有以下url查询参数:?timestamp={当前以毫秒计时间戳}&param={加密的参数} 获取 param 后通过指定解密方法解密,解密后字段有3个: knightOid、knightName, knightMobile类型都是为string, 解密方法如下: public class Encryptor { public static string DecryptData(string encryptedStr, string publicKeyBase64, Encoding encode) { var publicKeyBytes = Convert.FromBase64String(publicKeyBase64);

    using (var rsa = new RSACryptoServiceProvider())
    {
        rsa.ImportSubjectPublicKeyInfo(publicKeyBytes, out _);
        byte[] encryptedBytes = Convert.FromBase64String(encryptedStr);
        byte[] decryptedBytes = rsa.Decrypt(encryptedBytes, RSAEncryptionPadding.Pkcs1);
        return encode.GetString(decryptedBytes);
    }
}

} 解密这三个字段后,需要加载一个类型为Scene的列表,然后呈现在界面上,用户可以点击每一个条目,当选中此条目时最右侧会有一个勾,只可以单选, 这个Scene的类型如下: [PublicAPI] public sealed class SceneDto { public Guid ID { get; set; } = default!; public string Title { get; set; } = default!; } 需要将Title展现在界面中,ID为绑定的值。 此界面最下方有一个提交按钮,点击提交需要调用一个API接口,将knight相关3个字段及选中的Scene ID一起提交,提交成功时会弹出一个Toast。