首页 > 编程 > .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),希望大家喜欢。后续还会持续更新,请大家持续关注本站。

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表