skay1994/shipment-sdk-php

此包负责进行报价计算。

1.2.0.1 2021-10-22 17:10 UTC

This package is not auto-updated.

Last update: 2024-09-22 06:05:18 UTC


README

Latest Version on Packagist Build Status Quality Score Total Downloads

现在更容易将Melhor Envio的报价服务集成到您的电子商务项目中。

目录

依赖项

require

  • PHP >= 7.0
  • Ext-json = *
  • Guzzlehttp/guzzle >= 7.4

require-dev

  • phpunit/phpunit >= 5

安装

您可以通过运行以下命令来安装此包

composer require melhorenvio/shipment-sdk-php

初始配置

创建的Shipment实例允许您传递token和您将工作的环境作为参数,因此您将拥有完整的身份验证。

请注意,只有当token的创建属于与作为参数传递的环境相同的环境时,它才是有效的。

如果您还没有完成授权过程,Melhor Envio有一个其他包来简化此过程。您可以点击这里访问。

require "vendor/autoload.php";

use MelhorEnvio\Shipment;
use MelhorEnvio\Resources\Shipment\Package;
use MelhorEnvio\Enums\Service;
use MelhorEnvio\Enums\Environment;

// Create Shipment Instance
$shipment = new Shipment('your-token', Environment::PRODUCTION);

创建计算器实例

在此示例中,您将在代码中创建一个计算器实例。

// Create Calculator Instance
    $calculator = $shipment->calculator();

构建计算器的有效载荷

添加起始和目的地的CEP

在此部分,您必须分别定义起始和目的地的CEP。

//Builds calculator payload
$calculator->postalCode('01010010', '20271130');

产品

添加产品进行报价

在此部分,您将定义用于报价的产品,应作为参数传递的信息如下

  • 高度
  • 宽度
  • 长度
  • 重量
  • 保险价值
  • 数量

请注意,保险价值默认应为产品的价值。

$calculator->addProducts(
        new Product(uniqid(), 40, 30, 50, 10.00, 100.0, 1),
        new Product(uniqid(), 5, 1, 10, 0.1, 50.0, 1)
    );

包装

添加包装进行报价

在此部分,您将定义用于报价的包装,应作为参数传递的信息如下

  • 高度
  • 宽度
  • 长度
  • 重量
  • 保险价值

维度总是应以厘米为单位传递,重量应以千克为单位。这是Melhor Envio操作的单位。

请注意,保险价值默认应为产品的价值(以雷亚尔为单位)。

 $calculator->addPackages(
        new Package(12, 4, 17, 0.1, 6.0),
        new Package(12, 4, 17, 0.1, 6.0),
        new Package(12, 4, 17, 0.1, 6.0),
        new Package(12, 4, 17, 0.1, 6.0)
    );

重要的是要注意,PACOTES和PRODUTOS方法不能同时使用,只能使用其中一个。

添加运输公司的服务

如果您想自定义,在此部分将选择您想使用的运输公司的服务。今天,在Melhor Envio中,以下服务可用

  • Correios
  • Jadlog
  • Via Brasil
  • Azul Cargo
  • Latam Cargo
$calculator->addServices(
        Service::CORREIOS_PAC, 
        Service::CORREIOS_SEDEX,
        Service::CORREIOS_MINI,
        Service::JADLOG_PACKAGE, 
        Service::JADLOG_COM, 
        Service::AZULCARGO_AMANHA,
        Service::AZULCARGO_ECOMMERCE,
        Service::LATAMCARGO_JUNTOS,
        Service::VIABRASIL_RODOVIARIO
    );

添加附加服务

如果您想自定义,可以在报价中配置一些附加服务,它们是

  • 手递手
  • 收货通知
  • 收集

请注意,添加这些服务可能会在报价时增加价格。

$calculator->setOwnHand();
$calculator->setReceipt();
$calculator->setCollect();

返回报价信息

在这里,您将返回构建的有效载荷信息。

$quotations = $calculator->calculate();

更多示例

在这里,您可以访问更多实现示例

测试

在项目中,您将找到基于单元测试的一些测试文档

您可以在应用中使用以下命令

composer test

或者使用以下命令

vendor/bin/phpunit tests 

变更日志

有关最近更改的更多信息,请参阅变更日志

贡献

请查阅 CONTRIBUTING 以获取更多详细信息。

安全

如果您发现任何安全问题,请通过电子邮件发送到 tecnologia@melhorenvio.com,而不是使用 issue tracker

致谢

许可证

Melhor Envio。有关更多信息,请查阅 许可文件