ordersify / shopify-api-php
PHP Shopify API 客户端
2.4.19
2022-03-18 05:05 UTC
Requires
- php: >=5.6.0
- doctrine/cache: ^1.0
- doctrine/inflector: ^1.0|^2.0
- guzzlehttp/guzzle: ^6.0|^7.0
- jms/serializer: ^1.0
- slince/di: ^3.0
- symfony/yaml: ^2.0|^3.0|^4.0
Requires (Dev)
- phpunit/phpunit: ^5.0|^6.0
- symfony/filesystem: ^2.0|^3.0|^4.0
- symfony/property-access: ^2.0|^3.0|^4.0
- dev-master
- 4.x-dev
- 3.x-dev
- 2.4.19
- 2.4.18
- 2.4.17
- 2.4.16
- 2.4.15
- 2.4.14
- 2.4.13
- v2.4.12
- 2.4.11
- 2.4.10
- 2.4.9
- 2.4.8
- 2.4.7
- 2.4.6
- 2.4.5
- 2.4.4
- 2.4.3
- 2.4.2
- 2.4.1
- 2.4.0
- 2.3.2
- 2.3.1
- 2.3.0
- 2.2.0
- 2.1.2
- 2.1.1
- 2.1.0
- 2.0.3
- 2.0.2
- 2.0.1
- 2.0.0-beta1
- 1.0.0-beta2
- 1.0.0-beta1
- dev-scrutinizer-patch-1
- dev-revert-24-admin-graphql-api-id
This package is auto-updated.
Last update: 2024-09-18 10:49:08 UTC
README
🚀 Shopify API 的 PHP SDK
安装
通过 Composer 安装
$ composer require slince/shopify-api-php
快速入门
初始化客户端
您首先需要初始化客户端。为此,您需要您的商店名称和访问令牌
require __DIR__ . '/vendor/autoload.php'; $credential = new Slince\Shopify\PublicAppCredential('Access Token'); // Or Private App $credential = new Slince\Shopify\PrivateAppCredential('API KEY', 'PASSWORD', 'SHARED SECRET'); $client = new Slince\Shopify\Client($credential, 'your-store.myshopify.com', [ 'metaCacheDir' => './tmp' // Metadata cache dir, required ]);
使用管理器操作您的数据;
- 列出产品
$products = $client->getProductManager()->findAll([ // Filter your product 'collection_id' => 841564295 'page' => 2 // deprecated ]);
- 按分页列出产品
$pagination = $client->getProductManager()->paginate([ // filter your product 'limit' => 3, 'created_at_min' => '2015-04-25T16:15:47-04:00' ]); // $pagination is instance of `Slince\Shopify\Common\CursorBasedPagination` $currentProducts = $pagination->current(); //current page while ($pagination->hasNext()) { $nextProducts = $pagination->next(); } # to persist across requests you can use next_page_info and previous_page_info $nextPageInfo = $pagination->getNextPageInfo(); $prevPageInfo = $pagination->getPrevPageInfo(); $products = $pagination->current($nextPageInfo);
- 获取指定产品
$product = $client->getProductManager()->find(12800); // Update the given product $product = $client->getProductManager()->update(12800, [ "title" => "Burton Custom Freestyle 151", "body_html" => "<strong>Good snowboard!<\/strong>", "vendor"=> "Burton", "product_type" => "Snowboard", ]);
- 创建新产品
$product = $client->getProductManager()->create([ "title" => "Burton Custom Freestyle 151", "body_html" => "<strong>Good snowboard!<\/strong>", "vendor"=> "Burton", "product_type" => "Snowboard", ]);
- 通过其 ID 删除产品
$client->getProductManager()->remove(12800);
产品是 Slince\Shopify\Manager\Product\Product
的实例;您可以通过以下方式访问属性
echo $product->getTitle(); echo $product->getCreatedAt(); // DateTime Object //... print_r($product->getVariants()); print_r($product->getImages());
可用的管理器
- 文章
- 资产
- 博客
- 承运服务
- 收藏
- 评论
- 国家
- 自定义收藏夹
- 客户
- 客户地址
- 客户保存的搜索
- 折扣码
- 草稿订单
- 履行
- 履行服务
- 库存项
- 库存水平
- 位置
- 订单
- 订单风险
- 页面
- 策略
- 价格规则
- 产品
- 产品图片
- 产品变体
- 省
- 定期应用程序费用
- 重定向
- 退款
- 脚本标签
- 配送区域
- 商店
- 智能收藏夹
- 主题
- 交易
- Webhook
您可以通过 $client->getProductManager()
、$client->getOrderManager()
等方式访问管理器。
基本 CRUD
如果您不喜欢使用管理器,您也可以像这样操作数据
返回值只是一个数组;
$products = $client->get('products', [ // Filter your products ]); $product = $client->get('products/12800'); $product = $client->post('products', [ "product" => [ "title" => "Burton Custom Freestyle 151", "body_html" => "<strong>Good snowboard!<\/strong>", "vendor"=> "Burton", "product_type" => "Snowboard", "images" => [ [ "attachment" => "R0lGODlhAQABAIAAAAAAAAAAACH5BAEAAAAALAAAAAABAAEAAAICRAEAOw==\n" ] ] ] ]); $product = $client->put('products/12800', [ "product" => [ "title" => "Burton Custom Freestyle 151", "body_html" => "<strong>Good snowboard!<\/strong>", "vendor"=> "Burton", "product_type" => "Snowboard", "images" => [ [ "attachment" => "R0lGODlhAQABAIAAAAAAAAAAACH5BAEAAAAALAAAAAABAAEAAAICRAEAOw==\n" ] ] ] ]); $client->delete('products/12800');
LICENSE
MIT 许可证。请参阅 MIT