Практическое руководство. Просмотр содержимого сборки
Вы можете использовать Ildasm.exe (IL Disassembler) для просмотра сведений о общем промежуточном языке (CIL) в файле. Если анализируемый файл является сборкой, то эти данные могут включать в себя атрибуты сборки, а также ссылки на другие модули и сборки. Эти данные полезны для определения того, является ли файл сборкой или частью сборки и содержит ли он ссылки на другие модули и сборки.
Чтобы отобразить содержимое сборки с помощью Ildasm.exe, введите имя> сборки ildasm <в командной строке. Например, следующая команда дизассемблирует сборку Hello.exe.
ildasm Hello.exe
Чтобы просмотреть сведения о манифесте сборки, дважды щелкните значок манифеста в окне disassembler IL.
Пример
Следующий пример начинается с простой программы "Hello World". После компиляции программы используйте Ildasm.exe, чтобы декомпилировать сборку Hello.exe и просмотреть манифест сборки.
using namespace System;
class MainApp
{
public:
static void Main()
{
Console::WriteLine("Hello World using C++/CLI!");
}
};
int main()
{
MainApp::Main();
}
using System;
class MainApp
{
public static void Main()
{
Console.WriteLine("Hello World using C#!");
}
}
Class MainApp
Public Shared Sub Main()
Console.WriteLine("Hello World using Visual Basic!")
End Sub
End Class
При выполнении команды ildasm.exe сборки Hello.exe и дважды щелкните значок манифеста в окне дизассемблера IL, выведя следующие выходные данные:
// Metadata version: v4.0.30319
.assembly extern mscorlib
{
.publickeytoken = (B7 7A 5C 56 19 34 E0 89 ) // .z\V.4..
.ver 4:0:0:0
}
.assembly Hello
{
.custom instance void [mscorlib]System.Runtime.CompilerServices.CompilationRelaxationsAttribute::.ctor(int32) = ( 01 00 08 00 00 00 00 00 )
.custom instance void [mscorlib]System.Runtime.CompilerServices.RuntimeCompatibilityAttribute::.ctor() = ( 01 00 01 00 54 02 16 57 72 61 70 4E 6F 6E 45 78 // ....T..WrapNonEx
63 65 70 74 69 6F 6E 54 68 72 6F 77 73 01 ) // ceptionThrows.
.hash algorithm 0x00008004
.ver 0:0:0:0
}
.module Hello.exe
// MVID: {7C2770DB-1594-438D-BAE5-98764C39CCCA}
.imagebase 0x00400000
.file alignment 0x00000200
.stackreserve 0x00100000
.subsystem 0x0003 // WINDOWS_CUI
.corflags 0x00000001 // ILONLY
// Image base: 0x00600000
В следующей таблице описаны все директивы в манифесте сборки Hello.exe, используемой в этом примере.
Директива | Description |
---|---|
.assembly extern <имя_сборки> | Определяет другую сборку, содержащую элементы, на которые имеются ссылки в текущем модуле (в этом примере — mscorlib ). |
.publickeytoken <маркер> | Определяет маркер действующего ключа сборки, на которую имеется ссылка. |
.ver <номер_версии> | Задает номер версии, на которую имеется ссылка. |
.assembly <имя_сборки> | Задает имя сборки. |
.hash algorithm <значение_int32> | Задает используемый хэш-алгоритм. |
.ver <номер_версии> | Задает номер версии сборки. |
.module <имя_файла> | Задает имена модулей, составляющих сборку. В этом примере сборка состоит только из одного файла. |
.subsystem <значение> | Указывает требуемую для программы среду приложения. В этом примере значение "3" указывает на то, что выполняемый модуль запускается на консоли. |
.corflags | В настоящее время представляет собой зарезервированное поле метаданных. |
Манифест сборки может содержать несколько различных директив, зависящих от содержимого сборки. Подробный список директив в манифесте сборки см. в документации ecma, особенно "Partition II: Metadata Definition and Semantics" (Определение метаданных и семантика секции III: набор инструкций CIL):
- Стандарты ECMA для C# и Common Language Infrastructure
- Стандарт ECMA-335 — Common Language Infrastructure (CLI)