Compartilhar via


Interoperabilidade com serviços Web ASMX

A amostra de ASMX demonstra como integrar um aplicativo cliente do Windows Communication Foundation (WCF) a um serviço Web ASMX existente.

Observação

O procedimento de instalação e as instruções de compilação dessa amostra estão no final deste tópico.

Esta amostra consiste em um programa de console do cliente (.exe) e uma biblioteca de serviços (.dll) hospedada pelos Serviços de Informações da Internet (IIS). O serviço é um serviço Web ASMX que implementa um contrato que define um padrão de comunicação solicitação-resposta. O serviço expõe operações matemáticas (Add, Subtract, Multiply e Divide). O cliente faz solicitações síncronas para uma operação matemática e o serviço responde com o resultado. A atividade do cliente é visível na janela do console.

A implementação do serviço Web ASMX mostrada no código de amostra a seguir calcula e retorna o resultado apropriado.

[WebService(Namespace="http://Microsoft.ServiceModel.Samples")]
public class CalculatorService : System.Web.Services.WebService
    {
        [WebMethod]
        public double Add(double n1, double n2)
        {
            return n1 + n2;
        }
        [WebMethod]
        public double Subtract(double n1, double n2)
        {
            return n1 - n2;
        }
        [WebMethod]
        public double Multiply(double n1, double n2)
        {
            return n1 * n2;
        }
        [WebMethod]
        public double Divide(double n1, double n2)
        {
            return n1 / n2;
        }
    }

Conforme configurado, o serviço pode ser acessado em http://localhost/servicemodelsamples/service.asmx por um cliente no mesmo computador. Para que os clientes em computadores remotos acessem o serviço, um nome de domínio qualificado deve ser especificado em vez do localhost.

A comunicação é feita por meio de um cliente gerado pela Ferramenta de utilitário de metadados ServiceModel (Svcutil.exe). O cliente está contido no arquivo generatedClient.cs. O serviço ASMX deve estar disponível para gerar o código proxy, pois ele é usado para recuperar os metadados atualizados. Execute o comando a seguir em um prompt de comando no diretório do cliente para gerar o proxy tipado.

svcutil.exe /n:http://Microsoft.ServiceModel.Samples,Microsoft.ServiceModel.Samples http://localhost/servicemodelsamples/service.svc?wsdl /out:generatedClient.cs

Usando o cliente gerado, você pode acessar um ponto de extremidade de serviço configurando o endereço e a associação apropriados. Assim como o serviço, o cliente usa um arquivo de configuração (App.config) para especificar o ponto de extremidade com o qual se comunicar. A configuração do ponto de extremidade do cliente consiste em um endereço absoluto para o ponto de extremidade de serviço, a associação e o contrato, conforme mostrado na configuração de amostra a seguir.

<client>
   <endpoint
      address="http://localhost/ServiceModelSamples/service.asmx"
      binding="basicHttpBinding"
      contract="Microsoft.ServiceModel.Samples.CalculatorServiceSoap" />
</client>

A implementação do cliente constrói uma instância do cliente gerado. Em seguida, o cliente gerado pode ser usado para se comunicar com o serviço.

// Create a client.
CalculatorServiceSoapClient client = new CalculatorServiceSoapClient();

// Call the Add service operation.
double value1 = 100.00D;
double value2 = 15.99D;
double result = client.Add(value1, value2);
Console.WriteLine("Add({0},{1}) = {2}", value1, value2, result);

// Call the Subtract service operation.
value1 = 145.00D;
value2 = 76.54D;
result = client.Subtract(value1, value2);
Console.WriteLine("Subtract({0},{1}) = {2}", value1, value2, result);

// Call the Multiply service operation.
value1 = 9.00D;
value2 = 81.25D;
result = client.Multiply(value1, value2);
Console.WriteLine("Multiply({0},{1}) = {2}", value1, value2, result);

// Call the Divide service operation.
value1 = 22.00D;
value2 = 7.00D;
result = client.Divide(value1, value2);
Console.WriteLine("Divide({0},{1}) = {2}", value1, value2, result);

//Closing the client gracefully closes the connection and cleans up resources.
client.Close();

Console.WriteLine();
Console.WriteLine("Press <ENTER> to terminate client.");
Console.ReadLine();

Quando você executa a amostra, as solicitações de operação e as respostas são exibidas na janela do console do cliente. Pressione ENTER na janela do cliente para desligar o cliente.

Add(100,15.99) = 115.99
Subtract(145,76.54) = 68.46
Multiply(9,81.25) = 731.25
Divide(22,7) = 3.14285714285714

Press <ENTER> to terminate client.

Para configurar, compilar, e executar o exemplo

  1. Verifique se você executou o Procedimento de instalação única para os exemplos do Windows Communication Foundation.

  2. Para compilar a edição .NET do C# ou do Visual Basic da solução, siga as instruções contidas em Como Compilar as Amostras do Windows Communication Foundation.

  3. Para executar a amostra em uma configuração de computador único ou entre computadores, siga as instruções contidas em Como executar as amostras do Windows Communication Foundation.