Gewusst wie: Ändern von Typen in Proxyklassen, die generiert werden mit WSDL.exe verwendet

SPRACHE AUSWÄHLEN SPRACHE AUSWÄHLEN
Artikel-ID: 326790 - Produkte anzeigen, auf die sich dieser Artikel bezieht
Alles erweitern | Alles schließen

Auf dieser Seite

Zusammenfassung

Der Web Services Description Language-Tool (WSDL.exe) generiert Proxycode für XML-Webdienste. Die generierten Typen, die in der Proxyklasse dienen basieren auf dem Inhalt der WSDL-Dokument, die den XML-Webdienst beschreibt. Die generierten Typen möglicherweise jedoch nicht, was soll und was Sie erwarten.

WSDL.exe bestimmt die beste generierten Typ für die Objekte, die in der Dienstbeschreibung angegeben sind. In einigen Fällen verwendet das Tool einen Ansatz am wenigsten-gemeinsamen Nenner für Umwandlung Objekte ein. Z. B. wird ein ArrayList -Parameter in einer WebMethod beschrieben, in WSDL als XML-Schema (XSD) Reihenfolge. Wenn WSDL.exe eine Proxyklasse generiert anschließend dieses Arraybeschreibung in der Dienstbeschreibung WSDL.exe findet verwendet, die ein Object-Array. Möglicherweise möchten Sie arbeiten mit einer ArrayList , wurde der ursprüngliche Typ, der in der WebMethod verwendet wurde. Wenn Sie nicht, die generierten Typen zu verwenden möchten, können Sie die generierten Typen in sinnvoller Typen ändern. Den Typ des entsprechenden Objekts zu erhalten, können Sie öffnen die Datei, die die generierte Proxyklasse enthält, manuell den generierten Methodenparameter ändern und dann Rückgabetypen den entsprechenden Objekttypen.

Proxy-Code generieren

Im folgenden Beispiel der XML-Dienst hat den Webdienst-Methode mit dem folgenden Prototyp:
string DummyMethod(System.Collections.ArrayList intList)
				
können Sie WSDL.exe verwenden, um die Proxy-Quelldatei zu generieren.

Manuelles Ändern des Codes

  1. Öffnen Sie die Proxy-Quelldatei in einem Text-Editor.
  2. Suchen Sie die beiden Methoden:
            public string DummyMethod(object[] intList) {
                object[] results = this.Invoke("DummyMethod", new object[] {
                            intList});
                return ((string)(results[0]));
            }
    
            public System.IAsyncResult BeginDummyMethod(object[] intList, System.AsyncCallback callback, object asyncState) {
                return this.BeginInvoke("DummyMethod", new object[] {
                            intList}, callback, asyncState);
            }
    					
  3. Ändern Sie den Code zu:
            public string DummyMethod(System.Collections.ArrayList intList) {
                object[] results = this.Invoke("DummyMethod", new object[] {
                            intList});
                return ((string)(results[0]));
            }
    
            public System.IAsyncResult BeginDummyMethod(System.Collections.ArrayList intList, System.AsyncCallback callback, object asyncState) {
                return this.BeginInvoke("DummyMethod", new object[] {
                            intList}, callback, asyncState);
            }
    					

Weitere Informationen

XML-Webdiensten Objekte in XML serialisieren und Deserialisieren die XML zurück zu Objekten. Im Allgemeinen kann ein Objekt eines bestimmten Typs serialisiert und deserialisiert anschließend einem anderen Objekt desselben Typs werden. Jedoch, wenn Sie verschiedene Arten verwenden, dies funktioniert nicht.



Informationsquellen

Weitere Informationen darüber, wie Typen serialisiert und deserialisiert werden die folgende Microsoft-Website:
XML and SOAP Serialization
http://msdn.microsoft.com/library/?url=/library/en-us/cpguide/html/cpconserialization.asp?frame=true


Eigenschaften

Artikel-ID: 326790 - Geändert am: Montag, 28. April 2003 - Version: 4.1
Die Informationen in diesem Artikel beziehen sich auf:
  • Microsoft Web Services (included with the .NET Framework) 1.0
  • Microsoft Web Services Enhancements for Microsoft .NET 1.1
Keywords: 
kbmt kbhowtomaster KB326790 KbMtde
Maschinell übersetzter Artikel
Wichtig: Dieser Artikel wurde maschinell und nicht von einem Menschen übersetzt. Die Microsoft Knowledge Base ist sehr umfangreich und ihre Inhalte werden ständig ergänzt beziehungsweise überarbeitet. Um Ihnen dennoch alle Inhalte auf Deutsch anbieten zu können, werden viele Artikel nicht von Menschen, sondern von Übersetzungsprogrammen übersetzt, die kontinuierlich optimiert werden. Doch noch sind maschinell übersetzte Texte in der Regel nicht perfekt, insbesondere hinsichtlich Grammatik und des Einsatzes von Fremdwörtern sowie Fachbegriffen. Microsoft übernimmt keine Gewähr für die sprachliche Qualität oder die technische Richtigkeit der Übersetzungen und ist nicht für Probleme haftbar, die direkt oder indirekt durch Übersetzungsfehler oder die Verwendung der übersetzten Inhalte durch Kunden entstehen könnten.
Den englischen Originalartikel können Sie über folgenden Link abrufen: 326790
Microsoft stellt Ihnen die in der Knowledge Base angebotenen Artikel und Informationen als Service-Leistung zur Verfügung. Microsoft übernimmt keinerlei Gewährleistung dafür, dass die angebotenen Artikel und Informationen auch in Ihrer Einsatzumgebung die erwünschten Ergebnisse erzielen. Die Entscheidung darüber, ob und in welcher Form Sie die angebotenen Artikel und Informationen nutzen, liegt daher allein bei Ihnen. Mit Ausnahme der gesetzlichen Haftung für Vorsatz ist jede Haftung von Microsoft im Zusammenhang mit Ihrer Nutzung dieser Artikel oder Informationen ausgeschlossen.
Disclaimer zu nicht mehr gepflegten KB-Inhalten
Dieser Artikel wurde für Produkte verfasst, für die Microsoft keinen Support mehr anbietet. Der Artikel wird deshalb in der vorliegenden Form bereitgestellt und nicht mehr weiter aktualisiert.

Ihr Feedback an uns

 

Contact us for more help

Contact us for more help
Connect with Answer Desk for expert help.
Get more support from smallbusiness.support.microsoft.com