Asp.Net Core 项目实战之权限管理系统(2) 功能及实体设计
0 Asp.Net Core 项目实战之权限管理系统(0) 无中生有
1 Asp.Net Core 项目实战之权限管理系统(1) 使用AdminLTE搭建前端
2 Asp.Net Core 项目实战之权限管理系统(2) 功能及实体设计
3 Asp.Net Core 项目实战之权限管理系统(3) 通过EntityFramework Core使用PostgreSQL
4 Asp.Net Core 项目实战之权限管理系统(4) 依赖注入、仓储、服务的多项目分层实现
5 Asp.Net Core 项目实战之权限管理系统(5) 用户登录
6 Asp.Net Core 项目实战之权限管理系统(6) 功能管理
7 Asp.Net Core 项目实战之权限管理系统(7) 组织机构、角色、用户权限
8 Asp.Net Core 项目实战之权限管理系统(8) 功能菜单的动态加载
0 功能设计
实现一个最简单最基本的权限管理系统,主要包括组织机构管理、角色管理、用户管理、功能管理、角色授权。
1 功能管理包括功能菜单、功能页面按钮两个层次。
2 功能授权针对角色进行。
3 每个用户可以拥有多个角色,用户的实际权限根据多角色求取并集得到。

0.0 组织机构管理
实现组织机构(或者叫部门)的相关管理操作,组织机构主要包括部门名称、部门编码、部门负责人、联系电话、备注、上级部门、创建人、创建电话等属性。
组织机构管理包括新增顶级、新增(新增当前选中部门的下级)、编辑、删除等功能。
考虑到组织机构、用户等权限管理相关的基本实体经常会在业务数据中使用,比如要记录业务数据的部门、创建人等信息(以外键形式记录DepartmentId、UserId等),为避免组织机构、用户等信息删除后,业务数据出现找不到相关联的对应实体,即为了保证数据的完整性,对权限管理设计到的实体统一做软删除(采用一个删除标记的逻辑删除,非物理删除)处理。

0.1 功能管理
系统功能的统一维护,这里进行深一级的控制,管理到各个功能界面业务逻辑操作按钮的级别,以树形格式展示,其中以一个标记属性标识该实体是一个导航菜单,还是菜单下包含的一个操作按钮。以上述组织机构管理为例,功能管理中存在一个名称为组织机构管理的项,其下包括新增组织机构、新增顶级组织机构、编辑组织机构、删除组织机构等子级。
功能管理实体主要包含父级、序号、名称、编码、地址、类型(导航菜单、功能按钮)、图标、备注等属性。
功能管理主要包括,新增顶级、新增、编辑、删除等功能。
0.2 角色管理
角色是一组具有相同功能用户的一个抽象,权限管理系统将具体功能的授权赋予角色,实现针对角色的权限管理。
角色实体主要包括角色编码、角色名称、创建人、创建时间、备注等属性。
角色管理主要包括新增角色、编辑角色、删除角色、角色授权等功能。
角色授权是为当前选中的角色授予功能导航菜单及功能页面按钮的相关权限的操作。用户登录后,会根据当前用户获取所属角色,然后取该用户所有角色的功能并集,确定功能菜单及相关功能界面按钮的是否可用状态。
0.3 用户管理
用户实体主要包括用户名、密码、用户姓名、邮箱、手机、备注、创建人、创建时间、上次登录时间、登录次数、所属部门等属性。
用户管理主要包括新增用户、编辑用户、删除用户、重置密码等功能。
新增及编辑用户时,需要首先选择用户所属部门,同时必须为当前用户分配对应的角色。

1 实体设计
根据上述功能设计,对实体类进行如下设计。对所有实体建立一个泛型基类Entity<TPrimaryKey>,默认的主键类型为Guid的实体基类Entity,权限管理系统的所有实体都从Entity基类继承,如果想要实现其他类型主键,新建的实体从Entity<TPrimaryKey>泛型基类继承即可。
/// <summary>
/// 泛型实体基类
/// </summary>
/// <typeparam name="TPrimaryKey">主键类型</typeparam>
public abstract class Entity<TPrimaryKey>
{
/// <summary>
/// 主键
/// </summary>
public virtual TPrimaryKey Id { get; set; }
} /// <summary>
/// 定义默认主键类型为Guid的实体基类
/// </summary>
public abstract class Entity : Entity<Guid>
{ }
1.0 组织机构实体
/// <summary>
/// 部门实体
/// </summary>
public class Department : Entity
{
/// <summary>
/// 部门名称
/// </summary>
public string Name { get; set; } /// <summary>
/// 部门编号
/// </summary>
public string Code { get; set; } /// <summary>
/// 部门负责人
/// </summary>
public string Manager { get; set; } /// <summary>
/// 联系电话
/// </summary>
public string ContactNumber { get; set; } /// <summary>
/// 备注
/// </summary>
public string Remarks { get; set; } /// <summary>
/// 父级部门ID
/// </summary>
public Guid ParentId { get; set; } /// <summary>
/// 创建人
/// </summary>
public Guid CreateUserId { get; set; } /// <summary>
/// 创建时间
/// </summary>
public DateTime? CreateTime { get; set; } /// <summary>
/// 是否已删除
/// </summary>
public int IsDeleted { get; set; } /// <summary>
/// 包含用户
/// </summary>
public virtual ICollection<User> Users { get; set; } /// <summary>
/// 创建人信息
/// </summary>
public virtual User CreateUser { get; set; }
}
1.1 功能实体
/// <summary>
/// 功能菜单实体
/// </summary>
public class Menu : Entity
{
/// <summary>
/// 父级ID
/// </summary>
public Guid ParentId { get; set; } /// <summary>
/// 序号
/// </summary>
public int SerialNumber { get; set; } /// <summary>
/// 菜单名称
/// </summary>
public string Name { get; set; } /// <summary>
/// 菜单编码
/// </summary>
public string Code { get; set; } /// <summary>
/// 菜单地址
/// </summary>
public string Url { get; set; } /// <summary>
/// 类型:0导航菜单;1操作按钮。
/// </summary>
public int Type { get; set; } /// <summary>
/// 菜单图标
/// </summary>
public string Icon { get; set; } /// <summary>
/// 菜单备注
/// </summary>
public string Remarks { get; set; }
}
1.2 角色实体
public class Role : Entity
{
public string Code { get; set; } public string Name { get; set; } public Guid CreateUserId { get; set; } public DateTime? CreateTime { get; set; } public string Remarks { get; set; } public virtual User CreateUser { get; set; } public virtual ICollection<User> Users { get; set; } public virtual ICollection<Menu> Menus { get; set; }
}
1.3 用户实体
public class User : Entity
{
/// <summary>
/// 用户名
/// </summary>
public string UserName { get; set; } /// <summary>
/// 密码
/// </summary>
public string Password { get; set; } /// <summary>
/// 用户姓名
/// </summary>
public string Name { get; set; } /// <summary>
/// 邮箱地址
/// </summary>
public string EMail { get; set; } /// <summary>
/// 手机号
/// </summary>
public string MobileNumber { get; set; } /// <summary>
/// 备注
/// </summary>
public string Remarks { get; set; } /// <summary>
/// 创建人
/// </summary>
public Guid CreateUserId { get; set; } /// <summary>
/// 创建时间
/// </summary>
public DateTime? CreateTime { get; set; } /// <summary>
/// 上次登录时间
/// </summary>
public DateTime LastLoginTime { get; set; } /// <summary>
/// 登录次数
/// </summary>
public int LoginTimes { get; set; } /// <summary>
/// 部门ID
/// </summary>
public Guid DeptmentId { get; set; } /// <summary>
/// 是否已删除
/// </summary>
public int IsDeleted { get; set; } /// <summary>
/// 所属部门实体
/// </summary>
public virtual Department Department { get; set; } /// <summary>
/// 创建人实体
/// </summary> public virtual User CreateUser { get; set; } /// <summary>
/// 角色集合
/// </summary> public virtual ICollection<Role> Roles { get; set; }
}
2 总结
本次主要针对一个最简单的权限管理系统进行了功能及实体的设计,项目中新增了相关实体类文件,目前解决方案结构如下下所示:

接下来会介绍如何在Asp.Net Core中通过EntityFramework Core使用PostgreSQL数据库。
Asp.Net Core 项目实战之权限管理系统(2) 功能及实体设计的更多相关文章
- Asp.Net Core 项目实战之权限管理系统(4) 依赖注入、仓储、服务的多项目分层实现
0 Asp.Net Core 项目实战之权限管理系统(0) 无中生有 1 Asp.Net Core 项目实战之权限管理系统(1) 使用AdminLTE搭建前端 2 Asp.Net Core 项目实战之 ...
- Asp.Net Core 项目实战之权限管理系统(0) 无中生有
0 Asp.Net Core 项目实战之权限管理系统(0) 无中生有 1 Asp.Net Core 项目实战之权限管理系统(1) 使用AdminLTE搭建前端 2 Asp.Net Core 项目实战之 ...
- Asp.Net Core 项目实战之权限管理系统(1) 使用AdminLTE搭建前端
0 Asp.Net Core 项目实战之权限管理系统(0) 无中生有 1 Asp.Net Core 项目实战之权限管理系统(1) 使用AdminLTE搭建前端 2 Asp.Net Core 项目实战之 ...
- Asp.Net Core 项目实战之权限管理系统(3) 通过EntityFramework Core使用PostgreSQL
0 Asp.Net Core 项目实战之权限管理系统(0) 无中生有 1 Asp.Net Core 项目实战之权限管理系统(1) 使用AdminLTE搭建前端 2 Asp.Net Core 项目实战之 ...
- Asp.Net Core 项目实战之权限管理系统(5) 用户登录
0 Asp.Net Core 项目实战之权限管理系统(0) 无中生有 1 Asp.Net Core 项目实战之权限管理系统(1) 使用AdminLTE搭建前端 2 Asp.Net Core 项目实战之 ...
- Asp.Net Core 项目实战之权限管理系统(6) 功能管理
0 Asp.Net Core 项目实战之权限管理系统(0) 无中生有 1 Asp.Net Core 项目实战之权限管理系统(1) 使用AdminLTE搭建前端 2 Asp.Net Core 项目实战之 ...
- Asp.Net Core 项目实战之权限管理系统(7) 组织机构、角色、用户权限
0 Asp.Net Core 项目实战之权限管理系统(0) 无中生有 1 Asp.Net Core 项目实战之权限管理系统(1) 使用AdminLTE搭建前端 2 Asp.Net Core 项目实战之 ...
- Asp.Net Core 项目实战之权限管理系统(8) 功能菜单的动态加载
0 Asp.Net Core 项目实战之权限管理系统(0) 无中生有 1 Asp.Net Core 项目实战之权限管理系统(1) 使用AdminLTE搭建前端 2 Asp.Net Core 项目实战之 ...
- Net Core 项目实战之权限管理系统(0)
0 前言 Net Core 项目实战之权限管理系统(0) 无中生有 0 http://www.cnblogs.com/fonour/p/5848933.html 学习的最好方法就是动手去做,这里以 ...
随机推荐
- Centos 下 mysql root 密码重置
重置mysql密码的方法有很多,官网也提供了很方便的快捷操作办法,可参考资料 resetting permissions .本文重置密码的具体步骤如下: 一.停止MySQL(如果处于运行状态) #se ...
- CRL快速开发框架系列教程十(导出对象结构)
本系列目录 CRL快速开发框架系列教程一(Code First数据表不需再关心) CRL快速开发框架系列教程二(基于Lambda表达式查询) CRL快速开发框架系列教程三(更新数据) CRL快速开发框 ...
- hadoop2.7之Mapper/reducer源码分析
一切从示例程序开始: 示例程序 Hadoop2.7 提供的示例程序WordCount.java package org.apache.hadoop.examples; import java.io.I ...
- Python(九) Python 操作 MySQL 之 pysql 与 SQLAchemy
本文针对 Python 操作 MySQL 主要使用的两种方式讲解: 原生模块 pymsql ORM框架 SQLAchemy 本章内容: pymsql 执行 sql 增\删\改\查 语句 pymsql ...
- golang sync.WaitGroup bug
注意,这个结构体,要是想在函数之间传来传去的话,必须要使用指针....... 这个结构体里没有 指针,这个类型可以说没有“引用特性”. 被坑了一晚上.特此记录.
- docker4dotnet #4 使用Azure云存储构建高速 Docker registry
使用Docker来构建应用程序最常见的操作就是 docker run 或者 docker pull了,但是由于众所周知的原因,在国内想要高速稳定的获取docker hub上面的资源并不是件容易的事情, ...
- μCos-ii学习笔记1_概述
一.μCos-ii _概述 网上关于μCosii的文章多不胜数,本人学习的过程中也参考了很多人的理解和想法,看的是卢有亮老师的<嵌入式实时操作系统-μC/OS原理与实践>(第2版),同时也 ...
- Zephyr OS 简介
最新发布的开源 Zephyr Project™(Zephyr 项目)是一款小型且可伸缩的实时操作系统,尤其适用于资源受限的系统,可支持多种架构:该系统高度开源,对于开发人员社区完全开放,开发人员可根据 ...
- OpenSUSE下编译安装OpenFoam
在不是Ubuntu系统下安装OpenFoam,需要采用编译安装的方式.以下以OpenSuSE为例进行编译安装. 1 软件包准备 需要下载两个程序包: OpenFOAM-4.x-version-4.1. ...
- Android快乐贪吃蛇游戏实战项目开发教程-01项目概述与目录
一.项目简介 贪吃蛇是一个很经典的游戏,也很适合用来学习.本教程将和大家一起做一个Android版的贪吃蛇游戏. 我已经将做好的案例上传到了应用宝,无病毒.无广告,大家可以放心下载下来把玩一下.应用宝 ...