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 ZoneIdentityPermission
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 gehört nicht zum gleichen 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.
Die Schnittmenge zwei identischer ZoneIdentityPermission-Objekte ist dieselbe Berechtigung. Alle sonstigen Kombinationen ergeben eine Berechtigung, die NULL (Nothing in Visual Basic) ist.
Beispiel
' Intersect creates and returns a new permission that is the intersection of the current
' permission and the permission specified.
Private Function IntersectDemo() As Boolean
Dim returnValue As Boolean = True
Dim zone1, zone2 As SecurityZone
Dim zoneIdPerm1, zoneIdPerm2, zoneIdPerm3 As ZoneIdentityPermission
Dim zoneGen1 As New ZoneGenerator()
Dim zoneGen2 As New ZoneGenerator()
zoneGen1.ResetIndex()
While zoneGen1.CreateZone(zone1)
zoneIdPerm1 = New ZoneIdentityPermission(zone1)
Console.WriteLine("**********************************************************" & ControlChars.Cr)
zoneGen2.ResetIndex()
While zoneGen2.CreateZone(zone2)
zoneIdPerm2 = New ZoneIdentityPermission(zone2)
zoneIdPerm3 = CType(zoneIdPerm1.Intersect(zoneIdPerm2), ZoneIdentityPermission)
If Not (zoneIdPerm3 Is Nothing) Then
Console.WriteLine(("The intersection of " & zone1.ToString() & " and " & _
zone2.ToString() & " = " & CType(zoneIdPerm3, Object).SecurityZone.ToString()))
Else
Console.WriteLine(("The intersection of " & zone1.ToString() & " and " & _
zone2.ToString() & " is null."))
End If
ContinueWhile2:
End While
ContinueWhile1:
End While
Return returnValue
End Function 'IntersectDemo
// Intersect creates and returns a new permission that is the intersection of the current
// permission and the permission specified.
private bool IntersectDemo()
{
bool returnValue = true;
SecurityZone zone1, zone2;
ZoneIdentityPermission zoneIdPerm1, zoneIdPerm2, zoneIdPerm3;
ZoneGenerator zoneGen1 = new ZoneGenerator();
ZoneGenerator zoneGen2 = new ZoneGenerator();
zoneGen1.ResetIndex();
while (zoneGen1.CreateZone(out zone1))
{
zoneIdPerm1 = new ZoneIdentityPermission( zone1);
Console.WriteLine("**********************************************************\n");
zoneGen2.ResetIndex();
while (zoneGen2.CreateZone(out zone2))
{
zoneIdPerm2 = new ZoneIdentityPermission( zone2);
zoneIdPerm3 = (ZoneIdentityPermission)zoneIdPerm1.Intersect(zoneIdPerm2);
if (zoneIdPerm3 != null)
{
Console.WriteLine("The intersection of " + zone1 + " and " + zone2 + " = " +
((ZoneIdentityPermission)zoneIdPerm3).SecurityZone.ToString());
}
else
{
Console.WriteLine("The intersection of " + zone1 + " and " + zone2 + " is null.");
}
}
}
return returnValue;
}
// Intersect creates and returns a new permission that is the intersection of the current
// permission and the permission specified.
bool IntersectDemo()
{
bool returnValue = true;
SecurityZone zone1;
SecurityZone zone2;
ZoneIdentityPermission^ zoneIdPerm1;
ZoneIdentityPermission^ zoneIdPerm2;
ZoneIdentityPermission^ zoneIdPerm3;
ZoneGenerator^ zoneGen1 = gcnew ZoneGenerator;
ZoneGenerator^ zoneGen2 = gcnew ZoneGenerator;
zoneGen1->ResetIndex();
while ( zoneGen1->CreateZone( &zone1 ) )
{
zoneIdPerm1 = gcnew ZoneIdentityPermission( zone1 );
Console::WriteLine( "**********************************************************\n" );
zoneGen2->ResetIndex();
while ( zoneGen2->CreateZone( &zone2 ) )
{
zoneIdPerm2 = gcnew ZoneIdentityPermission( zone2 );
zoneIdPerm3 = dynamic_cast<ZoneIdentityPermission^>(zoneIdPerm1->Intersect( zoneIdPerm2 ));
if ( zoneIdPerm3 != nullptr )
{
Console::WriteLine( "The intersection of {0} and {1} = {2}", zone1, zone2, (dynamic_cast<ZoneIdentityPermission^>(zoneIdPerm3))->SecurityZone );
}
else
{
Console::WriteLine( "The intersection of {0} and {1} is null.", zone1, zone2 );
}
}
}
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;
SecurityZone zone1[] = new SecurityZone[1];
SecurityZone zone2[] = new SecurityZone[1];
ZoneIdentityPermission zoneIdPerm1[] = new ZoneIdentityPermission[1];
ZoneIdentityPermission zoneIdPerm2[] = new ZoneIdentityPermission[1];
ZoneIdentityPermission zoneIdPerm3 = null;
ZoneGenerator zoneGen1 = new ZoneGenerator();
ZoneGenerator zoneGen2 = new ZoneGenerator();
zoneGen1.ResetIndex();
while (zoneGen1.CreateZone(zoneIdPerm1, zone1)) {
if (zoneIdPerm1[0] == null) {
continue;
}
Console.WriteLine("**********************************"
+ "************************\n");
zoneGen2.ResetIndex();
while (zoneGen2.CreateZone(zoneIdPerm2, zone2)) {
if (zoneIdPerm2[0] == null) {
continue;
}
zoneIdPerm3 = ((ZoneIdentityPermission)(zoneIdPerm1[0].
Intersect(zoneIdPerm2[0])));
if (zoneIdPerm3 != null) {
Console.WriteLine(("The intersection of " + zone1[0]
+ " and " + zone2[0] + " = " +
((ZoneIdentityPermission)(zoneIdPerm3)).
get_SecurityZone().ToString()));
}
else {
Console.WriteLine(("The intersection of " + zone1[0]
+ " and " + zone2[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
ZoneIdentityPermission-Klasse
ZoneIdentityPermission-Member
System.Security.Permissions-Namespace