


下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、-众所周知,Java语言具有完善的安全框架,从编程语言,编译器、解释程序到Java虚拟机,都能确保Java系统不被无效的代码或敌对的编译器暗中破坏,基本上,它们保证了Java代码按预定的规则运作。但是,当我们需要逾越这些限制时,例如,读写文件,监听和读写Socket,退出Java系统等,就必须使用数字签名或安全策略文件(*.Policy)。-在企业内部网中,本文提出了使用安全策略文件来设置java程序权限的一种简单的方法。由于企业内部网中各台计算机的位置、用途和安全性明确,更适于使用安全策略文件来设置java的权限,软件的安装、设置、升级和迁移都非常的方便,并且,还可以和数字签名配合使用,更重
2、要的是,可以细分每个java程序的权限,使用起来灵活方便。一.Java中安全策略的概念- -Java应用程序环境的安全策略,详细说明了对于不同的代码所拥有的不同资源的许可,它由一个Policy对象来表达。为了让applet(或者运行在SecurityManager下的一个应用程序)能够执行受保护的行为,例如读写文件,applet(或Java应用程序)必须获得那项操作的许可,安全策略文件就是用来实现这些许可。- -Policy对象可能有多个实体,虽然任何时候只能有一个起作用。当前安装的Policy对象,在程序中可以通过调用getPolicy方法得到,也可以通过调用setPolicy方法改变。Po
3、licy对象评估整个策略,返回一个适当的Permissions对象,详细说明那些代码可以访问那些资源。- -策略文件可以储存在无格式的ASCII文件,或Policy类的二进制文件,或数据库中。本文仅讨论无格式的ASCII文件的形式。二.Policy文件的格式- -为了能够更好地理解下面的内容,建议在阅读时参照jdk1.2jrelibsecurityjava.policy文件和jdk1.2jrelibsecurityjava.security文件的内容。- -1.Policy文件的语法格式与说明- -一个Policy文件实质上是一个记录列表,它可能含有一个"keystore”记录,以及
4、含有零个或多个“grant”记录。其格式如下:keystore"some_keystore_url","keystore_type"grantSignedBy"signer_names",CodeBase"URL"Permissionpermission_class_name"target_name","action",SignedBy"signer_names"Permission.;- -1.1"keystore"记录- -一个ke
5、ystore是一个私有密钥(privatekeys)数据库和相应的数字签名,例如X.509证书。Policy文件中可能只有一条keystore记录(也可能不含有该记录),它可以出现在文件中grant记录以外的任何地方。Policy配置文件中指定的keystores用于寻找grant记录中指定的、签名者的公共密钥(publickeys),如果任何grant记录指定签名者(signer_names),那么,keystore记录必须出现在policy配置文件中。- -"some_keystore_url"是指keystore的URL位置,"keystore_type&q
6、uot;是指keystore的类型。第二个选项是可选项,如果没有指定,该类型则假定由安全属性文件(java.security)中的"keystore.type”属性来确定。keystore类型定义了keystore信息的存储和数据格式,用于保护keystore中的私有密钥和keystore完整性的算法。SunMicrosystems支持的缺省类型为“JKS'。- -1.2"grant"记录- -在Policy文件中的每一个grant记录含有一个CodeSource(一个指定的代码)及其permission(许可)。- -Policy文件中的每一条grant
7、记录遵循下面的格式,以保留字“grant”开头,表示一条新的记录的开始,“Permission”是另一个保留字,在记录中用来标记一个新的许可的开始。每一个grant记录授予一个指定的代码(CodeBase一套许可(Permissions)。- -permission_class_name必须是一个合格并存在的类名,例如java.io.FilePermission,不能使用缩写(例如,FilePermission)。- -target_name用来指定目标类的位置,action用于指定目标类拥有的权限。- -target_name可以直接指定类名(可以是绝对或相对路径),目录名,也可以是下而的通
8、配符:directory/*目录下的所有文件- 当前目录的所有文件directory/-目录下的所有文件,包括子目录- 当前目录下的所有文件,包括子目录ALLFILES文件系统中的所有文件对于java.io.FilePermission,action可以是:read,write,delete和execute。对于.SocketPermission,action可以是:listen,accept,connect,read,write。- -1.3Policy文件中的属性扩展(PropertyExpansion)- -属性扩展与shell中使用的变量扩展类似,它的格式为:"$some.p
9、roperty”实际使用的例子为:permissionjava.io.FilePermission"$user.home","read""$user.home"的值为"d:Project",因此,下面的语句和上面的语句是一样的:permissionjava.io.FilePermission"d:Project","read"三.实例-当初始化Policy时,首先装载系统Policy,然后再增加用户Policy,如果两者都不存在,则使用缺省的Policy,即原始的沙箱模型。-
10、 -系统Policy文件的缺省位置为:java.home/lib/security/java.policy(Solaris)java.homelibsecurityjava.policy(Windows)用户Policy文件的缺省位置为:user.home/.java.policy(Solaris)user.home.java.policy(Windows)-其实,在实际使用中,我们可能不会象上面介绍的那么复杂,特别是在不使用数字签名时。这时,我们完全可以借鉴JDK1.2提供给我们的现成的jdk1.2jrelibsecurityjava.policy文件,根据我们的需要作相应的修改,本文就针对
11、不使用数字签名情况详细说明安全策略文件的用法。-下面,是一个完整的在Windows95/98/NT下使用的.java.policy文件。在文件中,分别使用注释的形式说明了每个“permission”记录的用途。/ForLanServerTalk.javaandLanClientTalk.javagrant/对系统和用户目录“读”的权限permissionjava.util.PropertyPermission"user.dir","read"permissionjava.util.PropertyPermission"user.home&quo
12、t;,"read"permissionjava.util.PropertyPermission"java.home","read"permissionjava.util.PropertyPermission"java.class.path","read"permissionjava.util.PropertyPermission"","read"/对线程和线程组的操作权限permissionjava.lang.RuntimePermiss
13、ion"modifyThread"permissionjava.lang.RuntimePermission"modifyThreadGroup"/操作Socket端口的各种权限.SocketPermission"-","listen".SocketPermission"-","accept".SocketPermission"-","connect".SocketPermission"-","read&q
14、uot;.SocketPermission"-","write"/读写文件的权限permissionjava.io.FilePermission"-","read"permissionjava.io.FilePermission"-","write"/退出系统的权限,例如System.exit(0)permissionjava.lang.RuntimePermission"exitVM"四.java.policy文件的使用- -对于windows95/98
15、/NT,使用.java.policy文件的方法主要有下面两种。- 1.使用缺省目录- -我们可以简单地将编辑好的.java.policy文件拷贝到windows95/98/NT的HOMIB录,这时,所有的applet(或Java应用程序)可能都拥有某些相同的权限,使用起来简单,但不灵活(例如:对于java.io.FilePermission,其目标类的target_name必须使用绝对路径),如果不是在企业内部网中使用,还可能存在一定安全隐患。- 2.在命令行中指定- -在命令行,如果我们希望传递一个Policy文件给appletviewer,还可以使用"-J-Djava.secuHty.policy”参数来指定policy的位置:appletviewer-J-Djava.security.policy=pURLmyApplet- -pURL为Policy文件的位置。下面,是
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 老人中考语文作文
- 玻璃熔化工艺模拟与优化考核试卷
- 什么中的身影初一语文作文
- 难忘的友谊初一语文作文
- 绿色初二语文作文
- 河南省洛阳市新安县2023-2024学年七年级下学期期末考试数学试卷(含答案)
- 磷肥生产设备结构与原理考核卷考核试卷
- 玩具行业人才培养需求考核试卷
- 宁波九校高二上学期语文作文
- 烘炉设备维护与管理考核试卷
- 2025年有关“我为群众办实事”主题日活动工作方案
- 2025中国新型储能行业发展白皮书
- 油气管道输送试题及答案
- 海南省天一大联考2024-2025学年高三学业水平诊断(四)语文试题及答案
- 旅游合同签署委托协议
- 山东司法警官职业学院招聘笔试真题2024
- 2025-2030中国非邻苯二甲酸酯类增塑剂行业市场发展趋势与前景展望战略研究报告
- 2025年台球理论测试题及答案
- 加油站现场服务提升方案
- 绝缘摇表培训
- 保险合规知识培训课件
评论
0/150
提交评论