XACML-PolicySet与request结构简介
本文由@呆代待殆原创,转载请注明出处。
一、PolicySet的结构

PolicySet 的基本嵌套结构如上图所示,下面让我们一个一个来说明。
PolicySet:XACML策略架构的顶层元素,由PolicySetId、Version、PolicyCombiningAlgld、Target、Policy、ObligationExpressions、AdviceExpressions以及其他PolicySet组成
PolicySetId:PolicySet的唯一标识用来确保PAP和PDP没有两个相同的标识,相当于人的身份证号码。
Version:PolicySet的版本号
PolicyCombiningAlgld:PolicySet所采用的组合算法,policySet会包含多个policies或者PolicySets,所以有时候一个请求会返回多个结果(Permit,Deny,NotApplicable,Indeterminate)所以需要有能调和这种情况的机制,于是提 出了combining Algorithms,举一个常用的算法当例子。
Deny-overrides:
1, 如果有一个Deny出现,则最终结果为Deny。
2, 若上述不满足,若有一个Indeterminate{DP} 则最终为Indeterminate{DP}。
3, 若上述都不满足,若有一个Indeterminate{D},且其他都为Indeterminate{P}或Permit,则结果为Indeterminate{DP}。
4, 若上述都不满足,若有一个是Indeterminate{D},则结果为Indeterminate{D}。
5, 若上述都不满足,若有一个是Permit,则结果为Permit。
6, 若上述都不满足,若有一个是Indeterminate{P},这结果是Indeterminate{P}。
7, 若上述都不满足,则结果是NotApplicable。
ObligationExpressions与Advicexpressions:他们是可选的,可以是rule,policy或者policySet的组成部分,一个obligation是一个对PEP的指令,必须在access request被(拒绝/接受)之(前/后)被执行,用来执行一些额外的操作(如维护访问记录等),advice和obligation的唯一区别是advice可以被PEP忽略。
Target:定义了一组适用于PolicySet的request,当发来的request与target匹配时,说明PolicySet适用于request,Target可以由PolicySet的创建者声名也可以从policy元素用到的<Target>元素计算,包括4个基本元素,即资源(Resource)、主体(Subject)、动作(Actions)和环境(Environment)。
subject attributes:代表这个请求的发起者。
resource attributes:要访问的资源。
action attributes:要对资源执行的动作。
environment attribute:取决于可用的system sensor,可能包括系统时间、威胁等级threat level等等。
Policy:Policy元素是能提交PDP的最小实体,主要元素有PolicyId、Version、Target、Rule、ObligationExpressions、AdviceExpressions、CombinedDesicion。
PolicyId:Policy的Id。它是PAP的依赖确保PDP只可见一个持有相同Id的Policy。
Version:Policy的版本号。
RuleCombiningAlgld:规则组合算法,与PolicyCombiningAlgld类似理解即可。
Target:定义了一个Policy或一个决定请求集合的适用性。Target能够被Policy元素的构造者声明,也可能由被引用Rule元素中的target元素作交集或并集计算得到。
Rule:Rule元素应当定义在policy中的单个规则里。这个元素的主要组件分别是RuleId、Target、Condition、ObligationExpressions和AdviceExpressions以及Effect。
RuleId:验证所属规则的标识。
Effect:Rule被满足时返回的结果,可以取值Permit或者Deny。
Condition:Rule里需要被检验的断言。
标准定义如下,其中有些元素上面并没有提到:

二、request元素的结构
Request 元素的结构:主要包括ReturnPolicyIdList、CombinedDecision、Attributes
ReturnPolicyIdList:这个属性用于请求,PDP返回了一个完全可应用policy和policy set的列表,这些policy和policy set在决定中被用于作为一个决定回应。
CombinedDecision:这个属性提出通过PDP将多个决定合并成为一个单独决定的请求。
Attributes:通常有多个,用来表示请求属性的相关信息,一般包括subject、resource、action、environment或者其他access request。
标准定义如下,有些元素上面并没有提到:

本文参考:
[1] http://docs.oasis-open.org/xacml/3.0/xacml-3.0-core-spec-os-en.html#_Toc325047147
[2] Ferraiolo, David, Chandramouli, Ramaswamy, Kuhn, Rick, et al. Extensible Access Control Markup Language (XACML) and Next Generation Access Control (NGAC)[C]// ACM International Workshop on Attribute Based Access Control. ACM, 2016.
XACML-PolicySet与request结构简介的更多相关文章
- 老李分享:jvm结构简介 1
老李分享:jvm结构简介 poptest是国内唯一一家培养测试开发工程师的培训机构,以学员能胜任自动化测试,性能测试,测试工具开发等工作为目标.如果对课程感兴趣,请大家咨询qq:9088214 ...
- Laravel 文件夹结构简介
表 1.1:Laravel 文件夹结构简介 文件夹名称 简介 app 应用程序的业务逻辑代码存放文件夹 app/Console 存放自定义 Artisian 命令文件 app/Http/Control ...
- .NetCore微服务Surging新手傻瓜式 入门教程 学习日志---结构简介(二)
原文:.NetCore微服务Surging新手傻瓜式 入门教程 学习日志---结构简介(二) 先上项目解决方案图: 以上可以看出项目结构可以划分为4大块,1是surging的核心底层,2,3,4都可以 ...
- Intent 意图 结构 简介
Intent简介 官方解释: An intent is an abstract description of an operation操作 to be performed展示.表演. It can b ...
- 6-MVC结构简介
一.javeEE的项目结构层次:MVC1.Model:模型层(DAO+业务层) 2.View:视图层 jsp3.Control:控制层 servlet 二.分层的原则:1.层与层之间松耦合,层内保持高 ...
- Nodejs事件引擎libuv源码剖析之:请求(request)结构的设计剖析
声明:本文为原创博文,转载请注明出处. 在libuv中,请求(request)代表一个用户向libuv发出的指令,比如uv_connect_s就表示一个tcp的连接请求.uv_work ...
- AngularJS结构简介
AngularJS是MVC架构,M是C里面的属性-值,C是js的class,V是DOM 各个关键特性的结构如下图所示: http://my.oschina.net/tommyfok/blog/2970 ...
- Android 工程目录结构简介
一般来说,一个Android工程的目录结构如下图所示. 1:src JAVA源代码都放在这里面. 2:gen 编译器自动生成的一些JAVA代码 3:Android 4.2 Android平台(本工程用 ...
- C++结构简介
结构是一种比数组更灵活的数据格式,因为同一个结构可以储存多种类型的数据,这使得能够将篮球运动员的信息放在一个结构中,从而将数据的表示的合并到一起. 结构也是C++堡垒OOP(类)的基石.结构是用户定义 ...
随机推荐
- Dagger2学习资源
文章 Jack Wharton关于Dagger的幻灯片 代码 用Dagger2改写Jack Wharton的U+2020 我自己写的,包含了dagger2和单元测试 chiuki写的,包含了dagge ...
- 从今天开始每天刷一题,并写在这里 分类: ACM 2015-06-16 23:52 14人阅读 评论(0) 收藏
开始什么题都可以,后面会加大难度. 每天! 如果有一天有特殊情况,也要来这里打卡,并说明原因,并在其他某一天补上! 版权声明:本文为博主原创文章,未经博主允许不得转载.
- c语言中用宏定义一个常量,数字后面带个U, L, F的含义
转: c语言中数字后面带个U是什么意思?#define F_CPU 12000000U答:U表示该常数用无符号整型方式存储,相当于unsigned int;L表示该常数用长整型方式存储,相当于long ...
- hdu 1155 Bungee Jumping
http://acm.hdu.edu.cn/showproblem.php?pid=1155 Bungee Jumping Time Limit: 2000/1000 MS (Java/Others) ...
- codeforces 659A Round House
A. Round House time limit per test 1 second memory limit per test 256 megabytes input standard input ...
- ThinkPad X220i 安装 Mac OSX
联想笔记本是安装黑苹果相对比较容易的~~ ThinkPad X220i配置 型号:ThinkPad X220i CPU: i3 内存:4G 显卡:HD3000 其他: X220i的通用硬件 确认以 ...
- 埃氏筛法(快速筛选n以内素数的个数)
给你一个数n,请问n以内有多少个素数?(n <= 10e7) 一般来说,要是对一个整数进行素数判断,首先想到的是写个函数判断是否为素数,然后调用这个函数,时间复杂度为O(n^(½)),但是要求n ...
- Flipping Parentheses(CSU1542 线段树)
http://acm.csu.edu.cn/OnlineJudge/problem.php?id=1542 赛后发现这套题是2014东京区域赛的题目,看了排名才发现自己有多low = =! 题目大意 ...
- CCF 201312-4 有趣的数 (数位DP, 状压DP, 组合数学+暴力枚举, 推公式, 矩阵快速幂)
问题描述 我们把一个数称为有趣的,当且仅当: 1. 它的数字只包含0, 1, 2, 3,且这四个数字都出现过至少一次. 2. 所有的0都出现在所有的1之前,而所有的2都出现在所有的3之前. 3. 最高 ...
- HDU 2437 Jerboas (剪枝搜索)
题意:给定一幅图,图上有两种点T,P.......一只跳鼠在一个T点作为起始点,它想通过图上的路到达某个P点,P点满足如下要求: (1).到达P点的途中路径权值为k的倍数 (2).尽量让路径权值取最小 ...