CDC 1.1.2

java.security
クラス PermissionCollection

java.lang.Object
  上位を拡張 java.security.PermissionCollection
すべての実装されたインタフェース:
Serializable
直系の既知のサブクラス:
Permissions

public abstract class PermissionCollection
extends Object
implements Serializable

Permission オブジェクトのコレクションを表す abstract クラスです。

PermissionCollection を使うと、次の処理を行えます。

同じ型の複数の Permission オブジェクトをグループ化するには、まずその特定の型に対して newPermissionCollection メソッドを呼び出す必要があります。Permission クラスの場合、このメソッドのデフォルト動作は単純に null を返すというものです。PermissionCollection.implies メソッドの呼び出し時に正しいセマンティクスを提供できるように特定の PermissionCollection オブジェクト内にアクセス権を格納する必要がある場合には、Permission クラスのサブクラスが newPermissionCollection メソッドをオーバーライドします。このメソッドから null 以外の値が返された場合、その PermissionCollection を使用する必要があります。null が返された場合、newPermissionCollection の呼び出し元は、指定された種類のアクセス権を、任意の PermissionCollection (Hashtable を使用するもの、Vector を使用するものなど) に自由に格納できます。

Permission.newPermissionCollection メソッドが返す PermissionCollection は同種コレクションであり、指定された種類のアクセス権の Permission オブジェクトだけを格納します。PermissionCollection は異種コレクションでもあります。たとえば Permissions は、PermissionCollections のコレクションを表す PermissionCollection サブクラスです。つまりそのメンバーは、それぞれが同種の PermissionCollection です。たとえば Permissions オブジェクトは、すべての FilePermission オブジェクトに対しては FilePermissionCollection、すべての SocketPermission オブジェクトに対しては SocketPermissionCollection などといった対応でコレクションを持ちます。その add メソッドはアクセス権を適切なコレクションに追加します。

Permissions などの異種の PermissionCollection にアクセス権を追加する際、指定されたアクセス権に対する PermissionCollection がその PermissionCollection 内に存在しなかった場合、その PermissionCollection は、そのアクセス権のクラス上で newPermissionCollection メソッドを呼び出し、それが特別な PermissionCollection を必要とするかどうかを確認する必要があります。newPermissionCollection から null が返された場合、その PermissionCollection は任意の種類の PermissionCollection (Hastable を使用するもの、Vector を使用するものなど) にそのアクセス権を格納できます。たとえば、Permissions オブジェクトは、アクセス権オブジェクトを Hashtable に格納する、デフォルトの PermissionCollection 実装を使用します。

PermissionCollection のサブクラス実装は、複数スレッドから同時に呼び出されることを想定しなければならず、そのため、適切に同期を取る必要があります。それだけでなく、elements メソッドで返される Enumerations は「フェイルファスト」ではありません。コレクションの列挙中に、コレクションへ変更を加えてはいけません。

関連項目:
Permission, Permissions, 直列化された形式

コンストラクタの概要
PermissionCollection()
           
 
メソッドの概要
abstract  void add(Permission permission)
          アクセス権オブジェクトの現在のコレクションにアクセス権オブジェクトを追加します。
abstract  Enumeration elements()
          コレクション内のすべての Permission オブジェクトの列挙を返します。
abstract  boolean implies(Permission permission)
          指定されたアクセス権が、この PermissionCollection で保持される Permission オブジェクトのコレクションによって包含されるかどうかを判定します。
 boolean isReadOnly()
          PermissionCollection オブジェクトが読み取り専用としてマークされている場合に true を返します。
 void setReadOnly()
          PermissionCollection オブジェクトを「読み取り専用」としてマークします。
 String toString()
          PermissionCollection オブジェクトを記述する文字列を返し、オブジェクトが保持するすべてのアクセス権についての情報を提供します。
 
クラス java.lang.Object から継承されたメソッド
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait
 

コンストラクタの詳細

PermissionCollection

public PermissionCollection()
メソッドの詳細

add

public abstract void add(Permission permission)
アクセス権オブジェクトの現在のコレクションにアクセス権オブジェクトを追加します。

パラメータ:
permission - 追加される Permission オブジェクト
例外:
SecurityException - この PermissionCollection オブジェクトが読み取り専用としてマークされている場合

implies

public abstract boolean implies(Permission permission)
指定されたアクセス権が、この PermissionCollection で保持される Permission オブジェクトのコレクションによって包含されるかどうかを判定します。

パラメータ:
permission - 比較対象の Permission オブジェクト
戻り値:
アクセス権がコレクション内のアクセス権に包含される場合は true、そうでない場合は false

elements

public abstract Enumeration elements()
コレクション内のすべての Permission オブジェクトの列挙を返します。

戻り値:
すべての Permissions の列挙

setReadOnly

public void setReadOnly()
PermissionCollection オブジェクトを「読み取り専用」としてマークします。PermissionCollection オブジェクトを読み取り専用としてマークすると新規 Permission オブジェクトを add で PermissionCollection に追加することはできません。


isReadOnly

public boolean isReadOnly()
PermissionCollection オブジェクトが読み取り専用としてマークされている場合に true を返します。読み取り専用の場合、新規 Permission オブジェクトを add で PermissionCollection に追加することはできません。

デフォルトでは、オブジェクトは読み取り専用ではありません。setReadOnly を呼び出すことによって読み取り専用に設定できます。

戻り値:
この PermissionCollection オブジェクトが読み取り専用としてマークされている場合は true、そうでない場合は false

toString

public String toString()
PermissionCollection オブジェクトを記述する文字列を返し、オブジェクトが保持するすべてのアクセス権についての情報を提供します。コマンドの形式は、次のとおりです。
 super.toString() (
   // すべての Permission オブジェクトを
   // 列挙して、行ごとに 1 回ずつ
   // toString() を呼び出します。
 )
super.toString は、このオブジェクトのスーパークラス (つまり Object) の toString メソッドの呼び出しです。結果として返されるのは、この PermissionCollection の種類名のあとにこのオブジェクトのハッシュコードが続く文字列なので、複数の PermissionCollections オブジェクトが同じアクセス権を保持する場合でも、クライアントは各オブジェクトを区別できます。

オーバーライド:
クラス Object 内の toString
戻り値:
PermissionCollection オブジェクトについての情報 (上記を参照)

CDC 1.1.2

Copyright 2006 Sun Microsystems, Inc. All Rights Reserved. Use of this specification is subject to license terms.