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

来源:https://www.cnblogs.com/MrHSR/archive/2019/03/25/10593987.html
-Advertisement-
Play Games

一.概述 ASP.NET Core Identity提供了一個框架,用於管理和存儲在 ASP.NET Core 應用中的用戶帳戶。 Identity添加到項目時單個用戶帳戶選擇作為身份驗證機制。 預設情況下,Identity可以使用的 Entity Framework (EF) Core 數據模型。 ...


一.概述

  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.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表主鍵類型,以及相關代碼改動

    // 用戶表設置主鍵為Int
    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; }
    }

   // 角色表設置主鍵為Int
    public 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 UserClaims
                b.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

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • Markdown 是一種輕量級標記語言,允許人們使用易讀易寫的純文本格式編寫文檔。當前許多網站都廣泛使用 Markdown 來撰寫幫助文檔或是用於論壇上發表消息。推薦使用 Typora 編輯器,它支持 MacOS 、Windows、Linux 平臺,且包含多種主題,編輯後直接渲染出效果。 ...
  • 題意 "題目鏈接" Sol 這題也比較休閑。 直接把$X_{i+1} = (aX_i + b) \pmod P$展開,推到最後會得到這麼個玩意兒 $$ a^{i 1} (x_1 + \frac{b}{a 1}) \frac{b}{a 1} \equiv T \pmod P $$ 然後再合併一下就可以 ...
  • Java語言是強類型語言,所有變數都必須確定具體的數據類型。 原生數據類型 byte(1位元組)、short(2位元組)、int(4位元組)、long(8位元組)、 boolean(1位元組) 、float(4位元組) 、double(8位元組) 、char(2位元組) 引用類型 範圍小的類型轉換為範圍大的類型,可 ...
  • 1RabbitMQ 特點 與 SpringAMQP 完美整合、API 豐富。 集群模式豐富,表達式配置,HA 模式,鏡像隊列模型。 保證數據不丟失的前提做到高可靠性、可用性。 ...
  • 給定一個按照升序排列的整數數組 nums,和一個目標值 target。找出給定目標值在數組中的開始位置和結束位置。你的演算法時間複雜度必須是 O(log n) 級別。如果數組中不存在目標值,返回 [-1, -1]。 示例 1:輸入: nums = [5,7,7,8,8,10], target = 8輸 ...
  • VBCSHARP代碼互轉工具,適用於VB.NET和C#代碼相互轉換翻譯,可代碼段轉換和批量文件轉換。於2019年3月5日製作完成,允許各群隨意分發和使用。 下載地址:下載鏈接 歡迎使用 下載地址:下載鏈接 ...
  • 我說一句話你就知道我是乾什麼的 hello world ...
  • 當 多條件 left join on 時 LEFT OUTER JOIN on new { u.UserId, ue.ExamId } equals new { sac.UserId, sac.ExamId } into sac2 from sac in sac2.DefaultIfEmpty() ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...