Asp.net core 学习笔记 (授权)
更新 : 2018-11-24
记入一些思考
asp.net core + identity 的权限是这样的
user = 1 个登入账号
role = 1 个角色 (类似于公司里的一个职位)
claim = 令牌 (类似于古代,见令令牌如见皇帝或者将军)
一般上我们会把权限建立在 Page, 操作, 资源上.
这里我只说操作, 操作指的是一个 api 接口, 一个 controller 或是一个 action
identity 给了我们一个 policy 的概念
一个 policy 就是说,一个对令牌的判断.
比如,如果一个 user 访问用于某几个令牌,就表示它可以执行.
所以 controller 和 action 我们就会写很多对令牌的要求.
常见的是问,请问你有没有 "admin" 这个令牌丫 ?
也可以是, 请问你有没有 "可转账" 这个令牌丫 ?
那么,令牌这么多,要怎样管理呢 ?
我们知道一间公司一定会有很多工作,要分工。
通常我们把工作分组成任务 (task).
比如,管理广告,管理 live chat, 管理网页内容。等等
这些都是任务。
然后我们需要把任务交给某些人做,人来人往我们得找到一个固定的依赖,所以就有了职位这个概念。
所以任务最后都分给了某些职位.
在 identity 管理中,如果我们的职位很少,而且任务没有重叠,我们可以把 claim 当做 role 来用。
当职位变得多, 任务又有重叠 (同样任务,但是 2 个职位都可以做). 我们可以把 claim 设计当 task 来用。
如果真的要分到很细的话,我们可以把每个 action 定义为一个 cliam, 然后设计一个 task 的概念
1 个任务需要调用多个 action, 所以一个 task 需要多个 claim
然后 1 个 role 可以拥有多个 task (一个职位可以拥有多个 task 符合管理)
最后一个 user 可以有多个 roles, 或者直接拥有某些 task
要有 task 的概念,需要对 identity 扩展一些些.
另外说说授权。
一般上一个公司都会有一个 HR 部分.
只有 HR 有能力处理 user account.
比如给予权限等等。但是有一点不要混淆。在系统上开来,HR 的权限很大,他可以 disable 一个 CEO 的账号。
但是其实他只是任命执行操作而已。就好像是一个 sales man 可以创建订单,但前提是客户要购买东西。他并不可以自己提客户下单一样。
HR 有可能会因为区域很大,而分出好几个区。
account 应该是属于某个区的,也就是说 2 个 HR 并不可以互相访问对方的人事。
参考 :
https://www.cnblogs.com/RainingNight/p/authorization-in-asp-net-core.html
https://www.cnblogs.com/RainingNight/p/authorize-how-to-work-in-asp-net-core.html
https://www.cnblogs.com/RainingNight/p/dynamic-authorization-in-asp-net-core.html
这 3 篇基本上已经讲完了.
对比 .net 4.x 主要是多了 policy, requirement, authoService
一个 policy 表示多个 requirement
一个 requirement 表示多种断言, 比如有没有 claim, 有没有 role 等等
同一个 requirement 还能有不同的验证逻辑.
policy 还有一个合并与其它 policy 的能力. 非常灵活.
Asp.net core 学习笔记 (授权)的更多相关文章
- Asp.Net Core学习笔记:入门篇
Asp.Net Core 学习 基于.Net Core 2.2版本的学习笔记. 常识 像Django那样自动检查代码更新,自动重载服务器(太方便了) dotnet watch run 托管设置 设置项 ...
- ASP.NET Core 学习笔记 第一篇 ASP.NET Core初探
前言 因为工作原因博客断断续续更新,其实在很早以前就有想法做一套关于ASP.NET CORE整体学习度路线,整体来说国内的环境的.NET生态环境还是相对比较严峻的,但是干一行爱一行,还是希望更多人加入 ...
- Asp.net core 学习笔记 ( identity server 4 JWT Part )
更新 : id4 使用这个 DbContext 哦 dotnet ef migrations add identity-server-init --context PersistedGrantDbCo ...
- Asp.net Core学习笔记
之前记在github上的,现在搬运过来 变化还是很大的,感觉和Nodejs有点类似,比如中间件的使用 ,努力学习ing... 优点 不依赖IIS 开源和跨平台 中间件支持 性能优化 无所不在的依赖注入 ...
- ASP.NET Core 学习笔记 第三篇 依赖注入框架的使用
前言 首先感谢小可爱门的支持,写了这个系列的第二篇后,得到了好多人的鼓励,也更加坚定我把这个系列写完的决心,也能更好的督促自己的学习,分享自己的学习成果.还记得上篇文章中最后提及到,假如服务越来越多怎 ...
- ASP.NET Core 学习笔记 第四篇 ASP.NET Core 中的配置
前言 说道配置文件,基本大多数软件为了扩展性.灵活性都会涉及到配置文件,比如之前常见的app.config和web.config.然后再说.NET Core,很多都发生了变化.总体的来说技术在进步,新 ...
- ASP.NET Core 学习笔记 第五篇 ASP.NET Core 中的选项
前言 还记得上一篇文章中所说的配置吗?本篇文章算是上一篇的延续吧.在 .NET Core 中读取配置文件大多数会为配置选项绑定一个POCO(Plain Old CLR Object)对象,并通过依赖注 ...
- Asp.net core 学习笔记 ( Data protection )
参考 : http://www.cnblogs.com/xishuai/p/aspnet-5-identity-part-one.html http://cnblogs.com/xishuai/p/a ...
- Asp.net core 学习笔记 SignalR
refer : https://kimsereyblog.blogspot.com/2018/07/signalr-with-asp-net-core.html https://github.com/ ...
随机推荐
- MySql数据库表操作(二)
一.增加表记录: insert [into] tab_name (field1,field2....) values (values1,values2....) , (values1,values2. ...
- 详解设计模式之工厂模式(简单工厂+工厂方法+抽象工厂) v阅读目录
1楼留头头大神:http://www.cnblogs.com/toutou/p/4899388.html v阅读目录 v写在前面 v简单工厂模式 v工厂方法模式 v抽象工厂模式 v博客总结 v博客 ...
- Codeforces Round 500 (Div 2) Solution
从这里开始 题目地址 瞎扯 Problem A Piles With Stones Problem B And Problem C Photo of The Sky Problem D Chemica ...
- ODAC(V9.5.15) 学习笔记(二)控件列表
ODAC的控件有26个,简单介绍如下: TOraSession 管理Oracle的连接 TOraQuery 使用SQL进行数据获取,自动将更新提交数据库 TSmartQuery 在处理字 ...
- 【问题解决:时区】连接MySQL时错误The server time zone value 'Öйú±ê׼ʱ¼ä' is unrecognized or represents more than one time zone
问题描述: MySQL升级到8.0.11之后连接数据库报错: Your login attempt was not successful, try again. Reason: Could not g ...
- Run tomcat on port 80 not 8080
How to run Tomcat on Port 80 A standard Tomcat installation starts the webserver on port 8080 – whic ...
- 记一次oracle创建一个新数据库,并导入正式环境数据库备份的dmp包过程
背景:正式环境oracle数据库定时用exp备份一个dmp包,现在打算在一台机器上创建一个新数据库,并导入这个dmp包. 1.创建数据库 开始 -> 所有程序 -> Oracle -> ...
- 论文笔记:ReNet: A Recurrent Neural Network Based Alternative to Convolutional Networks
ReNet: A Recurrent Neural Network Based Alternative to Convolutional Networks2018-03-05 11:13:05 ...
- 【ASP.Net】publish asp.net to local IIS
做web项目难免要将项目部署, 要么部署在azure上,要么部署在本地, 使用IIS去host. 部署步骤很简单, 1. vs打开你的web项目, 项目名上面右键选择publish 2. 在弹出的pu ...
- Codeforces 884C.Bertown Subway ----判环,思路
The construction of subway in Bertown is almost finished! The President of Berland will visit this c ...