escapework / frete
运费计算库
1.0.1
2022-08-24 10:56 UTC
Requires
- php: >=5.5.0
- guzzlehttp/guzzle: ~5.0|~6.0|~7.0
Requires (Dev)
- phpspec/phpspec: ~2.0
README
PHP库,利用邮局的Web服务进行运费计算、包裹跟踪和通过CEP查找地址。
安装
通过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
搜索多个服务
也可以使用PrecoPrazo
类获取多个服务(如Sedex和PAC)的数组。
$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(); }
为多个产品计算
目前没有完全正确的方法来做这件事(直到现在)。我建议使用产品的立方根和来计算。您可以在此处查看更多信息
http://www.dothcom.net/blog/comercio-eletronico/calculo-de-frete-com-multiplos-volumes-dos-correios/
包裹跟踪
在线跟踪包裹。
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(); }
搜索多个包裹
也可以使用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()); ... } }
通过邮局Web服务查询CEP
您也可以通过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(); }
测试
如果想在您的电脑上运行测试,请克隆存储库,执行composer install --dev
,然后在终端中执行以下命令
$ vendor/bin/phpspec run
参考资料
用于开发的参考资料。
许可证
查看许可证