BuscaCEP é uma biblioteca para consulta de endereços online, permitindo buscas por CEP (Código de Endereçamento Postal) ou por logradouro (UF, Localidade e Logradouro).
Implementado na linguagem Delphi
, utiliza o conceito de fluent interface para guiar no uso da biblioteca, desenvolvida para oferecer praticidade e eficiência, a BuscaCEP integra os principais players do mercado: Correios, ViaCEP, BrasilAPI, entre outros.
Esta biblioteca é ideal para desenvolvedores Delphi que buscam uma solução robusta, flexível e eficiente para integrar consultas de endereços online em suas aplicações.
Utilizando o Boss (Dependency manager for Delphi) é possível instalar a biblioteca de forma automatizada.
boss install https://github.com/antoniojmsjr/BuscaCEP
Se você optar por instalar manualmente, basta adicionar as seguintes pastas ao seu projeto, em Project > Options > Delphi Compiler > Target > All Configurations > Search path
..BuscaCEPSource
Provedor | Usa APIKey? | Busca por CEP? | * Busca por Logradouro? |
---|---|---|---|
Correios | NÃO | SIM | SIM |
Via CEP | NÃO | SIM | SIM |
Brasil API | NÃO | SIM | NÃO |
CEP Aberto | SIM | SIM | SIM |
Republica Virtual | NÃO | SIM | NÃO |
CEP Certo | NÃO | SIM | SIM |
KingHost | SIM | SIM | NÃO |
Postmon | NÃO | SIM | NÃO |
CEP Livre | SIM | SIM | SIM |
Open CEP | SIM | SIM | SIM |
API CEP | SIM | SIM | SIM |
Brasil Aberto | SIM | SIM | SIM |
AwesomeAPI | NÃO | SIM | NÃO |
* Para consultar usando o logradouro, são necessários três parâmetros obrigatórios: UF, Cidade e Logradouro.
Para fornecer o código IBGE e o código DDD da localidade no retorno da consulta, foi criado o arquivo BuscaCEP.dat, com base na API de localidades do IBGE e nos dados disponibilizados pela Anatel.
Os exemplos estão disponíveis na pasta do projeto:
..BuscaCEPSamples
Consulta por CEP
uses
BuscaCEP, BuscaCEP.Types, BuscaCEP.Interfaces, System.SysUtils;
var
lBuscaCEPResponse: IBuscaCEPResponse;
lMsgError: string;
begin
try
lBuscaCEPResponse := TBuscaCEP.New
//.SetArquivoCache() [OPCIONAL]
.Providers[TBuscaCEPProvidersKind.Correios]
//.SetAPIKey() [CONFORME O PROVEDOR]
.Filtro
.SetCEP('90520-003')
.Request
//.SetTimeout() [OPCIONAL]
.Execute;
except
on E: EBuscaCEPRequest do
begin
lMsgError := Concat(lMsgError, Format('Provider: %s', [E.Provider]), sLineBreak);
lMsgError := Concat(lMsgError, Format('DateTime: %s', [DateTimeTostr(E.DateTime)]), sLineBreak);
lMsgError := Concat(lMsgError, Format('Kind: %s', [E.Kind.AsString]), sLineBreak);
lMsgError := Concat(lMsgError, Format('URL: %s', [E.URL]), sLineBreak);
lMsgError := Concat(lMsgError, Format('Method: %s', [E.Method]), sLineBreak);
lMsgError := Concat(lMsgError, Format('Status Code: %d', [E.StatusCode]), sLineBreak);
lMsgError := Concat(lMsgError, Format('Status Text: %s', [E.StatusText]), sLineBreak);
lMsgError := Concat(lMsgError, Format('Message: %s', [E.Message]));
Application.MessageBox(PWideChar(lMsgError), 'A T E N Ç Ã O', MB_OK + MB_ICONERROR);
Exit;
end;
on E: Exception do
begin
Application.MessageBox(PWideChar(E.Message), 'A T E N Ç Ã O', MB_OK + MB_ICONERROR);
Exit;
end;
end;
end;
Consulta por Logradouro
uses
BuscaCEP, BuscaCEP.Types, BuscaCEP.Interfaces, System.SysUtils;
var
lBuscaCEPResponse: IBuscaCEPResponse;
lMsgError: string;
begin
try
lBuscaCEPResponse := TBuscaCEP.New
//.SetArquivoCache() [OPCIONAL]
.Providers[TBuscaCEPProvidersKind.Correios]
//.SetAPIKey() [CONFORME O PROVEDOR]
.Filtro
.SetLogradouro('Avenida Plínio Brasil Milano')
.SetLocalidade('Porto Alegre')
.SetUF('RS')
.&End
.Request
//.SetTimeout() [OPCIONAL]
.Execute;
except
on E: EBuscaCEPRequest do
begin
lMsgError := Concat(lMsgError, Format('Provider: %s', [E.Provider]), sLineBreak);
lMsgError := Concat(lMsgError, Format('DateTime: %s', [DateTimeTostr(E.DateTime)]), sLineBreak);
lMsgError := Concat(lMsgError, Format('Kind: %s', [E.Kind.AsString]), sLineBreak);
lMsgError := Concat(lMsgError, Format('URL: %s', [E.URL]), sLineBreak);
lMsgError := Concat(lMsgError, Format('Method: %s', [E.Method]), sLineBreak);
lMsgError := Concat(lMsgError, Format('Status Code: %d', [E.StatusCode]), sLineBreak);
lMsgError := Concat(lMsgError, Format('Status Text: %s', [E.StatusText]), sLineBreak);
lMsgError := Concat(lMsgError, Format('Message: %s', [E.Message]));
Application.MessageBox(PWideChar(lMsgError), 'A T E N Ç Ã O', MB_OK + MB_ICONERROR);
Exit;
end;
on E: Exception do
begin
Application.MessageBox(PWideChar(E.Message), 'A T E N Ç Ã O', MB_OK + MB_ICONERROR);
Exit;
end;
end;
end;
Resultado da Consulta [IBuscaCEPResponse]
uses
BuscaCEP.Types, BuscaCEP.Interfaces;
var
lBuscaCEPResponse: IBuscaCEPResponse;
lBuscaCEPLogradouro: TBuscaCEPLogradouro;
begin
for lBuscaCEPLogradouro in lBuscaCEPResponse.Logradouros do
begin
lBuscaCEPLogradouro.Logradouro;
lBuscaCEPLogradouro.Complemento;
lBuscaCEPLogradouro.Unidade;
lBuscaCEPLogradouro.Bairro;
lBuscaCEPLogradouro.Localidade.Nome;
lBuscaCEPLogradouro.Localidade.IBGE;
lBuscaCEPLogradouro.Localidade.DDD;
lBuscaCEPLogradouro.Localidade.Estado.Nome;
lBuscaCEPLogradouro.Localidade.Estado.IBGE;
lBuscaCEPLogradouro.Localidade.Estado.Sigla;
lBuscaCEPLogradouro.Localidade.Estado.Regiao.Nome;
lBuscaCEPLogradouro.Localidade.Estado.Regiao.IBGE;
lBuscaCEPLogradouro.Localidade.Estado.Regiao.Sigla;
lBuscaCEPLogradouro.CEP;
end;
Resultado da Consulta [JSON]
{
"provider": "#CORREIOS",
"date_time": "2024-05-01T02:35:14.772-03:00",
"request_time": "75ms",
"total": 1,
"logradouros": [
{
"logradouro": "Avenida Plínio Brasil Milano",
"complemento": "de 1947 ao fim - lado ímpar",
"unidade": "",
"bairro": "Passo da Areia",
"cep": "90520003",
"localidade": {
"ibge": 4314902,
"ddd": 51,
"nome": "Porto Alegre",
"estado": {
"ibge": 43,
"nome": "Rio Grande do Sul",
"sigla": "RS",
"regiao": {
"ibge": 4,
"nome": "Sul",
"sigla": "S"
}
}
}
}
]
}
Download: Demos.zip
BuscaCEP
is free and open-source software licensed under the