`

使用Policy文件来设置Java的安全策略

 
阅读更多

---- 众所周知,Java语言具有完善的安全框架,从编程语言,编译器、解释程序到Java虚拟机,都能确保Java系统不被无效的代码或敌对的编译器暗中破坏,基本上,它们保证了Java代码按预定的规则运作。但是,当我们需要逾越这些限制时,例如,读写文件,监听和读写Socket,退出Java系统等,就必须使用数字签名或安全策略文件(*.Policy)。 

---- 在企业内部网中,本文提出了使用安全策略文件来设置java程序权限的一种简单的方法。由于企业内部网中各台计算机的位置、用途和安全性明确,更适于使用安全策略文件来设置java的权限,软件的安装、设置、升级和迁移都非常的方便,并且,还可以和数字签名配合使用,更重要的是,可以细分每个java程序的权限,使用起来灵活方便。 

一. Java中安全策略的概念 
---- Java应用程序环境的安全策略,详细说明了对于不同的代码所拥有的不同资源的许可,它由一个Policy对象来表达。为了让applet(或者运行在SecurityManager下的一个应用程序)能够执行受保护的行为,例如读写文件,applet(或Java应用程序)必须获得那项操作的许可,安全策略文件就是用来实现这些许可。 
---- Policy对象可能有多个实体,虽然任何时候只能有一个起作用。当前安装的Policy对象,在程序中可以通过调用getPolicy方法得到,也可以通过调用setPolicy方法改变。Policy对象评估整个策略,返回一个适当的Permissions对象,详细说明那些代码可以访问那些资源。 

---- 策略文件可以储存在无格式的ASCII文件,或Policy类的二进制文件,或数据库中。本文仅讨论无格式的ASCII文件的形式。 

二. Policy文件的格式 
---- 为了能够更好地理解下面的内容,建议在阅读时参照\jdk1.2\jre\lib\security\java.policy文件和\jdk1.2\jre\lib\security\java.security文件的内容。 
---- 1. Policy文件的语法格式与说明 

---- 一个Policy文件实质上是一个记录列表,它可能含有一个“keystore”记录,以及含有零个或多个“grant”记录。其格式如下: 

keystore "some_keystore_url", 
"keystore_type";

grant [SignedBy "signer_names"] 
[, CodeBase "URL"] {
Permission permission_class_name 
[ "target_name" ] 
[, "action"] [, SignedBy "signer_names"];
Permission ...
};

---- 1.1"keystore"记录 
---- 一个keystore是一个私有密钥(private keys)数据库和相应的数字签名,例如X.509证书。Policy文件中可能只有一条keystore记录(也可能不含有该记录),它可以出现在文件中grant记录以外的任何地方。Policy配置文件中指定的keystores用于寻找grant记录中指定的、签名者的公共密钥(public keys),如果任何grant记录指定签名者(signer_names),那么,keystore记录必须出现在policy配置文件中。 

---- "some_keystore_url"是指keystore的URL位置,"keystore_type"是指keystore的类型。第二个选项是可选项,如果没有指定,该类型则假定由安全属性文件(java.security)中的"keystore.type"属性来确定。keystore类型定义了keystore信息的存储和数据格式,用于保护keystore中的私有密钥和keystore完整性的算法。Sun Microsystems支持的缺省类型为“JKS”。 

---- 1.2"grant"记录 

---- 在Policy文件中的每一个grant记录含有一个CodeSource(一个指定的代码)及其permission(许可)。 

---- Policy文件中的每一条grant记录遵循下面的格式,以保留字“grant”开头,表示一条新的记录的开始,“Permission”是另一个保留字,在记录中用来标记一个新的许可的开始。每一个grant记录授予一个指定的代码(CodeBase)一套许可(Permissions)。 

---- permission_class_name必须是一个合格并存在的类名,例如java.io.FilePermission,不能使用缩写(例如,FilePermission)。 

---- target_name用来指定目标类的位置,action用于指定目标类拥有的权限。 

---- target_name可以直接指定类名(可以是绝对或相对路径),目录名,也可以是下面的通配符: 

directory/* 目录下的所有文件
*当前目录的所有文件
directory/-目录下的所有文件,包括子目录
- 当前目录下的所有文件,包括子目录
《ALL FILES》文件系统中的所有文件
对于java.io.FilePermission,action可以是:
read, write, delete和execute。
对于java.net.SocketPermission,action可以是:
listen,accept,connect,read,write。

---- 1.3 Policy文件中的属性扩展(Property Expansion) 
---- 属性扩展与shell中使用的变量扩展类似,它的格式为: 

"${some.property}"
实际使用的例子为:
permission java.io.FilePermission 
"${user.home}", "read";
"${user.home}"的值为"d:\Project",
因此,下面的语句和上面的语句是一样的:
permission java.io.FilePermission "
d:\Project ", "read";

三. 实例 
---- 当初始化Policy时,首先装载系统Policy,然后再增加用户Policy,如果两者都不存在,则使用缺省的Policy,即原始的沙箱模型。 
---- 系统Policy文件的缺省位置为: 

{java.home}/lib/security/java.policy (Solaris)
{java.home}\lib\security\java.policy (Windows)
用户Policy文件的缺省位置为:
{user.home}/.java.policy (Solaris)
{user.home}\.java.policy (Windows)

---- 其实,在实际使用中,我们可能不会象上面介绍的那么复杂,特别是在不使用数字签名时。这时,我们完全可以借鉴JDK 1.2提供给我们的现成的\jdk1.2\jre\lib\security\java.policy文件,根据我们的需要作相应的修改,本文就针对不使用数字签名情况详细说明安全策略文件的用法。 
---- 下面,是一个完整的在Windows 95/98/NT下使用的.java.policy文件。在文件中,分别使用注释的形式说明了每个“permission”记录的用途。 

// For LanServerTalk.java and LanClientTalk.java

grant { 
//对系统和用户目录“读”的权限
permission java.util.PropertyPermission
"user.dir", "read";
permission java.util.PropertyPermission 
"user.home", "read";
permission java.util.PropertyPermission 
"java.home", "read";
permission java.util.PropertyPermission 
"java.class.path", "read";
permission java.util.PropertyPermission 
"user.name", "read"; 

//对线程和线程组的操作权限
permission java.lang.RuntimePermission
"modifyThread";
permission java.lang.RuntimePermission
"modifyThreadGroup";

//操作Socket端口的各种权限
permission java.net.SocketPermission
"-", "listen";
permission java.net.SocketPermission
"-", "accept";
permission java.net.SocketPermission 
"-", "connect";
permission java.net.SocketPermission "-", "read";
permission java.net.SocketPermission "-", "write";

//读写文件的权限
permission java.io.FilePermission "-", "read";
permission java.io.FilePermission "-", "write";

//退出系统的权限,例如System.exit(0)
permission java.lang.RuntimePermission "exitVM";
};

四. java.policy文件的使用 
---- 对于windows 95/98/NT,使用.java.policy文件的方法主要有下面两种。 
---- 1. 使用缺省目录 

---- 我们可以简单地将编辑好的.java.policy文件拷贝到windows 95/98/NT的HOME目录,这时,所有的applet(或Java应用程序)可能都拥有某些相同的权限,使用起来简单,但不灵活(例如:对于java.io.FilePermission ,其目标类的target_name必须使用绝对路径),如果不是在企业内部网中使用,还可能存在一定安全隐患。 

---- 2. 在命令行中指定 

---- 在命令行,如果我们希望传递一个Policy文件给appletviewer,还可以使用"-J-Djava.security.policy"参数来指定policy的位置: 

appletviewer -J-Djava.security.
policy=pURL myApplet

---- pURL为Policy文件的位置。下面,是一个实际的例子,以当前目录的.java.policy文件所指定的安全策略运行当前目录的LanServerTalk.html(文件中装载并运行LanServerTalk.java): 
appletviewer -J-Djava.security.policy
=.java.policy LanServerTalk.html 

---- 这种方法使用灵活,特别是作为一个软件包在企业内部网中发布时,安装、设置和迁移软件,基本无须修改Policy文件的内容,使用起来相当简单,而且,安全许可的范围控制较精细。

分享到:
评论

相关推荐

    jce-policy-8 JDK8安装JCE无限强度

    总结起来,"jce-policy-8 JDK8安装JCE无限强度"涉及到Java开发中的一个关键安全环节,即通过替换JCE Policy文件来解除对加密强度的限制。这个过程对于需要高级加密功能的开发者和系统管理员来说是必要的,但同时也...

    jdk8加密使用的jce_policy-8替换原jar包

    标题“jdk8加密使用的jce_policy-8替换原jar包”指的是在Java 8环境中,为了扩展默认的加密强度,开发者通常需要替换JDK中的加密策略文件。这些文件位于JDK的`jre/lib/security`目录下,通常包括`local_policy.jar`...

    jce-policy-8.zip

    定期扫描并更新安全策略,可以及时修复已知的漏洞,提升系统的整体安全性。 总的来说,"jce-policy-8.zip" 是Java 8用户增强加密安全性的必备工具,它消除了默认的密钥长度限制,使得企业能够更好地保护其数据不被...

    jdk各文件夹的作用

    - 包含了安全策略文件`java.policy`、安全配置文件`java.security`等。 - 这些文件定义了Java应用程序的安全策略。 #### jdk1.5.0/jre/lib/applet - **描述**:支持Applet的资源文件存放位置。 - **作用**: - ...

    AES加密时抛出java.security.InvalidKeyException: Illegal key size or default parameter

    当在Java环境中使用AES加密时遇到 `java.security.InvalidKeyException: Illegal key size or default parameter` 这个异常,通常意味着密钥的长度超过了Java安全策略所允许的最大值。具体来说: - **非法密钥大小...

    jce_policy-6.7z

    使用JCE无限制强度Jurisdiction Policy Files后,开发者就可以在Java应用程序中自由地使用高强度的加密算法,这在处理敏感数据、确保通信安全以及符合合规性要求时尤其重要。例如,金融、政府和医疗等领域通常需要更...

    jce_policy.jar

    总之,`jce_policy.jar`及其相关的无限制策略文件是Java开发者用来增强其应用程序加密能力的重要工具,它们允许使用更强大的加密算法,提高数据的安全性。正确地替换和配置这些文件是确保Java应用遵循最佳安全实践的...

    基于属性的加密方法实现,cpabe属性加密JAVA源码实现

    CPABE(Ciphertext-Policy Attribute-Based Encryption,策略密文属性基加密)是ABE的一个子类,其主要特点是加密策略依赖于密文本身,而不是解密者的属性。在CPABE系统中,数据加密者可以根据需要设定任意的解密...

    jce_policy-8(jdk8).zip

    总结来说,"jce_policy-8(jdk8).zip" 提供了JDK 8的无限制加密策略,允许使用包括AES-256在内的高强度加密算法,增强了Java应用程序的安全性。正确安装和配置这些策略文件是确保数据安全的重要步骤,特别是在处理...

    local-policy.jar.US-export-policy.jar资源文件.zip

    这两个文件通常包含在Java安装目录的安全文件夹内,对于理解和配置Java安全环境至关重要。 1. **local_policy.jar**: - 这个文件包含了适用于除美国之外的所有地区的加密策略。它定义了JRE可以使用的加密算法的...

    jce_policy-8.zip

    它遵循Java安全模型,并且在跨平台的环境中提供了一致的安全性。 **加密策略文件**: JCE策略文件定义了Java虚拟机可以使用的加密算法强度。默认策略可能受到限制,特别是在美国出口法规的约束下。...

    java SFTP上传所需jar和秘钥工具

    1. **安装JCE**: 将`jce_policy-8.zip`解压并替换Java安装目录下的`jre\lib\security`文件夹中的默认策略文件。 2. **导入PuTTY生成的密钥对**: 使用PuTTYgen创建RSA或DSA密钥对,保存私钥(通常为.ppk格式),并将...

    Tomcat 的安全方面设置 简单配置过程 说明

    Apache Tomcat的安全配置主要涉及到以下几个方面:用户认证、访问控制、安全策略等。这些配置通常是在`conf`目录下的`tomcat-users.xml`和`web.xml`文件中完成的。 #### 二、用户认证配置 用户认证是Tomcat安全...

    Java入门源代码-同济大学软件学院习题

    2. **java.policy.applet**:这通常涉及到Java安全策略,特别是当在Applet(嵌入在网页中的小型Java程序)中运行代码时。 3. **.settings**:Eclipse项目配置文件夹,存储了关于项目编译器设置、代码格式化规则等...

    linux下jdk安装相关

    除了基本的JDK安装和环境配置外,还可以进行一些高级设置,如调整JVM参数、设置Java安全策略等。 ##### 4.1 调整JVM参数 为了优化Java应用程序的性能,可以根据具体需求调整JVM的相关参数。这些参数通常在启动Java...

    windows内部文件夹介绍.pdf

    - **GroupPolicy**:组策略配置文件夹。 - **DllCache**:再次提及,应理解为重复描述。 - **G**:可能是误打,具体意义不明。 - **$NtUninstall$**:每次系统更新后创建的目录,可以安全删除。 - **security**...

    WINDOWS下文件夹.txt

    通过GroupPolicy,管理员可以统一配置安全策略、软件部署和网络访问权限,实现高效的企业级管理。 ### 11. $NtUninstall$ $NtUninstall$目录记录了每次系统更新的历史信息,包括更新的日期、时间以及是否成功安装...

Global site tag (gtag.js) - Google Analytics