Visual Studio 2015 Preview 除了給我們帶了了C# 6.0的新語法、跨移動的開發以外,還給我們帶來了ASP.NET5(也就是之前被稱作下一代ASP.NET的ASP.NET vNext)。本文給大家介紹asp.net5中的用戶認證與授權(1),需要的朋友可以參考下
就在最近一段時間,微軟又有大動作了,在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),需要的朋友之間點擊查看就可以了。
|
新聞熱點
疑難解答
圖片精選