- 1、本文档共3页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
根据以前的几篇文章我们知道,Java 2 平台安全体系结构背后的基本原理可以总结如下:一个系统级的安全策略定义了按以保护域(protection domains.)方式组织的执行代码的访问权限(按照应用程序的需要)。安全策略用于访问控制检查,这是由 JVM 在运行时执行的。在 Java 2 平台中,所有的代码,不管它是本地代码还是远程代码,都可以由策略来控制,此基础上构建的 Java 2 平台安全策略设计为根据 ProtectionDomain 授权访问权限,而不是向单个的一段运行代码授权这种权限。因此,每一个类或者对象“属于”一个 ProtectionDomain ,安全策略对这个保护域授予了某种访问权限。一个特定的 ProtectionDomain 封装了一组类(例如,所有从特定位置上装载、并用特定密钥签名的所有类),它们的实例将会授予同样的一组权限。保护域和代码源显然,一定要能惟一地标识一段运行代码以保证它的访问权限没有冲突。运行代码的惟一标识属性共有两项:代码的来源(代码装载到内存所用的 URL)和代码的 signer 实体(由对应于运行代码的数字签名的一组公共密钥指定)。这两种特性的组合成运行代码的 CodeSource 。现在可以提供 ProtectionDomain 的更严格定义了: ProtectionDomain 是一组 CodeSource 及其访问权限。Java 运行时通过名为 java.security.Policy 的类(的具体扩展)设置 ProtectionDomain 与授予它的权限之间的映射。这个类的默认扩展是 vider.PolicyFile(参考jre下的java.security文件) 。它 从一个文件中获得 CodeSource (由位置 URL 和 signer 标识别名)与授予它的权限之间的映射。可以通过环境变量 java.security.policy 将这个文件的位置作为输入提供给 JVM。 Policy 类提供了一个名为 getPermissions() 的方法,可以调用它以获得授予特定 CodeSource 的一组权限。一个类与 其 ProtectionDomain 之间的映射是在类第一次装载时由一个名为 SecureClassLoader 的特殊类装载设置的。在 Java 2 平台 SDK 1.4 中, ProtectionDomain 可以同时封装(通过其构造函数传递的)静态权限和动态权限,以前版本权限必须在构建时就已经知道。运行时访问检查由一个名为 SecurityManager 的类负责实施系统安全策略。在默认情况下不安装安全管理器,必须通过一个在启动时传递给 JVM 的、名为 java.security.manager 的环境变量显式地指定。任何应用程序都可找到安装的 SecurityManager 并调用它相应的 checkXXX 方法。如果所要求的权限在给定运行时上下文中是授予的,那么调用将无声地返回。如果权限没有授予,那么将抛出一个 java.security.AccessControlException 。Java 2 平台安全体系结构通过引入一个名为 AccessController ,对 SecurityManager 类进行的所有 checkXXX 方法调用都解释为相应的 Permission 对象,并将它作为输入参数传递给 AccessController 类的 checkPermission() 方法访问检查方案权限的算法是要计算所有权限的交集,确定权限集的交集的算法是在 AccessController 类的 checkPermission 方法中间接实现的,属于能力更低的域的类不能通过调用属于能力更高的域的类而变得更强大,而属于能力更高的域中的类会在调用能力更低的类时损失其能力Policy File Syntax学习时参照jrelibsecurityjava.policy文件一个Policy文件实质上是一个记录列表,它可能含有一个“keystore”记录,以及含有零个或多个“grant”记录。其格式如下:
keystore?some_keystore_url,?keystore_type,?keystore_provider;keystorePasswordURL?some_password_url;
“keystore”是一个私有密钥(private keys)数据库和相应的数字签名,例如X.509证书。Policy文件中可能只有一条keystore记录(也可能不含有该记录),它可以出现在文件中grant记录以外的任何地方。Policy配置文件中指定的keystore
您可能关注的文档
- Jackson框架使用指南.docx
- java.io包中的File类.doc
- Java07类的高级特性.doc
- JavaAnnotation使用大全.doc
- JavaAnnotation详解.doc
- javac编译找不到符号.doc
- javajar命令的使用.doc
- JAVAJPAJPA学习手册.doc
- javajspjavascript中如何实现将统计表格保存成excel文件.doc
- javamail如何读取回执信息.docx
- 地理-安徽省天一大联考2024-2025学年(下)2025届高三3月调研考试试题和答案.pdf
- 数学-安徽省天一大联考2024-2025学年(下)2025届高三3月调研考试试题和答案.pdf
- 政治-安徽省天一大联考2024-2025学年(下)2025届高三3月调研考试试题和答案.docx
- AIoT+5G智慧社区实践(.pptx
- 历史-安徽省天一大联考2024-2025学年(下)2025届高三3月调研考试试题和答案.pdf
- 2025年货节阿里妈妈行业经营趋势报告.pptx
- 英语-安徽省天一大联考2024-2025学年(下)2025届高三3月调研考试试题和答案.pdf
- 数字家庭2025白皮书.pptx
- 化学-安徽省天一大联考2024-2025学年(下)2025届高三3月调研考试试题和答案.docx
- 物理-安徽省天一大联考2024-2025学年(下)2025届高三3月调研考试试题和答案.docx
文档评论(0)