ASP.NET 核心验证 Azure Table 实体已采用

ASP.NET Core validate Azure Table Entity already taken

我正在尝试将数据验证错误触发回我在查找数据库后端时的视图。

// Perform lookup to see if domain has been taken already
var domainResults = await _context.TenantEntity.SingleOrDefaultAsync(x => x.Office365DomainName == Input.Office365DomainName);
if (domainResults.Office365DomainName == Input.Office365DomainName)
{
    // duplicate domain name attempted
    user.Office365DomainName = "AlreadyTaken";
    return Page();
}

这是我的领域:

[Required]
[Display(Name = "Office 365 Domain Name")
public string Office365DomainName { get; set; }

我更喜欢使用 DataAnnotation,这样我就可以将自定义消息发回 view/user,但我不知道如何构建它。

我已经尝试将我的 属性 验证更改为正则表达式并观察 "AlreadyTaken",因为我将其设置在包含相同对象的 class 中。我的想法是对一些模糊的东西(比如 GUID)执行正则表达式匹配,然后让我的正则表达式匹配该 GUID 以获得验证错误。

我可能想太多了,我希望有人有一些见解。

正如所建议的,对此有一个非常简单的答案:

// Perform lookup to see if domain has been taken already
var domainResult = await _context.TenantEntity.SingleOrDefaultAsync(x => x.Office365DomainName == Input.Office365DomainName);
if (domainResult != null && domainResult.Office365DomainName == Input.Office365DomainName)
{
    // duplicate domain name attempted
    ModelState.AddModelError("Office365DomainName", "This domain has been registered already.");
    return Page();
}

我根本不需要修改我的字段。以下文章很有帮助:https://exceptionnotfound.net/asp-net-mvc-demystified-modelstate/