`

java.policy

阅读更多

一、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文件的内容。
    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)“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”。

    (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。

     (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.2jrelibsecurityjava.policy文件,根据我们的需要做相应的修改,本文就针对不使用数字签名情况详细说明安全策略文件的用法。

    下面,是一个完整的在Windows下使用的.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文件的内容,使用起来相当简单,而且,安全许可的范围控制较精细

如果要加上全部的权限:

    grant {
      permission java.security.AllPermission;
    };

分享到:
评论

相关推荐

    jre6+java.policy

    `java.policy`文件可以是全局的,影响所有运行在该JRE上的Java应用程序,也可以是特定应用程序的,通过 `-Djava.security.policy=&lt;policy_file&gt;` 启动选项指定。此外,如果应用程序没有指定自己的安全策略,那么它将...

    Java_jre6_lib_security_java.policy

    Java_jre6_lib_security_java.policy

    解决java.security.InvalidKeyException: Illegal key size

    总之,“java.security.InvalidKeyException: Illegal key size”是一个与Java加密策略相关的错误,通过更新`local_policy.jar`和`US_export_policy.jar`文件可以有效地解决。这个过程涉及到对Java安全策略的理解,...

    java.security.InvalidKeyException: Illegal key size 解决方案

    4. **替换现有策略文件**:找到对应Java版本的jre/lib/security目录,然后替换原有的`local_policy.jar`和`US_export_policy.jar`文件,用你刚刚解压的新文件覆盖。 5. **重启应用或系统**:为了确保更改生效,你...

    java.security.InvalidKeyException:illegal Key Size

    解压这个文件后,你需要替换JDK的lib/security目录下的两个策略文件:local_policy.jar和US_export_policy.jar。这两个文件定义了Java加密算法可以使用的最大密钥长度。 替换步骤如下: 1. 找到你的JDK6安装目录,...

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

    - 替换原有文件:下载完成后,需要替换`${java_home}/jre/lib/security`目录下的`local_policy.jar`和`US_export_policy.jar`这两个文件。 - 验证安装:安装后,可以通过测试加密过程是否正常来验证安装是否成功。...

    local_policy.jar和US_export_policy.jar资源.zip

    AES的256位密钥加解 Windows正常,linux上报错 java.security.InvalidKeyException: Illegal ...jdk8 和 java9 之后,$JAVA_HOME/jre/lib/security路径下 的 policy 的文件夹有相应的 带限制的jar包 和 不带限制的jar包

    利用数字签名超越Java Applet的安全限制.doc

    `.policy`文件通常有两个默认位置:`${java.home}/lib/security/java.policy`(全局设置)和`${user.home}/.java.policy`(用户特定设置)。在示例中,`java.policy`文件的片段展示了如何为标准扩展授予所有权限,并...

    Applet權限處理研究

    8. **修改Java安全配置**:编辑`${java.home}/jre/lib/security`目录下的`java.security`文件,在`policy.url`配置中添加新的policy文件路径。例如: ``` policy.url.1=file:${java.home}/lib/security/java....

    local_policy.jar和US_export_policy.jar java解密

    因为某些国家的进口管制限制,Java发布的运行环境包中的加解密有...将local_policy.jar和US_export_policy.jar这两个文件替换%JRE_HOME%\lib\security和%JDK_HOME%\jre\lib\security下原来的文件,注意先备份原文件。

    jdk1.8.zip (local_policy.jar & US_export_policy.jar)

    "local_policy.jar"和"US_export_policy.jar"是Java安全策略相关的两个重要文件,它们定义了JVM(Java Virtual Machine)在不同区域执行代码时的安全限制。 "local_policy.jar"包含本地安全策略,定义了Java在特定...

    jce_policy-8.AES加密版本.zip

    Exception in thread "main" java.security.NoSuchAlgorithmException: Cannot find any provider supporting AES/ECB/PKCS7Padding https://www.codeprj.com/blog/92cdc41.html

    JS实现截屏

    工作中有个项目需要将地图截屏以彩信方式发送给用户。...2、在客户端的JRE中对APPLET进行授权,即在...Java\jre1.5.0\lib\security的java.policy文件中加上permission java.security.AllPermission;

    US_export_policy.jar local_policy.jar

    US_export_policy.jar local_policy.jar 解决:java.security.InvalidKeyException: Illegal key size or default parameters

    libnodave-java-0.1.7z

    1. "java.policy.applet":这是Java安全策略文件,可能用于控制applet(即在浏览器中运行的Java小程序)的安全权限,确保libnodave库在执行时不会对系统造成安全隐患。 2. "hmiISO_TCP"、"hmiPPI":这些可能是与人...

    Oracle触发器里调用Java程序

    ALTER SYSTEM SET JAVAVM_INITARGS='-Djava.security.policy=java.policy' SCOPE=BOTH; ``` 接着,我们需要在数据库中创建一个Java源代码对象,将Java代码存储在数据库中。例如,假设我们有一个名为`MyJavaClass`的...

    local_policy.jar和US_export_policy.jar

    在Java 1.6、1.7和1.8版本中,JCE包括两个重要的jar文件:`local_policy.jar`和`US_export_policy.jar`。 `local_policy.jar`包含了本地加密策略文件,它定义了在特定地域内可以使用的加密强度限制。在某些国家或...

Global site tag (gtag.js) - Google Analytics