JavaTM Platform
Standard Ed. 6

java.security.acl
インタフェース Acl

すべてのスーパーインタフェース:
Owner

public interface Acl
extends Owner

アクセス制御リスト (ACL: Access Control List) を表すインタフェースです。ACL は、リソースに対するアクセスを保護するデータ構造体です。

ACL は、複数の ACL 項目を持つデータ構造体だと考えることができます。それぞれの ACL 項目は、特定のプリンシパルに関連するアクセス権のセットを含んでいます。(プリンシパルは個別のユーザーやグループなどのエンティティーを表す)。さらに、各 ACL 項目は、正または負に指定されています。正の場合は、関連するプリンシパルにアクセス権が与えられます。負の場合、アクセス権は拒否されます。

各 ACL 中の ACL エントリは次の規則に従います。

java.security.acl パッケージは、ACL と関連するデータ構造体 (ACL エントリ、グループ、アクセス権など) に対するインタフェースを提供し、sun.security.acl クラスは、インタフェースのデフォルトの実装を提供します。たとえば、java.security.acl.Acl は ACL に対するインタフェースを提供し、sun.security.acl.AclImpl クラスはそのインタフェースのデフォルトの実装を提供します。

java.security.acl.Acl インタフェースは、java.security.acl.Owner インタフェースを拡張したものです。Owner インタフェースは、各 ACL の所有者のリストを維持するために使用します。所有者にしか ACL の変更は許されません。たとえば、ACL の addEntry メソッドを呼び出し、新しい ACL エントリを ACL に追加することができるのは所有者だけです。

関連項目:
AclEntry, Owner, getPermissions(java.security.Principal)

メソッドの概要
 boolean addEntry(Principal caller, AclEntry entry)
          ACL エントリをこの ACL に追加します。
 boolean checkPermission(Principal principal, Permission permission)
          指定された主体が指定されたアクセス権を持っているかどうかを判定します。
 Enumeration<AclEntry> entries()
          この ACL 内のエントリの列挙を返します。
 String getName()
          この ACL の名前を返します。
 Enumeration<Permission> getPermissions(Principal user)
          指定された主体 (個人またはグループなどのエンティティーを表す) に対して許可されたアクセス権のセットに対する列挙を返します。
 boolean removeEntry(Principal caller, AclEntry entry)
          この ACL から 1 つの ACL を削除します。
 void setName(Principal caller, String name)
          ACL エントリをこの ACL に追加します。
 String toString()
          ACL の内容を文字列表現で返します。
 
インタフェース java.security.acl.Owner から継承されたメソッド
addOwner, deleteOwner, isOwner
 

メソッドの詳細

setName

void setName(Principal caller,
             String name)
             throws NotOwnerException
ACL エントリをこの ACL に追加します。

パラメータ:
caller - このメソッドを起動する主体。この ACL の所有者になっている必要がある
name - この ACL に与える名前
例外:
NotOwnerException - 呼び出す主体がこの ACL の所有者でない場合
関連項目:
getName()

getName

String getName()
この ACL の名前を返します。

戻り値:
この ACL の名前
関連項目:
setName(java.security.Principal, java.lang.String)

addEntry

boolean addEntry(Principal caller,
                 AclEntry entry)
                 throws NotOwnerException
ACL エントリをこの ACL に追加します。ACL エントリとは、主体 (個人またはグループなど) をアクセス権のセットに関連付けるものです。各主体は、正の ACL エントリ (主体に与えるアクセス権を指定する) と負の ACL エントリ (拒否するアクセス権を指定する) を多くても 1 つずつしか持つことはできません。ACL 内にすでに同じ種類 (正、負) の ACL エントリが存在する場合は、false が返されます。

パラメータ:
caller - このメソッドを起動する主体。この ACL の所有者になっている必要がある
entry - この ACL に追加される ACL エントリ
戻り値:
成功した場合は true。この ACL に、同じ主体に対する同じ種類 (正、負) の ACL エントリがすでに存在する場合は false
例外:
NotOwnerException - 呼び出す主体がこの ACL の所有者でない場合

removeEntry

boolean removeEntry(Principal caller,
                    AclEntry entry)
                    throws NotOwnerException
この ACL から 1 つの ACL を削除します。

パラメータ:
caller - このメソッドを起動する主体。この ACL の所有者になっている必要がある
entry - この ACL から削除する ACL エントリ
戻り値:
成功した場合は true。エントリがこの ACL の一部でない場合は false
例外:
NotOwnerException - 呼び出す主体がこの ACL の所有者でない場合

getPermissions

Enumeration<Permission> getPermissions(Principal user)
指定された主体 (個人またはグループなどのエンティティーを表す) に対して許可されたアクセス権のセットに対する列挙を返します。許可されるアクセス権のセットは次のようにして決定されます。

パラメータ:
user - そのアクセス権セットを返す主体
戻り値:
主体に許可されるアクセス権を指定するアクセス権セット

entries

Enumeration<AclEntry> entries()
この ACL 内のエントリの列挙を返します。列挙中の各要素は AclEntry 型です。

戻り値:
この ACL 内のエントリの列挙

checkPermission

boolean checkPermission(Principal principal,
                        Permission permission)
指定された主体が指定されたアクセス権を持っているかどうかを判定します。持っている場合は true を返し、そうでない場合は false を返します。 より詳しく説明すると、このメソッドは、指定されたアクセス権が指定された主体の許可アクセス権セットのメンバーであるかどうかを確認します。許可アクセス権セットは、getPermissions メソッドと同じアルゴリズムに基づいて決定されます。

パラメータ:
principal - 主体。有効な認証済みの主体を前提とする
permission - 判定対象のアクセス権
戻り値:
主体が指定されたアクセス権を持つ場合は true、そうでない場合は false
関連項目:
getPermissions(java.security.Principal)

toString

String toString()
ACL の内容を文字列表現で返します。

オーバーライド:
クラス Object 内の toString
戻り値:
ACL の内容の文字列表現

JavaTM Platform
Standard Ed. 6

バグの報告と機能のリクエスト
さらに詳しい API リファレンスおよび開発者ドキュメントについては、Java SE 開発者用ドキュメントを参照してください。開発者向けの詳細な解説、概念の概要、用語の定義、バグの回避策、およびコード実例が含まれています。

Copyright 2009 Sun Microsystems, Inc. All rights reserved. Use is subject to license terms. Documentation Redistribution Policy も参照してください。