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 SiteIdentityPermission
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 Schnittmenge der von beiden Berechtigungen beschriebenen Sites wiedergibt. Eine Anforderung über die Schnittmenge ist nur erfolgreich, wenn sie beide ursprünglichen Berechtigungen erfolgreich durchläuft. Die Schnittmenge einer Berechtigung, die den Zugriff auf www.fourthcoffee.com darstellt, und einer, die den Zugriff auf *.fourthcoffee.com darstellt, ist eine Berechtigung, die den Zugriff auf www.fourthcoffee.com darstellt.
Die Schnittmenge zweier identischer Berechtigungen für die Site-Identität ist ein und dieselbe Berechtigung. Die Schnittmenge zweier verschiedener Ausdrücke (ohne Platzhalterzeichen) ist eine leere Berechtigung. Die Schnittmenge eines Ausdrucks mit Platzhalterzeichen und einer übereinstimmenden Site ist die Site. Die Schnittmenge zweier Ausdrücke mit Platzhalterzeichen, die einander entsprechen, ist der längere und genauere der beiden Ausdrücke.
Beispiel
Das folgende Beispiel veranschaulicht die Ergebnisse der Verwendung der Intersect-Methode, jedoch nicht deren Verwendung. Dieser Code ist Teil eines umfangreicheren Beispiels. Sie sollten das gesamte Beispiel erstellen und ausführen und dann die Ausgabe anzeigen. Das vollständige Beispiel finden Sie in der SiteIdentityPermission-Klasse.
' 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 returnCodeCode As Boolean = True
Dim site1 As [String] = ""
Dim site2 As [String] = ""
Dim siteIdPerm1, siteIdPerm2, p3 As SiteIdentityPermission
Dim siteGen1 As New SiteGenerator()
Dim siteGen2 As New SiteGenerator()
siteGen1.ResetIndex()
While siteGen1.CreateSite(site1)
siteIdPerm1 = siteGen1.CreatePerm(site1)
If siteIdPerm1 Is Nothing Then
GoTo ContinueWhile1
End If
siteGen2.ResetIndex()
Console.WriteLine("**************************************************************************")
While siteGen2.CreateSite(site2)
siteIdPerm2 = siteGen2.CreatePerm(site2)
If siteIdPerm2 Is Nothing Then
GoTo ContinueWhile2
End If
Dim firstSite As [String] = IIf(site1 Is Nothing, "null", site1)
Dim secondSite As [String] = IIf(site2 Is Nothing, "null", site2)
Try
p3 = CType(siteIdPerm1.Intersect(siteIdPerm2), SiteIdentityPermission)
Dim thirdSite As [String] = IIf(p3.Site Is Nothing, "null", p3.Site.ToString())
If Not (p3 Is Nothing) Then
Console.WriteLine(("The intersection of " & firstSite & " and " & ControlChars.Lf & ControlChars.Tab & secondSite & " = " & thirdSite & ControlChars.Lf))
Else
Console.WriteLine(("The intersection of " & firstSite & " and " & ControlChars.Lf & ControlChars.Tab & secondSite & " = null." & ControlChars.Lf))
End If
Catch
Console.WriteLine(("The intersection of " & firstSite & " and " & ControlChars.Lf & ControlChars.Tab & secondSite & " = null." & ControlChars.Lf))
End Try
ContinueWhile2:
End While
ContinueWhile1:
End While
Return returnCodeCode
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 returnCodeCode = true;
String site1, site2;
SiteIdentityPermission siteIdPerm1, siteIdPerm2, p3;
SiteGenerator siteGen1 = new SiteGenerator();
SiteGenerator siteGen2 = new SiteGenerator();
siteGen1.ResetIndex();
while (siteGen1.CreateSite(out site1))
{
siteIdPerm1 = siteGen1.CreatePerm(site1);
if (siteIdPerm1 == null ) continue;
siteGen2.ResetIndex();
Console.WriteLine("**************************************************************************");
while (siteGen2.CreateSite(out site2))
{
siteIdPerm2 = siteGen2.CreatePerm(site2);
if (siteIdPerm2 == null ) continue;
String firstSite = site1 == null ? "null" : site1;
String secondSite = site2 == null ? "null" : site2;
try
{
p3 = (SiteIdentityPermission)siteIdPerm1.Intersect(siteIdPerm2);
String thirdSite = p3.Site == null ? "null" : p3.Site;
if (p3 != null)
{
Console.WriteLine("The intersection of " + firstSite + " and \n\t" + secondSite + " = " + thirdSite + "\n");
}
else
{
Console.WriteLine("The intersection of " + firstSite + " and \n\t" + secondSite + " = null.\n");
}
}
catch
{
Console.WriteLine("The intersection of " + firstSite + " and \n\t" + secondSite + " = null.\n");
}
}
}
return returnCodeCode;
}
// Intersect creates and returns a new permission that is the intersection of the
// current permission and the permission specified.
bool IntersectDemo()
{
bool returnCodeCode = true;
String^ site1;
String^ site2;
SiteIdentityPermission^ siteIdPerm1;
SiteIdentityPermission^ siteIdPerm2;
SiteIdentityPermission^ p3;
SiteGenerator^ siteGen1 = gcnew SiteGenerator;
SiteGenerator^ siteGen2 = gcnew SiteGenerator;
siteGen1->ResetIndex();
while ( siteGen1->CreateSite( &site1 ) )
{
siteIdPerm1 = siteGen1->CreatePerm(&site1);
if ( siteIdPerm1 == nullptr )
continue;
siteGen2->ResetIndex();
Console::WriteLine( "**************************************************************************" );
while ( siteGen2->CreateSite( &site2 ) )
{
siteIdPerm2 = siteGen2->CreatePerm(&site2);
if ( siteIdPerm2 == nullptr )
continue;
String^ firstSite = site1 == nullptr ? "0" : site1;
String^ secondSite = site2 == nullptr ? "0" : site2;
try
{
p3 = dynamic_cast<SiteIdentityPermission^>(siteIdPerm1->Intersect( siteIdPerm2 ));
String^ thirdSite = p3->Site == nullptr ? "0" : p3->Site;
if ( p3 != nullptr )
{
Console::WriteLine( "The intersection of {0} and \n\t{1} = {2}\n", firstSite, secondSite, thirdSite );
}
else
{
Console::WriteLine( "The intersection of {0} and \n\t{1} = null.\n", firstSite, secondSite );
}
}
catch ( Exception^ )
{
Console::WriteLine( "The intersection of {0} and \n\t{1} = null.\n", firstSite, secondSite );
}
}
}
return returnCodeCode;
}
// Intersect creates and returns a new permission that is the intersection
// of the current permission and the permission specified.
private boolean IntersectDemo()
{
boolean returnCodeCode = true;
String site1[] = new String[1];
String site2[] = new String[1];
boolean successFlag[] = new boolean[1];
SiteIdentityPermission siteIdPerm1[] = new SiteIdentityPermission[1];
SiteIdentityPermission siteIdPerm2[] = new SiteIdentityPermission[1];
SiteIdentityPermission p3 = null;
SiteGenerator siteGen1 = new SiteGenerator();
SiteGenerator siteGen2 = new SiteGenerator();
siteGen1.ResetIndex();
while(siteGen1.CreateSite(siteIdPerm1, site1, successFlag)) {
if (siteIdPerm1 == null | successFlag[0] == false) {
continue ;
}
siteGen2.ResetIndex();
Console.WriteLine("***************************************"
+ "***********************************");
while(siteGen2.CreateSite(siteIdPerm2, site2, successFlag)) {
if (siteIdPerm2[0] == null | successFlag[0] == false) {
continue ;
}
String firstSite = (site1[0] == null) ? "null" : site1[0];
String secondSite = (site2[0] == null) ? "null" : site2[0];
try {
p3 =((SiteIdentityPermission)(siteIdPerm1[0].
Intersect(siteIdPerm2[0])));
String thirdSite = (p3.get_Site() == null) ?
"null" : p3.get_Site();
if (p3 != null) {
Console.WriteLine(("The intersection of " + firstSite
+ " and \n\t" + secondSite + " = "
+ thirdSite + "\n"));
}
else {
Console.WriteLine(("The intersection of " + firstSite
+ " and \n\t" + secondSite + " = null.\n"));
}
}
catch(Exception exp) {
Console.WriteLine(("The intersection of " + firstSite
+ " and \n\t" + secondSite + " = null.\n"));
}
}
}
return returnCodeCode ;
} //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
SiteIdentityPermission-Klasse
SiteIdentityPermission-Member
System.Security.Permissions-Namespace