aarcarr / laravel5-amazon-mws
使用 Laravel 5.x 与 Amazon MWS 网络服务。基于 creacoon/amazon-mws-laravel 包,并修改以兼容最新 Laravel 版本(+ 错误修复)。
3.0.3
2017-12-20 15:58 UTC
Requires
- php: >=5.5.9
- ext-curl: *
- illuminate/support: 5.*
Requires (Dev)
- phpunit/phpunit: 5.*
This package is not auto-updated.
Last update: 2024-09-29 05:27:40 UTC
README
一个 PHP 包,用于以面向对象的方式连接到 Amazon 的商户网络服务(MWS),重点在于直观的使用。
目前针对 Laravel 框架进行优化。
这不是针对亚马逊网络服务(AWS)- 云计算服务。
安装
-
composer require aarcarr/laravel5-amazon-mws
-
将服务提供者添加到 config/app.php 中的 providers 数组中
Aarcarr\AmazonMws\ServiceProvider::class,
在 config/app.php 中不需要添加门面
- 将 src/config/amazon-mws.php 配置文件从 Laravel 的配置目录中复制。
使用方法
API 所需的所有技术细节都在幕后处理,因此用户可以轻松构建用于向 Amazon 发送请求的代码,无需跳过诸如参数 URL 格式化和令牌管理之类的障碍。使用其中一个对象的一般工作流程如下
- 为需要执行的任务创建一个对象。
- 使用 set____ 方法加载参数,具体取决于对象。
- 向 Amazon 提交请求。通常这些方法的名称为 fetch____ 或 submit____,并且没有参数。
- 使用 get____ 方法引用返回的数据,无论是单个值还是批量。
- 使用内置的日志系统监控库的性能。
请注意,如果您想要操作多个 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(); }