asp.net core系列 48 Identity 身份模型自定义

一.概述

  ASP.NET Core Identity提供了一个框架,用于管理和存储在 ASP.NET Core 应用中的用户帐户。 Identity添加到项目时单个用户帐户选择作为身份验证机制。 默认情况下,Identity可以使用的 Entity Framework (EF) Core 数据模型。 本文介绍如何自定义的身份标识模型。

 

  1.1 下面是已经存在的身份模型, 由以下实体类型组成:

实体类型

说明

关系

Users(用户表)登录用户 

Roles (角色表)

角色

 

UserClaims(用户声明表)用户拥有的权限每个Users有多个UserClaims
UserTokens用户的身份验证令牌每个Users有多个UserTokens
UserLogins将用户与登录相关联。每个Users有多个UserLogins
RoleClaims(角色声明表)角色拥有的权限每个Roles有多个RoleClaims
UserRoles用户和角色关联每个Users有多个Roles

    (1) Users 表

字段名称

字段类型

描述

IdGuid主键,默认是Guid
UserNameNvarchar(256)用户名或邮箱
NormalizedUserNameNvarchar(256)规范化用户名,转成了大写
EmailNvarchar(256)邮箱
NormalizedEmailNvarchar(256)规范化邮箱名,转成了大写
EmailConfirmedbit验证邮件确认,默认为false
PasswordHashNvarchar(max)密码哈希
SecurityStampNvarchar(max)安全标记,Guid类型,用户凭据更改时生成随机值,如更改用户名
ConcurrencyStampNvarchar(max)同步标记,Guid类型
PhoneNumberNvarchar(max)电话
PhoneNumberConfirmedbit>电话确认
TwoFactorEnabledbit双因子验证
LockoutEnddatetimeoffset(7)锁定的到期日期,null表示没有锁定
LockoutEnabledbit是否可以被锁定
AccessFailedCountint登陆失败的次数, 确定是否锁定用户

    

  1.2 默认模型的配置

    Identity定义了许多从DbContext继承以配置和使用模型的上下文类,此配置是使用上下文类的OnModelCreating方法中的EF Core Code First Fluent API完成的。默认模型结构可以查看Migration文件以及查看模型关系ModelSnapshot文件,但要修改模型不在这里更改。下面是AspNetUsers模型代码:

    下面是默认模型生成的数据表以及关系: 

  

二.模型自定义

   在EF上下文中当重写OnModelCreating方法时base.OnModelCreating方法首先调用; 接下来重写的会覆盖默认模型配置。

    public class ApplicationDbContext : IdentityDbContext<WebAppIdentityDemoUser>{public ApplicationDbContext(DbContextOptions<ApplicationDbContext> options): base(options){}protected override void OnModelCreating(ModelBuilder builder){base.OnModelCreating(builder);// Customize the ASP.NET Core Identity model and override the defaults if needed.// For example, you can rename the ASP.NET Core Identity table names and more.// Add your customizations after calling base.OnModelCreating(builder);
        }}

  

   2.1 自定义用户数据

     在上篇有讲过自定义用户数据,这里在总结下。自定义用户数据支持通过继承IdentityUser类。 自定义类命名约定 {Application}User。

     //定义{Application}User扩展类,实现用户模型public class WebAppIdentityDemoUser : IdentityUser//使用{Application}User作为上下文的泛型参数的类型:public class ApplicationDbContext : IdentityDbContext<WebAppIdentityDemoUser>//更新Startup.ConfigureServices以使用新{Application}User类,最后生成迁移,同步数据库。services.AddDefaultIdentity<WebAppIdentityDemoUser>().AddDefaultUI().AddEntityFrameworkStores<ApplicationDbContext>();    

 

  2.2 更改主键类型  

     在创建数据库之后更改PK列的数据类型在许多数据库系统上都存在问题。更改PK通常涉及删除和重新创建表。因此,在创建数据库时,应在初始迁移中指定PK类型。下面是更改主键类型步骤:

     (1) 删除数据库,命令如下:

        Drop-Database  

    (2) 移除之前生成的迁移,命令如下:

        Remove-Migration

    (3) 修改user,role表主键类型,以及相关代码改动

    // 用户表设置主键为Intpublic class WebAppIdentityDemoUser : IdentityUser<int>{/// <summary>/// Full name/// </summary>
        [PersonalData]public string Name { get; set; }/// <summary>/// Birth Date/// </summary>
        [PersonalData]public DateTime DOB { get; set; }}// 角色表设置主键为Intpublic class WebAppIdentityDemoRole : IdentityRole<int>{}

     (4) 修改上下文

    public class ApplicationDbContext : IdentityDbContext<WebAppIdentityDemoUser, WebAppIdentityDemoRole,int>

    (5) 修改服务注册

       services.AddIdentity<WebAppIdentityDemoUser, WebAppIdentityDemoRole>()//如果使用Identity scaffolder将Identity文件添加到项目中,请删除对该项目的调用AddDefaultUI//.AddDefaultUI().AddEntityFrameworkStores<ApplicationDbContext>().AddDefaultTokenProviders();

    (6) 生成迁移代码,命令如下

       Add-Migration IdentitySchema

    (7) 同步数据库

      Update-Database IdentitySchema

    此时表的主键类型已修改完成,包括关系表的外键类型也同步更新了,如下图所示:

 

   2.3 添加导航属性

     导航属性仅存在于EF模型中,而不存在于数据库中,如果导航关系没有改变,模型更改不需要更新数据库。如果更改关系的模型配置可能比进行其他更改更困难。必须注意取代现有的关系。下面示例是不改变模型关系,只是在user模型上添加导航属性以及在上下文中指定关系:

    public class WebAppIdentityDemoUser : IdentityUser<int>{/// <summary>/// Full name/// </summary>
        [PersonalData]public string Name { get; set; }/// <summary>/// Birth Date/// </summary>
        [PersonalData]public DateTime DOB { get; set; }//定义导航属性public virtual ICollection<IdentityUserClaim<int>> Claims { get; set; }}
     protected override void OnModelCreating(ModelBuilder builder){base.OnModelCreating(builder);// Customize the ASP.NET Core Identity model and override the defaults if needed.// For example, you can rename the ASP.NET Core Identity table names and more.// Add your customizations after calling base.OnModelCreating(builder);builder.Entity<WebAppIdentityDemoUser>(b =>{// Each User can have many UserClaimsb.HasMany(e => e.Claims).WithOne().HasForeignKey(uc => uc.UserId).IsRequired();});}

    对于所有用户导航属性, 用户和角色导航属性,添加所有导航属性。参考官网文档。

 

  2.4  更改表/列名称,字段长度(上下文中更改)  

     protected override void OnModelCreating(ModelBuilder builder){base.OnModelCreating(builder);//更改表名称builder.Entity<IdentityUser>(b =>{b.ToTable("MyUsers");});//更改表字段名称builder.Entity<IdentityUserClaim<string>>(b =>{b.Property(e => e.ClaimType).HasColumnName("CType");b.Property(e => e.ClaimValue).HasColumnName("CValue");});//更改长度builder.Entity<IdentityUser>(b =>{b.Property(u => u.UserName).HasMaxLength(128);});    }

 

   参考文献

    自定义Identity

 

转载于:https://www.cnblogs.com/MrHSR/p/10593987.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/536627.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

oracle中创建游标,oracle 存储过程创建游标

Oracle与Sql Server差异点详解1、create函数或存储过程异同点Oracle 创建函数或存储过程一般是 create or replace ……SQL SERVER 则是在创建之前加一条语句&#xff0c;先判断是否已经存在&#xff0c;如果存在删除已有的函数或存储过程。函数语句&#xff1a;if exists (sel…

hosts文件不起作用

突然发现电脑的hosts文件不起作用了。之前用的狠正常&#xff0c;近期也没有修改过。首先排除什么格式、DNS、注册表之类的问题。最终解决办法&#xff08;权限问题&#xff1a;有问题的hosts文件图标上有个锁&#xff09;&#xff1a;1.C:\Windows\System32\drivers\etc下复制…

oracle面临的挑战,未来数据库管理员面临的三大挑战

原标题&#xff1a;未来数据库管理员面临的三大挑战前言今天的数据库管理员面临着三大挑战&#xff1a;工作重心向以应用程序为中心转移、支持多个数据库平台的需求、在云端以及在本地管理数据库性能的责任不断扩大。为了在今天和未来都能站稳脚跟&#xff0c;数据库管理员需要…

打造汽车“安卓平台”,大众或亲手干掉传统汽车产业

干掉传统汽车产业的&#xff0c;很可能是大众&#xff0c;而不是特斯拉。 于无声处听惊雷。 2019年的日内瓦车展&#xff0c;看起来并没有传出太大的新闻。汽车世界的目光&#xff0c;依然被特斯拉的喧嚣所吸引。 然而&#xff0c;大众汽车展台上发生的一件看似不起眼的小事情&…

从 SPA 到 PWA:Web App的下一站在哪?

从AJAX&#xff08;Asynchronous JavaScript XML&#xff0c;异步JavaScript和XML&#xff09;开始&#xff0c; 尤其是 AngularJS 推出之后&#xff0c;SPA&#xff08;Single Page App&#xff0c;单页应用&#xff09;已经成为前端 App 的必选方案。 SPA 可以在客户端提供完…

Unable to resolve dependency问题解决

Unable to resolve dependency 是一个让我头疼的问题 之前总是阴差阳错调试好 但是也没有总结出来方法 但是今天找到了 方法来源 https://jingyan.baidu.com/article/19192ad8c489dfe53e5707ee.html 原因就是用户的gradle.properties 设置了代理&#xff0c;将文件内的代理注释…

计数排序与桶排序python实现

计数排序与桶排序python实现 计数排序 计数排序原理&#xff1a; 找到给定序列的最小值与最大值 创建一个长度为最大值-最小值1的数组&#xff0c;初始化都为0 然后遍历原序列&#xff0c;并为数组中索引为当前值&#xff0d;最小值的值&#xff0b;&#xff11; 此时数组中…

JVM快速调优手册02:常见的垃圾收集器

2019独角兽企业重金招聘Python工程师标准>>> 如果说收集算法是内存回收的方法论&#xff0c;那么垃圾收集器就是内存回收的具体实现。 Java虚拟机规范中对垃圾收集器应该如何实现并没有任何规定&#xff0c;因此不同的厂商、不同版本的虚拟机所提供的垃圾收集器都可…

linux运维平台工具,Linux运维自动化工具 Kickstart

简介&#xff1a;批量安装操作系统工具之 Kickstart &#xff0c;RedHat 早前推出的产品( 不多说了&#xff0c;现在都玩 Cobbler 啦&#xff0c;见 http://www.linuxidc.com/Linux/2016-04/129977.htm )。测试环境&#xff1a;CentOS 6.6 x86_64 minimal一、安装软件包shell &…

PostgreSQL 并行查询概述

2019独角兽企业重金招聘Python工程师标准>>> PostgreSQL从9.6版本开始加入并行查询&#xff0c;并在PostgreSQL10和PostgreSQL11分别做了大量加强工作。下面从&#xff1a; 何时启用并行查询功能并行查询是如何工作的worker进程数量越多&#xff0c;查询性能越高吗三…

Quarkus:一个Kubernetes原生Java框架

Red Hat发布了Quarkus&#xff0c;这是一个为GraalVM和OpenJDK HotSpot量身定制的Kubernetes原生Java框架。Quarkus的目标是使Java成为Kubernetes和无服务器环境中的领先平台&#xff0c;为开发人员提供统一的反应式和命令式编程模型。 Quarkus利用Java开发人员使用的一系列库&…

linux scp传输文件命令

scp -r /opt/test root192.168.2.105:/opt 转载于:https://www.cnblogs.com/LynnChen/p/10620576.html

nginx能访问html静态文件但无法访问php文件

nginx.conf中红框部分修改成你的实际网站根目录转载于:https://www.cnblogs.com/IT-Crowd/p/10626549.html

linux mariadb 升级,linux mariadb

linux mariadb转载 一 安装下载mariaDB MariaDB-5.5.29-rhel5-x86_64-common.rpm 和MariaDB-5.5.29-rhel5-x86_64-server.rpm 包,MariaDB-5.5.29-rhel5-x86_64-client.rpm2.然后再http.//yum。mariadb。org/ 找到 RPM-GPG-KEY-MariaDB 这个PGP文件&#xff0c;把文件放入到/etc…

Linux Note

日期&#xff1a;2019/3/31 内容&#xff1a;Linux学习笔记 一、Linux命令 ls -l 操作效果 第一列&#xff1a;文件权限 一共10位。 01(r)2(w)3(x)4(r)5(w)6(x)7(r)8(w)9(x)文件类型文件所有者权限 usr权限&#xff0c;u权限文件所有者所属组成员的权限 group权限&#xff0c;g…

linux nginx F配置,linux下nginx的安装及配置

1、安装nginx前&#xff0c;咱们首先要确保系统安装了g、gcc、openssl-devel、pcre-devel和zlib-devel软件&#xff0c;可经过如图所示命令进行检测,若是以安装咱们能够经过图二所示卸载&#xff1a;linuxyum install gcc-cyum -y install zlib zlib-devel openssl openssl--de…

你缺啥,你缺一个得力的办公软件

其实你缺啥我都知道&#xff0c;但是&#xff0c;我又不能给你发工资&#xff0c;还得你自己努力工作才行。不过我可以给你分享几款好用的办公软件&#xff0c;对你在进行有效率的办公会有很大帮助的。曲奇办公是一款以文档为载体的企业办公管理应用。帮助企业快速实现业务标准…

C语言做一个表格的程序,用C语言画个简单表格

今天见到个题目&#xff0c;就把他做了&#xff0c;题目如下&#xff1a;在图形环境中很容易做出漂亮的表格。但在控制台环境中就比较困难了。有的时候可以用一些符号大略地模拟&#xff1a;(word文档中可能不整齐&#xff0c;拷贝到记事本中看)-------------|abc |xyztt|…

深度学习框架PyTorch一书的学习-第四章-神经网络工具箱nn

参考https://github.com/chenyuntc/pytorch-book/tree/v1.0 希望大家直接到上面的网址去查看代码&#xff0c;下面是本人的笔记 本章介绍的nn模块是构建与autograd之上的神经网络模块 除了nn外还会介绍神经网络中常用的工具&#xff0c;比如优化器optim、初始化init等 1.nn.Mod…

地铁售票系统设计思想及部分代码

设计思想&#xff1a;地铁售票系统的关键点在于换乘&#xff0c;所以首先要分为换乘和不换乘两种情况。不换乘比较简单&#xff0c;通过起始站名和终点站名查询他们的num&#xff0c;然后list打包输出到jsp就可以。换乘的话就先要找到两条线路&#xff0c;找到两条线路的交点也…