安全-访问控制器

类java.security.AccessController提供了一个默认的安全策略执行机制,它使用栈检查来决定潜在不安全的操作是否被允许。

这个访问控制器不能被实例化,它不是一个对象。而是集合在单个类中的多个静态方法。

AccessController.checkPermission() 决定一个特定的操作能否被允许。

这个方法将指向Permission对象的引用作为唯一的参数,并且返回void。

如果AccessController确定这个操作被允许,将简单的返回;否则异常中止。


AccessController.checkPermission() 实现的基本算法决定了调用栈中的每个帧是否有权执行潜在不安全的操作。

每一个栈帧代表了由当前线程调用的某个方法,每一个方法是在某个类中定义的,每一个类属于某个保护域,每个保护域包含一些权限。为了使传递给AccessController.checkPermission() 的Permission对象所代表的的操作被允许,这个AccessController的基本算法要求,和调用栈上的每个帧相关连的权限必须包含或隐含传给checkPermission()的Permission对象


AccessController.checkPermission() 自顶向下检查栈,只要他遇到一个没有权限栈帧,它将抛出异常。

通过抛出异常,AccessController指明这个操作不能被允许。

相反,如果checkPermission() 方法到达栈的底部,也没有遇到这种栈帧情况,checkPermission() 将简单的返回。

通过简单返回而不是抛出异常,AccessController指明这个操作可以被允许。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值