.NET CORE 修改IdentityUser 的数据库模型 添加自定义字段

1. 新建class ApplicationUser

 //继承IdentityUser进行新增一些自定义字段
    public class ApplicationUser : IdentityUser
    {
        //补充的新字段
        public string Address { get; set; }
        //shoppingCart
        //orders
        // 用户角色 用户权限 用户信息 用户登录tokens  重新绑定与父类的关系 命名必须和父类一致
        public virtual ICollection<IdentityUserRole<string>> UserRoles { get; set; }
        public virtual ICollection<IdentityUserClaim<string>> Claims { get; set; }
        public virtual ICollection<IdentityUserLogin<string>> Logins { get; set; }
        public virtual ICollection<IdentityUserToken<string>> Tokens { get; set; }

    }

2. 全局用到IdentityUser的地方替换ApplicationUser(禁止替换migration 生成的数据源文件)

3. 设置基础数据


            //初始化用戶与角色的种子数据
            //1. 更新用戶与角色的外鍵
            modelBuilder.Entity<ApplicationUser>(
                u => u.HasMany(x => x.UserRoles).WithOne().HasForeignKey(ur => ur.UserId).IsRequired()
                );
            //2. 添加管理员角色
            var adminRoleId = "f8df1775-e889-46f4-acdd-421ec8d9ba64";
            modelBuilder.Entity<IdentityRole>().HasData(
                new IdentityRole()
                {
                    Id = adminRoleId,
                    Name = "Admin",
                    NormalizedName = "Admin".ToUpper()
                }
            );
            //3. 添加用户
            var adminUserId = "f8df1775-e889-46f4-acdd-421ec8d9ba65";
            ApplicationUser adminUser = new ApplicationUser
            {
                Id = adminUserId,
                UserName = "admin@qq.com",
                NormalizedEmail = "admin@qq.com".ToUpper(),
                Email = "admin@qq.com",
                TwoFactorEnabled = false,
                EmailConfirmed = true,
                PhoneNumber = "123456789",
                PhoneNumberConfirmed = false,

            };
            var ph = new PasswordHasher<ApplicationUser>();
            adminUser.PasswordHash = ph.HashPassword(adminUser, "lah123465.");
            modelBuilder.Entity<ApplicationUser>().HasData(adminUser);
            //4. 给用户加入管理员角色
            modelBuilder.Entity<IdentityUserRole<string>>().HasData(
                new IdentityUserRole<string>()
                {
                    RoleId = adminRoleId,
                    UserId = adminUserId
                }
                );

4. 更新数据库

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要向 ASP.NET Core MVC 模型添加列表,并将其保存到数据库中,可以按照以下步骤进行操作: 1. 首先,在模型类中定义一个 List 属性,如下所示: ```csharp public class MyModel { public int Id { get; set; } public List<string> MyList { get; set; } } ``` 2. 在数据库中创建一个表,其中包含一个主键列和一个用于存储列表数据的 JSON 列。例如: ```sql CREATE TABLE MyTable ( Id INT IDENTITY(1,1) PRIMARY KEY, MyList JSON NOT NULL ); ``` 3. 在视图中,使用 HTML 的 form 元素来提交表单数据。在表单中,可以通过使用 for 循环和 Html.HiddenFor() 方法来将列表中的每个元素都作为隐藏字段提交。例如: ```html @model MyModel @using (Html.BeginForm()) { for (int i = 0; i < Model.MyList.Count; i++) { @Html.HiddenFor(m => m.MyList[i]) } <input type="submit" value="Submit" /> } ``` 4. 在控制器的 POST 方法中,可以将列表数据保存到数据库中。例如: ```csharp [HttpPost] public IActionResult MyAction(MyModel model) { // Convert the list to a JSON string string json = JsonConvert.SerializeObject(model.MyList); // Insert the data into the database string connectionString = "your_connection_string_here"; using (SqlConnection connection = new SqlConnection(connectionString)) { connection.Open(); string sql = "INSERT INTO MyTable (MyList) VALUES (@MyList);"; SqlCommand command = new SqlCommand(sql, connection); command.Parameters.AddWithValue("@MyList", json); command.ExecuteNonQuery(); } return RedirectToAction("Index"); } ``` 这样就可以向 ASP.NET Core MVC 模型添加列表,并将其保存到数据库中了。请注意,此示例使用了 Newtonsoft.Json 库将列表转换为 JSON 字符串。如果您使用的是 .NET Core 3.0 或更高版本,则可以使用 System.Text.Json 库来完成此操作。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值