首页 > 解决方案 > INSERT 语句与具有用户 ID(ASP 身份)的 FOREIGN KEY 冲突

问题描述

我正在开发一个允许用户通过表单提交帖子的功能,它成功地从 AspNetUsers 获取用户 ID。我已经实现了一个单选按钮,让用户可以选择成为匿名提交。代码如下,

protected void AddPost(object sender, EventArgs e)
{



    var User = System.Web.HttpContext.Current.User.Identity.GetUserId();
    if (Convert.ToBoolean(Int32.Parse(inputAnonymous.SelectedValue)))
    {
        User = "anonymous";
    }

    Post newPost = new Post()
    {
        postTitle = inputTitle.Text,
        postBody = inputBody.Text,
        postDescription = inputDescription.Text,
        postCategory = inputCategory.SelectedValue,
        postAnonymous = Convert.ToBoolean(Int32.Parse(inputAnonymous.SelectedValue)),
        Id = User
    };

    using (var _dbContext = new ApplicationDbContext())
    {
        _dbContext.Posts.Add(newPost);
        _dbContext.SaveChanges();
    }
}

当为用户匿名选择“否”选项时,帖子正常提交,并将 id 发布到数据库等中,但是当我按照调试器单击“是”时,它说它正在识别它是匿名的,它应该将 userId 更改为字符串“anonymous”并将其作为数据库中的 Id 提交,但我不断收到这个错误,阻止我如下

SqlException:INSERT 语句与 FOREIGN KEY 约束“FK_dbo.Posts_dbo.AspNetUsers_Id”冲突。冲突发生在数据库“aspnet-WebEnterprise-20190201040107”、表“dbo.AspNetUsers”、“Id”列中。该语句已终止。

更新:我已将这段代码添加到我的 configuration.cs

 {
                var passwordHash = new PasswordHasher();
                string password = passwordHash.HashPassword("Anonymous@123");
                context.Users.AddOrUpdate(u => u.UserName,
                    new ApplicationUser
                    {
                        UserName = "Anonymous@Anonymous.com",
                        PasswordHash = password,
                        PhoneNumber = "12345678911",
                        Email = "Anonymous@Anonymous.com"
                    });
                context.Roles.AddOrUpdate(
                    new IdentityRole { Id = "a1f04ba5-5600-4a6e-be43-ae0d6360c0ab", Name = "Anonymous" }
                    );
            }

但是当我在 nuget 数据包管理器上更新数据库时,出现以下错误

“更新条目时发生错误。有关详细信息,请参阅内部异常。”

标签: c#asp.netasp.net-identity

解决方案


没有 ID 为“匿名”的用户,因此您会收到错误消息。AspNetUsers 不包含任何 ID 为“匿名”的用户。除了使用不存在的 Id 值之外,此代码没有任何问题。

就这个问题而言,我的建议是创建一个匿名用户,获取他的 ID 并将该 ID 绑定到所有应该匿名的帖子。所有匿名帖子都将具有相同的 ID,但这无关紧要,因为它们无论如何都是匿名的。检查链接和链接以获取有关如何通过代码优先架构插入用户的更多信息


推荐阅读