Biblioteca PHP que utiliza os webservices dos correios para cálculo de frete, rastreamento de encomendas e busca de endereços através do CEP.
Instalação via composer.
$ composer require escapework/frete:"0.5.*"
use EscapeWork\Frete\Correios\PrecoPrazo;
use EscapeWork\Frete\Correios\Data;
use EscapeWork\Frete\FreteException;
$frete = new PrecoPrazo();
$frete->setCodigoServico(Data::SEDEX)
->setCodigoEmpresa('Codigo') # opcional
->setSenha('Senha') # opcional
->setCepOrigem('cep de origem') # apenas numeros, sem hifen(-)
->setCepDestino('cep de destino') # apenas numeros, sem hifen(-)
->setComprimento(30) # obrigatorio
->setAltura(30) # obrigatorio
->setLargura(30) # obrigatorio
->setDiametro(30) # obrigatorio
->setPeso(0.5); # obrigatorio
try {
$result = $frete->calculate();
echo $result['cServico']['Valor'];
echo $result['cServico']['PrazoEntrega'];
var_dump($result); // debugge o resultado!
}
catch (FreteException $e) {
// trate o erro adequadamente (e não escrevendo na tela)
echo $e->getMessage();
echo $e->getCode(); // este código é o código de erro dos correios
// pode ser usado pra dar mensagens como CEP inválido para o cliente
}
EscapeWork\Frete\Correios\Data::SEDEX; # sedex
EscapeWork\Frete\Correios\Data::SEDEX_A_COBRAR; # sedex a cobrar
EscapeWork\Frete\Correios\Data::SEDEX_10; # sedex 10
EscapeWork\Frete\Correios\Data::SEDEX_HOJE; # sedex hoje
EscapeWork\Frete\Correios\Data::PAC; # pac
Também é possível obter um array com vários serviços (Sedex e PAC, por exemplo) utilizando a classe PrecoPrazo
.
$frete = new PrecoPrazo();
$frete->setCodigoServico([Data::SEDEX, Data::PAC])
... // todo os setters igual a chamada acima
try {
$results = $frete->calculate();
foreach ($results as $result) {
echo $result['cServico']['Valor'];
echo $result['cServico']['PrazoEntrega'];
var_dump($result); // debugge o resultado!
}
}
catch (FreteException $e) {
// trate o erro adequadamente (e não escrevendo na tela)
echo $e->getMessage();
}
Não existe nenhuma maneira completamente certa de se fazer isso (até onde ser). Eu recomendo usar a raiz cúbica dos produtos somadas para isto. Você pode ver mais informações aqui:
http://www.dothcom.net/blog/comercio-eletronico/calculo-de-frete-com-multiplos-volumes-dos-correios/
Fazendo o rastreio de encomendas online.
use EscapeWork\Frete\Correios\Rastreamento;
use EscapeWork\Frete\FreteException;
$rastreamento = new Rastreamento;
$rastreamento->setUsuario('ECT')
->setSenha('SRO')
->setObjetos('SQ458226057BR');
try {
$result = $rastreamento->track();
var_dump($result->delivered()); // se a entrega já foi finalizada (true ou false)
var_dump($result->inTransit()); // se o pacote está em transito (true ou false)
echo $result['evento']['tipo'];
echo $result['evento']['status'];
echo $result['evento']['data'];
echo $result['evento']['hora'];
echo $result['evento']['descricao'];
var_dump($result); // debugar, debugar!
}
catch (FreteException $e) {
// trate o erro adequadamente (e não escrevendo na tela)
echo $e->getMessage();
}
Também é possível buscar múltiplas encomendas com a classe Rastreamento
.
$rastreamento = new Rastreamento;
$rastreamento->setUsuario('ECT')
->setSenha('SRO')
->setObjetos(['SQ458226057BR', 'SQ458226057BR']); // passe um array com os objetos
try {
$results = $rastreamento->track();
foreach ($results as $result) {
var_dump($result->delivered());
...
}
}
Você também pode buscar o endereço através de um CEP.
use EscapeWork\Frete\Correios\ConsultaCEP;
use EscapeWork\Frete\FreteException;
try {
$consulta = new ConsultaCEP;
$result = $consulta->setCep(93320080)
->find();
# ou, pra facilitar, você pode usar o método
# ConsultaCEP::search(93320080)
echo $result->bairro;
echo $result->cep;
echo $result->cidade;
echo $result->complemento;
echo $result->complemento2;
echo $result->end;
echo $result->uf;
var_dump($result); // debugar, debugar!
}
catch (FreteException $e) {
// trate o erro adequadamente (e não escrevendo na tela)
echo $e->getMessage();
}
Caso queira rodar os testes em seu computador, clone o repositório, execute um composer install --dev
, e depois execute o seguinte comando no terminal:
$ vendor/bin/phpspec run
Referências utilizadas para o desenvolvimento.
See License