就在最近一段時(shí)間,微軟又有大動(dòng)作了,在IDE方面除了給我們發(fā)布了Viausl Studio 2013 社區(qū)版還發(fā)布了全新的Visual Studio 2015 Preview。
asp.net5中,關(guān)于用戶的認(rèn)證和授權(quán)提供了非常豐富的功能,如果結(jié)合ef7的話,可以自動(dòng)生成相關(guān)的數(shù)據(jù)庫表,調(diào)用也很方便。
但是,要理解這么一大堆關(guān)于認(rèn)證授權(quán)的類,或者想按照自己項(xiàng)目的特定要求對認(rèn)證授權(quán)進(jìn)行定制,確實(shí)很頭疼。為了解決這個(gè)問題,需要從根本上理解認(rèn)證和授權(quán)的機(jī)制,不過這不是個(gè)簡單的事情,一些概念也比較抽象,為了方便理解,這里我用最簡單的實(shí)例來演示如何進(jìn)行認(rèn)證和授權(quán),而且是在不使用ef,不使用數(shù)據(jù)庫的情況下,單純的演示認(rèn)證和授權(quán)本身。
要進(jìn)行認(rèn)證,首先你要有用戶,這里我們建立一個(gè)用戶類如下:
/// <summary> /// 用戶 /// </summary> public class HDUser { /// <summary> /// 用戶ID /// </summary> public string Id { get; set; } /// <summary> /// 登錄名 /// </summary> public string UserName { get; set; } /// <summary> /// 規(guī)范用戶名 /// </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類的字段大部分比較容易理解,就那個(gè)NormalizedUserName難理解一些,可以簡單認(rèn)為是UserName的大寫形式好了。
然后是角色類:
/// <summary> /// 角色 /// </summary> public class HDRole { /// <summary> /// 角色I(xiàn)D /// </summary> public string Id { get; set; } /// <summary> /// 角色名稱 /// </summary> public string Name { get; set; } }有了用戶和角色,要建立起用戶和角色的關(guān)系,就需要用戶角色類:
/// <summary> /// 用戶角色對應(yīng)關(guān)系 /// </summary> public class HDUserRole { /// <summary> /// 用戶ID /// </summary> public virtual string UserId { get; set; } /// <summary> ///角色I(xiàn)D /// </summary> public virtual string RoleId { get; set; } }這樣,最基礎(chǔ)的三個(gè)類我們就都建立起來了。
好了,以上通過一個(gè)簡單實(shí)例介紹了asp.net5中的用戶認(rèn)證與授權(quán)(1),下篇繼續(xù)跟大家介紹asp.net5中的用戶認(rèn)證與授權(quán)(2),需要的朋友之間點(diǎn)擊查看就可以了。
新聞熱點(diǎn)
疑難解答
圖片精選