Skip to content

Um módulo para a consulta de endereços usando o Web Service da ViaCep.

License

Notifications You must be signed in to change notification settings

tisanches/ViaCep

 
 

Repository files navigation

ViaCep

Um módulo para a consulta de endereços usando o Web Service da ViaCep.

Características

  • Fácil manipulação.
  • Retorna todos os formatos (Json, Xml, Piped, Querty).
  • Uso da Interface Fluent.
  • Uso de Callback Methods.

Como Utilizar

Primeiro você precisa instanciar um objeto da classe ViaCepService.

var viaCepService = new ViaCepService();

Existem duas formas de consultar endereços.

  • Consultando por Cep.

Crie um objeto do tipo Cep ou use uma string se preferir.

Cep cep = "01001000";

var endereco = viaCepService.ObterEndereco(cep); // viaCep.ObterEndereco("01001000");

Nesse caso o endereço será retornado como um objeto do tipo Endereco. Se desejar retornar como outros formatos:

var enderecoJson = viaCepService.ObterEnderecoComoJson(cep); //viaCep.ObterEnderecoComoJson("01001000");

Você ainda pode retornar com Xml, Piped, ou Querty utilizando os métodos ObterEnderecoComoXml , ObterEnderecoComoPiped e ObterEnderecoComoQuerty, respectivamente, ambos métodos da classe ViaCepService.

  • Consultando por Endereco

A consulta também pode ser realizada a partir de três parâmetros: Sigla do estado, Nome da Cidade, e Nome do Logradouro.

var requisicao = new EnderecoRequisicao {
                    UF = UF.RS,
                    Cidade = "Porto Alegre",
                    Logradouro = "Olavo"
                };

var enderecos = viaCepService.ObterEnderecos(requisicao);

Neste exemplo será pesquisado na cidade de "Porto Algre/RS" por todos os logradouros que contenham "Olavo" em seu nome. Quando o nome da cidade ou do logradouro não contiver ao menos três caracteres será lançado uma Exception;

O resultado desta consulta é um IEnumerable<Endereco> contendo todos os resultados. Caso nenhum endereço seja encontrado uma lista vazia será retornada.

Use os métodos ObterEnderecosComoJson e ObterEnderecosComoXml, ambos da classe ViaCepService, para retornar os resultados nos formatos Json e Xml, respectivamente.

A classe ViaCepService também fornece métodos assíncronos.

var xml = await viaCepService.ObterEnderecoComoXmlAsync("01001000");
  • Fluent Interface

Para facilitar ainda mais as consultas utilize a Fluent Interface veja como é simples.

var json = ViaCepFluent.De("01001000").ComoJson();

Se desejar utilizar callbacks adicione o namespace MosaicoSolutions.ViaCep.Fluent.Callback.

var requisicao = new EnderecoRequisicao {
                    UF = UF.RS,
                    Cidade = "Porto Alegre",
                    Logradouro = "Olavo"
                };

ViaCepFluent.De(requisicao)
            .ComoListaDeEnderecos(enderecos => {
                foreach(var endereco in enderecos)
                {
                      Console.WriteLine($"Cep: {endereco.Cep}");
                      Console.WriteLine($"Cidade: {endereco.Localidade}");
                      Console.WriteLine($"Logradouro: {endereco.Logradouro}");
                      Console.WriteLine(Environment.NewLine);
                }
             });

Você pode consultar mais sobre fluent aqui.

Dependências

Newtonsoft.Json 9.0.1

About

Um módulo para a consulta de endereços usando o Web Service da ViaCep.

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • C# 100.0%