次の方法で共有


PublisherIdentityPermission.Intersect メソッド

現在のアクセス許可と指定したアクセス許可の積集合を表すアクセス許可を作成して返します。

Overrides Public Function Intersect( _
   ByVal target As IPermission _) As IPermission Implements IPermission.Intersect
[C#]
public override IPermission Intersect(IPermissiontarget);
[C++]
public: IPermission* Intersect(IPermission* target);
[JScript]
public override function Intersect(
   target : IPermission) : IPermission;

パラメータ

  • target
    現在のアクセス許可との積集合を持つアクセス許可。これは、現在のアクセス許可と同じ型であることが必要です。

戻り値

現在のアクセス許可と指定したアクセス許可の積集合を表す新しいアクセス許可。積集合が空の場合、この新しいアクセス許可は null 参照 (Visual Basic では Nothing) です。

実装

IPermission.Intersect

例外

例外の種類 条件
ArgumentException target パラメータが null 参照 (Visual Basic では Nothing) ではなく、現在のアクセス許可と同じ型でもありません。

解説

2 つのアクセス許可の積集合となるアクセス許可には、両方に共通する操作の集合が記述されています。2 つのアクセス許可を要求し、その両方について要求が満たされる場合にだけ、それらの積集合を表すアクセス許可に対する要求も満たされます。

現在のアクセス許可が、指定したアクセス許可と等しい場合、 PublisherIdentityPermission は set 操作 (IsSubsetOfIntersect 、および Union) だけをサポートします。

使用例

 
' 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 retCode As Boolean = True

    Dim publisher1, publisher2 As [String]
    Dim pubIdPerm1, pubIdPerm2, p3 As PublisherIdentityPermission

    Dim pubGen1 As New PublisherGenerator()
    Dim pubGen2 As New PublisherGenerator()

    pubGen1.ResetIndex()
    While pubGen1.CreatePublisher(pubIdPerm1, publisher1)
        If pubIdPerm1 Is Nothing Or pubIdPerm1.Certificate Is Nothing Then
            GoTo ContinueWhile1
        End If
        pubGen2.ResetIndex()
        While pubGen2.CreatePublisher(pubIdPerm2, publisher2)
            If pubIdPerm2 Is Nothing Or pubIdPerm2.Certificate Is Nothing Then
                GoTo ContinueWhile2
            End If
            p3 = CType(pubIdPerm1.Intersect(pubIdPerm2), PublisherIdentityPermission)
            If Not (p3 Is Nothing) AndAlso Not (p3.Certificate Is Nothing) Then

                Console.WriteLine(("The intersection of " & pubIdPerm1.Certificate.GetName() & " and  " & pubIdPerm2.Certificate.GetName() & " = " & CType(p3, PublisherIdentityPermission).Certificate.GetName()))
            Else
                Console.WriteLine(("The intersection of " & pubIdPerm1.Certificate.GetName() & " and " & pubIdPerm2.Certificate.GetName() & " is null."))
            End If
ContinueWhile2:
        End While
ContinueWhile1:
    End While


    Return retCode
End Function 'IntersectDemo


[C#] 
// Intersect creates and returns a new permission that is the intersection of the 
// current permission and the permission specified.
    private bool IntersectDemo()
    {

        bool retCode = true;

        String publisher1,publisher2;
        PublisherIdentityPermission pubIdPerm1,pubIdPerm2,p3;

        PublisherGenerator pubGen1 = new PublisherGenerator();
        PublisherGenerator pubGen2 = new PublisherGenerator();

        pubGen1.ResetIndex();
        while(pubGen1.CreatePublisher(out pubIdPerm1, out publisher1)) 
        {
            if(pubIdPerm1 == null | pubIdPerm1.Certificate == null) continue;
            pubGen2.ResetIndex();
            while(pubGen2.CreatePublisher(out pubIdPerm2, out publisher2)) 
            {
            if(pubIdPerm2 == null | pubIdPerm2.Certificate == null) continue;
                p3 = (PublisherIdentityPermission)pubIdPerm1.Intersect(pubIdPerm2);
                if (p3 != null && p3.Certificate != null)
                {

                    Console.WriteLine("The intersection of " + pubIdPerm1.Certificate.GetName() + " and  "  + 
                        pubIdPerm2.Certificate.GetName() + " = " + 
                        ((PublisherIdentityPermission)p3).Certificate.GetName());
                }
                else
                {
                    Console.WriteLine("The intersection of " + pubIdPerm1.Certificate.GetName() + " and "  + 
                        pubIdPerm2.Certificate.GetName() + " is null.");
                }

            }
        }


        return retCode;

    }

[C++] 
// Intersect creates and returns a new permission that is the intersection of the 
// current permission and the permission specified.
bool IntersectDemo()
{

   bool retCode = true;

   String* publisher1;
   String* publisher2;

   PublisherIdentityPermission* pubIdPerm1;
   PublisherIdentityPermission* pubIdPerm2;
   PublisherIdentityPermission* p3;


   PublisherGenerator* pubGen1 = new PublisherGenerator();
   PublisherGenerator* pubGen2 = new PublisherGenerator();

   pubGen1->ResetIndex();
   while(pubGen1->CreatePublisher(&pubIdPerm1, &publisher1)) 
   {
      if(pubIdPerm1 == 0 || pubIdPerm1->Certificate == 0) continue;
      pubGen2->ResetIndex();
      while(pubGen2->CreatePublisher(&pubIdPerm2, &publisher2)) 
      {
         if(pubIdPerm2 == 0 || pubIdPerm2->Certificate == 0) continue;
         p3 = dynamic_cast<PublisherIdentityPermission*>(pubIdPerm1->Intersect(pubIdPerm2));
         if (p3 != 0 && p3->Certificate != 0)
         {

            Console::WriteLine(S"The intersection of {0} and  {1} = {2}",
               pubIdPerm1->Certificate->GetName(),
               pubIdPerm2->Certificate->GetName(), 
               (dynamic_cast<PublisherIdentityPermission*>(p3))->Certificate->GetName());
         }
         else
         {
            Console::WriteLine(S"The intersection of {0} and {1} is null.",
               pubIdPerm1->Certificate->GetName(), pubIdPerm2->Certificate->GetName());
         }

      }
   }


   return retCode;

}

[JScript] JScript のサンプルはありません。Visual Basic、C#、および C++ のサンプルを表示するには、このページの左上隅にある言語のフィルタ ボタン 言語のフィルタ をクリックします。

必要条件

プラットフォーム: Windows 98, Windows NT 4.0, Windows Millennium Edition, Windows 2000, Windows XP Home Edition, Windows XP Professional, Windows Server 2003 ファミリ

参照

PublisherIdentityPermission クラス | PublisherIdentityPermission メンバ | System.Security.Permissions 名前空間