aarcarr/laravel5-amazon-mws

使用 Laravel 5.x 与 Amazon MWS 网络服务。基于 creacoon/amazon-mws-laravel 包,并修改以兼容最新 Laravel 版本(+ 错误修复)。

3.0.3 2017-12-20 15:58 UTC

README

一个 PHP 包,用于以面向对象的方式连接到 Amazon 的商户网络服务(MWS),重点在于直观的使用。

目前针对 Laravel 框架进行优化。

不是针对亚马逊网络服务(AWS)- 云计算服务。

安装

  1. composer require aarcarr/laravel5-amazon-mws

  2. 将服务提供者添加到 config/app.php 中的 providers 数组中

Aarcarr\AmazonMws\ServiceProvider::class,

在 config/app.php 中不需要添加门面

  1. 将 src/config/amazon-mws.php 配置文件从 Laravel 的配置目录中复制。

使用方法

API 所需的所有技术细节都在幕后处理,因此用户可以轻松构建用于向 Amazon 发送请求的代码,无需跳过诸如参数 URL 格式化和令牌管理之类的障碍。使用其中一个对象的一般工作流程如下

  1. 为需要执行的任务创建一个对象。
  2. 使用 set____ 方法加载参数,具体取决于对象。
  3. 向 Amazon 提交请求。通常这些方法的名称为 fetch____submit____,并且没有参数。
  4. 使用 get____ 方法引用返回的数据,无论是单个值还是批量。
  5. 使用内置的日志系统监控库的性能。

请注意,如果您想要操作多个 Amazon 店铺,则需要为每个店铺创建一个单独的对象。

此外,请注意,对象在作为不可重复使用时表现最佳。否则,如果新的请求失败,您可能会获取到旧的数据响应。

示例用法

以下是该库的使用示例。API 所需的所有技术细节都在幕后处理,因此用户可以轻松构建用于向 Amazon 发送请求的代码,无需跳过诸如参数 URL 格式化和令牌管理之类的障碍。

以下是一个示例函数,用于获取过去 24 小时内更新的所有仓库履行的订单

use Aarcarr\AmazonMws\AmazonOrderList;

function getAmazonOrders() {
    $amz = new AmazonOrderList("myStore"); //store name matches the array key in the config file
    $amz->setLimits('Modified', "- 24 hours");
    $amz->setFulfillmentChannelFilter("MFN"); //no Amazon-fulfilled orders
    $amz->setOrderStatusFilter(
        array("Unshipped", "PartiallyShipped", "Canceled", "Unfulfillable")
        ); //no shipped or pending
    $amz->setUseToken(); //Amazon sends orders 100 at a time, but we want them all
    $amz->fetchOrders();
    return $amz->getList();
}

此示例显示了用于将先前创建的 XML 饲料发送到 Amazon 以更新库存编号的函数

use Aarcarr\AmazonMws\AmazonOrderList;

function sendInventoryFeed($feed) {
    $amz = new AmazonFeed("myStore"); //store name matches the array key in the config file
    $amz->setFeedType("_POST_INVENTORY_AVAILABILITY_DATA_"); //feed types listed in documentation
    $amz->setFeedContent($feed);
    $amz->submitFeed();
    return $amz->getResponse();
}