Um módulo para a consulta de endereços usando o Web Service da ViaCep.
- Fácil manipulação.
- Retorna todos os formatos (Json, Xml, Piped, Querty).
- Uso da Interface Fluent.
- Uso de Callback Methods.
Primeiro você precisa instanciar um objeto da classe ViaCepService.
var viaCepService = ViaCepService.Default();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); //viaCepService.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.
ViaCepFluent.RequisicaoPorCep
.ComOsDados("01001000")
.RetorneComoJson(Console.WriteLine);A novidade é poder capturar e tratar qualquer Exception lançada.
var cep = "01001000";
await ViaCepFluent.RequisicaoPorCep
.ComOsDados(cep)
.Capture(e => Console.WriteLine($"Erro ao tentar consultar o endereço com o Cep {cep}. Descrição: {e.Message}"))
.RetorneComoEnderecoAsync(Console.WriteLine);Você pode consultar mais sobre fluent aqui.
Se você estiver utilizando o SimpleInjector:
var container = new SimpleInjector.Container();
container.Options.DefaultScopedLifestyle = new WebRequestLifestyle();
container.Register<IViaCepService, ViaCepService>();
container.Register<IViaCepCliente, ViaCepCliente>();
container.Register<IEnderecoConvert, EnderecoConvert>();
container.Register<IViaCepRequisicaoPorCepFactory, ViaCepRequisicaoPorCepFactory>();
container.Register<IViaCepRequisicaoPorEnderecoFactory, ViaCepRequisicaoPorEnderecoFactory>();
container.RegisterMvcControllers(Assembly.GetExecutingAssembly());
DependencyResolver.SetResolver(new SimpleInjectorDependencyResolver(container));Depois basta injetar a Dependência via Construtor.
public class EmpresaController : Controller
{
private readonly IViaCepService _viaCepService;
public EmpresaController(IViaCepService viaCepService)
{
_viaCepService = viaCepService;
}
public Task<ActionResult> Index()
{
var endereco = await _viaCepService.ObterEnderecoAsync("01001000");
return View(endereco);
}
}Se você estiver utilizando o AspNet Core:
public void ConfigureServices(IServiceCollection services)
{
services.Configure<CookiePolicyOptions>(options =>
{
// This lambda determines whether user consent for non-essential cookies is needed for a given request.
options.CheckConsentNeeded = context => true;
options.MinimumSameSitePolicy = SameSiteMode.None;
});
services.AddMvc().SetCompatibilityVersion(CompatibilityVersion.Version_2_2);
services.AddScoped<IViaCepService>(serviceProvider => ViaCepService.Default());
}Newtonsoft.Json >= 11.0.1