国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > .NET > 正文

asp.net5中用戶認證與授權(2)

2024-07-10 13:29:28
字體:
來源:轉載
供稿:網友

ASP.NET5主要提供了兩種應用程序,其一就是ASP.NET5控制臺程序,另外一個是ASP.NET Web 應用程序。本文給大家介紹asp.net5中用戶認證與授權(2),需要的童鞋可以參考下

上篇文章給大家介紹了asp.net5中用戶認證與授權(1),基礎建立好了,緊接著就要創建對基礎類進行操作的類,也就是實現基礎類的增刪改查當然,為了使用asp.net5的認證機制,這些都是通過特定的接口來實現的。

比如,對于角色來說,角色管理要實現的接口如下:

 

 
  1. public interface IQueryableRoleStore<TRole> : IRoleStore<TRole>, IDisposable where TRole : class 
  2. IQueryable<TRole> Roles { get; } 
  3. public interface IRoleStore<TRole> : IDisposable where TRole : class 
  4. Task<IdentityResult> CreateAsync(TRole role, CancellationToken cancellationToken); 
  5. Task<IdentityResult> DeleteAsync(TRole role, CancellationToken cancellationToken); 
  6. Task<TRole> FindByIdAsync(string roleId, CancellationToken cancellationToken); 
  7. Task<TRole> FindByNameAsync(string normalizedRoleName, CancellationToken cancellationToken); 
  8. Task<string> GetNormalizedRoleNameAsync(TRole role, CancellationToken cancellationToken); 
  9. Task<string> GetRoleIdAsync(TRole role, CancellationToken cancellationToken); 
  10. Task<string> GetRoleNameAsync(TRole role, CancellationToken cancellationToken); 
  11. Task SetNormalizedRoleNameAsync(TRole role, string normalizedName, CancellationToken cancellationToken); 
  12. Task SetRoleNameAsync(TRole role, string roleName, CancellationToken cancellationToken); 
  13. Task<IdentityResult> UpdateAsync(TRole role, CancellationToken cancellationToken); 

其實,也沒什么復雜,一個是獲得所有預定義角色的列表,另一個是關于角色的增刪改查而已,代碼如下:

 

 
  1. public class HDRoleStore<TRole> : IQueryableRoleStore<TRole> 
  2. where TRole : HDRole, new() 
  3. /// <summary> 
  4. /// 存儲所有預定義的角色 
  5. /// </summary> 
  6. private readonly Dictionary<string, TRole> _roles = new Dictionary<string, TRole>(); 
  7. /// <summary> 
  8. /// 所有角色 
  9. /// </summary> 
  10. public IQueryable<TRole> Roles 
  11. get 
  12. if (_roles.Count == ) 
  13. TRole role = new TRole(); 
  14. role.Id = "admin"
  15. role.Name = "管理員"
  16. _roles.Add(role.Id, role); 
  17. role = new TRole(); 
  18. role.Id = "user"
  19. role.Name = "用戶"
  20. _roles.Add(role.Id, role); 
  21. role = new TRole(); 
  22. role.Id = "power"
  23. role.Name = "大蝦"
  24. _roles.Add(role.Id, role); 
  25. return _roles.Values.AsQueryable(); 
  26. public Task<IdentityResult> CreateAsync(TRole role, CancellationToken cancellationToken) 
  27. _roles[role.Id] = role; 
  28. return Task.FromResult(IdentityResult.Success); 
  29. public Task<IdentityResult> DeleteAsync(TRole role, CancellationToken cancellationToken) 
  30. if (role == null || !_roles.ContainsKey(role.Id)) 
  31. throw new InvalidOperationException("Unknown role"); 
  32. _roles.Remove(role.Id); 
  33. return Task.FromResult(IdentityResult.Success); 
  34. public void Dispose() 
  35. public Task<TRole> FindByIdAsync(string roleId, CancellationToken cancellationToken) 
  36. if (_roles.ContainsKey(roleId)) 
  37. return Task.FromResult(_roles[roleId]); 
  38. return Task.FromResult<TRole>(null); 
  39. public Task<TRole> FindByNameAsync(string normalizedRoleName, CancellationToken cancellationToken) 
  40. return 
  41. Task.FromResult( 
  42. Roles.SingleOrDefault(r => String.Equals(r.Name, normalizedRoleName, StringComparison.OrdinalIgnoreCase))); 
  43. public Task<string> GetNormalizedRoleNameAsync(TRole role, CancellationToken cancellationToken) 
  44. return Task.FromResult(role.Name); 
  45. public Task<string> GetRoleIdAsync(TRole role, CancellationToken cancellationToken) 
  46. return Task.FromResult(role.Id); 
  47. public Task<string> GetRoleNameAsync(TRole role, CancellationToken cancellationToken) 
  48. return Task.FromResult(role.Name); 
  49. public Task SetNormalizedRoleNameAsync(TRole role, string normalizedName, CancellationToken cancellationToken) 
  50. role.Name = normalizedName; 
  51. return Task.FromResult(); 
  52. public Task SetRoleNameAsync(TRole role, string roleName, CancellationToken cancellationToken) 
  53. role.Name = roleName; 
  54. return Task.FromResult(); 
  55. public Task<IdentityResult> UpdateAsync(TRole role, CancellationToken cancellationToken) 
  56. _roles[role.Id] = role; 
  57. return Task.FromResult(IdentityResult.Success); 

可以看到,在第12行,我們的方法里直接寫死了角色列表,如果相結合具體的項目的話,我相信葉良辰有一百種方法從各種數據庫、配置文件等取得角色列表,而其他程序代碼卻基本不用更改。

當然,asp.net5自帶的默認實現實現了很多其他接口,這里為了最簡單起見,只實現了最基本的。

以上就是給大家介紹的asp.net5中用戶認證與授權(2),希望大家喜歡。后續還會持續更新,請大家持續關注本站。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 英山县| 庄河市| 天门市| 峡江县| 夏河县| 马山县| 郧西县| 新乡县| 广宗县| 始兴县| 永和县| 衡东县| 改则县| 镇远县| 喜德县| 渝北区| 东方市| 信阳市| 漳浦县| 田阳县| 灵寿县| 柘城县| 和平县| 周口市| 砚山县| 阿尔山市| 通许县| 库尔勒市| 五指山市| 两当县| 怀安县| 德钦县| 安吉县| 东海县| 铁岭县| 镇坪县| 栾城县| 光泽县| 巴彦县| 连江县| 涡阳县|