java.applet

java.awt

java.awt.color

java.awt.datatransfer

java.awt.dnd

java.awt.event

java.awt.font

java.awt.geom

java.awt.im

java.awt.im.spi

java.awt.image

java.awt.image.renderable

java.awt.print

java.beans

java.beans.beancontext

java.io

java.lang

java.lang.annotation

java.lang.instrument

java.lang.management

java.lang.ref

java.lang.reflect

java.math

java.net

java.nio

java.nio.channels

java.nio.channels.spi

java.nio.charset

java.nio.charset.spi

java.rmi

java.rmi.activation

java.rmi.dgc

java.rmi.registry

java.rmi.server

java.security

java.security.acl

java.security.cert

java.security.interfaces

java.security.spec

java.sql

java.text

java.util

java.util.concurrent

java.util.concurrent.atomic

java.util.concurrent.locks

java.util.jar

java.util.logging

java.util.prefs

java.util.regex

java.util.zip

javax.accessibility

javax.activity

javax.crypto

javax.crypto.interfaces

javax.crypto.spec

javax.imageio

javax.imageio.event

javax.imageio.metadata

javax.imageio.plugins.bmp

javax.imageio.plugins.jpeg

javax.imageio.spi

javax.imageio.stream

javax.management

javax.management.loading

javax.management.modelmbean

javax.management.monitor

javax.management.openmbean

javax.management.relation

javax.management.remote

javax.management.remote.rmi

javax.management.timer

javax.naming

javax.naming.directory

javax.naming.event

javax.naming.ldap

javax.naming.spi

javax.net

javax.net.ssl

javax.print

javax.print.attribute

javax.print.attribute.standard

javax.print.event

javax.rmi

javax.rmi.CORBA

javax.rmi.ssl

javax.security.auth

javax.security.auth.callback

javax.security.auth.kerberos

javax.security.auth.login

javax.security.auth.spi

javax.security.auth.x500

javax.security.cert

javax.security.sasl

javax.sound.midi

javax.sound.midi.spi

javax.sound.sampled

javax.sound.sampled.spi

javax.sql

javax.sql.rowset

javax.sql.rowset.serial

javax.sql.rowset.spi

javax.swing

javax.swing.border

javax.swing.colorchooser

javax.swing.event

javax.swing.filechooser

javax.swing.plaf

javax.swing.plaf.basic

javax.swing.plaf.metal

javax.swing.plaf.multi

javax.swing.plaf.synth

javax.swing.table

javax.swing.text

javax.swing.text

javax.swing.text.parser

javax.swing.text.rtf

javax.swing.tree

javax.swing.undo

javax.transaction

javax.transaction.xa

javax.xml

javax.xml.datatype

javax.xml.namespace

javax.xml.parsers

javax.xml.transform

javax.xml.transform.dom

javax.xml.transform.sax

javax.xml.transform.stream

javax.xml.validation

javax.xml.xpath

org.ietf.jgss

org.omg.CORBA

org.omg.CORBA_2_3

org.omg.CORBA_2_3.portable

org.omg.CORBA.DynAnyPackage

org.omg.CORBA.ORBPackage

org.omg.CORBA.portable

org.omg.CORBA.TypeCodePackage

org.omg.CosNaming

org.omg.CosNaming.NamingContextExtPackage

org.omg.CosNaming.NamingContextPackage

org.omg.Dynamic

org.omg.DynamicAny

org.omg.DynamicAny.DynAnyFactoryPackage

org.omg.DynamicAny.DynAnyPackage

org.omg.IOP

org.omg.IOP.CodecFactoryPackage

org.omg.IOP.CodecPackage

org.omg.Messaging

org.omg.PortableInterceptor

org.omg.PortableInterceptor.ORBInitInfoPackage

org.omg.PortableServer

org.omg.PortableServer.CurrentPackage

org.omg.PortableServer.POAManagerPackage

org.omg.PortableServer.POAPackage

org.omg.PortableServer.portable

org.omg.PortableServer.ServantLocatorPackage

org.omg.SendingContext

org.omg.stub.java.rmi

org.w3c.dom

org.w3c.dom.bootstrap

org.w3c.dom.events

org.w3c.dom.ls

org.xml.sax

org.xml.sax.ext

org.xml.sax.helpers

allclasses-frame

allclasses-noframe

constant-values

deprecated-list

help-doc

JavaTM 2 Platform
Standard Ed. 5.0

javax.security.auth
类 PrivateCredentialPermission

java.lang.Object
  继承者 java.security.Permission
      继承者 javax.security.auth.PrivateCredentialPermission
所有已实现的接口:
Serializable, Guard

public final class PrivateCredentialPermission
extends Permission

此类用来保护对属于特定 Subject 的私有 Credential 的访问。Subject 通过 Principals Set 表示。

Permission 的目标名称指定了一个 Credential 类名和一个 Principals Set。此 Permission 的操作的惟一有效值是 "read"。目标名称必须遵守下面的语法:

        CredentialClass {PrincipalClass "PrincipalName"}*
 
例如,下面的权限授予对 Subjects 拥有的 com.sun.PrivateCredential 的访问,该 Subjects 有一个 com.sun.Principal,名称为 "duke"。注意,尽管此例子(以及下面的所有例子)在 grant 语句中不包含 Codebase、SignedBy 或 Principal 信息(为了使例子简单),但是实际的策略配置在适当的时候应该指定该信息。
    grant {
        permission javax.security.auth.PrivateCredentialPermission
                "com.sun.PrivateCredential com.sun.Principal \"duke\"",
                "read";
    };
 
如果 CredentialClass 为 "*",那么授予属于指定的 Subject 的所有 Credential 访问权限。如果 "PrincipalName" 为 "*",那么授予指定的由任何 Subject 拥有的 Credential 访问权限,此 Subject 具有指定的 Principal (实际的 PrincipalName 无关紧要)。例如,下面的语句授予对任何有 a.b.Principal 的 Subject 所拥有的 a.b.Credential 访问权限。
    grant {
        permission javax.security.auth.PrivateCredentialPermission
                "a.b.Credential a.b.Principal "*"",
                "read";
    };
 
如果 PrincipalClass 和 "PrincipalName" 都为 "*",那么授予由任何 Subject 拥有的指定的 Credential 访问权限。

另外,PrincipalClass/PrincipalName 对可以重复:

    grant {
        permission javax.security.auth.PrivateCredentialPermission
                "a.b.Credential a.b.Principal "duke" c.d.Principal "dukette"",
                "read";
    };
 
上面的语句授予对私有 Credential("a.b.Credential")的访问权限,"a.b.Credential" 属于带有至少两个 Principals 的 Subject:名称为 "duke" 的 "a.b.Principal",和名称为 "dukette" 的 "c.d.Principal"。

另请参见:
序列化表格

构造方法摘要
PrivateCredentialPermission(String name, String actions)
          创建具有指定 name 的新 PrivateCredentialPermission
 
方法摘要
 boolean equals(Object obj)
          检查两个 PrivateCredentialPermission 对象是否相等。
 String getActions()
          返回操作的“规范的字符串表示形式”。
 String getCredentialClass()
          返回与此 PrivateCredentialPermission 相关联的 Credential 的 Class 名称。
 String[][] getPrincipals()
          返回与此 PrivateCredentialPermission 相关联的 Principal 类和名称。
 int hashCode()
          返回此对象的哈希码值。
 boolean implies(Permission p)
          检查此 PrivateCredentialPermission 是否暗含指定的Permission
 PermissionCollection newPermissionCollection()
          返回 PermissionCollection 中同类的 PrivateCredentialPermissions 集合。
 
从类 java.security.Permission 继承的方法
checkGuard, getName, toString
 
从类 java.lang.Object 继承的方法
clone, finalize, getClass, notify, notifyAll, wait, wait, wait
 

构造方法详细信息

PrivateCredentialPermission

public PrivateCredentialPermission(String name,
                                   String actions)
创建具有指定 name 的新 PrivateCredentialPermissionname 指定了一个 Credential 类和一个 Principal 集合。

参数:
name - 指定 Credential 类和 Principal 集合的名称。

actions - 指定 Credential 能够被读取的操作。
抛出:
IllegalArgumentException - 如果 name 没有遵循正确的语法或者如果 actions 不是 "read"。
方法详细信息

getCredentialClass

public String getCredentialClass()
返回与此 PrivateCredentialPermission 相关联的 Credential 的 Class 名称。

返回:
与此 PrivateCredentialPermission 相关联的 Credential 的 Class 名称。

getPrincipals

public String[][] getPrincipals()
返回与此 PrivateCredentialPermission 相关联的 Principal 类和名称。信息以二维数组 (array[x][y]) 的形式返回。'x' 值对应于 Principal 的类和名称对的数目。当 (y==0) 时,它对应于 Principal 类值,当 (y==1) 时,它对应于 Principal 名称值。例如,array[0][0] 对应于数组中的第一个 Principal 的类名。array[0][1] 对应于数组中的第一个 PrincipalPrincipal 名。

返回:
与此 PrivateCredentialPermission 相关联的 Principal 类和名称。

implies

public boolean implies(Permission p)
检查此 PrivateCredentialPermission 是否暗含指定的Permission

如果满足下面的条件,则此方法返回 true:

  • p 是 PrivateCredentialPermission 的一个实例,且

  • 此对象的目标名称隐含了 p 的目标名称。例如:
            [* P1 "duke"] implies [a.b.Credential P1 "duke"].
            [C1 P1 "duke"] implies [C1 P1 "duke" P2 "dukette"].
            [C1 P2 "dukette"] implies [C1 P1 "duke" P2 "dukette"].
     

指定者:
Permission 中的 implies
参数:
p - 所要检查的 Permission
返回:
如果此 PrivateCredentialPermission 隐含了指定的 Permission,则返回 true;否则返回 false。

equals

public boolean equals(Object obj)
检查两个 PrivateCredentialPermission 对象是否相等。检查 obj 是否为 PrivateCredentialPermission,是否与此对象具有相同的 credential 类以及相同的 Principals。在各自的 Permission 的目标名称中的 Principals 的顺序是无关的。

指定者:
Permission 中的 equals
参数:
obj - 要与此对象进行相等性测试的对象。
返回:
如果 obj 为 PrivateCredentialPermission,与此对象具有相同的 credential 类以及相同的 Principals,则返回 true。
另请参见:
Object.hashCode(), Hashtable

hashCode

public int hashCode()
返回此对象的哈希码值。

指定者:
Permission 中的 hashCode
返回:
此对象的哈希码值。
另请参见:
Object.equals(java.lang.Object), Hashtable

getActions

public String getActions()
返回操作的“规范的字符串表示形式”。此方法总是返回 String "read"。

指定者:
Permission 中的 getActions
返回:
操作(总是返回 "read")。

newPermissionCollection

public PermissionCollection newPermissionCollection()
返回 PermissionCollection 中同类的 PrivateCredentialPermissions 集合。没有定义这种 PermissionCollection,所以此方法总是返回 null

覆盖:
Permission 中的 newPermissionCollection
返回:
所有情况下都返回 null。

JavaTM 2 Platform
Standard Ed. 5.0

提交错误或意见
有关更多的 API 参考资料和开发人员文档,请参阅 Java 2 SDK SE 开发人员文档。该文档包含更详细的、面向开发人员的描述,以及总体概述、术语定义、使用技巧和工作代码示例。

版权所有 2004 Sun Microsystems, Inc. 保留所有权利。 请遵守许可证条款。另请参阅文档重新分发政策