IAssemblyPostProcessor IAssemblyPostProcessor IAssemblyPostProcessor IAssemblyPostProcessor Interface

Definition

Definiert die Methode, die eine Klasse implementiert, um eine Assembly zu verarbeiten, nachdem diese erstellt wurde.Defines the method a class implements to process an assembly after the assembly has been built.

public interface class IAssemblyPostProcessor : IDisposable
public interface IAssemblyPostProcessor : IDisposable
type IAssemblyPostProcessor = interface
    interface IDisposable
Public Interface IAssemblyPostProcessor
Implements IDisposable
Implementiert

Beispiele

Im folgenden Codebeispiel wird veranschaulicht, wie eine Implementierung der IAssemblyPostProcessor -Schnittstelle erstellt und in der Web. config-Datei einer Webanwendung registriert wird.The following code example demonstrates how to create an implementation of the IAssemblyPostProcessor interface, and register it in the Web.config file of a Web application.

Der erste Teil des Code Beispiels erstellt eine Klasse mit dem Samples.Process.postProcessTest Namen, die IAssemblyPostProcessor die-Schnittstelle implementiert.The first part of the code example creates a class named Samples.Process.postProcessTest that implements the IAssemblyPostProcessor interface. Diese Klasse führt die einfache Aktion zum Schreiben einer Datei aus, PostProcessAssembly wenn die-Methode aufgerufen wird.This class performs the simple action of writing a file when the PostProcessAssembly method is called.

using System;
using System.Web.Compilation;
using System.IO;

namespace Samples.Process
{
    public class postProcessTest : IAssemblyPostProcessor
    {
        public static void Main(String[] args)
        {
        }

        public void PostProcessAssembly(string path)
        {
            StreamWriter sw = File.CreateText(@"c:\compile\MyTest.txt");
            sw.WriteLine("Compiled assembly:");
            sw.WriteLine(path);
            sw.Close();
        }

        public void Dispose()
        {

        }
    }
}
Imports System.Web.Compilation
Imports System.IO

Namespace Samples.Process
    Public Class postProcessTest
        Implements IAssemblyPostProcessor

        Sub Main()

        End Sub

        Public Sub PostProcessAssembly(ByVal path As String) _
            Implements IAssemblyPostProcessor.PostProcessAssembly
            Dim sw As StreamWriter
            sw = File.CreateText("c:\compile\MyTest.txt")
            sw.WriteLine("Compiled assembly:")
            sw.WriteLine(path)
            sw.Close()
        End Sub

        Public Sub Dispose() Implements IDisposable.Dispose

        End Sub
    End Class
End Namespace

Kompilieren Sie die Klasse mit dem Befehl csc /target:library postProcessTest.csin eine DLL-Datei.Compile the class into a .dll file with the command csc /target:library postProcessTest.cs. Fügen Sie die resultierende DLL-Datei dem Ordner "bin" einer ASP.NET-Anwendung hinzu, und registrieren Sie die DLL-Datei in der Datei "Web. config", wie im folgenden Code gezeigt.Add the resulting .dll file to the Bin folder of an ASP.NET application and register the .dll in the Web.config file, as shown in the following code.

<compilation debug="true" assemblyPostProcessorType="Samples.Process.postProcessTest" />  

Wenn ein Benutzer die Website besucht, wird die Webanwendung dynamisch kompiliert, und die Datei myTest. txt wird in c:\compilegeschrieben.When a user visits the Web site, the Web application is dynamically compiled and the file MyTest.txt will be written to C:\compile.

Hinweise

Eine Klasse, die diese Schnittstelle implementiert, kann nach der Kompilierung auf eine Assembly zugreifen.A class implementing this interface can access an assembly after it has been compiled. Die AssemblyBuilder -Klasse kompiliert Assemblys und überprüft dann, ob IAssemblyPostProcessor eine Schnittstelle in der Webkonfigurationsdatei registriert wurde.The AssemblyBuilder class compiles assemblies and then checks to see whether an IAssemblyPostProcessor interface has been registered in the Web configuration file. Wenn dies der Fall AssemblyBuilder ist, ruft PostProcessAssembly die-Instanz IAssemblyPostProcessor die-Methode für die-Schnittstelle auf, um nach der Kompilierung und vor dem Laden der Assembly Aktionen auszuführenIf so, the AssemblyBuilder instance calls the PostProcessAssembly method for the IAssemblyPostProcessor interface to perform any action after the compilation and before loading the assembly. Ein Profiler-Tool könnte diese Schnittstelle beispielsweise implementieren, um Tests in der Assembly herzustellen.For example, a profiler tool could implement this interface to establish probes in the assembly.

Wenn eine IAssemblyPostProcessor Schnittstelle registriert wird, werden die ASP.NET-Anwendung und die zugehörigen Assemblys immer im Debugmodus kompiliert.When an IAssemblyPostProcessor interface is registered, the ASP.NET application and its assemblies will always be compiled in debug mode.

Methoden

Dispose() Dispose() Dispose() Dispose()

Führt anwendungsspezifische Aufgaben durch, die mit der Freigabe, der Zurückgabe oder dem Zurücksetzen von nicht verwalteten Ressourcen zusammenhängen.Performs application-defined tasks associated with freeing, releasing, or resetting unmanaged resources.

(Inherited from IDisposable)
PostProcessAssembly(String) PostProcessAssembly(String) PostProcessAssembly(String) PostProcessAssembly(String)

Wird aufgerufen, bevor die Assembly geladen wird, um der implementierenden Klasse das Ändern der Assembly zu ermöglichen.Called before the assembly is loaded to allow the implementing class to modify the assembly.

Gilt für: