Freigeben über


Gewusst wie: Migrieren von ASP.NET-Webdienstcode zu Windows Communication Foundation

Die folgende Prozedur beschreibt, wie ein ASP.NET-Webdienst zu Windows Communication Foundation (WCF) migriert wird.

Prozedur

So migrieren Sie ASP.NET-Webdienstcode zu WCF

  1. Stellen Sie sicher, dass für den Dienst ein umfassender Satz von Tests vorhanden ist.

  2. Generieren Sie die WSDL für den Dienst, und speichern Sie eine Kopie in dem Ordner, in dem sich auch die ASMX-Datei des Diensts befindet.

  3. Aktualisieren Sie den ASP.NET-Webdienst für die Verwendung von .NET 2.0. Stellen Sie zunächst .NET Framework 2.0 für die Anwendungen der IIS bereit, und automatisieren Sie anschließend mithilfe von Visual Studio 2005 den Codeumwandlungsprozess gemäß den Anweisungen in Schritt-für-Schritt-Anweisungen zum Umwandeln von Webprojekten aus Visual Studio .NET 2002/2003 für Visual Studio 2005 (möglicherweise in englischer Sprache). Führen Sie die Tests aus.

  4. Geben Sie explizite Werte für den Namespace und die Name-Parameter der WebService-Attribute an, sofern diese nicht bereits vorhanden sind. Führen Sie die gleichen Schritte für die MessageName-Parameter von WebMethodAttribute aus. Sind für die SOAPAction-HTTP-Header, gemäß denen Anforderungen zu Methoden geroutet werden, noch keine expliziten Werte angegeben, geben Sie explizit den Standardwert für den Action-Parameter mit einem SoapDocumentMethodAttribute an.

    [WebService(Namespace = "http://tempuri.org/", Name = "Adder")]
    public class Adder
    {
         [WebMethod(MessageName = "Add")]
         [SoapDocumentMethod(Action = "http://tempuri.org/Add")]
         public double Add(SumInput input)
         {
              double sum = 0.00;
              foreach (double inputValue in input.Input)
              {
                  sum += inputValue;
              }
          return sum;
         }
    }
    
  5. Testen Sie die Änderung.

  6. Verschieben Sie sämtlichen substanziellen Code im Textkörper der Methoden der Klasse in eine separate Klasse, die von der ursprünglichen Klasse verwendet wird.

    [WebService(Namespace = "http://tempuri.org/", Name = "Adder")]
    public class Adder
    {
         [WebMethod(MessageName = "Add")]
         [SoapDocumentMethod(Action = "http://tempuri.org/Add")]
         public double Add(SumInput input)
         {
              return new ActualAdder().Add(input);
         }
    }
    
    internal class ActualAdder
    {
         internal double Add(SumInput input)
         {
              double sum = 0.00;
              foreach (double inputValue in input.Input)
              {
                  sum += inputValue;
              }
          return sum;
         }
    }
    
  7. Testen Sie die Änderung.

  8. Fügen Sie dem ASP.NET-Webdienstprojekt Verweise auf die WCF-Assemblys System.ServiceModel und System.Runtime.Serialization hinzu.

  9. Führen Sie ServiceModel Metadata Utility Tool (Svcutil.exe) aus, um eine WCF-Clientklasse der WSDL zu generieren. Fügen Sie der Lösung das generierte Klassenmodul hinzu.

  10. Das im vorangehenden Schritt generierte Klassenmodul enthält die Definition einer Schnittstelle.

    [System.ServiceModel.ServiceContractAttribute()]
    public interface AdderSoap
    {
         [System.ServiceModel.OperationContractAttribute(
          Action="http://tempuri.org/Add", 
          ReplyAction="http://tempuri.org/Add")]
         AddResponse Add(AddRequest request);
    }
    

    Passen Sie die Definition der ASP.NET-Webdienstklasse so an, dass für die Klasse die Implementierung dieser Schnittstelle festgelegt ist. Im Folgenden finden Sie ein entsprechendes Codebeispiel.

    [WebService(Namespace = "http://tempuri.org/", Name = "Adder")]
    public class Adder: AdderSoap
    {
         [WebMethod(MessageName = "Add")]
         [SoapDocumentMethod(Action = "http://tempuri.org/Add")]
         public double Add(SumInput input)
         {
              return new ActualAdder().Add(input);
         }
    
         public AddResponse Add(AddRequest request)
         {
            return new AddResponse(
            new AddResponseBody(
            this.Add(request.Body.input)));
         }
    }
    
  11. Kompilieren Sie das Projekt. Aufgrund des in Schritt 9 generierten Codes treten möglicherweise einige Fehler auf, da einige Typdefinitionen dupliziert wurden. Beheben Sie diese Fehler. In der Regel ist hierzu das Löschen der bereits vorhandenen Typendefinitionen ausreichend. Testen Sie die Änderung.

  12. Entfernen Sie die ASP.NET-spezifischen Attribute. Beispiele: WebService, WebMethodAttribute und SoapDocumentMethodAttribute.

    public class Adder: AdderSoap
    {
         public double Add(SumInput input)
         {
              return new ActualAdder().Add(input);
         }
    
         public AddResponse Add(AddRequest request)
         {
              return new AddResponse(
             new AddResponseBody(
            this.Add(request.Body.input)));
         }
    }
    
  13. Konfigurieren Sie die Klasse, bei der es sich nun um eine WCF-Dienstklasse handelt, sodass der WCF-ASP.NET-Kompatibilitätsmodus verwendet wird, wenn der ASP.NET-Webdienst auf einem der folgenden Elemente beruht:

    • Der HttpContext-Klasse.
    • Den ASP.NET-Profilen.
    • Den ACLs für ASMX-Dateien.
    • Den IIS-Authentifizierungsoptionen.
    • Den Identitätswechseloptionen von ASP.NET.
    • Der ASP.NET-Globalisierung.
    [System.ServiceModel.AspNetCompatibilityRequirements(
      RequirementsMode=AspNetCompatbilityRequirementsMode.Required)]
    public class Adder: AdderSoap
    
  14. Benennen Sie die ursprüngliche ASMX-Datei zu .asmx.old um.

  15. Erstellen Sie für den Dienst eine WCF-Dienstdatei, versehen Sie sie mit der Erweiterung .asmx, und speichern Sie sie im Anwendungsstammverzeichnis der IIS.

    <%@Service Class="MyOrganization.Adder" %>
    <%@Assembly Name="MyServiceAssembly" %> 
    
  16. Fügen Sie der entsprechenden Web.config-Datei eine WCF-Konfiguration hinzu. Konfigurieren Sie den Dienst so, dass basicHttpBinding Element sowie die im vorangegangenen Schritt erstellte ASMX-Datei verwendet werden und keine eigene WSDL erstellt, sondern die WSDL aus dem zweiten Schritt verwendet wird. Konfigurieren Sie den Dienst zudem für die Verwendung des ASP.NET-Kompatibilitätsmodus (sofern erforderlich).

    <?xml version="1.0" encoding="utf-8" ?>
    <configuration>
     <system.web>
      <compilation>
      <buildProviders>
       <remove extension=".asmx" />
       <add extension=".asmx" 
        type=
        "System.ServiceModel.Activation.ServiceBuildProvider,
        T:System.ServiceModel, Version=2.0.0.0, 
       Culture=neutral, 
       PublicKeyToken=b77a5c561934e089" />
      </buildProviders>
      </compilation>
     </system.web>
     <system.serviceModel>
      <services>
      <service name="MyOrganization.Adder "
        behaviorConfiguration="AdderBehavior">
       <endpoint 
        address="”
        binding="basicHttpBinding"
        contract="AdderSoap "/>
       </service>
      </services>
      <behaviors>
      <behavior name="AdderBehavior">
       <metadataPublishing 
        enableMetadataExchange="true" 
        enableGetWsdl="true" 
        enableHelpPage="true" 
        metadataLocation=
        "http://MyHost.com/AdderService/Service.WSDL"/>
      </behavior>
      </behaviors>
      <serviceHostingEnvironment 
       aspNetCompatibilityEnabled ="true"/>
     </system.serviceModel>
    </configuration>
    
  17. Speichern Sie die Konfiguration.

  18. Kompilieren Sie das Projekt.

  19. Vergewissern Sie sich durch Ausführen der Tests, dass alle Änderungen ordnungsgemäß funktionieren.

Siehe auch

Aufgaben

Gewusst wie: Migrieren von ASP.NET-Webdienstcode zu Windows Communication Foundation