ObfuscateAssemblyAttribute クラス


該当するアセンブリ型に対して標準の隠ぺい規則を使用するように、難読化ツールに指示します。Instructs obfuscation tools to use their standard obfuscation rules for the appropriate assembly type.

public ref class ObfuscateAssemblyAttribute sealed : Attribute
public sealed class ObfuscateAssemblyAttribute : Attribute
[System.AttributeUsage(System.AttributeTargets.Assembly, AllowMultiple=false, Inherited=false)]
public sealed class ObfuscateAssemblyAttribute : Attribute
[System.AttributeUsage(System.AttributeTargets.Assembly, AllowMultiple=false, Inherited=false)]
public sealed class ObfuscateAssemblyAttribute : Attribute
type ObfuscateAssemblyAttribute = class
    inherit Attribute
[<System.AttributeUsage(System.AttributeTargets.Assembly, AllowMultiple=false, Inherited=false)>]
type ObfuscateAssemblyAttribute = class
    inherit Attribute
[<System.AttributeUsage(System.AttributeTargets.Assembly, AllowMultiple=false, Inherited=false)>]
type ObfuscateAssemblyAttribute = class
    inherit Attribute
Public NotInheritable Class ObfuscateAssemblyAttribute
Inherits Attribute

次のコード例は、でマークされたプライベートアセンブリを示してい ObfuscateAssemblyAttribute ます。The following code example shows a private assembly that has been marked with the ObfuscateAssemblyAttribute. StripAfterObfuscationプロパティは false であり、難読化ツールが処理後に属性を削除しないようにします。The StripAfterObfuscation property is false, to prevent the obfuscation tool from stripping the attribute after processing.

でのの使用を示すコード例に ObfuscateAssemblyAttribute つい ObfuscationAttribute ては、クラスを参照してください ObfuscationAttributeFor a code example that shows the use of ObfuscateAssemblyAttribute with ObfuscationAttribute, see the ObfuscationAttribute class.

using System;
using System.Reflection;

[assembly: ObfuscateAssemblyAttribute(true,
Imports System.Reflection

<Assembly: ObfuscateAssemblyAttribute(False, _


ObfuscationAttribute属性と ObfuscateAssemblyAttribute 属性は、難読化ツールが最小限の外部構成で正しく処理できるように、アセンブリの作成者がバイナリに注釈を付ける方法を提供します。The ObfuscationAttribute and ObfuscateAssemblyAttribute attributes provide a way for assembly authors to annotate their binaries so that obfuscation tools can process them correctly with minimal external configuration.

アセンブリにこの属性を適用すると、難読化ツールはアセンブリの種類に既定の規則を使用するように指示します。Applying this attribute to an assembly tells the obfuscation tool to use its default rules for the assembly type.


この属性を適用しても、アセンブリは自動的に難読化されません。Applying this attribute does not automatically obfuscate the assembly. 属性を適用することは、難読化ツールの構成ファイルを作成する方法の1つです。Applying the attribute is an alternative to creating a configuration file for the obfuscation tool. つまり、難読化ツールの手順を説明するだけです。That is, it merely provides instructions for an obfuscation tool. 難読化ツールのベンダーは、ここで説明するセマンティクスに従うことをお勧めします。Microsoft recommends that vendors of obfuscation tools follow the semantics described here. ただし、特定のツールが Microsoft の推奨事項に従うという保証はありません。However, there is no guarantee that a particular tool follows Microsoft recommendations.

ObfuscationAttributeアセンブリ内の型、およびそれらの型のメンバーにを適用できます。You can apply ObfuscationAttribute to types within an assembly, and to members on those types. 最も内側の属性は、難読化ツールが特定のコードエンティティを扱う方法を制御します。The innermost attribute controls the way an obfuscation tool treats any particular code entity.



隠ぺいするアセンブリがパブリックであるかプライベートであるかを指定して、ObfuscateAssemblyAttribute クラスの新しいインスタンスを初期化します。Initializes a new instance of the ObfuscateAssemblyAttribute class, specifying whether the assembly to be obfuscated is public or private.



アセンブリがプライベートとしてマークされているかどうかを示す Boolean 値を取得します。Gets a Boolean value indicating whether the assembly was marked private.


難読化ツールが処理後に属性を削除する必要があるかどうかを示す Boolean 値を取得または設定します。Gets or sets a Boolean value indicating whether the obfuscation tool should remove the attribute after processing.


派生クラスで実装されると、この Attribute の一意の識別子を取得します。When implemented in a derived class, gets a unique identifier for this Attribute.

(継承元 Attribute)



このインスタンスが、指定されたオブジェクトと等価であるかどうかを示す値を返します。Returns a value that indicates whether this instance is equal to a specified object.

(継承元 Attribute)

このインスタンスのハッシュ コードを返します。Returns the hash code for this instance.

(継承元 Attribute)

現在のインスタンスの Type を取得します。Gets the Type of the current instance.

(継承元 Object)

派生クラスでオーバーライドされるとき、このインスタンスの値が派生クラスの既定値であるかどうかを示します。When overridden in a derived class, indicates whether the value of this instance is the default value for the derived class.

(継承元 Attribute)

派生クラス内でオーバーライドされたときに、指定したオブジェクトとこのインスタンスが等しいかどうかを示す値を返します。When overridden in a derived class, returns a value that indicates whether this instance equals a specified object.

(継承元 Attribute)

現在の Object の簡易コピーを作成します。Creates a shallow copy of the current Object.

(継承元 Object)

現在のオブジェクトを表す文字列を返します。Returns a string that represents the current object.

(継承元 Object)


_Attribute.GetIDsOfNames(Guid, IntPtr, UInt32, UInt32, IntPtr)

一連の名前を対応する一連のディスパッチ識別子に割り当てます。Maps a set of names to a corresponding set of dispatch identifiers.

(継承元 Attribute)
_Attribute.GetTypeInfo(UInt32, UInt32, IntPtr)

オブジェクトの型情報を取得します。この情報はインターフェイスの型情報の取得に使用できます。Retrieves the type information for an object, which can be used to get the type information for an interface.

(継承元 Attribute)

オブジェクトが提供する型情報インターフェイスの数 (0 または 1) を取得します。Retrieves the number of type information interfaces that an object provides (either 0 or 1).

(継承元 Attribute)
_Attribute.Invoke(UInt32, Guid, UInt32, Int16, IntPtr, IntPtr, IntPtr, IntPtr)

オブジェクトによって公開されたプロパティおよびメソッドへのアクセスを提供します。Provides access to properties and methods exposed by an object.

(継承元 Attribute)