Exemplarische Vorgehensweise: Umleiten einer Anwendung an einen anderen Webdienst während der Installation
Aktualisiert: November 2007
Diese exemplarische Vorgehensweise demonstriert die Erstellung einer Webanwendung, die unter Verwendung der URL Behavior-Eigenschaft, einer Installerklasse und eines Websetup-Projekts an einen anderen Webdienst umgeleitet werden kann. Dies ist nützlich, wenn Sie einen Webdienst während der Entwicklung lokal als Ziel und eine Produktionsversion des Webdiensts bei der Bereitstellung der Anwendung verwenden möchten.
Hinweis: |
---|
Je nach den aktiven Einstellungen oder der verwendeten Version können sich die angezeigten Dialogfelder und Menübefehle von den in der Hilfe beschriebenen unterscheiden. Klicken Sie im Menü Extras auf Einstellungen importieren und exportieren, um die Einstellungen zu ändern. Weitere Informationen finden Sie unter Visual Studio-Einstellungen. |
Erstellen des Webanwendungs-Projekts
Der erste Schritt besteht im Erstellen eines ASP.NET-Webanwendungsprojekts, das einen Webverweis zu einem Webdienst enthält.
So erstellen Sie das Projekt
- Erstellen Sie eine Webanwendung mit einem Webverweis zu einem Webdienst. Für diese exemplarische Vorgehensweise genügt ein Webverweis auf einen beliebigen gültigen Webdienst. Beispielsweise können Sie die unter Exemplarische Vorgehensweise: Zugreifen auf einen Webdienst mit Visual Basic oder Visual C# beschriebene Webanwendung verwenden.
Hinzufügen einer Installerklasse
Installerklassen, auch als Installationskomponenten bezeichnet, sind .NET Framework-Klassen, die während der Installation als benutzerdefinierte Aktionen aufgerufen werden. In diesem Fall wird der Projektmappe ein Klassenbibliotheks-Projekt hinzugefügt. In diesem Klassenbibliotheks-Projekt erstellen Sie eine Installerklasse und überschreiben ihre Install-Methode, wobei Sie Code zum Ändern der CONFIG-Datei der Webanwendung hinzufügen. Weitere Informationen zu Installerklassen finden Sie unter Einführung in Installationskomponenten.
So erstellen Sie ein Klassenbibliotheks-Projekt
Klicken Sie mit der rechten Maustaste auf den Projektmappenknoten im Projektmappen-Explorer, klicken Sie auf Hinzufügen, und klicken Sie dann auf Neues Projekt.
Wählen Sie im Dialogfeld Neues Projekt hinzufügen im Visual Basic-Knoten die Option Klassenbibliothek aus.
Nennen Sie das Projekt InstallerClassLibrary.
So fügen Sie eine Installerklasse hinzu und implementieren diese
Klicken Sie im Projektmappen-Explorer mit der rechten Maustaste auf den InstallerClassLibrary-Projektknoten, klicken Sie auf Hinzufügen, und klicken Sie dann auf Klasse.
Wählen Sie im Dialogfeld Neues Element hinzufügen den Eintrag Installerklasse, und ändern Sie den Namen in WebServiceInstaller.vb.
Wenn Sie auf Hinzufügen klicken, wird die Klasse zum Projekt hinzugefügt und der Designer für die Installerklasse geöffnet.
Doppelklicken Sie auf den Designer, um den Code-Editor zu öffnen.
Fügen Sie in WebServiceInstaller.vb den folgenden Code am Ende des Moduls Installerklasse hinzu (genau oberhalb der End Class-Deklaration), mit dem die Install-Methode implementiert wird:
Public Overrides Sub Install(ByVal stateSaver As _ System.Collections.IDictionary) ' Gets the parameter passed across in the CustomActionData. Dim installlog As New System.IO.StreamWriter("Installation.log") installlog.AutoFlush = True Try Dim ProvidedName As String = Me.Context.Parameters.Item("ServerName") Dim SvcName As String = Me.Context.Parameters.Item("ServiceName") installlog.WriteLine("Starting Edit of the config file") If ProvidedName = "" Or SvcName = "" Then Throw New InstallException("No arguments specified") End If ' Uses reflection to find the location of the config file. Dim Asm As System.Reflection.Assembly = _ System.Reflection.Assembly.GetExecutingAssembly Dim strConfigLoc As String strConfigLoc = Asm.Location Dim strTemp As String strTemp = strConfigLoc strTemp = strTemp.Remove(strTemp.LastIndexOf("\"), Len(strTemp) - _ strTemp.LastIndexOf("\")) strTemp = strTemp.Remove(strTemp.LastIndexOf("\"), Len(strTemp) - _ strTemp.LastIndexOf("\")) Dim FileInfo As System.IO.FileInfo = New System.IO.FileInfo( _ strTemp & "\web.config") installlog.WriteLine("File info: " & strTemp) If Not FileInfo.Exists Then Throw New InstallException("Missing config file") End If ' Loads the config file into the XML DOM. Dim XmlDocument As New System.Xml.XmlDocument() XmlDocument.Load(FileInfo.FullName) ' Finds the right node and change it to the new value. Dim Node As System.Xml.XmlNode Dim FoundIt As Boolean = False For Each Node In _ XmlDocument.Item("configuration").Item("appSettings") ' Skips any comments. If Node.Name = "add" Then If Node.Attributes.GetNamedItem("key").Value = _ "servername.service" Then ' Note that "Service1.asmx" should be replaced with the ' actual name of the XML Web service file. Node.Attributes.GetNamedItem("value").Value = "http://" _ & ProvidedName & "/" & SvcName & "/Service1.asmx" FoundIt = True End If End If Next Node If Not FoundIt Then Throw New InstallException("Config file did not contain a ServerName section") End If ' Writes out the new config file. XmlDocument.Save(FileInfo.FullName) Finally installlog.WriteLine("Ending edit of config file") installlog.Close() End Try End Sub
Mit dem oben genannten Code wird zunächst eine Installationsprotokolldatei erstellt, in der der Fortschritt der benutzerdefinierten Aktion aufgezeichnet wird. Der System.Reflection-Namespace wird zum Suchen der zu installierenden Assembly sowie der zugehörigen CONFIG-Datei verwendet. Das XML-Dokumentmodell wird verwendet, um die CONFIG-Datei bis zum Abschnitt appSettings zu durchlaufen. Wenn der Schlüssel servername.service gefunden wird, wird der zugehörige Wert so geändert, dass die übergebenen Parameter aufgenommen werden. Dadurch wird die Anwendung umgeleitet und der neue Webdienst verwendet.
Doppelklicken Sie im Projektmappen-Explorer auf die Datei Web.config, um sie zu öffnen.
Kopieren Sie den Wert des Schlüssels für den Webdienst in den Abschnitt appSettings. Der Schlüssel weist das Format servername.service auf, wobei servername der Server ist, auf dem sich der Webdienst befindet, und service der Name des Webdiensts ist.
Öffnen Sie das Modul Installerklasse im Code-Editor, und ersetzen Sie den Text "servername.service" durch den im vorherigen Schritt kopierten Wert.
Hinzufügen eines Websetup-Projekts
Setup-Projekte werden zum Erstellen eines Installationsprogramms für die Anwendung verwendet. Setup-Projekte basieren auf Windows Installer-Technologie. Sie umfassen u. a. Features zum Ausführen von benutzerdefinierten Aktionen bei der Installation und Anpassen der Benutzeroberfläche für die Installation. Weitere Informationen über Setup-Projekte finden Sie unter Bereitstellen von Anwendungen und Komponenten.
So fügen Sie ein Websetup-Projekt hinzu
Klicken Sie mit der rechten Maustaste auf den Projektmappenknoten im Projektmappen-Explorer, klicken Sie auf Hinzufügen, und klicken Sie dann auf Neues Projekt.
Erweitern Sie im Dialogfeld Neues Projekt hinzufügen im Bereich Projekttypen den Knoten Andere Projekttypen, und wählen Sie den Knoten Setup- und Bereitstellungsprojekte aus.
Wählen Sie im Bereich Vorlagen die Option Websetup-Projekt aus. Geben Sie im Feld Name den Projektnamen WebAppSetup ein.
Wenn Sie auf OK klicken, wird das Projekt zur Projektmappe hinzugefügt, und der Dateisystem-Editor wird geöffnet.
Wählen Sie im Eigenschaftenfenster die ProductName-Eigenschaft aus, und legen Sie diese auf den Namen der Webanwendung fest.
Wählen Sie im Dateisystem-Editor den Webanwendungsordner aus.
Zeigen Sie im Menü Aktion auf Hinzufügen, und klicken Sie auf Projektausgabe.
Wählen Sie im Dialogfeld Projektausgabegruppe hinzufügen aus der Dropdownliste Projekt den Eintrag InstallerClassLibrary aus, und wählen Sie dann Primäre Ausgabe aus.
Wenn Sie auf OK klicken, wird dem Websetup-Projekt die primäre Ausgabe von InstallerClassLibrary hinzugefügt.
Hinzufügen einer benutzerdefinierten Aktion
Mit benutzerdefinierten Aktionen wird die Ausführung eines Codes nach Abschluss der Installation möglich. Dadurch lassen sich Aktionen ausführen, die nicht während der Installation verarbeitet werden können. Der Code für eine benutzerdefinierte Aktion kann in einer DLL-, EXE-, Skript- oder Assemblydatei enthalten sein. Weitere Informationen zu benutzerdefinierten Aktionen finden Sie unter Verwalten von benutzerdefinierten Aktionen bei der Bereitstellung.
So fügen Sie die Installerklasse als benutzerdefinierte Aktion hinzu
Wählen Sie im Projektmappen-Explorer das Projekt WebAppSetup aus.
Klicken Sie im Menü Ansicht auf Editor, und klicken Sie anschließend auf Benutzerdefinierte Aktionen.
Der Editor für benutzerdefinierte Aktionen wird angezeigt.
Wählen Sie im Editor für benutzerdefinierte Aktionen den Knoten Installieren aus.
Klicken Sie im Menü Aktion auf Benutzerdefinierte Aktion hinzufügen.
Doppelklicken Sie auf den Webanwendungsordner, wählen Sie dann Primäre Ausgabe von InstallerClassLibrary (Aktiv) aus.
Stellen Sie im Eigenschaftenfenster sicher, dass die InstallerClass-Eigenschaft auf True festgelegt ist.
Wählen Sie die CustomActionData-Eigenschaft, und geben Sie den folgenden Text ein: /ServerName=[EDITA1] /ServiceName=[EDITA2]
Die CustomActionData-Eigenschaft umfasst zwei durch ein Leerzeichen voneinander getrennte Parameter, die an die benutzerdefinierte Aktion übergeben werden.
Hinzufügen eines Dialogfelds
Während der Installation werden Benutzeroberflächendialogfelder zum Erfassen von Informationen zum Benutzer angezeigt. Weitere Informationen zu Dialogen der Benutzeroberfläche finden Sie unter Verwalten der Benutzeroberfläche bei der Bereitstellung.
So fügen Sie ein Benutzeroberflächendialogfeld hinzu
Wählen Sie im Projektmappen-Explorer das Setup-Projekt aus.
Zeigen Sie im Menü Ansicht auf Editor, und klicken Sie anschließend auf Benutzeroberfläche.
Wählen Sie im Benutzeroberflächen-Editor unter Installieren den Knoten Start aus.
Klicken Sie im Menü Aktion auf Dialogfeld hinzufügen.
Wählen Sie im Dialogfeld Dialogfeld hinzufügen das Dialogfeld Textfelder (A) aus, und klicken Sie auf OK.
Wählen Sie im Menü Aktion den Eintrag Nach oben so oft aus, bis sich das Dialogfeld Textfelder (A) über dem Dialogfeld Installationsadresse befindet.
Legen Sie im Eigenschaftenfenster die folgenden Eigenschaften fest:
Eigenschaft
Wert
BannerText
Geben Sie den Namen des Servers und des Diensts ein.
Edit1Label
Servername:
Edit1Value
Localhost
Hinweis: Gibt einen Standardserver an. Sie können hier einen eigenen Standardservernamen eingeben.
Edit2Label
Dienstname:
Edit2Value
<Name des Diensts>
Edit3Visible
False
Edit4Visible
False
Beachten Sie, dass die Edit1Property-Eigenschaft auf "EDITA1" und die Edit2Property-Eigenschaft auf "EDITA2" festgelegt ist. Diese beiden Werte entsprechen den Werten, die Sie im Editor für benutzerdefinierte Aktionen in die CustomActionData-Eigenschaft eingegeben haben. Wenn der Benutzer während der Installation Text in diese Edit-Steuerelemente eingibt, werden diese Werte automatisch mithilfe der CustomActionData-Eigenschaft weitergegeben.
Erstellen und Bereitstellen der Anwendung
Im letzten Schritt erfolgt die Erstellung des Setup-Projekts, damit das Installationsprogramm erstellt werden kann. Dann wird die Anwendung auf dem Zielserver installiert.
So erstellen Sie das Setup-Projekt
- Wählen Sie im Menü Erstellen die Option Projektname erstellen aus, wobei Projektname der Name des Setup-Projekts ist.
So geben Sie die Anwendung an einen Webserver auf Ihrem Entwicklungscomputer weiter
Wählen Sie im Projektmappen-Explorer das Setup-Projekt aus.
Klicken Sie im Menü Projekt auf Installieren.
So geben Sie die Anwendung an einen Webserver auf einem anderen Computer weiter
Navigieren Sie in Windows Explorer zu dem Projektverzeichnis, und suchen Sie das erstellte Installationsprogramm. Der Standardpfad ist \Dokumente und Einstellungen \Ihr Anmeldename\Eigene Dateien\Visual Studio Projects \Setup-Projektname\Projektkonfiguration\Produktname.msi. Die standardmäßige Projektkonfiguration ist Debug.
Kopieren Sie die MSI-Datei und alle anderen Dateien und Unterverzeichnisse in das Verzeichnis auf dem Webservercomputer.
Doppelklicken Sie auf dem Webservercomputer auf die Datei Setup.exe, um den Installer auszuführen.
Siehe auch
Konzepte
Einführung in Installationskomponenten
Weitere Ressourcen
Bereitstellen von Anwendungen und Komponenten
Verwalten von benutzerdefinierten Aktionen bei der Bereitstellung