欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

asp.net5中的用户认证与授权(1)

程序员文章站 2024-02-13 12:56:28
就在最近一段时间,微软又有大动作了,在ide方面除了给我们发布了viausl studio 2013 社区版还发布了全新的visual studio 2015 previe...

就在最近一段时间,微软又有大动作了,在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),下篇继续跟大家介绍需要的朋友之间点击查看就可以了。