Hinweis
Für den Zugriff auf diese Seite ist eine Autorisierung erforderlich. Sie können versuchen, sich anzumelden oder das Verzeichnis zu wechseln.
Für den Zugriff auf diese Seite ist eine Autorisierung erforderlich. Sie können versuchen, das Verzeichnis zu wechseln.
Erstellt eine Berechtigung als Schnittmenge der aktuellen und der angegebenen Berechtigung und gibt diese zurück.
Namespace: System.Security.Permissions
Assembly: mscorlib (in mscorlib.dll)
Syntax
'Declaration
Public Overrides Function Intersect ( _
target As IPermission _
) As IPermission
'Usage
Dim instance As FileDialogPermission
Dim target As IPermission
Dim returnValue As IPermission
returnValue = instance.Intersect(target)
public override IPermission Intersect (
IPermission target
)
public:
virtual IPermission^ Intersect (
IPermission^ target
) override
public IPermission Intersect (
IPermission target
)
public override function Intersect (
target : IPermission
) : IPermission
Parameter
- target
Eine Berechtigung, deren Schnittmenge mit der aktuellen Berechtigung gebildet wird. Diese muss von demselben Typ wie die aktuelle Berechtigung sein.
Rückgabewert
Eine neue Berechtigung, die die Schnittmenge der aktuellen und der angegebenen Berechtigung darstellt. Diese neue Berechtigung ist NULL (Nothing in Visual Basic), wenn die Schnittmenge leer ist.
Ausnahmen
| Ausnahmetyp | Bedingung |
|---|---|
Der target-Parameter ist nicht NULL (Nothing in Visual Basic) und nicht von demselben Typ wie die aktuelle Berechtigung. |
Hinweise
Die Schnittmenge zweier Berechtigungen ist eine Berechtigung, die die von beiden Berechtigungen gemeinsam beschriebene Gruppe von Operationen wiedergibt. Eine Anforderung über die Schnittmenge ist nur erfolgreich, wenn sie beide ursprünglichen Berechtigungen erfolgreich durchläuft.
Beispiel
Im folgenden Codebeispiel soll lediglich das Verhalten der Intersect-Methode veranschaulicht werden, nicht ihre Verwendung. Im Allgemeinen werden die Methoden von Berechtigungsklassen durch die Sicherheitsinfrastruktur verwendet; sie sind nicht für die Verwendung in Anwendungen bestimmt. Im folgenden Codebeispiel wird jedoch veranschaulicht, wie sich die Methode verhält, wenn sie aus Ihrem Code ausgeführt wird. Den vollständigen Beispielcode finden Sie unter der FileDialogPermission-Klasse.
Private Function IntersectDemo() As Boolean
Dim returnValue As Boolean = True
fileDialogPerm3 = CType(fileDialogPerm1.Intersect(fileDialogPerm2), FileDialogPermission)
If Not (fileDialogPerm3 Is Nothing) Then
Console.WriteLine("The intersection of " + fileDialogPerm1.Access.ToString() + " and " _
+ fileDialogPerm2.Access.ToString() + " = " + CType(fileDialogPerm3, _
FileDialogPermission).Access.ToString())
Else
Console.WriteLine("The intersection of " + fileDialogPerm1.Access.ToString() + " and " + _
fileDialogPerm2.Access + " is null.")
End If
Return returnValue
End Function 'IntersectDemo
private bool IntersectDemo()
{
bool returnValue = true;
fileDialogPerm3 = (FileDialogPermission)fileDialogPerm1.Intersect(fileDialogPerm2);
if (fileDialogPerm3 != null)
{
Console.WriteLine("The intersection of " + fileDialogPerm1.Access +
" and " + fileDialogPerm2.Access + " = " +
((FileDialogPermission)fileDialogPerm3).Access.ToString());
}
else
{
Console.WriteLine("The intersection of " + fileDialogPerm1.Access +
" and " + fileDialogPerm2.Access + " is null.");
}
return returnValue;
}
bool IntersectDemo()
{
bool returnValue = true;
FileDialogPermission^ fileDialogIdPerm1 =
gcnew FileDialogPermission(FileDialogPermissionAccess::Open );
FileDialogPermission^ fileDialogIdPerm2 =
gcnew FileDialogPermission( FileDialogPermissionAccess::OpenSave );
FileDialogPermission^ fileDialogIdPerm3 =
gcnew FileDialogPermission(PermissionState::None);
//Console.WriteLine("\tfileDialogIdPerm2 = " +fileDialogIdPerm2.ToString());
fileDialogIdPerm3 = dynamic_cast<FileDialogPermission^>(fileDialogIdPerm1->Intersect( fileDialogIdPerm2 ));
if ( fileDialogIdPerm3 != nullptr )
{
Console::WriteLine( "The intersection of {0} and {1} = {2}",
fileDialogIdPerm1->Access, fileDialogIdPerm2->Access, (dynamic_cast<FileDialogPermission^>(fileDialogIdPerm3))->Access );
}
else
{
Console::WriteLine( "The intersection of {0} and {1} is null.",
fileDialogIdPerm1->Access, fileDialogIdPerm2->Access );
}
return returnValue;
}
// Intersect creates and returns a new permission that is the
// intersection of the current
// permission and the permission specified.
private boolean IntersectDemo()
{
boolean returnValue = true;
FileDialogPermissionAccess fileDialog1[] =
new FileDialogPermissionAccess[1];
FileDialogPermissionAccess fileDialog2[] =
new FileDialogPermissionAccess[1];
FileDialogPermission fileDialogIdPerm1[] =
new FileDialogPermission[1];
FileDialogPermission fileDialogIdPerm2[] =
new FileDialogPermission[1];
FileDialogPermission fileDialogIdPerm3 = null;
FileDialogGenerator fileDialogGen1 =
new FileDialogGenerator();
FileDialogGenerator fileDialogGen2 =
new FileDialogGenerator();
fileDialogGen1.ResetIndex();
while(fileDialogGen1.CreateFileDialog(
fileDialogIdPerm1, fileDialog1)) {
if (fileDialogIdPerm1[0] == null) {
continue ;
}
Console.WriteLine("***************************"
+ "*******************************\n");
fileDialogGen2.ResetIndex();
while(fileDialogGen2.CreateFileDialog(
fileDialogIdPerm2, fileDialog2)) {
if (fileDialogIdPerm2[0] == null) {
continue ;
}
fileDialogIdPerm3 =((FileDialogPermission)
(fileDialogIdPerm1[0].Intersect
(fileDialogIdPerm2[0])));
if (fileDialogIdPerm3 != null) {
Console.WriteLine(("The intersection of "
+ fileDialog1[0] + " and " + fileDialog2[0]
+ " = " +((FileDialogPermission)(fileDialogIdPerm3)).
get_Access().ToString()));
}
else {
Console.WriteLine(("The intersection of "
+ fileDialog1[0] + " and " + fileDialog2[0]
+ " is null."));
}
}
}
return returnValue ;
} //IntersectDemo
Plattformen
Windows 98, Windows 2000 SP4, Windows Millennium Edition, Windows Server 2003, Windows XP Media Center Edition, Windows XP Professional x64 Edition, Windows XP SP2, Windows XP Starter Edition
.NET Framework unterstützt nicht alle Versionen sämtlicher Plattformen. Eine Liste der unterstützten Versionen finden Sie unter Systemanforderungen.
Versionsinformationen
.NET Framework
Unterstützt in: 2.0, 1.1, 1.0
Siehe auch
Referenz
FileDialogPermission-Klasse
FileDialogPermission-Member
System.Security.Permissions-Namespace