JavaTM 2 Platform
Std. Ed. v1.3

java.security
クラス PermissionCollection

java.lang.Object
  |
  +--java.security.PermissionCollection
すべての実装インタフェース:
Serializable
直系の既知のサブクラス:
Permissions

public abstract class PermissionCollection
extends Object
implements Serializable

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

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

同じ種類の相当数の Permission オブジェクトを一緒にグループ化するには、特定種類の Permission オブジェクトの newPermissionCollection メソッドを最初に呼び出さなければなりません。デフォルトの動作 (Permission クラスから) では単純に null を返します。Permission クラスのサブクラスは、PermissionCollection.implies メソッドの呼び出し時に正しいセマンティクスを提供するためにそのアクセス権を特定の PermissionCollection オブジェクトに格納する必要がある場合、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 実装を使います。

関連項目:
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 オブジェクト
戻り値:
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() (
   // enumerate all the Permission
   // objects and call toString() on them,
   // one per line..
 )
super.toString は、このオブジェクトのスーパークラス (つまり Object) の toString メソッドの呼び出しです。結果として返されるのは、この PermissionCollection の種類名のあとにこのオブジェクトのハッシュコードが続く文字列なので、複数の PermissionCollections オブジェクトが同じアクセス権を保持する場合でも、クライアントは各オブジェクトを区別できます。
オーバーライド:
クラス Object 内の toString
戻り値:
PermissionCollection オブジェクトについての情報 (上記を参照)

JavaTM 2 Platform
Std. Ed. v1.3

バグや機能要求の報告
さらに詳しい API リファレンスおよび開発者ドキュメントについては、 Java 2 SDK SE Developer Documentation を参照してください。このドキュメントには、概念、用語の定義、回避策、 実用的なコード例など、開発者を対象にした詳細な解説が掲載されています。

Java、Java 2D、JDBC は、米国およびその他の国における米国 Sun Microsystems, Inc. の商標もしくは登録商標です。
Copyright 1993-2000 Sun Microsystems, Inc. 901 San Antonio Road,
Palo Alto, California, 94303, U.S.A. All Rights Reserved.