方法: 署名のないフレンド アセンブリを作成する (C# および Visual Basic)
次の例は、署名のないアセンブリと共にフレンド アセンブリを使用する方法を示しています。
Visual Studio でアセンブリとフレンド アセンブリを作成するには
Visual Studio コマンド プロンプトを開きます。
次のコードを含む、friend_signed_A という名前の Visual Basic ファイルまたは C# ファイルを作成します。 このコードは、InternalsVisibleToAttribute 属性により、friend_signed_B をフレンド アセンブリとして宣言します。
' friend_unsigned_A.vb ' Compile with: ' Vbc /target:library friend_unsigned_A.vb Imports System.Runtime.CompilerServices Imports System <Assembly: InternalsVisibleTo("friend_unsigned_B")> ' Friend type. Friend Class Class1 Public Sub Test() Console.WriteLine("Class1.Test") End Sub End Class ' Public type with Friend member. Public Class Class2 Friend Sub Test() Console.WriteLine("Class2.Test") End Sub End Class
// friend_unsigned_A.cs // Compile with: // csc /target:library friend_unsigned_A.cs using System.Runtime.CompilerServices; using System; [assembly: InternalsVisibleTo("friend_unsigned_B")] // Type is internal by default. class Class1 { public void Test() { Console.WriteLine("Class1.Test"); } } // Public type with internal member. public class Class2 { internal void Test() { Console.WriteLine("Class2.Test"); } }
次のコマンドを使用して friend_signed_A をコンパイルおよび署名します。
Vbc /target:library friend_unsigned_A.vb
csc /target:library friend_unsigned_A.cs
次のコードを含む、friend_unsigned_B という名前の Visual Basic ファイルまたは C# ファイルを作成します。 friend_unsigned_A が friend_unsigned_B をフレンド アセンブリとして指定しているため、friend_unsigned_B 内のコードは、friend_unsigned_A の Friend 型 (Visual Basic) または internal 型 (C#) とそのメンバーにアクセスできます。
' friend_unsigned_B.vb ' Compile with: ' Vbc /r:friend_unsigned_A.dll friend_unsigned_B.vb Module Module1 Sub Main() ' Access a Friend type. Dim inst1 As New Class1() inst1.Test() Dim inst2 As New Class2() ' Access a Friend member of a public type. inst2.Test() System.Console.ReadLine() End Sub End Module
// friend_unsigned_B.cs // Compile with: // csc /r:friend_unsigned_A.dll /out:friend_unsigned_B.exe friend_unsigned_B.cs public class Program { static void Main() { // Access an internal type. Class1 inst1 = new Class1(); inst1.Test(); Class2 inst2 = new Class2(); // Access an internal member of a public type. inst2.Test(); System.Console.ReadLine(); } }
次のコマンドを使用して friend_signed_B をコンパイルします。
Vbc /r:friend_unsigned_A.dll friend_unsigned_B.vb
csc /r:friend_unsigned_A.dll /out:friend_unsigned_B.exe friend_unsigned_B.cs
コンパイラによって生成されるアセンブリの名前は、InternalsVisibleToAttribute 属性に渡されるフレンド アセンブリ名と一致している必要があります。 /out コンパイラ オプションを使用すると、アセンブリを明示的に設定できます。
C# では、/out コンパイラ オプションを使用して出力アセンブリ (.exe または .dll) の名前を明示的に指定する必要があります。 Visual Basic の場合、これは省略可能です。 詳細については、「/out (Visual Basic)」および「/out (C# コンパイラ オプション)」を参照してください。
friend_signed_B.exe ファイルを実行します。
このプログラムでは、2 つの文字列 "Class1.Test" と "Class2.Test" が出力されます。
セキュリティ
InternalsVisibleToAttribute 属性と StrongNameIdentityPermission クラスには、いくつかの類似点があります。 主な違いは、StrongNameIdentityPermission は特定のコード セクションを実行するのにセキュリティ アクセス許可を要求し、InternalsVisibleToAttribute 属性は Friend 型 (Visual Basic) または internal 型 (C#) とそのメンバーの参照可能範囲を制御するという点です。
参照
処理手順
方法: 署名されたフレンド アセンブリを作成する (C# および Visual Basic)
関連項目
概念
アセンブリとグローバル アセンブリ キャッシュ (C# および Visual Basic)
フレンド アセンブリ (C# および Visual Basic)