就在最近一段時間,微軟又有大動作了,在IDE方面除了給我們發布了Viausl Studio 2013 社區版還發布了全新的Visual Studio 2015 Preview。
asp.net5中,關於使用者的認證和授權提供了非常豐富的功能,如果結合ef7的話,可以自動產生相關的資料庫表,調用也很方便。
但是,要理解這麼一大堆關於認證授權的類,或者想按照自己項目的特定要求對認證授權進行定製,確實很頭疼。為瞭解決這個問題,需要從根本上理解認證和授權的機制,不過這不是個簡單的事情,一些概念也比較抽象,為了方便理解,這裡我用最簡單的執行個體來示範如何進行認證和授權,而且是在不使用ef,不使用資料庫的情況下,單純的示範認證和授權本身。
要進行認證,首先你要有使用者,這裡我們建立一個使用者類如下:
/// <summary> /// 使用者 /// </summary> public class HDUser { /// <summary> /// 使用者ID /// </summary> public string Id { get; set; } /// <summary> /// 登入名稱 /// </summary> public string UserName { get; set; } /// <summary> /// 規範使用者名稱 /// </summary> public string NormalizedUserName { get; set; } /// <summary> /// 密碼 /// </summary> public string PassWord { get; set; } /// <summary> /// 雜湊編碼後的密碼 /// </summary> public string PasswordHash { get; set; } /// <summary> /// 使用者具有的角色 /// </summary> public virtual ICollection<HDUserRole> Roles { get; private set; } = new List<HDUserRole>(); }
這裡,HDUser類的欄位大部分比較容易理解,就那個NormalizedUserName難理解一些,可以簡單認為是UserName的大寫形式好了。
然後是角色類:
/// <summary> /// 角色 /// </summary> public class HDRole { /// <summary> /// 角色ID /// </summary> public string Id { get; set; } /// <summary> /// 角色名稱 /// </summary> public string Name { get; set; } }
有了使用者和角色,要建立起使用者和角色的關係,就需要使用者角色類:
/// <summary> /// 使用者角色對應關係 /// </summary> public class HDUserRole { /// <summary> /// 使用者ID /// </summary> public virtual string UserId { get; set; } /// <summary> ///角色ID /// </summary> public virtual string RoleId { get; set; } }
這樣,最基礎的三個類我們就都建立起來了。
好了,以上通過一個簡單一實例介紹了asp.net5中的使用者認證與授權(1),下篇繼續跟大家介紹asp.net5中的使用者認證與授權(2),需要的朋友之間點擊查看就可以了。